xref: /aosp_15_r20/external/googleapis/google/cloud/compute/v1/compute.v1.json (revision d5c09012810ac0c9f33fe448fb6da8260d444cc9)
1{
2  "schemas": {
3    "AcceleratorTypeList": {
4      "id": "AcceleratorTypeList",
5      "description": "Contains a list of accelerator types.",
6      "type": "object",
7      "properties": {
8        "kind": {
9          "description": "[Output Only] Type of resource. Always compute#acceleratorTypeList for lists of accelerator types.",
10          "default": "compute#acceleratorTypeList",
11          "type": "string"
12        },
13        "id": {
14          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
15          "type": "string"
16        },
17        "items": {
18          "description": "A list of AcceleratorType resources.",
19          "type": "array",
20          "items": {
21            "$ref": "AcceleratorType"
22          }
23        },
24        "nextPageToken": {
25          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
26          "type": "string"
27        },
28        "selfLink": {
29          "description": "[Output Only] Server-defined URL for this resource.",
30          "type": "string"
31        },
32        "warning": {
33          "description": "[Output Only] Informational warning message.",
34          "type": "object",
35          "properties": {
36            "code": {
37              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
38              "type": "string",
39              "enumDescriptions": [
40                "Warning about failed cleanup of transient changes made by a failed operation.",
41                "A link to a deprecated resource was created.",
42                "When deploying and at least one of the resources has a type marked as deprecated",
43                "The user created a boot disk that is larger than image size.",
44                "When deploying and at least one of the resources has a type marked as experimental",
45                "Warning that is present in an external api call",
46                "Warning that value of a field has been overridden. Deprecated unused field.",
47                "The operation involved use of an injected kernel, which is deprecated.",
48                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
49                "When deploying a deployment with a exceedingly large number of resources",
50                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
51                "A resource depends on a missing type",
52                "The route's nextHopIp address is not assigned to an instance on the network.",
53                "The route's next hop instance cannot ip forward.",
54                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
55                "The route's nextHopInstance URL refers to an instance that does not exist.",
56                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
57                "The route's next hop instance does not have a status of RUNNING.",
58                "Error which is not critical. We decided to continue the process despite the mentioned error.",
59                "No results are present on a particular list page.",
60                "Success is reported, but some results may be missing due to errors",
61                "The user attempted to use a resource that requires a TOS they have not accepted.",
62                "Warning that a resource is in use.",
63                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
64                "When a resource schema validation is ignored.",
65                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
66                "When undeclared properties in the schema are present",
67                "A given scope cannot be reached."
68              ],
69              "enumDeprecated": [
70                false,
71                false,
72                false,
73                false,
74                false,
75                false,
76                true,
77                false,
78                false,
79                false,
80                false,
81                false,
82                false,
83                false,
84                false,
85                false,
86                false,
87                false,
88                false,
89                false,
90                false,
91                false,
92                false,
93                false,
94                false,
95                false,
96                false,
97                false
98              ],
99              "enum": [
100                "CLEANUP_FAILED",
101                "DEPRECATED_RESOURCE_USED",
102                "DEPRECATED_TYPE_USED",
103                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
104                "EXPERIMENTAL_TYPE_USED",
105                "EXTERNAL_API_WARNING",
106                "FIELD_VALUE_OVERRIDEN",
107                "INJECTED_KERNELS_DEPRECATED",
108                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
109                "LARGE_DEPLOYMENT_WARNING",
110                "LIST_OVERHEAD_QUOTA_EXCEED",
111                "MISSING_TYPE_DEPENDENCY",
112                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
113                "NEXT_HOP_CANNOT_IP_FORWARD",
114                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
115                "NEXT_HOP_INSTANCE_NOT_FOUND",
116                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
117                "NEXT_HOP_NOT_RUNNING",
118                "NOT_CRITICAL_ERROR",
119                "NO_RESULTS_ON_PAGE",
120                "PARTIAL_SUCCESS",
121                "REQUIRED_TOS_AGREEMENT",
122                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
123                "RESOURCE_NOT_DELETED",
124                "SCHEMA_VALIDATION_IGNORED",
125                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
126                "UNDECLARED_PROPERTIES",
127                "UNREACHABLE"
128              ]
129            },
130            "message": {
131              "description": "[Output Only] A human-readable description of the warning code.",
132              "type": "string"
133            },
134            "data": {
135              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
136              "type": "array",
137              "items": {
138                "type": "object",
139                "properties": {
140                  "key": {
141                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
142                    "type": "string"
143                  },
144                  "value": {
145                    "description": "[Output Only] A warning data value corresponding to the key.",
146                    "type": "string"
147                  }
148                }
149              }
150            }
151          }
152        }
153      }
154    },
155    "AcceleratorType": {
156      "id": "AcceleratorType",
157      "description": "Represents an Accelerator Type resource. Google Cloud Platform provides graphics processing units (accelerators) that you can add to VM instances to improve or accelerate performance when working with intensive workloads. For more information, read GPUs on Compute Engine.",
158      "type": "object",
159      "properties": {
160        "kind": {
161          "description": "[Output Only] The type of the resource. Always compute#acceleratorType for accelerator types.",
162          "default": "compute#acceleratorType",
163          "type": "string"
164        },
165        "id": {
166          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
167          "type": "string",
168          "format": "uint64"
169        },
170        "creationTimestamp": {
171          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
172          "type": "string"
173        },
174        "name": {
175          "description": "[Output Only] Name of the resource.",
176          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
177          "type": "string"
178        },
179        "description": {
180          "description": "[Output Only] An optional textual description of the resource.",
181          "type": "string"
182        },
183        "deprecated": {
184          "description": "[Output Only] The deprecation status associated with this accelerator type.",
185          "$ref": "DeprecationStatus"
186        },
187        "zone": {
188          "description": "[Output Only] The name of the zone where the accelerator type resides, such as us-central1-a. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
189          "type": "string"
190        },
191        "selfLink": {
192          "description": "[Output Only] Server-defined, fully qualified URL for this resource.",
193          "type": "string"
194        },
195        "maximumCardsPerInstance": {
196          "description": "[Output Only] Maximum number of accelerator cards allowed per instance.",
197          "type": "integer",
198          "format": "int32"
199        }
200      }
201    },
202    "DeprecationStatus": {
203      "id": "DeprecationStatus",
204      "description": "Deprecation status for a public resource.",
205      "type": "object",
206      "properties": {
207        "state": {
208          "description": "The deprecation state of this resource. This can be ACTIVE, DEPRECATED, OBSOLETE, or DELETED. Operations which communicate the end of life date for an image, can use ACTIVE. Operations which create a new resource using a DEPRECATED resource will return successfully, but with a warning indicating the deprecated resource and recommending its replacement. Operations which use OBSOLETE or DELETED resources will be rejected and result in an error.",
209          "type": "string",
210          "enumDescriptions": [
211            "",
212            "",
213            "",
214            ""
215          ],
216          "enum": [
217            "ACTIVE",
218            "DELETED",
219            "DEPRECATED",
220            "OBSOLETE"
221          ]
222        },
223        "replacement": {
224          "description": "The URL of the suggested replacement for a deprecated resource. The suggested replacement resource must be the same kind of resource as the deprecated resource.",
225          "type": "string"
226        },
227        "deprecated": {
228          "description": "An optional RFC3339 timestamp on or after which the state of this resource is intended to change to DEPRECATED. This is only informational and the status will not change unless the client explicitly changes it.",
229          "type": "string"
230        },
231        "obsolete": {
232          "description": "An optional RFC3339 timestamp on or after which the state of this resource is intended to change to OBSOLETE. This is only informational and the status will not change unless the client explicitly changes it.",
233          "type": "string"
234        },
235        "deleted": {
236          "description": "An optional RFC3339 timestamp on or after which the state of this resource is intended to change to DELETED. This is only informational and the status will not change unless the client explicitly changes it.",
237          "type": "string"
238        }
239      }
240    },
241    "AcceleratorTypeAggregatedList": {
242      "id": "AcceleratorTypeAggregatedList",
243      "type": "object",
244      "properties": {
245        "kind": {
246          "description": "[Output Only] Type of resource. Always compute#acceleratorTypeAggregatedList for aggregated lists of accelerator types.",
247          "default": "compute#acceleratorTypeAggregatedList",
248          "type": "string"
249        },
250        "id": {
251          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
252          "type": "string"
253        },
254        "items": {
255          "description": "A list of AcceleratorTypesScopedList resources.",
256          "type": "object",
257          "additionalProperties": {
258            "description": "[Output Only] Name of the scope containing this set of accelerator types.",
259            "$ref": "AcceleratorTypesScopedList"
260          }
261        },
262        "nextPageToken": {
263          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
264          "type": "string"
265        },
266        "selfLink": {
267          "description": "[Output Only] Server-defined URL for this resource.",
268          "type": "string"
269        },
270        "warning": {
271          "description": "[Output Only] Informational warning message.",
272          "type": "object",
273          "properties": {
274            "code": {
275              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
276              "type": "string",
277              "enumDescriptions": [
278                "Warning about failed cleanup of transient changes made by a failed operation.",
279                "A link to a deprecated resource was created.",
280                "When deploying and at least one of the resources has a type marked as deprecated",
281                "The user created a boot disk that is larger than image size.",
282                "When deploying and at least one of the resources has a type marked as experimental",
283                "Warning that is present in an external api call",
284                "Warning that value of a field has been overridden. Deprecated unused field.",
285                "The operation involved use of an injected kernel, which is deprecated.",
286                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
287                "When deploying a deployment with a exceedingly large number of resources",
288                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
289                "A resource depends on a missing type",
290                "The route's nextHopIp address is not assigned to an instance on the network.",
291                "The route's next hop instance cannot ip forward.",
292                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
293                "The route's nextHopInstance URL refers to an instance that does not exist.",
294                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
295                "The route's next hop instance does not have a status of RUNNING.",
296                "Error which is not critical. We decided to continue the process despite the mentioned error.",
297                "No results are present on a particular list page.",
298                "Success is reported, but some results may be missing due to errors",
299                "The user attempted to use a resource that requires a TOS they have not accepted.",
300                "Warning that a resource is in use.",
301                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
302                "When a resource schema validation is ignored.",
303                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
304                "When undeclared properties in the schema are present",
305                "A given scope cannot be reached."
306              ],
307              "enumDeprecated": [
308                false,
309                false,
310                false,
311                false,
312                false,
313                false,
314                true,
315                false,
316                false,
317                false,
318                false,
319                false,
320                false,
321                false,
322                false,
323                false,
324                false,
325                false,
326                false,
327                false,
328                false,
329                false,
330                false,
331                false,
332                false,
333                false,
334                false,
335                false
336              ],
337              "enum": [
338                "CLEANUP_FAILED",
339                "DEPRECATED_RESOURCE_USED",
340                "DEPRECATED_TYPE_USED",
341                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
342                "EXPERIMENTAL_TYPE_USED",
343                "EXTERNAL_API_WARNING",
344                "FIELD_VALUE_OVERRIDEN",
345                "INJECTED_KERNELS_DEPRECATED",
346                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
347                "LARGE_DEPLOYMENT_WARNING",
348                "LIST_OVERHEAD_QUOTA_EXCEED",
349                "MISSING_TYPE_DEPENDENCY",
350                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
351                "NEXT_HOP_CANNOT_IP_FORWARD",
352                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
353                "NEXT_HOP_INSTANCE_NOT_FOUND",
354                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
355                "NEXT_HOP_NOT_RUNNING",
356                "NOT_CRITICAL_ERROR",
357                "NO_RESULTS_ON_PAGE",
358                "PARTIAL_SUCCESS",
359                "REQUIRED_TOS_AGREEMENT",
360                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
361                "RESOURCE_NOT_DELETED",
362                "SCHEMA_VALIDATION_IGNORED",
363                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
364                "UNDECLARED_PROPERTIES",
365                "UNREACHABLE"
366              ]
367            },
368            "message": {
369              "description": "[Output Only] A human-readable description of the warning code.",
370              "type": "string"
371            },
372            "data": {
373              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
374              "type": "array",
375              "items": {
376                "type": "object",
377                "properties": {
378                  "key": {
379                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
380                    "type": "string"
381                  },
382                  "value": {
383                    "description": "[Output Only] A warning data value corresponding to the key.",
384                    "type": "string"
385                  }
386                }
387              }
388            }
389          }
390        },
391        "unreachables": {
392          "description": "[Output Only] Unreachable resources.",
393          "type": "array",
394          "items": {
395            "type": "string"
396          }
397        }
398      }
399    },
400    "AcceleratorTypesScopedList": {
401      "id": "AcceleratorTypesScopedList",
402      "type": "object",
403      "properties": {
404        "acceleratorTypes": {
405          "description": "[Output Only] A list of accelerator types contained in this scope.",
406          "type": "array",
407          "items": {
408            "$ref": "AcceleratorType"
409          }
410        },
411        "warning": {
412          "description": "[Output Only] An informational warning that appears when the accelerator types list is empty.",
413          "type": "object",
414          "properties": {
415            "code": {
416              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
417              "type": "string",
418              "enumDescriptions": [
419                "Warning about failed cleanup of transient changes made by a failed operation.",
420                "A link to a deprecated resource was created.",
421                "When deploying and at least one of the resources has a type marked as deprecated",
422                "The user created a boot disk that is larger than image size.",
423                "When deploying and at least one of the resources has a type marked as experimental",
424                "Warning that is present in an external api call",
425                "Warning that value of a field has been overridden. Deprecated unused field.",
426                "The operation involved use of an injected kernel, which is deprecated.",
427                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
428                "When deploying a deployment with a exceedingly large number of resources",
429                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
430                "A resource depends on a missing type",
431                "The route's nextHopIp address is not assigned to an instance on the network.",
432                "The route's next hop instance cannot ip forward.",
433                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
434                "The route's nextHopInstance URL refers to an instance that does not exist.",
435                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
436                "The route's next hop instance does not have a status of RUNNING.",
437                "Error which is not critical. We decided to continue the process despite the mentioned error.",
438                "No results are present on a particular list page.",
439                "Success is reported, but some results may be missing due to errors",
440                "The user attempted to use a resource that requires a TOS they have not accepted.",
441                "Warning that a resource is in use.",
442                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
443                "When a resource schema validation is ignored.",
444                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
445                "When undeclared properties in the schema are present",
446                "A given scope cannot be reached."
447              ],
448              "enumDeprecated": [
449                false,
450                false,
451                false,
452                false,
453                false,
454                false,
455                true,
456                false,
457                false,
458                false,
459                false,
460                false,
461                false,
462                false,
463                false,
464                false,
465                false,
466                false,
467                false,
468                false,
469                false,
470                false,
471                false,
472                false,
473                false,
474                false,
475                false,
476                false
477              ],
478              "enum": [
479                "CLEANUP_FAILED",
480                "DEPRECATED_RESOURCE_USED",
481                "DEPRECATED_TYPE_USED",
482                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
483                "EXPERIMENTAL_TYPE_USED",
484                "EXTERNAL_API_WARNING",
485                "FIELD_VALUE_OVERRIDEN",
486                "INJECTED_KERNELS_DEPRECATED",
487                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
488                "LARGE_DEPLOYMENT_WARNING",
489                "LIST_OVERHEAD_QUOTA_EXCEED",
490                "MISSING_TYPE_DEPENDENCY",
491                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
492                "NEXT_HOP_CANNOT_IP_FORWARD",
493                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
494                "NEXT_HOP_INSTANCE_NOT_FOUND",
495                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
496                "NEXT_HOP_NOT_RUNNING",
497                "NOT_CRITICAL_ERROR",
498                "NO_RESULTS_ON_PAGE",
499                "PARTIAL_SUCCESS",
500                "REQUIRED_TOS_AGREEMENT",
501                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
502                "RESOURCE_NOT_DELETED",
503                "SCHEMA_VALIDATION_IGNORED",
504                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
505                "UNDECLARED_PROPERTIES",
506                "UNREACHABLE"
507              ]
508            },
509            "message": {
510              "description": "[Output Only] A human-readable description of the warning code.",
511              "type": "string"
512            },
513            "data": {
514              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
515              "type": "array",
516              "items": {
517                "type": "object",
518                "properties": {
519                  "key": {
520                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
521                    "type": "string"
522                  },
523                  "value": {
524                    "description": "[Output Only] A warning data value corresponding to the key.",
525                    "type": "string"
526                  }
527                }
528              }
529            }
530          }
531        }
532      }
533    },
534    "OperationList": {
535      "id": "OperationList",
536      "description": "Contains a list of Operation resources.",
537      "type": "object",
538      "properties": {
539        "kind": {
540          "description": "[Output Only] Type of resource. Always `compute#operations` for Operations resource.",
541          "default": "compute#operationList",
542          "type": "string"
543        },
544        "id": {
545          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
546          "type": "string"
547        },
548        "items": {
549          "description": "[Output Only] A list of Operation resources.",
550          "type": "array",
551          "items": {
552            "$ref": "Operation"
553          }
554        },
555        "nextPageToken": {
556          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than `maxResults`, use the `nextPageToken` as a value for the query parameter `pageToken` in the next list request. Subsequent list requests will have their own `nextPageToken` to continue paging through the results.",
557          "type": "string"
558        },
559        "selfLink": {
560          "description": "[Output Only] Server-defined URL for this resource.",
561          "type": "string"
562        },
563        "warning": {
564          "description": "[Output Only] Informational warning message.",
565          "type": "object",
566          "properties": {
567            "code": {
568              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
569              "type": "string",
570              "enumDescriptions": [
571                "Warning about failed cleanup of transient changes made by a failed operation.",
572                "A link to a deprecated resource was created.",
573                "When deploying and at least one of the resources has a type marked as deprecated",
574                "The user created a boot disk that is larger than image size.",
575                "When deploying and at least one of the resources has a type marked as experimental",
576                "Warning that is present in an external api call",
577                "Warning that value of a field has been overridden. Deprecated unused field.",
578                "The operation involved use of an injected kernel, which is deprecated.",
579                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
580                "When deploying a deployment with a exceedingly large number of resources",
581                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
582                "A resource depends on a missing type",
583                "The route's nextHopIp address is not assigned to an instance on the network.",
584                "The route's next hop instance cannot ip forward.",
585                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
586                "The route's nextHopInstance URL refers to an instance that does not exist.",
587                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
588                "The route's next hop instance does not have a status of RUNNING.",
589                "Error which is not critical. We decided to continue the process despite the mentioned error.",
590                "No results are present on a particular list page.",
591                "Success is reported, but some results may be missing due to errors",
592                "The user attempted to use a resource that requires a TOS they have not accepted.",
593                "Warning that a resource is in use.",
594                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
595                "When a resource schema validation is ignored.",
596                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
597                "When undeclared properties in the schema are present",
598                "A given scope cannot be reached."
599              ],
600              "enumDeprecated": [
601                false,
602                false,
603                false,
604                false,
605                false,
606                false,
607                true,
608                false,
609                false,
610                false,
611                false,
612                false,
613                false,
614                false,
615                false,
616                false,
617                false,
618                false,
619                false,
620                false,
621                false,
622                false,
623                false,
624                false,
625                false,
626                false,
627                false,
628                false
629              ],
630              "enum": [
631                "CLEANUP_FAILED",
632                "DEPRECATED_RESOURCE_USED",
633                "DEPRECATED_TYPE_USED",
634                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
635                "EXPERIMENTAL_TYPE_USED",
636                "EXTERNAL_API_WARNING",
637                "FIELD_VALUE_OVERRIDEN",
638                "INJECTED_KERNELS_DEPRECATED",
639                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
640                "LARGE_DEPLOYMENT_WARNING",
641                "LIST_OVERHEAD_QUOTA_EXCEED",
642                "MISSING_TYPE_DEPENDENCY",
643                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
644                "NEXT_HOP_CANNOT_IP_FORWARD",
645                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
646                "NEXT_HOP_INSTANCE_NOT_FOUND",
647                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
648                "NEXT_HOP_NOT_RUNNING",
649                "NOT_CRITICAL_ERROR",
650                "NO_RESULTS_ON_PAGE",
651                "PARTIAL_SUCCESS",
652                "REQUIRED_TOS_AGREEMENT",
653                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
654                "RESOURCE_NOT_DELETED",
655                "SCHEMA_VALIDATION_IGNORED",
656                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
657                "UNDECLARED_PROPERTIES",
658                "UNREACHABLE"
659              ]
660            },
661            "message": {
662              "description": "[Output Only] A human-readable description of the warning code.",
663              "type": "string"
664            },
665            "data": {
666              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
667              "type": "array",
668              "items": {
669                "type": "object",
670                "properties": {
671                  "key": {
672                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
673                    "type": "string"
674                  },
675                  "value": {
676                    "description": "[Output Only] A warning data value corresponding to the key.",
677                    "type": "string"
678                  }
679                }
680              }
681            }
682          }
683        }
684      }
685    },
686    "Operation": {
687      "id": "Operation",
688      "description": "Represents an Operation resource. Google Compute Engine has three Operation resources: * [Global](/compute/docs/reference/rest/v1/globalOperations) * [Regional](/compute/docs/reference/rest/v1/regionOperations) * [Zonal](/compute/docs/reference/rest/v1/zoneOperations) You can use an operation resource to manage asynchronous API requests. For more information, read Handling API responses. Operations can be global, regional or zonal. - For global operations, use the `globalOperations` resource. - For regional operations, use the `regionOperations` resource. - For zonal operations, use the `zoneOperations` resource. For more information, read Global, Regional, and Zonal Resources. Note that completed Operation resources have a limited retention period.",
689      "type": "object",
690      "properties": {
691        "kind": {
692          "description": "[Output Only] Type of the resource. Always `compute#operation` for Operation resources.",
693          "default": "compute#operation",
694          "type": "string"
695        },
696        "id": {
697          "description": "[Output Only] The unique identifier for the operation. This identifier is defined by the server.",
698          "type": "string",
699          "format": "uint64"
700        },
701        "creationTimestamp": {
702          "description": "[Deprecated] This field is deprecated.",
703          "type": "string"
704        },
705        "name": {
706          "description": "[Output Only] Name of the operation.",
707          "type": "string"
708        },
709        "zone": {
710          "description": "[Output Only] The URL of the zone where the operation resides. Only applicable when performing per-zone operations.",
711          "type": "string"
712        },
713        "clientOperationId": {
714          "description": "[Output Only] The value of `requestId` if you provided it in the request. Not present otherwise.",
715          "type": "string"
716        },
717        "operationType": {
718          "description": "[Output Only] The type of operation, such as `insert`, `update`, or `delete`, and so on.",
719          "type": "string"
720        },
721        "targetLink": {
722          "description": "[Output Only] The URL of the resource that the operation modifies. For operations related to creating a snapshot, this points to the persistent disk that the snapshot was created from.",
723          "type": "string"
724        },
725        "targetId": {
726          "description": "[Output Only] The unique target ID, which identifies a specific incarnation of the target resource.",
727          "type": "string",
728          "format": "uint64"
729        },
730        "status": {
731          "description": "[Output Only] The status of the operation, which can be one of the following: `PENDING`, `RUNNING`, or `DONE`.",
732          "type": "string",
733          "enumDescriptions": [
734            "",
735            "",
736            ""
737          ],
738          "enum": [
739            "DONE",
740            "PENDING",
741            "RUNNING"
742          ]
743        },
744        "statusMessage": {
745          "description": "[Output Only] An optional textual description of the current status of the operation.",
746          "type": "string"
747        },
748        "user": {
749          "description": "[Output Only] User who requested the operation, for example: `[email protected]` or `alice_smith_identifier (global/workforcePools/example-com-us-employees)`.",
750          "type": "string"
751        },
752        "progress": {
753          "description": "[Output Only] An optional progress indicator that ranges from 0 to 100. There is no requirement that this be linear or support any granularity of operations. This should not be used to guess when the operation will be complete. This number should monotonically increase as the operation progresses.",
754          "type": "integer",
755          "format": "int32"
756        },
757        "insertTime": {
758          "description": "[Output Only] The time that this operation was requested. This value is in RFC3339 text format.",
759          "type": "string"
760        },
761        "startTime": {
762          "description": "[Output Only] The time that this operation was started by the server. This value is in RFC3339 text format.",
763          "type": "string"
764        },
765        "endTime": {
766          "description": "[Output Only] The time that this operation was completed. This value is in RFC3339 text format.",
767          "type": "string"
768        },
769        "error": {
770          "description": "[Output Only] If errors are generated during processing of the operation, this field will be populated.",
771          "type": "object",
772          "properties": {
773            "errors": {
774              "description": "[Output Only] The array of errors encountered while processing this operation.",
775              "type": "array",
776              "items": {
777                "type": "object",
778                "properties": {
779                  "code": {
780                    "description": "[Output Only] The error type identifier for this error.",
781                    "type": "string"
782                  },
783                  "location": {
784                    "description": "[Output Only] Indicates the field in the request that caused the error. This property is optional.",
785                    "type": "string"
786                  },
787                  "message": {
788                    "description": "[Output Only] An optional, human-readable error message.",
789                    "type": "string"
790                  },
791                  "errorDetails": {
792                    "description": "[Output Only] An optional list of messages that contain the error details. There is a set of defined message types to use for providing details.The syntax depends on the error code. For example, QuotaExceededInfo will have details when the error code is QUOTA_EXCEEDED.",
793                    "type": "array",
794                    "items": {
795                      "type": "object",
796                      "properties": {
797                        "errorInfo": {
798                          "$ref": "ErrorInfo"
799                        },
800                        "quotaInfo": {
801                          "$ref": "QuotaExceededInfo"
802                        },
803                        "help": {
804                          "$ref": "Help"
805                        },
806                        "localizedMessage": {
807                          "$ref": "LocalizedMessage"
808                        }
809                      }
810                    }
811                  }
812                }
813              }
814            }
815          }
816        },
817        "warnings": {
818          "description": "[Output Only] If warning messages are generated during processing of the operation, this field will be populated.",
819          "type": "array",
820          "items": {
821            "type": "object",
822            "properties": {
823              "code": {
824                "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
825                "type": "string",
826                "enumDescriptions": [
827                  "Warning about failed cleanup of transient changes made by a failed operation.",
828                  "A link to a deprecated resource was created.",
829                  "When deploying and at least one of the resources has a type marked as deprecated",
830                  "The user created a boot disk that is larger than image size.",
831                  "When deploying and at least one of the resources has a type marked as experimental",
832                  "Warning that is present in an external api call",
833                  "Warning that value of a field has been overridden. Deprecated unused field.",
834                  "The operation involved use of an injected kernel, which is deprecated.",
835                  "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
836                  "When deploying a deployment with a exceedingly large number of resources",
837                  "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
838                  "A resource depends on a missing type",
839                  "The route's nextHopIp address is not assigned to an instance on the network.",
840                  "The route's next hop instance cannot ip forward.",
841                  "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
842                  "The route's nextHopInstance URL refers to an instance that does not exist.",
843                  "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
844                  "The route's next hop instance does not have a status of RUNNING.",
845                  "Error which is not critical. We decided to continue the process despite the mentioned error.",
846                  "No results are present on a particular list page.",
847                  "Success is reported, but some results may be missing due to errors",
848                  "The user attempted to use a resource that requires a TOS they have not accepted.",
849                  "Warning that a resource is in use.",
850                  "One or more of the resources set to auto-delete could not be deleted because they were in use.",
851                  "When a resource schema validation is ignored.",
852                  "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
853                  "When undeclared properties in the schema are present",
854                  "A given scope cannot be reached."
855                ],
856                "enumDeprecated": [
857                  false,
858                  false,
859                  false,
860                  false,
861                  false,
862                  false,
863                  true,
864                  false,
865                  false,
866                  false,
867                  false,
868                  false,
869                  false,
870                  false,
871                  false,
872                  false,
873                  false,
874                  false,
875                  false,
876                  false,
877                  false,
878                  false,
879                  false,
880                  false,
881                  false,
882                  false,
883                  false,
884                  false
885                ],
886                "enum": [
887                  "CLEANUP_FAILED",
888                  "DEPRECATED_RESOURCE_USED",
889                  "DEPRECATED_TYPE_USED",
890                  "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
891                  "EXPERIMENTAL_TYPE_USED",
892                  "EXTERNAL_API_WARNING",
893                  "FIELD_VALUE_OVERRIDEN",
894                  "INJECTED_KERNELS_DEPRECATED",
895                  "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
896                  "LARGE_DEPLOYMENT_WARNING",
897                  "LIST_OVERHEAD_QUOTA_EXCEED",
898                  "MISSING_TYPE_DEPENDENCY",
899                  "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
900                  "NEXT_HOP_CANNOT_IP_FORWARD",
901                  "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
902                  "NEXT_HOP_INSTANCE_NOT_FOUND",
903                  "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
904                  "NEXT_HOP_NOT_RUNNING",
905                  "NOT_CRITICAL_ERROR",
906                  "NO_RESULTS_ON_PAGE",
907                  "PARTIAL_SUCCESS",
908                  "REQUIRED_TOS_AGREEMENT",
909                  "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
910                  "RESOURCE_NOT_DELETED",
911                  "SCHEMA_VALIDATION_IGNORED",
912                  "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
913                  "UNDECLARED_PROPERTIES",
914                  "UNREACHABLE"
915                ]
916              },
917              "message": {
918                "description": "[Output Only] A human-readable description of the warning code.",
919                "type": "string"
920              },
921              "data": {
922                "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
923                "type": "array",
924                "items": {
925                  "type": "object",
926                  "properties": {
927                    "key": {
928                      "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
929                      "type": "string"
930                    },
931                    "value": {
932                      "description": "[Output Only] A warning data value corresponding to the key.",
933                      "type": "string"
934                    }
935                  }
936                }
937              }
938            }
939          }
940        },
941        "httpErrorStatusCode": {
942          "description": "[Output Only] If the operation fails, this field contains the HTTP error status code that was returned. For example, a `404` means the resource was not found.",
943          "type": "integer",
944          "format": "int32"
945        },
946        "httpErrorMessage": {
947          "description": "[Output Only] If the operation fails, this field contains the HTTP error message that was returned, such as `NOT FOUND`.",
948          "type": "string"
949        },
950        "selfLink": {
951          "description": "[Output Only] Server-defined URL for the resource.",
952          "type": "string"
953        },
954        "region": {
955          "description": "[Output Only] The URL of the region where the operation resides. Only applicable when performing regional operations.",
956          "type": "string"
957        },
958        "description": {
959          "description": "[Output Only] A textual description of the operation, which is set when the operation is created.",
960          "type": "string"
961        },
962        "operationGroupId": {
963          "description": "[Output Only] An ID that represents a group of operations, such as when a group of operations results from a `bulkInsert` API request.",
964          "type": "string"
965        },
966        "setCommonInstanceMetadataOperationMetadata": {
967          "description": "[Output Only] If the operation is for projects.setCommonInstanceMetadata, this field will contain information on all underlying zonal actions and their state.",
968          "$ref": "SetCommonInstanceMetadataOperationMetadata"
969        },
970        "instancesBulkInsertOperationMetadata": {
971          "$ref": "InstancesBulkInsertOperationMetadata"
972        }
973      }
974    },
975    "ErrorInfo": {
976      "id": "ErrorInfo",
977      "description": "Describes the cause of the error with structured details. Example of an error when contacting the \"pubsub.googleapis.com\" API when it is not enabled: { \"reason\": \"API_DISABLED\" \"domain\": \"googleapis.com\" \"metadata\": { \"resource\": \"projects/123\", \"service\": \"pubsub.googleapis.com\" } } This response indicates that the pubsub.googleapis.com API is not enabled. Example of an error that is returned when attempting to create a Spanner instance in a region that is out of stock: { \"reason\": \"STOCKOUT\" \"domain\": \"spanner.googleapis.com\", \"metadata\": { \"availableRegions\": \"us-central1,us-east2\" } }",
978      "type": "object",
979      "properties": {
980        "reason": {
981          "description": "The reason of the error. This is a constant value that identifies the proximate cause of the error. Error reasons are unique within a particular domain of errors. This should be at most 63 characters and match a regular expression of `A-Z+[A-Z0-9]`, which represents UPPER_SNAKE_CASE.",
982          "type": "string"
983        },
984        "domain": {
985          "description": "The logical grouping to which the \"reason\" belongs. The error domain is typically the registered service name of the tool or product that generates the error. Example: \"pubsub.googleapis.com\". If the error is generated by some common infrastructure, the error domain must be a globally unique value that identifies the infrastructure. For Google API infrastructure, the error domain is \"googleapis.com\".",
986          "type": "string"
987        },
988        "metadatas": {
989          "description": "Additional structured details about this error. Keys should match /[a-zA-Z0-9-_]/ and be limited to 64 characters in length. When identifying the current value of an exceeded limit, the units should be contained in the key, not the value. For example, rather than {\"instanceLimit\": \"100/request\"}, should be returned as, {\"instanceLimitPerRequest\": \"100\"}, if the client exceeds the number of instances that can be created in a single (batch) request.",
990          "type": "object",
991          "additionalProperties": {
992            "type": "string"
993          }
994        }
995      }
996    },
997    "QuotaExceededInfo": {
998      "id": "QuotaExceededInfo",
999      "description": "Additional details for quota exceeded error for resource quota.",
1000      "type": "object",
1001      "properties": {
1002        "metricName": {
1003          "description": "The Compute Engine quota metric name.",
1004          "type": "string"
1005        },
1006        "limitName": {
1007          "description": "The name of the quota limit.",
1008          "type": "string"
1009        },
1010        "dimensions": {
1011          "description": "The map holding related quota dimensions.",
1012          "type": "object",
1013          "additionalProperties": {
1014            "type": "string"
1015          }
1016        },
1017        "limit": {
1018          "description": "Current effective quota limit. The limit's unit depends on the quota type or metric.",
1019          "type": "number",
1020          "format": "double"
1021        },
1022        "futureLimit": {
1023          "description": "Future quota limit being rolled out. The limit's unit depends on the quota type or metric.",
1024          "type": "number",
1025          "format": "double"
1026        },
1027        "rolloutStatus": {
1028          "description": "Rollout status of the future quota limit.",
1029          "type": "string",
1030          "enumDescriptions": [
1031            "IN_PROGRESS - A rollout is in process which will change the limit value to future limit.",
1032            "ROLLOUT_STATUS_UNSPECIFIED - Rollout status is not specified. The default value."
1033          ],
1034          "enum": [
1035            "IN_PROGRESS",
1036            "ROLLOUT_STATUS_UNSPECIFIED"
1037          ]
1038        }
1039      }
1040    },
1041    "Help": {
1042      "id": "Help",
1043      "description": "Provides links to documentation or for performing an out of band action. For example, if a quota check failed with an error indicating the calling project hasn't enabled the accessed service, this can contain a URL pointing directly to the right place in the developer console to flip the bit.",
1044      "type": "object",
1045      "properties": {
1046        "links": {
1047          "description": "URL(s) pointing to additional information on handling the current error.",
1048          "type": "array",
1049          "items": {
1050            "$ref": "HelpLink"
1051          }
1052        }
1053      }
1054    },
1055    "HelpLink": {
1056      "id": "HelpLink",
1057      "description": "Describes a URL link.",
1058      "type": "object",
1059      "properties": {
1060        "description": {
1061          "description": "Describes what the link offers.",
1062          "type": "string"
1063        },
1064        "url": {
1065          "description": "The URL of the link.",
1066          "type": "string"
1067        }
1068      }
1069    },
1070    "LocalizedMessage": {
1071      "id": "LocalizedMessage",
1072      "description": "Provides a localized error message that is safe to return to the user which can be attached to an RPC error.",
1073      "type": "object",
1074      "properties": {
1075        "locale": {
1076          "description": "The locale used following the specification defined at https://www.rfc-editor.org/rfc/bcp/bcp47.txt. Examples are: \"en-US\", \"fr-CH\", \"es-MX\"",
1077          "type": "string"
1078        },
1079        "message": {
1080          "description": "The localized error message in the above locale.",
1081          "type": "string"
1082        }
1083      }
1084    },
1085    "SetCommonInstanceMetadataOperationMetadata": {
1086      "id": "SetCommonInstanceMetadataOperationMetadata",
1087      "type": "object",
1088      "properties": {
1089        "clientOperationId": {
1090          "description": "[Output Only] The client operation id.",
1091          "type": "string"
1092        },
1093        "perLocationOperations": {
1094          "description": "[Output Only] Status information per location (location name is key). Example key: zones/us-central1-a",
1095          "type": "object",
1096          "additionalProperties": {
1097            "$ref": "SetCommonInstanceMetadataOperationMetadataPerLocationOperationInfo"
1098          }
1099        }
1100      }
1101    },
1102    "SetCommonInstanceMetadataOperationMetadataPerLocationOperationInfo": {
1103      "id": "SetCommonInstanceMetadataOperationMetadataPerLocationOperationInfo",
1104      "type": "object",
1105      "properties": {
1106        "state": {
1107          "description": "[Output Only] Status of the action, which can be one of the following: `PROPAGATING`, `PROPAGATED`, `ABANDONED`, `FAILED`, or `DONE`.",
1108          "type": "string",
1109          "enumDescriptions": [
1110            "Operation not tracked in this location e.g. zone is marked as DOWN.",
1111            "Operation has completed successfully.",
1112            "Operation is in an error state.",
1113            "Operation is confirmed to be in the location.",
1114            "Operation is not yet confirmed to have been created in the location.",
1115            ""
1116          ],
1117          "enum": [
1118            "ABANDONED",
1119            "DONE",
1120            "FAILED",
1121            "PROPAGATED",
1122            "PROPAGATING",
1123            "UNSPECIFIED"
1124          ]
1125        },
1126        "error": {
1127          "description": "[Output Only] If state is `ABANDONED` or `FAILED`, this field is populated.",
1128          "$ref": "Status"
1129        }
1130      }
1131    },
1132    "Status": {
1133      "id": "Status",
1134      "description": "The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors).",
1135      "type": "object",
1136      "properties": {
1137        "code": {
1138          "description": "The status code, which should be an enum value of google.rpc.Code.",
1139          "type": "integer",
1140          "format": "int32"
1141        },
1142        "message": {
1143          "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.",
1144          "type": "string"
1145        },
1146        "details": {
1147          "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.",
1148          "type": "array",
1149          "items": {
1150            "type": "object",
1151            "additionalProperties": {
1152              "type": "any",
1153              "description": "Properties of the object. Contains field @type with type URL."
1154            }
1155          }
1156        }
1157      }
1158    },
1159    "InstancesBulkInsertOperationMetadata": {
1160      "id": "InstancesBulkInsertOperationMetadata",
1161      "type": "object",
1162      "properties": {
1163        "perLocationStatus": {
1164          "description": "Status information per location (location name is key). Example key: zones/us-central1-a",
1165          "type": "object",
1166          "additionalProperties": {
1167            "$ref": "BulkInsertOperationStatus"
1168          }
1169        }
1170      }
1171    },
1172    "BulkInsertOperationStatus": {
1173      "id": "BulkInsertOperationStatus",
1174      "type": "object",
1175      "properties": {
1176        "status": {
1177          "description": "[Output Only] Creation status of BulkInsert operation - information if the flow is rolling forward or rolling back.",
1178          "type": "string",
1179          "enumDescriptions": [
1180            "Rolling forward - creating VMs.",
1181            "Done",
1182            "Rolling back - cleaning up after an error.",
1183            ""
1184          ],
1185          "enum": [
1186            "CREATING",
1187            "DONE",
1188            "ROLLING_BACK",
1189            "STATUS_UNSPECIFIED"
1190          ]
1191        },
1192        "targetVmCount": {
1193          "description": "[Output Only] Count of VMs originally planned to be created.",
1194          "type": "integer",
1195          "format": "int32"
1196        },
1197        "createdVmCount": {
1198          "description": "[Output Only] Count of VMs successfully created so far.",
1199          "type": "integer",
1200          "format": "int32"
1201        },
1202        "failedToCreateVmCount": {
1203          "description": "[Output Only] Count of VMs that started creating but encountered an error.",
1204          "type": "integer",
1205          "format": "int32"
1206        },
1207        "deletedVmCount": {
1208          "description": "[Output Only] Count of VMs that got deleted during rollback.",
1209          "type": "integer",
1210          "format": "int32"
1211        }
1212      }
1213    },
1214    "OperationAggregatedList": {
1215      "id": "OperationAggregatedList",
1216      "type": "object",
1217      "properties": {
1218        "kind": {
1219          "description": "[Output Only] Type of resource. Always `compute#operationAggregatedList` for aggregated lists of operations.",
1220          "default": "compute#operationAggregatedList",
1221          "type": "string"
1222        },
1223        "id": {
1224          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
1225          "type": "string"
1226        },
1227        "items": {
1228          "description": "[Output Only] A map of scoped operation lists.",
1229          "type": "object",
1230          "additionalProperties": {
1231            "description": "[Output Only] Name of the scope containing this set of operations.",
1232            "$ref": "OperationsScopedList"
1233          }
1234        },
1235        "nextPageToken": {
1236          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than `maxResults`, use the `nextPageToken` as a value for the query parameter `pageToken` in the next list request. Subsequent list requests will have their own `nextPageToken` to continue paging through the results.",
1237          "type": "string"
1238        },
1239        "selfLink": {
1240          "description": "[Output Only] Server-defined URL for this resource.",
1241          "type": "string"
1242        },
1243        "warning": {
1244          "description": "[Output Only] Informational warning message.",
1245          "type": "object",
1246          "properties": {
1247            "code": {
1248              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
1249              "type": "string",
1250              "enumDescriptions": [
1251                "Warning about failed cleanup of transient changes made by a failed operation.",
1252                "A link to a deprecated resource was created.",
1253                "When deploying and at least one of the resources has a type marked as deprecated",
1254                "The user created a boot disk that is larger than image size.",
1255                "When deploying and at least one of the resources has a type marked as experimental",
1256                "Warning that is present in an external api call",
1257                "Warning that value of a field has been overridden. Deprecated unused field.",
1258                "The operation involved use of an injected kernel, which is deprecated.",
1259                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
1260                "When deploying a deployment with a exceedingly large number of resources",
1261                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
1262                "A resource depends on a missing type",
1263                "The route's nextHopIp address is not assigned to an instance on the network.",
1264                "The route's next hop instance cannot ip forward.",
1265                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
1266                "The route's nextHopInstance URL refers to an instance that does not exist.",
1267                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
1268                "The route's next hop instance does not have a status of RUNNING.",
1269                "Error which is not critical. We decided to continue the process despite the mentioned error.",
1270                "No results are present on a particular list page.",
1271                "Success is reported, but some results may be missing due to errors",
1272                "The user attempted to use a resource that requires a TOS they have not accepted.",
1273                "Warning that a resource is in use.",
1274                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
1275                "When a resource schema validation is ignored.",
1276                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
1277                "When undeclared properties in the schema are present",
1278                "A given scope cannot be reached."
1279              ],
1280              "enumDeprecated": [
1281                false,
1282                false,
1283                false,
1284                false,
1285                false,
1286                false,
1287                true,
1288                false,
1289                false,
1290                false,
1291                false,
1292                false,
1293                false,
1294                false,
1295                false,
1296                false,
1297                false,
1298                false,
1299                false,
1300                false,
1301                false,
1302                false,
1303                false,
1304                false,
1305                false,
1306                false,
1307                false,
1308                false
1309              ],
1310              "enum": [
1311                "CLEANUP_FAILED",
1312                "DEPRECATED_RESOURCE_USED",
1313                "DEPRECATED_TYPE_USED",
1314                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
1315                "EXPERIMENTAL_TYPE_USED",
1316                "EXTERNAL_API_WARNING",
1317                "FIELD_VALUE_OVERRIDEN",
1318                "INJECTED_KERNELS_DEPRECATED",
1319                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
1320                "LARGE_DEPLOYMENT_WARNING",
1321                "LIST_OVERHEAD_QUOTA_EXCEED",
1322                "MISSING_TYPE_DEPENDENCY",
1323                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
1324                "NEXT_HOP_CANNOT_IP_FORWARD",
1325                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
1326                "NEXT_HOP_INSTANCE_NOT_FOUND",
1327                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
1328                "NEXT_HOP_NOT_RUNNING",
1329                "NOT_CRITICAL_ERROR",
1330                "NO_RESULTS_ON_PAGE",
1331                "PARTIAL_SUCCESS",
1332                "REQUIRED_TOS_AGREEMENT",
1333                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
1334                "RESOURCE_NOT_DELETED",
1335                "SCHEMA_VALIDATION_IGNORED",
1336                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
1337                "UNDECLARED_PROPERTIES",
1338                "UNREACHABLE"
1339              ]
1340            },
1341            "message": {
1342              "description": "[Output Only] A human-readable description of the warning code.",
1343              "type": "string"
1344            },
1345            "data": {
1346              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
1347              "type": "array",
1348              "items": {
1349                "type": "object",
1350                "properties": {
1351                  "key": {
1352                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
1353                    "type": "string"
1354                  },
1355                  "value": {
1356                    "description": "[Output Only] A warning data value corresponding to the key.",
1357                    "type": "string"
1358                  }
1359                }
1360              }
1361            }
1362          }
1363        },
1364        "unreachables": {
1365          "description": "[Output Only] Unreachable resources.",
1366          "type": "array",
1367          "items": {
1368            "type": "string"
1369          }
1370        }
1371      }
1372    },
1373    "OperationsScopedList": {
1374      "id": "OperationsScopedList",
1375      "type": "object",
1376      "properties": {
1377        "operations": {
1378          "description": "[Output Only] A list of operations contained in this scope.",
1379          "type": "array",
1380          "items": {
1381            "$ref": "Operation"
1382          }
1383        },
1384        "warning": {
1385          "description": "[Output Only] Informational warning which replaces the list of operations when the list is empty.",
1386          "type": "object",
1387          "properties": {
1388            "code": {
1389              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
1390              "type": "string",
1391              "enumDescriptions": [
1392                "Warning about failed cleanup of transient changes made by a failed operation.",
1393                "A link to a deprecated resource was created.",
1394                "When deploying and at least one of the resources has a type marked as deprecated",
1395                "The user created a boot disk that is larger than image size.",
1396                "When deploying and at least one of the resources has a type marked as experimental",
1397                "Warning that is present in an external api call",
1398                "Warning that value of a field has been overridden. Deprecated unused field.",
1399                "The operation involved use of an injected kernel, which is deprecated.",
1400                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
1401                "When deploying a deployment with a exceedingly large number of resources",
1402                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
1403                "A resource depends on a missing type",
1404                "The route's nextHopIp address is not assigned to an instance on the network.",
1405                "The route's next hop instance cannot ip forward.",
1406                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
1407                "The route's nextHopInstance URL refers to an instance that does not exist.",
1408                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
1409                "The route's next hop instance does not have a status of RUNNING.",
1410                "Error which is not critical. We decided to continue the process despite the mentioned error.",
1411                "No results are present on a particular list page.",
1412                "Success is reported, but some results may be missing due to errors",
1413                "The user attempted to use a resource that requires a TOS they have not accepted.",
1414                "Warning that a resource is in use.",
1415                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
1416                "When a resource schema validation is ignored.",
1417                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
1418                "When undeclared properties in the schema are present",
1419                "A given scope cannot be reached."
1420              ],
1421              "enumDeprecated": [
1422                false,
1423                false,
1424                false,
1425                false,
1426                false,
1427                false,
1428                true,
1429                false,
1430                false,
1431                false,
1432                false,
1433                false,
1434                false,
1435                false,
1436                false,
1437                false,
1438                false,
1439                false,
1440                false,
1441                false,
1442                false,
1443                false,
1444                false,
1445                false,
1446                false,
1447                false,
1448                false,
1449                false
1450              ],
1451              "enum": [
1452                "CLEANUP_FAILED",
1453                "DEPRECATED_RESOURCE_USED",
1454                "DEPRECATED_TYPE_USED",
1455                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
1456                "EXPERIMENTAL_TYPE_USED",
1457                "EXTERNAL_API_WARNING",
1458                "FIELD_VALUE_OVERRIDEN",
1459                "INJECTED_KERNELS_DEPRECATED",
1460                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
1461                "LARGE_DEPLOYMENT_WARNING",
1462                "LIST_OVERHEAD_QUOTA_EXCEED",
1463                "MISSING_TYPE_DEPENDENCY",
1464                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
1465                "NEXT_HOP_CANNOT_IP_FORWARD",
1466                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
1467                "NEXT_HOP_INSTANCE_NOT_FOUND",
1468                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
1469                "NEXT_HOP_NOT_RUNNING",
1470                "NOT_CRITICAL_ERROR",
1471                "NO_RESULTS_ON_PAGE",
1472                "PARTIAL_SUCCESS",
1473                "REQUIRED_TOS_AGREEMENT",
1474                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
1475                "RESOURCE_NOT_DELETED",
1476                "SCHEMA_VALIDATION_IGNORED",
1477                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
1478                "UNDECLARED_PROPERTIES",
1479                "UNREACHABLE"
1480              ]
1481            },
1482            "message": {
1483              "description": "[Output Only] A human-readable description of the warning code.",
1484              "type": "string"
1485            },
1486            "data": {
1487              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
1488              "type": "array",
1489              "items": {
1490                "type": "object",
1491                "properties": {
1492                  "key": {
1493                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
1494                    "type": "string"
1495                  },
1496                  "value": {
1497                    "description": "[Output Only] A warning data value corresponding to the key.",
1498                    "type": "string"
1499                  }
1500                }
1501              }
1502            }
1503          }
1504        }
1505      }
1506    },
1507    "AddressList": {
1508      "id": "AddressList",
1509      "description": "Contains a list of addresses.",
1510      "type": "object",
1511      "properties": {
1512        "kind": {
1513          "description": "[Output Only] Type of resource. Always compute#addressList for lists of addresses.",
1514          "default": "compute#addressList",
1515          "type": "string"
1516        },
1517        "id": {
1518          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
1519          "type": "string"
1520        },
1521        "items": {
1522          "description": "A list of Address resources.",
1523          "type": "array",
1524          "items": {
1525            "$ref": "Address"
1526          }
1527        },
1528        "nextPageToken": {
1529          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
1530          "type": "string"
1531        },
1532        "warning": {
1533          "description": "[Output Only] Informational warning message.",
1534          "type": "object",
1535          "properties": {
1536            "code": {
1537              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
1538              "type": "string",
1539              "enumDescriptions": [
1540                "Warning about failed cleanup of transient changes made by a failed operation.",
1541                "A link to a deprecated resource was created.",
1542                "When deploying and at least one of the resources has a type marked as deprecated",
1543                "The user created a boot disk that is larger than image size.",
1544                "When deploying and at least one of the resources has a type marked as experimental",
1545                "Warning that is present in an external api call",
1546                "Warning that value of a field has been overridden. Deprecated unused field.",
1547                "The operation involved use of an injected kernel, which is deprecated.",
1548                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
1549                "When deploying a deployment with a exceedingly large number of resources",
1550                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
1551                "A resource depends on a missing type",
1552                "The route's nextHopIp address is not assigned to an instance on the network.",
1553                "The route's next hop instance cannot ip forward.",
1554                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
1555                "The route's nextHopInstance URL refers to an instance that does not exist.",
1556                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
1557                "The route's next hop instance does not have a status of RUNNING.",
1558                "Error which is not critical. We decided to continue the process despite the mentioned error.",
1559                "No results are present on a particular list page.",
1560                "Success is reported, but some results may be missing due to errors",
1561                "The user attempted to use a resource that requires a TOS they have not accepted.",
1562                "Warning that a resource is in use.",
1563                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
1564                "When a resource schema validation is ignored.",
1565                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
1566                "When undeclared properties in the schema are present",
1567                "A given scope cannot be reached."
1568              ],
1569              "enumDeprecated": [
1570                false,
1571                false,
1572                false,
1573                false,
1574                false,
1575                false,
1576                true,
1577                false,
1578                false,
1579                false,
1580                false,
1581                false,
1582                false,
1583                false,
1584                false,
1585                false,
1586                false,
1587                false,
1588                false,
1589                false,
1590                false,
1591                false,
1592                false,
1593                false,
1594                false,
1595                false,
1596                false,
1597                false
1598              ],
1599              "enum": [
1600                "CLEANUP_FAILED",
1601                "DEPRECATED_RESOURCE_USED",
1602                "DEPRECATED_TYPE_USED",
1603                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
1604                "EXPERIMENTAL_TYPE_USED",
1605                "EXTERNAL_API_WARNING",
1606                "FIELD_VALUE_OVERRIDEN",
1607                "INJECTED_KERNELS_DEPRECATED",
1608                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
1609                "LARGE_DEPLOYMENT_WARNING",
1610                "LIST_OVERHEAD_QUOTA_EXCEED",
1611                "MISSING_TYPE_DEPENDENCY",
1612                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
1613                "NEXT_HOP_CANNOT_IP_FORWARD",
1614                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
1615                "NEXT_HOP_INSTANCE_NOT_FOUND",
1616                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
1617                "NEXT_HOP_NOT_RUNNING",
1618                "NOT_CRITICAL_ERROR",
1619                "NO_RESULTS_ON_PAGE",
1620                "PARTIAL_SUCCESS",
1621                "REQUIRED_TOS_AGREEMENT",
1622                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
1623                "RESOURCE_NOT_DELETED",
1624                "SCHEMA_VALIDATION_IGNORED",
1625                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
1626                "UNDECLARED_PROPERTIES",
1627                "UNREACHABLE"
1628              ]
1629            },
1630            "message": {
1631              "description": "[Output Only] A human-readable description of the warning code.",
1632              "type": "string"
1633            },
1634            "data": {
1635              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
1636              "type": "array",
1637              "items": {
1638                "type": "object",
1639                "properties": {
1640                  "key": {
1641                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
1642                    "type": "string"
1643                  },
1644                  "value": {
1645                    "description": "[Output Only] A warning data value corresponding to the key.",
1646                    "type": "string"
1647                  }
1648                }
1649              }
1650            }
1651          }
1652        },
1653        "selfLink": {
1654          "description": "[Output Only] Server-defined URL for this resource.",
1655          "type": "string"
1656        }
1657      }
1658    },
1659    "Address": {
1660      "id": "Address",
1661      "description": "Represents an IP Address resource. Google Compute Engine has two IP Address resources: * [Global (external and internal)](https://cloud.google.com/compute/docs/reference/rest/v1/globalAddresses) * [Regional (external and internal)](https://cloud.google.com/compute/docs/reference/rest/v1/addresses) For more information, see Reserving a static external IP address.",
1662      "type": "object",
1663      "properties": {
1664        "kind": {
1665          "description": "[Output Only] Type of the resource. Always compute#address for addresses.",
1666          "default": "compute#address",
1667          "type": "string"
1668        },
1669        "id": {
1670          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
1671          "type": "string",
1672          "format": "uint64"
1673        },
1674        "creationTimestamp": {
1675          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
1676          "type": "string"
1677        },
1678        "name": {
1679          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?`. The first character must be a lowercase letter, and all following characters (except for the last character) must be a dash, lowercase letter, or digit. The last character must be a lowercase letter or digit.",
1680          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
1681          "annotations": {
1682            "required": [
1683              "compute.addresses.insert"
1684            ]
1685          },
1686          "type": "string"
1687        },
1688        "description": {
1689          "description": "An optional description of this resource. Provide this field when you create the resource.",
1690          "type": "string"
1691        },
1692        "address": {
1693          "description": "The static IP address represented by this resource.",
1694          "type": "string"
1695        },
1696        "prefixLength": {
1697          "description": "The prefix length if the resource represents an IP range.",
1698          "type": "integer",
1699          "format": "int32"
1700        },
1701        "status": {
1702          "description": "[Output Only] The status of the address, which can be one of RESERVING, RESERVED, or IN_USE. An address that is RESERVING is currently in the process of being reserved. A RESERVED address is currently reserved and available to use. An IN_USE address is currently being used by another resource and is not available.",
1703          "type": "string",
1704          "enumDescriptions": [
1705            "Address is being used by another resource and is not available.",
1706            "Address is reserved and available to use.",
1707            "Address is being reserved."
1708          ],
1709          "enum": [
1710            "IN_USE",
1711            "RESERVED",
1712            "RESERVING"
1713          ]
1714        },
1715        "region": {
1716          "description": "[Output Only] The URL of the region where a regional address resides. For regional addresses, you must specify the region as a path parameter in the HTTP request URL. *This field is not applicable to global addresses.*",
1717          "type": "string"
1718        },
1719        "selfLink": {
1720          "description": "[Output Only] Server-defined URL for the resource.",
1721          "type": "string"
1722        },
1723        "users": {
1724          "description": "[Output Only] The URLs of the resources that are using this address.",
1725          "type": "array",
1726          "items": {
1727            "type": "string"
1728          }
1729        },
1730        "networkTier": {
1731          "description": "This signifies the networking tier used for configuring this address and can only take the following values: PREMIUM or STANDARD. Internal IP addresses are always Premium Tier; global external IP addresses are always Premium Tier; regional external IP addresses can be either Standard or Premium Tier. If this field is not specified, it is assumed to be PREMIUM.",
1732          "type": "string",
1733          "enumDescriptions": [
1734            "Public internet quality with fixed bandwidth.",
1735            "High quality, Google-grade network tier, support for all networking products.",
1736            "Public internet quality, only limited support for other networking products.",
1737            "(Output only) Temporary tier for FIXED_STANDARD when fixed standard tier is expired or not configured."
1738          ],
1739          "enum": [
1740            "FIXED_STANDARD",
1741            "PREMIUM",
1742            "STANDARD",
1743            "STANDARD_OVERRIDES_FIXED_STANDARD"
1744          ]
1745        },
1746        "labels": {
1747          "description": "Labels for this resource. These can only be added or modified by the setLabels method. Each label key/value pair must comply with RFC1035. Label values may be empty.",
1748          "type": "object",
1749          "additionalProperties": {
1750            "type": "string"
1751          }
1752        },
1753        "labelFingerprint": {
1754          "description": "A fingerprint for the labels being applied to this Address, which is essentially a hash of the labels set used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve an Address.",
1755          "type": "string",
1756          "format": "byte"
1757        },
1758        "ipVersion": {
1759          "description": "The IP version that will be used by this address. Valid options are IPV4 or IPV6.",
1760          "type": "string",
1761          "enumDescriptions": [
1762            "",
1763            "",
1764            ""
1765          ],
1766          "enum": [
1767            "IPV4",
1768            "IPV6",
1769            "UNSPECIFIED_VERSION"
1770          ]
1771        },
1772        "addressType": {
1773          "description": "The type of address to reserve, either INTERNAL or EXTERNAL. If unspecified, defaults to EXTERNAL.",
1774          "type": "string",
1775          "enumDescriptions": [
1776            "A publicly visible external IP address.",
1777            "A private network IP address, for use with an Instance or Internal Load Balancer forwarding rule.",
1778            ""
1779          ],
1780          "enum": [
1781            "EXTERNAL",
1782            "INTERNAL",
1783            "UNSPECIFIED_TYPE"
1784          ]
1785        },
1786        "purpose": {
1787          "description": "The purpose of this resource, which can be one of the following values: - GCE_ENDPOINT for addresses that are used by VM instances, alias IP ranges, load balancers, and similar resources. - DNS_RESOLVER for a DNS resolver address in a subnetwork for a Cloud DNS inbound forwarder IP addresses (regional internal IP address in a subnet of a VPC network) - VPC_PEERING for global internal IP addresses used for private services access allocated ranges. - NAT_AUTO for the regional external IP addresses used by Cloud NAT when allocating addresses using automatic NAT IP address allocation. - IPSEC_INTERCONNECT for addresses created from a private IP range that are reserved for a VLAN attachment in an *HA VPN over Cloud Interconnect* configuration. These addresses are regional resources. - `SHARED_LOADBALANCER_VIP` for an internal IP address that is assigned to multiple internal forwarding rules. - `PRIVATE_SERVICE_CONNECT` for a private network address that is used to configure Private Service Connect. Only global internal addresses can use this purpose. ",
1788          "type": "string",
1789          "enumDescriptions": [
1790            "DNS resolver address in the subnetwork.",
1791            "VM internal/alias IP, Internal LB service IP, etc.",
1792            "A regional internal IP address range reserved for the VLAN attachment that is used in HA VPN over Cloud Interconnect. This regional internal IP address range must not overlap with any IP address range of subnet/route in the VPC network and its peering networks. After the VLAN attachment is created with the reserved IP address range, when creating a new VPN gateway, its interface IP address is allocated from the associated VLAN attachment’s IP address range.",
1793            "External IP automatically reserved for Cloud NAT.",
1794            "A private network IP address that can be used to configure Private Service Connect. This purpose can be specified only for GLOBAL addresses of Type INTERNAL",
1795            "A regional internal IP address range reserved for Serverless.",
1796            "A private network IP address that can be shared by multiple Internal Load Balancer forwarding rules.",
1797            "IP range for peer networks."
1798          ],
1799          "enum": [
1800            "DNS_RESOLVER",
1801            "GCE_ENDPOINT",
1802            "IPSEC_INTERCONNECT",
1803            "NAT_AUTO",
1804            "PRIVATE_SERVICE_CONNECT",
1805            "SERVERLESS",
1806            "SHARED_LOADBALANCER_VIP",
1807            "VPC_PEERING"
1808          ]
1809        },
1810        "subnetwork": {
1811          "description": "The URL of the subnetwork in which to reserve the address. If an IP address is specified, it must be within the subnetwork's IP range. This field can only be used with INTERNAL type with a GCE_ENDPOINT or DNS_RESOLVER purpose.",
1812          "type": "string"
1813        },
1814        "network": {
1815          "description": "The URL of the network in which to reserve the address. This field can only be used with INTERNAL type with the VPC_PEERING purpose.",
1816          "type": "string"
1817        },
1818        "ipv6EndpointType": {
1819          "description": "The endpoint type of this address, which should be VM or NETLB. This is used for deciding which type of endpoint this address can be used after the external IPv6 address reservation.",
1820          "type": "string",
1821          "enumDescriptions": [
1822            "Reserved IPv6 address can be used on network load balancer.",
1823            "Reserved IPv6 address can be used on VM."
1824          ],
1825          "enum": [
1826            "NETLB",
1827            "VM"
1828          ]
1829        }
1830      }
1831    },
1832    "GlobalAddressesMoveRequest": {
1833      "id": "GlobalAddressesMoveRequest",
1834      "type": "object",
1835      "properties": {
1836        "destinationAddress": {
1837          "description": "The URL of the destination address to move to. This can be a full or partial URL. For example, the following are all valid URLs to a address: - https://www.googleapis.com/compute/v1/projects/project /global/addresses/address - projects/project/global/addresses/address Note that destination project must be different from the source project. So /global/addresses/address is not valid partial url.",
1838          "type": "string"
1839        },
1840        "description": {
1841          "description": "An optional destination address description if intended to be different from the source.",
1842          "type": "string"
1843        }
1844      }
1845    },
1846    "GlobalSetLabelsRequest": {
1847      "id": "GlobalSetLabelsRequest",
1848      "type": "object",
1849      "properties": {
1850        "labels": {
1851          "description": "A list of labels to apply for this resource. Each label must comply with the requirements for labels. For example, \"webserver-frontend\": \"images\". A label value can also be empty (e.g. \"my-label\": \"\").",
1852          "type": "object",
1853          "additionalProperties": {
1854            "type": "string"
1855          }
1856        },
1857        "labelFingerprint": {
1858          "description": "The fingerprint of the previous set of labels for this resource, used to detect conflicts. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash when updating or changing labels, otherwise the request will fail with error 412 conditionNotMet. Make a get() request to the resource to get the latest fingerprint.",
1859          "type": "string",
1860          "format": "byte"
1861        }
1862      }
1863    },
1864    "AddressAggregatedList": {
1865      "id": "AddressAggregatedList",
1866      "type": "object",
1867      "properties": {
1868        "kind": {
1869          "description": "[Output Only] Type of resource. Always compute#addressAggregatedList for aggregated lists of addresses.",
1870          "default": "compute#addressAggregatedList",
1871          "type": "string"
1872        },
1873        "id": {
1874          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
1875          "type": "string"
1876        },
1877        "items": {
1878          "description": "A list of AddressesScopedList resources.",
1879          "type": "object",
1880          "additionalProperties": {
1881            "description": "[Output Only] Name of the scope containing this set of addresses.",
1882            "$ref": "AddressesScopedList"
1883          }
1884        },
1885        "nextPageToken": {
1886          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
1887          "type": "string"
1888        },
1889        "selfLink": {
1890          "description": "[Output Only] Server-defined URL for this resource.",
1891          "type": "string"
1892        },
1893        "warning": {
1894          "description": "[Output Only] Informational warning message.",
1895          "type": "object",
1896          "properties": {
1897            "code": {
1898              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
1899              "type": "string",
1900              "enumDescriptions": [
1901                "Warning about failed cleanup of transient changes made by a failed operation.",
1902                "A link to a deprecated resource was created.",
1903                "When deploying and at least one of the resources has a type marked as deprecated",
1904                "The user created a boot disk that is larger than image size.",
1905                "When deploying and at least one of the resources has a type marked as experimental",
1906                "Warning that is present in an external api call",
1907                "Warning that value of a field has been overridden. Deprecated unused field.",
1908                "The operation involved use of an injected kernel, which is deprecated.",
1909                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
1910                "When deploying a deployment with a exceedingly large number of resources",
1911                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
1912                "A resource depends on a missing type",
1913                "The route's nextHopIp address is not assigned to an instance on the network.",
1914                "The route's next hop instance cannot ip forward.",
1915                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
1916                "The route's nextHopInstance URL refers to an instance that does not exist.",
1917                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
1918                "The route's next hop instance does not have a status of RUNNING.",
1919                "Error which is not critical. We decided to continue the process despite the mentioned error.",
1920                "No results are present on a particular list page.",
1921                "Success is reported, but some results may be missing due to errors",
1922                "The user attempted to use a resource that requires a TOS they have not accepted.",
1923                "Warning that a resource is in use.",
1924                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
1925                "When a resource schema validation is ignored.",
1926                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
1927                "When undeclared properties in the schema are present",
1928                "A given scope cannot be reached."
1929              ],
1930              "enumDeprecated": [
1931                false,
1932                false,
1933                false,
1934                false,
1935                false,
1936                false,
1937                true,
1938                false,
1939                false,
1940                false,
1941                false,
1942                false,
1943                false,
1944                false,
1945                false,
1946                false,
1947                false,
1948                false,
1949                false,
1950                false,
1951                false,
1952                false,
1953                false,
1954                false,
1955                false,
1956                false,
1957                false,
1958                false
1959              ],
1960              "enum": [
1961                "CLEANUP_FAILED",
1962                "DEPRECATED_RESOURCE_USED",
1963                "DEPRECATED_TYPE_USED",
1964                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
1965                "EXPERIMENTAL_TYPE_USED",
1966                "EXTERNAL_API_WARNING",
1967                "FIELD_VALUE_OVERRIDEN",
1968                "INJECTED_KERNELS_DEPRECATED",
1969                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
1970                "LARGE_DEPLOYMENT_WARNING",
1971                "LIST_OVERHEAD_QUOTA_EXCEED",
1972                "MISSING_TYPE_DEPENDENCY",
1973                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
1974                "NEXT_HOP_CANNOT_IP_FORWARD",
1975                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
1976                "NEXT_HOP_INSTANCE_NOT_FOUND",
1977                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
1978                "NEXT_HOP_NOT_RUNNING",
1979                "NOT_CRITICAL_ERROR",
1980                "NO_RESULTS_ON_PAGE",
1981                "PARTIAL_SUCCESS",
1982                "REQUIRED_TOS_AGREEMENT",
1983                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
1984                "RESOURCE_NOT_DELETED",
1985                "SCHEMA_VALIDATION_IGNORED",
1986                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
1987                "UNDECLARED_PROPERTIES",
1988                "UNREACHABLE"
1989              ]
1990            },
1991            "message": {
1992              "description": "[Output Only] A human-readable description of the warning code.",
1993              "type": "string"
1994            },
1995            "data": {
1996              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
1997              "type": "array",
1998              "items": {
1999                "type": "object",
2000                "properties": {
2001                  "key": {
2002                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
2003                    "type": "string"
2004                  },
2005                  "value": {
2006                    "description": "[Output Only] A warning data value corresponding to the key.",
2007                    "type": "string"
2008                  }
2009                }
2010              }
2011            }
2012          }
2013        },
2014        "unreachables": {
2015          "description": "[Output Only] Unreachable resources.",
2016          "type": "array",
2017          "items": {
2018            "type": "string"
2019          }
2020        }
2021      }
2022    },
2023    "AddressesScopedList": {
2024      "id": "AddressesScopedList",
2025      "type": "object",
2026      "properties": {
2027        "addresses": {
2028          "description": "[Output Only] A list of addresses contained in this scope.",
2029          "type": "array",
2030          "items": {
2031            "$ref": "Address"
2032          }
2033        },
2034        "warning": {
2035          "description": "[Output Only] Informational warning which replaces the list of addresses when the list is empty.",
2036          "type": "object",
2037          "properties": {
2038            "code": {
2039              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
2040              "type": "string",
2041              "enumDescriptions": [
2042                "Warning about failed cleanup of transient changes made by a failed operation.",
2043                "A link to a deprecated resource was created.",
2044                "When deploying and at least one of the resources has a type marked as deprecated",
2045                "The user created a boot disk that is larger than image size.",
2046                "When deploying and at least one of the resources has a type marked as experimental",
2047                "Warning that is present in an external api call",
2048                "Warning that value of a field has been overridden. Deprecated unused field.",
2049                "The operation involved use of an injected kernel, which is deprecated.",
2050                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
2051                "When deploying a deployment with a exceedingly large number of resources",
2052                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
2053                "A resource depends on a missing type",
2054                "The route's nextHopIp address is not assigned to an instance on the network.",
2055                "The route's next hop instance cannot ip forward.",
2056                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
2057                "The route's nextHopInstance URL refers to an instance that does not exist.",
2058                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
2059                "The route's next hop instance does not have a status of RUNNING.",
2060                "Error which is not critical. We decided to continue the process despite the mentioned error.",
2061                "No results are present on a particular list page.",
2062                "Success is reported, but some results may be missing due to errors",
2063                "The user attempted to use a resource that requires a TOS they have not accepted.",
2064                "Warning that a resource is in use.",
2065                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
2066                "When a resource schema validation is ignored.",
2067                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
2068                "When undeclared properties in the schema are present",
2069                "A given scope cannot be reached."
2070              ],
2071              "enumDeprecated": [
2072                false,
2073                false,
2074                false,
2075                false,
2076                false,
2077                false,
2078                true,
2079                false,
2080                false,
2081                false,
2082                false,
2083                false,
2084                false,
2085                false,
2086                false,
2087                false,
2088                false,
2089                false,
2090                false,
2091                false,
2092                false,
2093                false,
2094                false,
2095                false,
2096                false,
2097                false,
2098                false,
2099                false
2100              ],
2101              "enum": [
2102                "CLEANUP_FAILED",
2103                "DEPRECATED_RESOURCE_USED",
2104                "DEPRECATED_TYPE_USED",
2105                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
2106                "EXPERIMENTAL_TYPE_USED",
2107                "EXTERNAL_API_WARNING",
2108                "FIELD_VALUE_OVERRIDEN",
2109                "INJECTED_KERNELS_DEPRECATED",
2110                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
2111                "LARGE_DEPLOYMENT_WARNING",
2112                "LIST_OVERHEAD_QUOTA_EXCEED",
2113                "MISSING_TYPE_DEPENDENCY",
2114                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
2115                "NEXT_HOP_CANNOT_IP_FORWARD",
2116                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
2117                "NEXT_HOP_INSTANCE_NOT_FOUND",
2118                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
2119                "NEXT_HOP_NOT_RUNNING",
2120                "NOT_CRITICAL_ERROR",
2121                "NO_RESULTS_ON_PAGE",
2122                "PARTIAL_SUCCESS",
2123                "REQUIRED_TOS_AGREEMENT",
2124                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
2125                "RESOURCE_NOT_DELETED",
2126                "SCHEMA_VALIDATION_IGNORED",
2127                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
2128                "UNDECLARED_PROPERTIES",
2129                "UNREACHABLE"
2130              ]
2131            },
2132            "message": {
2133              "description": "[Output Only] A human-readable description of the warning code.",
2134              "type": "string"
2135            },
2136            "data": {
2137              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
2138              "type": "array",
2139              "items": {
2140                "type": "object",
2141                "properties": {
2142                  "key": {
2143                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
2144                    "type": "string"
2145                  },
2146                  "value": {
2147                    "description": "[Output Only] A warning data value corresponding to the key.",
2148                    "type": "string"
2149                  }
2150                }
2151              }
2152            }
2153          }
2154        }
2155      }
2156    },
2157    "RegionAddressesMoveRequest": {
2158      "id": "RegionAddressesMoveRequest",
2159      "type": "object",
2160      "properties": {
2161        "destinationAddress": {
2162          "description": "The URL of the destination address to move to. This can be a full or partial URL. For example, the following are all valid URLs to a address: - https://www.googleapis.com/compute/v1/projects/project/regions/region /addresses/address - projects/project/regions/region/addresses/address Note that destination project must be different from the source project. So /regions/region/addresses/address is not valid partial url.",
2163          "type": "string"
2164        },
2165        "description": {
2166          "description": "An optional destination address description if intended to be different from the source.",
2167          "type": "string"
2168        }
2169      }
2170    },
2171    "RegionSetLabelsRequest": {
2172      "id": "RegionSetLabelsRequest",
2173      "type": "object",
2174      "properties": {
2175        "labels": {
2176          "description": "The labels to set for this resource.",
2177          "type": "object",
2178          "additionalProperties": {
2179            "type": "string"
2180          }
2181        },
2182        "labelFingerprint": {
2183          "description": "The fingerprint of the previous set of labels for this resource, used to detect conflicts. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels. Make a get() request to the resource to get the latest fingerprint.",
2184          "type": "string",
2185          "format": "byte"
2186        }
2187      }
2188    },
2189    "ImageList": {
2190      "id": "ImageList",
2191      "description": "Contains a list of images.",
2192      "type": "object",
2193      "properties": {
2194        "kind": {
2195          "description": "Type of resource.",
2196          "default": "compute#imageList",
2197          "type": "string"
2198        },
2199        "id": {
2200          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
2201          "type": "string"
2202        },
2203        "items": {
2204          "description": "A list of Image resources.",
2205          "type": "array",
2206          "items": {
2207            "$ref": "Image"
2208          }
2209        },
2210        "nextPageToken": {
2211          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
2212          "type": "string"
2213        },
2214        "selfLink": {
2215          "description": "[Output Only] Server-defined URL for this resource.",
2216          "type": "string"
2217        },
2218        "warning": {
2219          "description": "[Output Only] Informational warning message.",
2220          "type": "object",
2221          "properties": {
2222            "code": {
2223              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
2224              "type": "string",
2225              "enumDescriptions": [
2226                "Warning about failed cleanup of transient changes made by a failed operation.",
2227                "A link to a deprecated resource was created.",
2228                "When deploying and at least one of the resources has a type marked as deprecated",
2229                "The user created a boot disk that is larger than image size.",
2230                "When deploying and at least one of the resources has a type marked as experimental",
2231                "Warning that is present in an external api call",
2232                "Warning that value of a field has been overridden. Deprecated unused field.",
2233                "The operation involved use of an injected kernel, which is deprecated.",
2234                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
2235                "When deploying a deployment with a exceedingly large number of resources",
2236                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
2237                "A resource depends on a missing type",
2238                "The route's nextHopIp address is not assigned to an instance on the network.",
2239                "The route's next hop instance cannot ip forward.",
2240                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
2241                "The route's nextHopInstance URL refers to an instance that does not exist.",
2242                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
2243                "The route's next hop instance does not have a status of RUNNING.",
2244                "Error which is not critical. We decided to continue the process despite the mentioned error.",
2245                "No results are present on a particular list page.",
2246                "Success is reported, but some results may be missing due to errors",
2247                "The user attempted to use a resource that requires a TOS they have not accepted.",
2248                "Warning that a resource is in use.",
2249                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
2250                "When a resource schema validation is ignored.",
2251                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
2252                "When undeclared properties in the schema are present",
2253                "A given scope cannot be reached."
2254              ],
2255              "enumDeprecated": [
2256                false,
2257                false,
2258                false,
2259                false,
2260                false,
2261                false,
2262                true,
2263                false,
2264                false,
2265                false,
2266                false,
2267                false,
2268                false,
2269                false,
2270                false,
2271                false,
2272                false,
2273                false,
2274                false,
2275                false,
2276                false,
2277                false,
2278                false,
2279                false,
2280                false,
2281                false,
2282                false,
2283                false
2284              ],
2285              "enum": [
2286                "CLEANUP_FAILED",
2287                "DEPRECATED_RESOURCE_USED",
2288                "DEPRECATED_TYPE_USED",
2289                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
2290                "EXPERIMENTAL_TYPE_USED",
2291                "EXTERNAL_API_WARNING",
2292                "FIELD_VALUE_OVERRIDEN",
2293                "INJECTED_KERNELS_DEPRECATED",
2294                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
2295                "LARGE_DEPLOYMENT_WARNING",
2296                "LIST_OVERHEAD_QUOTA_EXCEED",
2297                "MISSING_TYPE_DEPENDENCY",
2298                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
2299                "NEXT_HOP_CANNOT_IP_FORWARD",
2300                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
2301                "NEXT_HOP_INSTANCE_NOT_FOUND",
2302                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
2303                "NEXT_HOP_NOT_RUNNING",
2304                "NOT_CRITICAL_ERROR",
2305                "NO_RESULTS_ON_PAGE",
2306                "PARTIAL_SUCCESS",
2307                "REQUIRED_TOS_AGREEMENT",
2308                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
2309                "RESOURCE_NOT_DELETED",
2310                "SCHEMA_VALIDATION_IGNORED",
2311                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
2312                "UNDECLARED_PROPERTIES",
2313                "UNREACHABLE"
2314              ]
2315            },
2316            "message": {
2317              "description": "[Output Only] A human-readable description of the warning code.",
2318              "type": "string"
2319            },
2320            "data": {
2321              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
2322              "type": "array",
2323              "items": {
2324                "type": "object",
2325                "properties": {
2326                  "key": {
2327                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
2328                    "type": "string"
2329                  },
2330                  "value": {
2331                    "description": "[Output Only] A warning data value corresponding to the key.",
2332                    "type": "string"
2333                  }
2334                }
2335              }
2336            }
2337          }
2338        }
2339      }
2340    },
2341    "Image": {
2342      "id": "Image",
2343      "description": "Represents an Image resource. You can use images to create boot disks for your VM instances. For more information, read Images.",
2344      "type": "object",
2345      "properties": {
2346        "kind": {
2347          "description": "[Output Only] Type of the resource. Always compute#image for images.",
2348          "default": "compute#image",
2349          "type": "string"
2350        },
2351        "id": {
2352          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
2353          "type": "string",
2354          "format": "uint64"
2355        },
2356        "creationTimestamp": {
2357          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
2358          "type": "string"
2359        },
2360        "name": {
2361          "description": "Name of the resource; provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
2362          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
2363          "annotations": {
2364            "required": [
2365              "compute.images.insert"
2366            ]
2367          },
2368          "type": "string"
2369        },
2370        "description": {
2371          "description": "An optional description of this resource. Provide this property when you create the resource.",
2372          "type": "string"
2373        },
2374        "sourceType": {
2375          "description": "The type of the image used to create this disk. The default and only valid value is RAW.",
2376          "default": "RAW",
2377          "type": "string",
2378          "enumDescriptions": [
2379            ""
2380          ],
2381          "enum": [
2382            "RAW"
2383          ]
2384        },
2385        "rawDisk": {
2386          "description": "The parameters of the raw disk image.",
2387          "type": "object",
2388          "properties": {
2389            "source": {
2390              "description": "The full Google Cloud Storage URL where the raw disk image archive is stored. The following are valid formats for the URL: - https://storage.googleapis.com/bucket_name/image_archive_name - https://storage.googleapis.com/bucket_name/folder_name/ image_archive_name In order to create an image, you must provide the full or partial URL of one of the following: - The rawDisk.source URL - The sourceDisk URL - The sourceImage URL - The sourceSnapshot URL ",
2391              "type": "string"
2392            },
2393            "sha1Checksum": {
2394              "description": "[Deprecated] This field is deprecated. An optional SHA1 checksum of the disk image before unpackaging provided by the client when the disk image is created.",
2395              "pattern": "[a-f0-9]{40}",
2396              "deprecated": true,
2397              "type": "string"
2398            },
2399            "containerType": {
2400              "description": "The format used to encode and transmit the block device, which should be TAR. This is just a container and transmission format and not a runtime format. Provided by the client when the disk image is created.",
2401              "type": "string",
2402              "enumDescriptions": [
2403                ""
2404              ],
2405              "enum": [
2406                "TAR"
2407              ]
2408            }
2409          }
2410        },
2411        "deprecated": {
2412          "description": "The deprecation status associated with this image.",
2413          "$ref": "DeprecationStatus"
2414        },
2415        "status": {
2416          "description": "[Output Only] The status of the image. An image can be used to create other resources, such as instances, only after the image has been successfully created and the status is set to READY. Possible values are FAILED, PENDING, or READY.",
2417          "type": "string",
2418          "enumDescriptions": [
2419            "Image is deleting.",
2420            "Image creation failed due to an error.",
2421            "Image hasn't been created as yet.",
2422            "Image has been successfully created."
2423          ],
2424          "enum": [
2425            "DELETING",
2426            "FAILED",
2427            "PENDING",
2428            "READY"
2429          ]
2430        },
2431        "archiveSizeBytes": {
2432          "description": "Size of the image tar.gz archive stored in Google Cloud Storage (in bytes).",
2433          "type": "string",
2434          "format": "int64"
2435        },
2436        "diskSizeGb": {
2437          "description": "Size of the image when restored onto a persistent disk (in GB).",
2438          "type": "string",
2439          "format": "int64"
2440        },
2441        "sourceDisk": {
2442          "description": "URL of the source disk used to create this image. For example, the following are valid values: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /disks/disk - projects/project/zones/zone/disks/disk - zones/zone/disks/disk In order to create an image, you must provide the full or partial URL of one of the following: - The rawDisk.source URL - The sourceDisk URL - The sourceImage URL - The sourceSnapshot URL ",
2443          "type": "string"
2444        },
2445        "sourceDiskId": {
2446          "description": "[Output Only] The ID value of the disk used to create this image. This value may be used to determine whether the image was taken from the current or a previous instance of a given disk name.",
2447          "type": "string"
2448        },
2449        "licenses": {
2450          "description": "Any applicable license URI.",
2451          "type": "array",
2452          "items": {
2453            "type": "string"
2454          }
2455        },
2456        "family": {
2457          "description": "The name of the image family to which this image belongs. The image family name can be from a publicly managed image family provided by Compute Engine, or from a custom image family you create. For example, centos-stream-9 is a publicly available image family. For more information, see Image family best practices. When creating disks, you can specify an image family instead of a specific image name. The image family always returns its latest image that is not deprecated. The name of the image family must comply with RFC1035.",
2458          "type": "string"
2459        },
2460        "imageEncryptionKey": {
2461          "description": "Encrypts the image using a customer-supplied encryption key. After you encrypt an image with a customer-supplied key, you must provide the same key if you use the image later (e.g. to create a disk from the image). Customer-supplied encryption keys do not protect access to metadata of the disk. If you do not provide an encryption key when creating the image, then the disk will be encrypted using an automatically generated key and you do not need to provide a key to use the image later.",
2462          "$ref": "CustomerEncryptionKey"
2463        },
2464        "sourceDiskEncryptionKey": {
2465          "description": "The customer-supplied encryption key of the source disk. Required if the source disk is protected by a customer-supplied encryption key.",
2466          "$ref": "CustomerEncryptionKey"
2467        },
2468        "selfLink": {
2469          "description": "[Output Only] Server-defined URL for the resource.",
2470          "type": "string"
2471        },
2472        "labels": {
2473          "description": "Labels to apply to this image. These can be later modified by the setLabels method.",
2474          "type": "object",
2475          "additionalProperties": {
2476            "type": "string"
2477          }
2478        },
2479        "labelFingerprint": {
2480          "description": "A fingerprint for the labels being applied to this image, which is essentially a hash of the labels used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve an image.",
2481          "type": "string",
2482          "format": "byte"
2483        },
2484        "guestOsFeatures": {
2485          "description": "A list of features to enable on the guest operating system. Applicable only for bootable images. To see a list of available options, see the guestOSfeatures[].type parameter.",
2486          "type": "array",
2487          "items": {
2488            "$ref": "GuestOsFeature"
2489          }
2490        },
2491        "licenseCodes": {
2492          "description": "Integer license codes indicating which licenses are attached to this image.",
2493          "type": "array",
2494          "items": {
2495            "type": "string",
2496            "format": "int64"
2497          }
2498        },
2499        "sourceImage": {
2500          "description": "URL of the source image used to create this image. The following are valid formats for the URL: - https://www.googleapis.com/compute/v1/projects/project_id/global/ images/image_name - projects/project_id/global/images/image_name In order to create an image, you must provide the full or partial URL of one of the following: - The rawDisk.source URL - The sourceDisk URL - The sourceImage URL - The sourceSnapshot URL ",
2501          "type": "string"
2502        },
2503        "sourceImageId": {
2504          "description": "[Output Only] The ID value of the image used to create this image. This value may be used to determine whether the image was taken from the current or a previous instance of a given image name.",
2505          "type": "string"
2506        },
2507        "sourceImageEncryptionKey": {
2508          "description": "The customer-supplied encryption key of the source image. Required if the source image is protected by a customer-supplied encryption key.",
2509          "$ref": "CustomerEncryptionKey"
2510        },
2511        "sourceSnapshot": {
2512          "description": "URL of the source snapshot used to create this image. The following are valid formats for the URL: - https://www.googleapis.com/compute/v1/projects/project_id/global/ snapshots/snapshot_name - projects/project_id/global/snapshots/snapshot_name In order to create an image, you must provide the full or partial URL of one of the following: - The rawDisk.source URL - The sourceDisk URL - The sourceImage URL - The sourceSnapshot URL ",
2513          "type": "string"
2514        },
2515        "sourceSnapshotId": {
2516          "description": "[Output Only] The ID value of the snapshot used to create this image. This value may be used to determine whether the snapshot was taken from the current or a previous instance of a given snapshot name.",
2517          "type": "string"
2518        },
2519        "sourceSnapshotEncryptionKey": {
2520          "description": "The customer-supplied encryption key of the source snapshot. Required if the source snapshot is protected by a customer-supplied encryption key.",
2521          "$ref": "CustomerEncryptionKey"
2522        },
2523        "storageLocations": {
2524          "description": "Cloud Storage bucket storage location of the image (regional or multi-regional).",
2525          "type": "array",
2526          "items": {
2527            "type": "string"
2528          }
2529        },
2530        "shieldedInstanceInitialState": {
2531          "description": "Set the secure boot keys of shielded instance.",
2532          "$ref": "InitialStateConfig"
2533        },
2534        "satisfiesPzs": {
2535          "description": "[Output Only] Reserved for future use.",
2536          "type": "boolean"
2537        },
2538        "architecture": {
2539          "description": "The architecture of the image. Valid values are ARM64 or X86_64.",
2540          "type": "string",
2541          "enumDescriptions": [
2542            "Default value indicating Architecture is not set.",
2543            "Machines with architecture ARM64",
2544            "Machines with architecture X86_64"
2545          ],
2546          "enum": [
2547            "ARCHITECTURE_UNSPECIFIED",
2548            "ARM64",
2549            "X86_64"
2550          ]
2551        },
2552        "enableConfidentialCompute": {
2553          "description": "Whether this image is created from a confidential compute mode disk. [Output Only]: This field is not set by user, but from source disk.",
2554          "type": "boolean"
2555        },
2556        "satisfiesPzi": {
2557          "description": "Output only. Reserved for future use.",
2558          "readOnly": true,
2559          "type": "boolean"
2560        }
2561      }
2562    },
2563    "CustomerEncryptionKey": {
2564      "id": "CustomerEncryptionKey",
2565      "type": "object",
2566      "properties": {
2567        "rawKey": {
2568          "description": "Specifies a 256-bit customer-supplied encryption key, encoded in RFC 4648 base64 to either encrypt or decrypt this resource. You can provide either the rawKey or the rsaEncryptedKey. For example: \"rawKey\": \"SGVsbG8gZnJvbSBHb29nbGUgQ2xvdWQgUGxhdGZvcm0=\" ",
2569          "type": "string"
2570        },
2571        "rsaEncryptedKey": {
2572          "description": "Specifies an RFC 4648 base64 encoded, RSA-wrapped 2048-bit customer-supplied encryption key to either encrypt or decrypt this resource. You can provide either the rawKey or the rsaEncryptedKey. For example: \"rsaEncryptedKey\": \"ieCx/NcW06PcT7Ep1X6LUTc/hLvUDYyzSZPPVCVPTVEohpeHASqC8uw5TzyO9U+Fka9JFH z0mBibXUInrC/jEk014kCK/NPjYgEMOyssZ4ZINPKxlUh2zn1bV+MCaTICrdmuSBTWlUUiFoD D6PYznLwh8ZNdaheCeZ8ewEXgFQ8V+sDroLaN3Xs3MDTXQEMMoNUXMCZEIpg9Vtp9x2oe==\" The key must meet the following requirements before you can provide it to Compute Engine: 1. The key is wrapped using a RSA public key certificate provided by Google. 2. After being wrapped, the key must be encoded in RFC 4648 base64 encoding. Gets the RSA public key certificate provided by Google at: https://cloud-certs.storage.googleapis.com/google-cloud-csek-ingress.pem ",
2573          "type": "string"
2574        },
2575        "kmsKeyName": {
2576          "description": "The name of the encryption key that is stored in Google Cloud KMS. For example: \"kmsKeyName\": \"projects/kms_project_id/locations/region/keyRings/ key_region/cryptoKeys/key The fully-qualifed key name may be returned for resource GET requests. For example: \"kmsKeyName\": \"projects/kms_project_id/locations/region/keyRings/ key_region/cryptoKeys/key /cryptoKeyVersions/1 ",
2577          "type": "string"
2578        },
2579        "sha256": {
2580          "description": "[Output only] The RFC 4648 base64 encoded SHA-256 hash of the customer-supplied encryption key that protects this resource.",
2581          "type": "string"
2582        },
2583        "kmsKeyServiceAccount": {
2584          "description": "The service account being used for the encryption request for the given KMS key. If absent, the Compute Engine default service account is used. For example: \"kmsKeyServiceAccount\": \"name@project_id.iam.gserviceaccount.com/ ",
2585          "type": "string"
2586        }
2587      }
2588    },
2589    "GuestOsFeature": {
2590      "id": "GuestOsFeature",
2591      "description": "Guest OS features.",
2592      "type": "object",
2593      "properties": {
2594        "type": {
2595          "description": "The ID of a supported feature. To add multiple values, use commas to separate values. Set to one or more of the following values: - VIRTIO_SCSI_MULTIQUEUE - WINDOWS - MULTI_IP_SUBNET - UEFI_COMPATIBLE - GVNIC - SEV_CAPABLE - SUSPEND_RESUME_COMPATIBLE - SEV_LIVE_MIGRATABLE - SEV_SNP_CAPABLE - TDX_CAPABLE - IDPF For more information, see Enabling guest operating system features.",
2596          "type": "string",
2597          "enumDescriptions": [
2598            "",
2599            "",
2600            "",
2601            "",
2602            "",
2603            "",
2604            "",
2605            "",
2606            "",
2607            "",
2608            "",
2609            ""
2610          ],
2611          "enum": [
2612            "FEATURE_TYPE_UNSPECIFIED",
2613            "GVNIC",
2614            "IDPF",
2615            "MULTI_IP_SUBNET",
2616            "SECURE_BOOT",
2617            "SEV_CAPABLE",
2618            "SEV_LIVE_MIGRATABLE",
2619            "SEV_LIVE_MIGRATABLE_V2",
2620            "SEV_SNP_CAPABLE",
2621            "UEFI_COMPATIBLE",
2622            "VIRTIO_SCSI_MULTIQUEUE",
2623            "WINDOWS"
2624          ]
2625        }
2626      }
2627    },
2628    "InitialStateConfig": {
2629      "id": "InitialStateConfig",
2630      "description": "Initial State for shielded instance, these are public keys which are safe to store in public",
2631      "type": "object",
2632      "properties": {
2633        "pk": {
2634          "description": "The Platform Key (PK).",
2635          "$ref": "FileContentBuffer"
2636        },
2637        "keks": {
2638          "description": "The Key Exchange Key (KEK).",
2639          "type": "array",
2640          "items": {
2641            "$ref": "FileContentBuffer"
2642          }
2643        },
2644        "dbs": {
2645          "description": "The Key Database (db).",
2646          "type": "array",
2647          "items": {
2648            "$ref": "FileContentBuffer"
2649          }
2650        },
2651        "dbxs": {
2652          "description": "The forbidden key database (dbx).",
2653          "type": "array",
2654          "items": {
2655            "$ref": "FileContentBuffer"
2656          }
2657        }
2658      }
2659    },
2660    "FileContentBuffer": {
2661      "id": "FileContentBuffer",
2662      "type": "object",
2663      "properties": {
2664        "content": {
2665          "description": "The raw content in the secure keys file.",
2666          "type": "string",
2667          "format": "byte"
2668        },
2669        "fileType": {
2670          "description": "The file type of source file.",
2671          "type": "string",
2672          "enumDescriptions": [
2673            "",
2674            "",
2675            ""
2676          ],
2677          "enum": [
2678            "BIN",
2679            "UNDEFINED",
2680            "X509"
2681          ]
2682        }
2683      }
2684    },
2685    "Policy": {
2686      "id": "Policy",
2687      "description": "An Identity and Access Management (IAM) policy, which specifies access controls for Google Cloud resources. A `Policy` is a collection of `bindings`. A `binding` binds one or more `members`, or principals, to a single `role`. Principals can be user accounts, service accounts, Google groups, and domains (such as G Suite). A `role` is a named list of permissions; each `role` can be an IAM predefined role or a user-created custom role. For some types of Google Cloud resources, a `binding` can also specify a `condition`, which is a logical expression that allows access to a resource only if the expression evaluates to `true`. A condition can add constraints based on attributes of the request, the resource, or both. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies). **JSON example:** ``` { \"bindings\": [ { \"role\": \"roles/resourcemanager.organizationAdmin\", \"members\": [ \"user:[email protected]\", \"group:[email protected]\", \"domain:google.com\", \"serviceAccount:[email protected]\" ] }, { \"role\": \"roles/resourcemanager.organizationViewer\", \"members\": [ \"user:[email protected]\" ], \"condition\": { \"title\": \"expirable access\", \"description\": \"Does not grant access after Sep 2020\", \"expression\": \"request.time \u003c timestamp('2020-10-01T00:00:00.000Z')\", } } ], \"etag\": \"BwWWja0YfJA=\", \"version\": 3 } ``` **YAML example:** ``` bindings: - members: - user:[email protected] - group:[email protected] - domain:google.com - serviceAccount:[email protected] role: roles/resourcemanager.organizationAdmin - members: - user:[email protected] role: roles/resourcemanager.organizationViewer condition: title: expirable access description: Does not grant access after Sep 2020 expression: request.time \u003c timestamp('2020-10-01T00:00:00.000Z') etag: BwWWja0YfJA= version: 3 ``` For a description of IAM and its features, see the [IAM documentation](https://cloud.google.com/iam/docs/).",
2688      "type": "object",
2689      "properties": {
2690        "version": {
2691          "description": "Specifies the format of the policy. Valid values are `0`, `1`, and `3`. Requests that specify an invalid value are rejected. Any operation that affects conditional role bindings must specify version `3`. This requirement applies to the following operations: * Getting a policy that includes a conditional role binding * Adding a conditional role binding to a policy * Changing a conditional role binding in a policy * Removing any role binding, with or without a condition, from a policy that includes conditions **Important:** If you use IAM Conditions, you must include the `etag` field whenever you call `setIamPolicy`. If you omit this field, then IAM allows you to overwrite a version `3` policy with a version `1` policy, and all of the conditions in the version `3` policy are lost. If a policy does not include any conditions, operations on that policy may specify any valid version or leave the field unset. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies).",
2692          "type": "integer",
2693          "format": "int32"
2694        },
2695        "bindings": {
2696          "description": "Associates a list of `members`, or principals, with a `role`. Optionally, may specify a `condition` that determines how and when the `bindings` are applied. Each of the `bindings` must contain at least one principal. The `bindings` in a `Policy` can refer to up to 1,500 principals; up to 250 of these principals can be Google groups. Each occurrence of a principal counts towards these limits. For example, if the `bindings` grant 50 different roles to `user:[email protected]`, and not to any other principal, then you can add another 1,450 principals to the `bindings` in the `Policy`.",
2697          "type": "array",
2698          "items": {
2699            "$ref": "Binding"
2700          }
2701        },
2702        "auditConfigs": {
2703          "description": "Specifies cloud audit logging configuration for this policy.",
2704          "type": "array",
2705          "items": {
2706            "$ref": "AuditConfig"
2707          }
2708        },
2709        "rules": {
2710          "description": "This is deprecated and has no effect. Do not use.",
2711          "type": "array",
2712          "items": {
2713            "$ref": "Rule"
2714          }
2715        },
2716        "etag": {
2717          "description": "`etag` is used for optimistic concurrency control as a way to help prevent simultaneous updates of a policy from overwriting each other. It is strongly suggested that systems make use of the `etag` in the read-modify-write cycle to perform policy updates in order to avoid race conditions: An `etag` is returned in the response to `getIamPolicy`, and systems are expected to put that etag in the request to `setIamPolicy` to ensure that their change will be applied to the same version of the policy. **Important:** If you use IAM Conditions, you must include the `etag` field whenever you call `setIamPolicy`. If you omit this field, then IAM allows you to overwrite a version `3` policy with a version `1` policy, and all of the conditions in the version `3` policy are lost.",
2718          "type": "string",
2719          "format": "byte"
2720        }
2721      }
2722    },
2723    "Binding": {
2724      "id": "Binding",
2725      "description": "Associates `members`, or principals, with a `role`.",
2726      "type": "object",
2727      "properties": {
2728        "role": {
2729          "description": "Role that is assigned to the list of `members`, or principals. For example, `roles/viewer`, `roles/editor`, or `roles/owner`. For an overview of the IAM roles and permissions, see the [IAM documentation](https://cloud.google.com/iam/docs/roles-overview). For a list of the available pre-defined roles, see [here](https://cloud.google.com/iam/docs/understanding-roles).",
2730          "type": "string"
2731        },
2732        "members": {
2733          "description": "Specifies the principals requesting access for a Google Cloud resource. `members` can have the following values: * `allUsers`: A special identifier that represents anyone who is on the internet; with or without a Google account. * `allAuthenticatedUsers`: A special identifier that represents anyone who is authenticated with a Google account or a service account. Does not include identities that come from external identity providers (IdPs) through identity federation. * `user:{emailid}`: An email address that represents a specific Google account. For example, `[email protected]` . * `serviceAccount:{emailid}`: An email address that represents a Google service account. For example, `[email protected]`. * `serviceAccount:{projectid}.svc.id.goog[{namespace}/{kubernetes-sa}]`: An identifier for a [Kubernetes service account](https://cloud.google.com/kubernetes-engine/docs/how-to/kubernetes-service-accounts). For example, `my-project.svc.id.goog[my-namespace/my-kubernetes-sa]`. * `group:{emailid}`: An email address that represents a Google group. For example, `[email protected]`. * `domain:{domain}`: The G Suite domain (primary) that represents all the users of that domain. For example, `google.com` or `example.com`. * `principal://iam.googleapis.com/locations/global/workforcePools/{pool_id}/subject/{subject_attribute_value}`: A single identity in a workforce identity pool. * `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/group/{group_id}`: All workforce identities in a group. * `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/attribute.{attribute_name}/{attribute_value}`: All workforce identities with a specific attribute value. * `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/*`: All identities in a workforce identity pool. * `principal://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/subject/{subject_attribute_value}`: A single identity in a workload identity pool. * `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/group/{group_id}`: A workload identity pool group. * `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/attribute.{attribute_name}/{attribute_value}`: All identities in a workload identity pool with a certain attribute. * `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/*`: All identities in a workload identity pool. * `deleted:user:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a user that has been recently deleted. For example, `[email protected]?uid=123456789012345678901`. If the user is recovered, this value reverts to `user:{emailid}` and the recovered user retains the role in the binding. * `deleted:serviceAccount:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a service account that has been recently deleted. For example, `[email protected]?uid=123456789012345678901`. If the service account is undeleted, this value reverts to `serviceAccount:{emailid}` and the undeleted service account retains the role in the binding. * `deleted:group:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a Google group that has been recently deleted. For example, `[email protected]?uid=123456789012345678901`. If the group is recovered, this value reverts to `group:{emailid}` and the recovered group retains the role in the binding. * `deleted:principal://iam.googleapis.com/locations/global/workforcePools/{pool_id}/subject/{subject_attribute_value}`: Deleted single identity in a workforce identity pool. For example, `deleted:principal://iam.googleapis.com/locations/global/workforcePools/my-pool-id/subject/my-subject-attribute-value`.",
2734          "type": "array",
2735          "items": {
2736            "type": "string"
2737          }
2738        },
2739        "condition": {
2740          "description": "The condition that is associated with this binding. If the condition evaluates to `true`, then this binding applies to the current request. If the condition evaluates to `false`, then this binding does not apply to the current request. However, a different role binding might grant the same role to one or more of the principals in this binding. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies).",
2741          "$ref": "Expr"
2742        },
2743        "bindingId": {
2744          "description": "This is deprecated and has no effect. Do not use.",
2745          "type": "string"
2746        }
2747      }
2748    },
2749    "Expr": {
2750      "id": "Expr",
2751      "description": "Represents a textual expression in the Common Expression Language (CEL) syntax. CEL is a C-like expression language. The syntax and semantics of CEL are documented at https://github.com/google/cel-spec. Example (Comparison): title: \"Summary size limit\" description: \"Determines if a summary is less than 100 chars\" expression: \"document.summary.size() \u003c 100\" Example (Equality): title: \"Requestor is owner\" description: \"Determines if requestor is the document owner\" expression: \"document.owner == request.auth.claims.email\" Example (Logic): title: \"Public documents\" description: \"Determine whether the document should be publicly visible\" expression: \"document.type != 'private' && document.type != 'internal'\" Example (Data Manipulation): title: \"Notification string\" description: \"Create a notification string with a timestamp.\" expression: \"'New message received at ' + string(document.create_time)\" The exact variables and functions that may be referenced within an expression are determined by the service that evaluates it. See the service documentation for additional information.",
2752      "type": "object",
2753      "properties": {
2754        "expression": {
2755          "description": "Textual representation of an expression in Common Expression Language syntax.",
2756          "type": "string"
2757        },
2758        "title": {
2759          "description": "Optional. Title for the expression, i.e. a short string describing its purpose. This can be used e.g. in UIs which allow to enter the expression.",
2760          "type": "string"
2761        },
2762        "description": {
2763          "description": "Optional. Description of the expression. This is a longer text which describes the expression, e.g. when hovered over it in a UI.",
2764          "type": "string"
2765        },
2766        "location": {
2767          "description": "Optional. String indicating the location of the expression for error reporting, e.g. a file name and a position in the file.",
2768          "type": "string"
2769        }
2770      }
2771    },
2772    "AuditLogConfig": {
2773      "id": "AuditLogConfig",
2774      "description": "Provides the configuration for logging a type of permissions. Example: { \"audit_log_configs\": [ { \"log_type\": \"DATA_READ\", \"exempted_members\": [ \"user:[email protected]\" ] }, { \"log_type\": \"DATA_WRITE\" } ] } This enables 'DATA_READ' and 'DATA_WRITE' logging, while exempting [email protected] from DATA_READ logging.",
2775      "type": "object",
2776      "properties": {
2777        "logType": {
2778          "description": "The log type that this config enables.",
2779          "type": "string",
2780          "enumDescriptions": [
2781            "Admin reads. Example: CloudIAM getIamPolicy",
2782            "Data reads. Example: CloudSQL Users list",
2783            "Data writes. Example: CloudSQL Users create",
2784            "Default case. Should never be this."
2785          ],
2786          "enum": [
2787            "ADMIN_READ",
2788            "DATA_READ",
2789            "DATA_WRITE",
2790            "LOG_TYPE_UNSPECIFIED"
2791          ]
2792        },
2793        "exemptedMembers": {
2794          "description": "Specifies the identities that do not cause logging for this type of permission. Follows the same format of Binding.members.",
2795          "type": "array",
2796          "items": {
2797            "type": "string"
2798          }
2799        },
2800        "ignoreChildExemptions": {
2801          "description": "This is deprecated and has no effect. Do not use.",
2802          "type": "boolean"
2803        }
2804      }
2805    },
2806    "Rule": {
2807      "id": "Rule",
2808      "description": "This is deprecated and has no effect. Do not use.",
2809      "type": "object",
2810      "properties": {
2811        "description": {
2812          "description": "This is deprecated and has no effect. Do not use.",
2813          "type": "string"
2814        },
2815        "permissions": {
2816          "description": "This is deprecated and has no effect. Do not use.",
2817          "type": "array",
2818          "items": {
2819            "type": "string"
2820          }
2821        },
2822        "action": {
2823          "description": "This is deprecated and has no effect. Do not use.",
2824          "type": "string",
2825          "enumDescriptions": [
2826            "This is deprecated and has no effect. Do not use.",
2827            "This is deprecated and has no effect. Do not use.",
2828            "This is deprecated and has no effect. Do not use.",
2829            "This is deprecated and has no effect. Do not use.",
2830            "This is deprecated and has no effect. Do not use.",
2831            "This is deprecated and has no effect. Do not use."
2832          ],
2833          "enum": [
2834            "ALLOW",
2835            "ALLOW_WITH_LOG",
2836            "DENY",
2837            "DENY_WITH_LOG",
2838            "LOG",
2839            "NO_ACTION"
2840          ]
2841        },
2842        "ins": {
2843          "description": "This is deprecated and has no effect. Do not use.",
2844          "type": "array",
2845          "items": {
2846            "type": "string"
2847          }
2848        },
2849        "notIns": {
2850          "description": "This is deprecated and has no effect. Do not use.",
2851          "type": "array",
2852          "items": {
2853            "type": "string"
2854          }
2855        },
2856        "conditions": {
2857          "description": "This is deprecated and has no effect. Do not use.",
2858          "type": "array",
2859          "items": {
2860            "$ref": "Condition"
2861          }
2862        },
2863        "logConfigs": {
2864          "description": "This is deprecated and has no effect. Do not use.",
2865          "type": "array",
2866          "items": {
2867            "$ref": "LogConfig"
2868          }
2869        }
2870      }
2871    },
2872    "Condition": {
2873      "id": "Condition",
2874      "description": "This is deprecated and has no effect. Do not use.",
2875      "type": "object",
2876      "properties": {
2877        "iam": {
2878          "description": "This is deprecated and has no effect. Do not use.",
2879          "type": "string",
2880          "enumDescriptions": [
2881            "This is deprecated and has no effect. Do not use.",
2882            "This is deprecated and has no effect. Do not use.",
2883            "This is deprecated and has no effect. Do not use.",
2884            "This is deprecated and has no effect. Do not use.",
2885            "This is deprecated and has no effect. Do not use.",
2886            "This is deprecated and has no effect. Do not use.",
2887            "This is deprecated and has no effect. Do not use.",
2888            "This is deprecated and has no effect. Do not use."
2889          ],
2890          "enum": [
2891            "APPROVER",
2892            "ATTRIBUTION",
2893            "AUTHORITY",
2894            "CREDENTIALS_TYPE",
2895            "CREDS_ASSERTION",
2896            "JUSTIFICATION_TYPE",
2897            "NO_ATTR",
2898            "SECURITY_REALM"
2899          ]
2900        },
2901        "sys": {
2902          "description": "This is deprecated and has no effect. Do not use.",
2903          "type": "string",
2904          "enumDescriptions": [
2905            "This is deprecated and has no effect. Do not use.",
2906            "This is deprecated and has no effect. Do not use.",
2907            "This is deprecated and has no effect. Do not use.",
2908            "This is deprecated and has no effect. Do not use.",
2909            "This is deprecated and has no effect. Do not use."
2910          ],
2911          "enum": [
2912            "IP",
2913            "NAME",
2914            "NO_ATTR",
2915            "REGION",
2916            "SERVICE"
2917          ]
2918        },
2919        "svc": {
2920          "description": "This is deprecated and has no effect. Do not use.",
2921          "type": "string"
2922        },
2923        "op": {
2924          "description": "This is deprecated and has no effect. Do not use.",
2925          "type": "string",
2926          "enumDescriptions": [
2927            "This is deprecated and has no effect. Do not use.",
2928            "This is deprecated and has no effect. Do not use.",
2929            "This is deprecated and has no effect. Do not use.",
2930            "This is deprecated and has no effect. Do not use.",
2931            "This is deprecated and has no effect. Do not use.",
2932            "This is deprecated and has no effect. Do not use."
2933          ],
2934          "enum": [
2935            "DISCHARGED",
2936            "EQUALS",
2937            "IN",
2938            "NOT_EQUALS",
2939            "NOT_IN",
2940            "NO_OP"
2941          ]
2942        },
2943        "values": {
2944          "description": "This is deprecated and has no effect. Do not use.",
2945          "type": "array",
2946          "items": {
2947            "type": "string"
2948          }
2949        }
2950      }
2951    },
2952    "LogConfig": {
2953      "id": "LogConfig",
2954      "description": "This is deprecated and has no effect. Do not use.",
2955      "type": "object",
2956      "properties": {
2957        "counter": {
2958          "description": "This is deprecated and has no effect. Do not use.",
2959          "$ref": "LogConfigCounterOptions"
2960        },
2961        "dataAccess": {
2962          "description": "This is deprecated and has no effect. Do not use.",
2963          "$ref": "LogConfigDataAccessOptions"
2964        },
2965        "cloudAudit": {
2966          "description": "This is deprecated and has no effect. Do not use.",
2967          "$ref": "LogConfigCloudAuditOptions"
2968        }
2969      }
2970    },
2971    "LogConfigCounterOptions": {
2972      "id": "LogConfigCounterOptions",
2973      "description": "This is deprecated and has no effect. Do not use.",
2974      "type": "object",
2975      "properties": {
2976        "metric": {
2977          "description": "This is deprecated and has no effect. Do not use.",
2978          "type": "string"
2979        },
2980        "field": {
2981          "description": "This is deprecated and has no effect. Do not use.",
2982          "type": "string"
2983        },
2984        "customFields": {
2985          "description": "This is deprecated and has no effect. Do not use.",
2986          "type": "array",
2987          "items": {
2988            "$ref": "LogConfigCounterOptionsCustomField"
2989          }
2990        }
2991      }
2992    },
2993    "LogConfigCounterOptionsCustomField": {
2994      "id": "LogConfigCounterOptionsCustomField",
2995      "description": "This is deprecated and has no effect. Do not use.",
2996      "type": "object",
2997      "properties": {
2998        "name": {
2999          "description": "This is deprecated and has no effect. Do not use.",
3000          "type": "string"
3001        },
3002        "value": {
3003          "description": "This is deprecated and has no effect. Do not use.",
3004          "type": "string"
3005        }
3006      }
3007    },
3008    "LogConfigDataAccessOptions": {
3009      "id": "LogConfigDataAccessOptions",
3010      "description": "This is deprecated and has no effect. Do not use.",
3011      "type": "object",
3012      "properties": {
3013        "logMode": {
3014          "description": "This is deprecated and has no effect. Do not use.",
3015          "type": "string",
3016          "enumDescriptions": [
3017            "This is deprecated and has no effect. Do not use.",
3018            "This is deprecated and has no effect. Do not use."
3019          ],
3020          "enum": [
3021            "LOG_FAIL_CLOSED",
3022            "LOG_MODE_UNSPECIFIED"
3023          ]
3024        }
3025      }
3026    },
3027    "LogConfigCloudAuditOptions": {
3028      "id": "LogConfigCloudAuditOptions",
3029      "description": "This is deprecated and has no effect. Do not use.",
3030      "type": "object",
3031      "properties": {
3032        "logName": {
3033          "description": "This is deprecated and has no effect. Do not use.",
3034          "type": "string",
3035          "enumDescriptions": [
3036            "This is deprecated and has no effect. Do not use.",
3037            "This is deprecated and has no effect. Do not use.",
3038            "This is deprecated and has no effect. Do not use."
3039          ],
3040          "enum": [
3041            "ADMIN_ACTIVITY",
3042            "DATA_ACCESS",
3043            "UNSPECIFIED_LOG_NAME"
3044          ]
3045        },
3046        "authorizationLoggingOptions": {
3047          "description": "This is deprecated and has no effect. Do not use.",
3048          "$ref": "AuthorizationLoggingOptions"
3049        }
3050      }
3051    },
3052    "AuthorizationLoggingOptions": {
3053      "id": "AuthorizationLoggingOptions",
3054      "description": "This is deprecated and has no effect. Do not use.",
3055      "type": "object",
3056      "properties": {
3057        "permissionType": {
3058          "description": "This is deprecated and has no effect. Do not use.",
3059          "type": "string",
3060          "enumDescriptions": [
3061            "This is deprecated and has no effect. Do not use.",
3062            "This is deprecated and has no effect. Do not use.",
3063            "This is deprecated and has no effect. Do not use.",
3064            "This is deprecated and has no effect. Do not use.",
3065            "This is deprecated and has no effect. Do not use."
3066          ],
3067          "enum": [
3068            "ADMIN_READ",
3069            "ADMIN_WRITE",
3070            "DATA_READ",
3071            "DATA_WRITE",
3072            "PERMISSION_TYPE_UNSPECIFIED"
3073          ]
3074        }
3075      }
3076    },
3077    "GlobalSetPolicyRequest": {
3078      "id": "GlobalSetPolicyRequest",
3079      "type": "object",
3080      "properties": {
3081        "policy": {
3082          "description": "REQUIRED: The complete policy to be applied to the 'resource'. The size of the policy is limited to a few 10s of KB. An empty policy is in general a valid policy but certain services (like Projects) might reject them.",
3083          "$ref": "Policy"
3084        },
3085        "bindings": {
3086          "description": "Flatten Policy to create a backward compatible wire-format. Deprecated. Use 'policy' to specify bindings.",
3087          "type": "array",
3088          "items": {
3089            "$ref": "Binding"
3090          }
3091        },
3092        "etag": {
3093          "description": "Flatten Policy to create a backward compatible wire-format. Deprecated. Use 'policy' to specify the etag.",
3094          "type": "string",
3095          "format": "byte"
3096        }
3097      }
3098    },
3099    "TestPermissionsRequest": {
3100      "id": "TestPermissionsRequest",
3101      "type": "object",
3102      "properties": {
3103        "permissions": {
3104          "description": "The set of permissions to check for the 'resource'. Permissions with wildcards (such as '*' or 'storage.*') are not allowed.",
3105          "type": "array",
3106          "items": {
3107            "type": "string"
3108          }
3109        }
3110      }
3111    },
3112    "TestPermissionsResponse": {
3113      "id": "TestPermissionsResponse",
3114      "type": "object",
3115      "properties": {
3116        "permissions": {
3117          "description": "A subset of `TestPermissionsRequest.permissions` that the caller is allowed.",
3118          "type": "array",
3119          "items": {
3120            "type": "string"
3121          }
3122        }
3123      }
3124    },
3125    "ImageFamilyView": {
3126      "id": "ImageFamilyView",
3127      "type": "object",
3128      "properties": {
3129        "image": {
3130          "description": "The latest image that is part of the specified image family in the requested location, and that is not deprecated.",
3131          "$ref": "Image"
3132        }
3133      }
3134    },
3135    "SnapshotList": {
3136      "id": "SnapshotList",
3137      "description": "Contains a list of Snapshot resources.",
3138      "type": "object",
3139      "properties": {
3140        "kind": {
3141          "description": "Type of resource.",
3142          "default": "compute#snapshotList",
3143          "type": "string"
3144        },
3145        "id": {
3146          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
3147          "type": "string"
3148        },
3149        "items": {
3150          "description": "A list of Snapshot resources.",
3151          "type": "array",
3152          "items": {
3153            "$ref": "Snapshot"
3154          }
3155        },
3156        "nextPageToken": {
3157          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
3158          "type": "string"
3159        },
3160        "selfLink": {
3161          "description": "[Output Only] Server-defined URL for this resource.",
3162          "type": "string"
3163        },
3164        "warning": {
3165          "description": "[Output Only] Informational warning message.",
3166          "type": "object",
3167          "properties": {
3168            "code": {
3169              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
3170              "type": "string",
3171              "enumDescriptions": [
3172                "Warning about failed cleanup of transient changes made by a failed operation.",
3173                "A link to a deprecated resource was created.",
3174                "When deploying and at least one of the resources has a type marked as deprecated",
3175                "The user created a boot disk that is larger than image size.",
3176                "When deploying and at least one of the resources has a type marked as experimental",
3177                "Warning that is present in an external api call",
3178                "Warning that value of a field has been overridden. Deprecated unused field.",
3179                "The operation involved use of an injected kernel, which is deprecated.",
3180                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
3181                "When deploying a deployment with a exceedingly large number of resources",
3182                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
3183                "A resource depends on a missing type",
3184                "The route's nextHopIp address is not assigned to an instance on the network.",
3185                "The route's next hop instance cannot ip forward.",
3186                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
3187                "The route's nextHopInstance URL refers to an instance that does not exist.",
3188                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
3189                "The route's next hop instance does not have a status of RUNNING.",
3190                "Error which is not critical. We decided to continue the process despite the mentioned error.",
3191                "No results are present on a particular list page.",
3192                "Success is reported, but some results may be missing due to errors",
3193                "The user attempted to use a resource that requires a TOS they have not accepted.",
3194                "Warning that a resource is in use.",
3195                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
3196                "When a resource schema validation is ignored.",
3197                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
3198                "When undeclared properties in the schema are present",
3199                "A given scope cannot be reached."
3200              ],
3201              "enumDeprecated": [
3202                false,
3203                false,
3204                false,
3205                false,
3206                false,
3207                false,
3208                true,
3209                false,
3210                false,
3211                false,
3212                false,
3213                false,
3214                false,
3215                false,
3216                false,
3217                false,
3218                false,
3219                false,
3220                false,
3221                false,
3222                false,
3223                false,
3224                false,
3225                false,
3226                false,
3227                false,
3228                false,
3229                false
3230              ],
3231              "enum": [
3232                "CLEANUP_FAILED",
3233                "DEPRECATED_RESOURCE_USED",
3234                "DEPRECATED_TYPE_USED",
3235                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
3236                "EXPERIMENTAL_TYPE_USED",
3237                "EXTERNAL_API_WARNING",
3238                "FIELD_VALUE_OVERRIDEN",
3239                "INJECTED_KERNELS_DEPRECATED",
3240                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
3241                "LARGE_DEPLOYMENT_WARNING",
3242                "LIST_OVERHEAD_QUOTA_EXCEED",
3243                "MISSING_TYPE_DEPENDENCY",
3244                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
3245                "NEXT_HOP_CANNOT_IP_FORWARD",
3246                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
3247                "NEXT_HOP_INSTANCE_NOT_FOUND",
3248                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
3249                "NEXT_HOP_NOT_RUNNING",
3250                "NOT_CRITICAL_ERROR",
3251                "NO_RESULTS_ON_PAGE",
3252                "PARTIAL_SUCCESS",
3253                "REQUIRED_TOS_AGREEMENT",
3254                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
3255                "RESOURCE_NOT_DELETED",
3256                "SCHEMA_VALIDATION_IGNORED",
3257                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
3258                "UNDECLARED_PROPERTIES",
3259                "UNREACHABLE"
3260              ]
3261            },
3262            "message": {
3263              "description": "[Output Only] A human-readable description of the warning code.",
3264              "type": "string"
3265            },
3266            "data": {
3267              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
3268              "type": "array",
3269              "items": {
3270                "type": "object",
3271                "properties": {
3272                  "key": {
3273                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
3274                    "type": "string"
3275                  },
3276                  "value": {
3277                    "description": "[Output Only] A warning data value corresponding to the key.",
3278                    "type": "string"
3279                  }
3280                }
3281              }
3282            }
3283          }
3284        }
3285      }
3286    },
3287    "Snapshot": {
3288      "id": "Snapshot",
3289      "description": "Represents a Persistent Disk Snapshot resource. You can use snapshots to back up data on a regular interval. For more information, read Creating persistent disk snapshots.",
3290      "type": "object",
3291      "properties": {
3292        "kind": {
3293          "description": "[Output Only] Type of the resource. Always compute#snapshot for Snapshot resources.",
3294          "default": "compute#snapshot",
3295          "type": "string"
3296        },
3297        "id": {
3298          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
3299          "type": "string",
3300          "format": "uint64"
3301        },
3302        "creationTimestamp": {
3303          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
3304          "type": "string"
3305        },
3306        "name": {
3307          "description": "Name of the resource; provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
3308          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
3309          "annotations": {
3310            "required": [
3311              "compute.disks.createSnapshot",
3312              "compute.snapshots.insert"
3313            ]
3314          },
3315          "type": "string"
3316        },
3317        "description": {
3318          "description": "An optional description of this resource. Provide this property when you create the resource.",
3319          "type": "string"
3320        },
3321        "status": {
3322          "description": "[Output Only] The status of the snapshot. This can be CREATING, DELETING, FAILED, READY, or UPLOADING.",
3323          "type": "string",
3324          "enumDescriptions": [
3325            "Snapshot creation is in progress.",
3326            "Snapshot is currently being deleted.",
3327            "Snapshot creation failed.",
3328            "Snapshot has been created successfully.",
3329            "Snapshot is being uploaded."
3330          ],
3331          "enum": [
3332            "CREATING",
3333            "DELETING",
3334            "FAILED",
3335            "READY",
3336            "UPLOADING"
3337          ]
3338        },
3339        "sourceDisk": {
3340          "description": "The source disk used to create this snapshot.",
3341          "type": "string"
3342        },
3343        "sourceDiskId": {
3344          "description": "[Output Only] The ID value of the disk used to create this snapshot. This value may be used to determine whether the snapshot was taken from the current or a previous instance of a given disk name.",
3345          "type": "string"
3346        },
3347        "diskSizeGb": {
3348          "description": "[Output Only] Size of the source disk, specified in GB.",
3349          "type": "string",
3350          "format": "int64"
3351        },
3352        "storageBytes": {
3353          "description": "[Output Only] A size of the storage used by the snapshot. As snapshots share storage, this number is expected to change with snapshot creation/deletion.",
3354          "type": "string",
3355          "format": "int64"
3356        },
3357        "storageBytesStatus": {
3358          "description": "[Output Only] An indicator whether storageBytes is in a stable state or it is being adjusted as a result of shared storage reallocation. This status can either be UPDATING, meaning the size of the snapshot is being updated, or UP_TO_DATE, meaning the size of the snapshot is up-to-date.",
3359          "type": "string",
3360          "enumDescriptions": [
3361            "",
3362            ""
3363          ],
3364          "enum": [
3365            "UPDATING",
3366            "UP_TO_DATE"
3367          ]
3368        },
3369        "licenses": {
3370          "description": "[Output Only] A list of public visible licenses that apply to this snapshot. This can be because the original image had licenses attached (such as a Windows image).",
3371          "type": "array",
3372          "items": {
3373            "type": "string"
3374          }
3375        },
3376        "snapshotEncryptionKey": {
3377          "description": "Encrypts the snapshot using a customer-supplied encryption key. After you encrypt a snapshot using a customer-supplied key, you must provide the same key if you use the snapshot later. For example, you must provide the encryption key when you create a disk from the encrypted snapshot in a future request. Customer-supplied encryption keys do not protect access to metadata of the snapshot. If you do not provide an encryption key when creating the snapshot, then the snapshot will be encrypted using an automatically generated key and you do not need to provide a key to use the snapshot later.",
3378          "$ref": "CustomerEncryptionKey"
3379        },
3380        "sourceDiskEncryptionKey": {
3381          "description": "The customer-supplied encryption key of the source disk. Required if the source disk is protected by a customer-supplied encryption key.",
3382          "$ref": "CustomerEncryptionKey"
3383        },
3384        "selfLink": {
3385          "description": "[Output Only] Server-defined URL for the resource.",
3386          "type": "string"
3387        },
3388        "labels": {
3389          "description": "Labels to apply to this snapshot. These can be later modified by the setLabels method. Label values may be empty.",
3390          "type": "object",
3391          "additionalProperties": {
3392            "type": "string"
3393          }
3394        },
3395        "labelFingerprint": {
3396          "description": "A fingerprint for the labels being applied to this snapshot, which is essentially a hash of the labels set used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve a snapshot.",
3397          "type": "string",
3398          "format": "byte"
3399        },
3400        "licenseCodes": {
3401          "description": "[Output Only] Integer license codes indicating which licenses are attached to this snapshot.",
3402          "type": "array",
3403          "items": {
3404            "type": "string",
3405            "format": "int64"
3406          }
3407        },
3408        "storageLocations": {
3409          "description": "Cloud Storage bucket storage location of the snapshot (regional or multi-regional).",
3410          "type": "array",
3411          "items": {
3412            "type": "string"
3413          }
3414        },
3415        "autoCreated": {
3416          "description": "[Output Only] Set to true if snapshots are automatically created by applying resource policy on the target disk.",
3417          "type": "boolean"
3418        },
3419        "guestOsFeatures": {
3420          "description": "[Output Only] A list of features to enable on the guest operating system. Applicable only for bootable images. Read Enabling guest operating system features to see a list of available options.",
3421          "type": "array",
3422          "items": {
3423            "$ref": "GuestOsFeature"
3424          }
3425        },
3426        "downloadBytes": {
3427          "description": "[Output Only] Number of bytes downloaded to restore a snapshot to a disk.",
3428          "type": "string",
3429          "format": "int64"
3430        },
3431        "chainName": {
3432          "description": "Creates the new snapshot in the snapshot chain labeled with the specified name. The chain name must be 1-63 characters long and comply with RFC1035. This is an uncommon option only for advanced service owners who needs to create separate snapshot chains, for example, for chargeback tracking. When you describe your snapshot resource, this field is visible only if it has a non-empty value.",
3433          "type": "string"
3434        },
3435        "satisfiesPzs": {
3436          "description": "[Output Only] Reserved for future use.",
3437          "type": "boolean"
3438        },
3439        "locationHint": {
3440          "description": "An opaque location hint used to place the snapshot close to other resources. This field is for use by internal tools that use the public API.",
3441          "type": "string"
3442        },
3443        "sourceSnapshotSchedulePolicy": {
3444          "description": "[Output Only] URL of the resource policy which created this scheduled snapshot.",
3445          "type": "string"
3446        },
3447        "sourceSnapshotSchedulePolicyId": {
3448          "description": "[Output Only] ID of the resource policy which created this scheduled snapshot.",
3449          "type": "string"
3450        },
3451        "sourceInstantSnapshot": {
3452          "description": "The source instant snapshot used to create this snapshot. You can provide this as a partial or full URL to the resource. For example, the following are valid values: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /instantSnapshots/instantSnapshot - projects/project/zones/zone/instantSnapshots/instantSnapshot - zones/zone/instantSnapshots/instantSnapshot ",
3453          "type": "string"
3454        },
3455        "sourceInstantSnapshotId": {
3456          "description": "[Output Only] The unique ID of the instant snapshot used to create this snapshot. This value identifies the exact instant snapshot that was used to create this persistent disk. For example, if you created the persistent disk from an instant snapshot that was later deleted and recreated under the same name, the source instant snapshot ID would identify the exact instant snapshot that was used.",
3457          "type": "string"
3458        },
3459        "architecture": {
3460          "description": "[Output Only] The architecture of the snapshot. Valid values are ARM64 or X86_64.",
3461          "type": "string",
3462          "enumDescriptions": [
3463            "Default value indicating Architecture is not set.",
3464            "Machines with architecture ARM64",
3465            "Machines with architecture X86_64"
3466          ],
3467          "enum": [
3468            "ARCHITECTURE_UNSPECIFIED",
3469            "ARM64",
3470            "X86_64"
3471          ]
3472        },
3473        "snapshotType": {
3474          "description": "Indicates the type of the snapshot.",
3475          "type": "string",
3476          "enumDescriptions": [
3477            "",
3478            ""
3479          ],
3480          "enum": [
3481            "ARCHIVE",
3482            "STANDARD"
3483          ]
3484        },
3485        "creationSizeBytes": {
3486          "description": "[Output Only] Size in bytes of the snapshot at creation time.",
3487          "type": "string",
3488          "format": "int64"
3489        },
3490        "enableConfidentialCompute": {
3491          "description": "Whether this snapshot is created from a confidential compute mode disk. [Output Only]: This field is not set by user, but from source disk.",
3492          "type": "boolean"
3493        },
3494        "sourceDiskForRecoveryCheckpoint": {
3495          "description": "The source disk whose recovery checkpoint will be used to create this snapshot.",
3496          "type": "string"
3497        },
3498        "sourceInstantSnapshotEncryptionKey": {
3499          "description": "Customer provided encryption key when creating Snapshot from Instant Snapshot.",
3500          "$ref": "CustomerEncryptionKey"
3501        },
3502        "satisfiesPzi": {
3503          "description": "Output only. Reserved for future use.",
3504          "readOnly": true,
3505          "type": "boolean"
3506        }
3507      }
3508    },
3509    "DiskList": {
3510      "id": "DiskList",
3511      "description": "A list of Disk resources.",
3512      "type": "object",
3513      "properties": {
3514        "kind": {
3515          "description": "[Output Only] Type of resource. Always compute#diskList for lists of disks.",
3516          "default": "compute#diskList",
3517          "type": "string"
3518        },
3519        "id": {
3520          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
3521          "type": "string"
3522        },
3523        "items": {
3524          "description": "A list of Disk resources.",
3525          "type": "array",
3526          "items": {
3527            "$ref": "Disk"
3528          }
3529        },
3530        "nextPageToken": {
3531          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
3532          "type": "string"
3533        },
3534        "selfLink": {
3535          "description": "[Output Only] Server-defined URL for this resource.",
3536          "type": "string"
3537        },
3538        "warning": {
3539          "description": "[Output Only] Informational warning message.",
3540          "type": "object",
3541          "properties": {
3542            "code": {
3543              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
3544              "type": "string",
3545              "enumDescriptions": [
3546                "Warning about failed cleanup of transient changes made by a failed operation.",
3547                "A link to a deprecated resource was created.",
3548                "When deploying and at least one of the resources has a type marked as deprecated",
3549                "The user created a boot disk that is larger than image size.",
3550                "When deploying and at least one of the resources has a type marked as experimental",
3551                "Warning that is present in an external api call",
3552                "Warning that value of a field has been overridden. Deprecated unused field.",
3553                "The operation involved use of an injected kernel, which is deprecated.",
3554                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
3555                "When deploying a deployment with a exceedingly large number of resources",
3556                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
3557                "A resource depends on a missing type",
3558                "The route's nextHopIp address is not assigned to an instance on the network.",
3559                "The route's next hop instance cannot ip forward.",
3560                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
3561                "The route's nextHopInstance URL refers to an instance that does not exist.",
3562                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
3563                "The route's next hop instance does not have a status of RUNNING.",
3564                "Error which is not critical. We decided to continue the process despite the mentioned error.",
3565                "No results are present on a particular list page.",
3566                "Success is reported, but some results may be missing due to errors",
3567                "The user attempted to use a resource that requires a TOS they have not accepted.",
3568                "Warning that a resource is in use.",
3569                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
3570                "When a resource schema validation is ignored.",
3571                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
3572                "When undeclared properties in the schema are present",
3573                "A given scope cannot be reached."
3574              ],
3575              "enumDeprecated": [
3576                false,
3577                false,
3578                false,
3579                false,
3580                false,
3581                false,
3582                true,
3583                false,
3584                false,
3585                false,
3586                false,
3587                false,
3588                false,
3589                false,
3590                false,
3591                false,
3592                false,
3593                false,
3594                false,
3595                false,
3596                false,
3597                false,
3598                false,
3599                false,
3600                false,
3601                false,
3602                false,
3603                false
3604              ],
3605              "enum": [
3606                "CLEANUP_FAILED",
3607                "DEPRECATED_RESOURCE_USED",
3608                "DEPRECATED_TYPE_USED",
3609                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
3610                "EXPERIMENTAL_TYPE_USED",
3611                "EXTERNAL_API_WARNING",
3612                "FIELD_VALUE_OVERRIDEN",
3613                "INJECTED_KERNELS_DEPRECATED",
3614                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
3615                "LARGE_DEPLOYMENT_WARNING",
3616                "LIST_OVERHEAD_QUOTA_EXCEED",
3617                "MISSING_TYPE_DEPENDENCY",
3618                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
3619                "NEXT_HOP_CANNOT_IP_FORWARD",
3620                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
3621                "NEXT_HOP_INSTANCE_NOT_FOUND",
3622                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
3623                "NEXT_HOP_NOT_RUNNING",
3624                "NOT_CRITICAL_ERROR",
3625                "NO_RESULTS_ON_PAGE",
3626                "PARTIAL_SUCCESS",
3627                "REQUIRED_TOS_AGREEMENT",
3628                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
3629                "RESOURCE_NOT_DELETED",
3630                "SCHEMA_VALIDATION_IGNORED",
3631                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
3632                "UNDECLARED_PROPERTIES",
3633                "UNREACHABLE"
3634              ]
3635            },
3636            "message": {
3637              "description": "[Output Only] A human-readable description of the warning code.",
3638              "type": "string"
3639            },
3640            "data": {
3641              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
3642              "type": "array",
3643              "items": {
3644                "type": "object",
3645                "properties": {
3646                  "key": {
3647                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
3648                    "type": "string"
3649                  },
3650                  "value": {
3651                    "description": "[Output Only] A warning data value corresponding to the key.",
3652                    "type": "string"
3653                  }
3654                }
3655              }
3656            }
3657          }
3658        }
3659      }
3660    },
3661    "Disk": {
3662      "id": "Disk",
3663      "description": "Represents a Persistent Disk resource. Google Compute Engine has two Disk resources: * [Zonal](/compute/docs/reference/rest/v1/disks) * [Regional](/compute/docs/reference/rest/v1/regionDisks) Persistent disks are required for running your VM instances. Create both boot and non-boot (data) persistent disks. For more information, read Persistent Disks. For more storage options, read Storage options. The disks resource represents a zonal persistent disk. For more information, read Zonal persistent disks. The regionDisks resource represents a regional persistent disk. For more information, read Regional resources.",
3664      "type": "object",
3665      "properties": {
3666        "kind": {
3667          "description": "[Output Only] Type of the resource. Always compute#disk for disks.",
3668          "default": "compute#disk",
3669          "type": "string"
3670        },
3671        "id": {
3672          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
3673          "type": "string",
3674          "format": "uint64"
3675        },
3676        "creationTimestamp": {
3677          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
3678          "type": "string"
3679        },
3680        "name": {
3681          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
3682          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
3683          "annotations": {
3684            "required": [
3685              "compute.disks.insert"
3686            ]
3687          },
3688          "type": "string"
3689        },
3690        "description": {
3691          "description": "An optional description of this resource. Provide this property when you create the resource.",
3692          "type": "string"
3693        },
3694        "sizeGb": {
3695          "description": "Size, in GB, of the persistent disk. You can specify this field when creating a persistent disk using the sourceImage, sourceSnapshot, or sourceDisk parameter, or specify it alone to create an empty persistent disk. If you specify this field along with a source, the value of sizeGb must not be less than the size of the source. Acceptable values are greater than 0.",
3696          "type": "string",
3697          "format": "int64"
3698        },
3699        "zone": {
3700          "description": "[Output Only] URL of the zone where the disk resides. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
3701          "type": "string"
3702        },
3703        "status": {
3704          "description": "[Output Only] The status of disk creation. - CREATING: Disk is provisioning. - RESTORING: Source data is being copied into the disk. - FAILED: Disk creation failed. - READY: Disk is ready for use. - DELETING: Disk is deleting. ",
3705          "type": "string",
3706          "enumDescriptions": [
3707            "Disk is provisioning",
3708            "Disk is deleting.",
3709            "Disk creation failed.",
3710            "Disk is ready for use.",
3711            "Source data is being copied into the disk."
3712          ],
3713          "enum": [
3714            "CREATING",
3715            "DELETING",
3716            "FAILED",
3717            "READY",
3718            "RESTORING"
3719          ]
3720        },
3721        "sourceSnapshot": {
3722          "description": "The source snapshot used to create this disk. You can provide this as a partial or full URL to the resource. For example, the following are valid values: - https://www.googleapis.com/compute/v1/projects/project /global/snapshots/snapshot - projects/project/global/snapshots/snapshot - global/snapshots/snapshot ",
3723          "type": "string"
3724        },
3725        "sourceSnapshotId": {
3726          "description": "[Output Only] The unique ID of the snapshot used to create this disk. This value identifies the exact snapshot that was used to create this persistent disk. For example, if you created the persistent disk from a snapshot that was later deleted and recreated under the same name, the source snapshot ID would identify the exact version of the snapshot that was used.",
3727          "type": "string"
3728        },
3729        "sourceStorageObject": {
3730          "description": "The full Google Cloud Storage URI where the disk image is stored. This file must be a gzip-compressed tarball whose name ends in .tar.gz or virtual machine disk whose name ends in vmdk. Valid URIs may start with gs:// or https://storage.googleapis.com/. This flag is not optimized for creating multiple disks from a source storage object. To create many disks from a source storage object, use gcloud compute images import instead.",
3731          "type": "string"
3732        },
3733        "options": {
3734          "description": "Internal use only.",
3735          "type": "string"
3736        },
3737        "selfLink": {
3738          "description": "[Output Only] Server-defined fully-qualified URL for this resource.",
3739          "type": "string"
3740        },
3741        "sourceImage": {
3742          "description": "The source image used to create this disk. If the source image is deleted, this field will not be set. To create a disk with one of the public operating system images, specify the image by its family name. For example, specify family/debian-9 to use the latest Debian 9 image: projects/debian-cloud/global/images/family/debian-9 Alternatively, use a specific version of a public operating system image: projects/debian-cloud/global/images/debian-9-stretch-vYYYYMMDD To create a disk with a custom image that you created, specify the image name in the following format: global/images/my-custom-image You can also specify a custom image by its image family, which returns the latest version of the image in that family. Replace the image name with family/family-name: global/images/family/my-image-family ",
3743          "type": "string"
3744        },
3745        "sourceImageId": {
3746          "description": "[Output Only] The ID value of the image used to create this disk. This value identifies the exact image that was used to create this persistent disk. For example, if you created the persistent disk from an image that was later deleted and recreated under the same name, the source image ID would identify the exact version of the image that was used.",
3747          "type": "string"
3748        },
3749        "type": {
3750          "description": "URL of the disk type resource describing which disk type to use to create the disk. Provide this when creating the disk. For example: projects/project /zones/zone/diskTypes/pd-ssd . See Persistent disk types.",
3751          "type": "string"
3752        },
3753        "licenses": {
3754          "description": "A list of publicly visible licenses. Reserved for Google's use.",
3755          "type": "array",
3756          "items": {
3757            "type": "string"
3758          }
3759        },
3760        "guestOsFeatures": {
3761          "description": "A list of features to enable on the guest operating system. Applicable only for bootable images. Read Enabling guest operating system features to see a list of available options.",
3762          "type": "array",
3763          "items": {
3764            "$ref": "GuestOsFeature"
3765          }
3766        },
3767        "lastAttachTimestamp": {
3768          "description": "[Output Only] Last attach timestamp in RFC3339 text format.",
3769          "type": "string"
3770        },
3771        "lastDetachTimestamp": {
3772          "description": "[Output Only] Last detach timestamp in RFC3339 text format.",
3773          "type": "string"
3774        },
3775        "users": {
3776          "description": "[Output Only] Links to the users of the disk (attached instances) in form: projects/project/zones/zone/instances/instance",
3777          "type": "array",
3778          "items": {
3779            "type": "string"
3780          }
3781        },
3782        "diskEncryptionKey": {
3783          "description": "Encrypts the disk using a customer-supplied encryption key or a customer-managed encryption key. Encryption keys do not protect access to metadata of the disk. After you encrypt a disk with a customer-supplied key, you must provide the same key if you use the disk later. For example, to create a disk snapshot, to create a disk image, to create a machine image, or to attach the disk to a virtual machine. After you encrypt a disk with a customer-managed key, the diskEncryptionKey.kmsKeyName is set to a key *version* name once the disk is created. The disk is encrypted with this version of the key. In the response, diskEncryptionKey.kmsKeyName appears in the following format: \"diskEncryptionKey.kmsKeyName\": \"projects/kms_project_id/locations/region/keyRings/ key_region/cryptoKeys/key /cryptoKeysVersions/version If you do not provide an encryption key when creating the disk, then the disk is encrypted using an automatically generated key and you don't need to provide a key to use the disk later.",
3784          "$ref": "CustomerEncryptionKey"
3785        },
3786        "sourceImageEncryptionKey": {
3787          "description": "The customer-supplied encryption key of the source image. Required if the source image is protected by a customer-supplied encryption key.",
3788          "$ref": "CustomerEncryptionKey"
3789        },
3790        "sourceSnapshotEncryptionKey": {
3791          "description": "The customer-supplied encryption key of the source snapshot. Required if the source snapshot is protected by a customer-supplied encryption key.",
3792          "$ref": "CustomerEncryptionKey"
3793        },
3794        "labels": {
3795          "description": "Labels to apply to this disk. These can be later modified by the setLabels method.",
3796          "type": "object",
3797          "additionalProperties": {
3798            "type": "string"
3799          }
3800        },
3801        "labelFingerprint": {
3802          "description": "A fingerprint for the labels being applied to this disk, which is essentially a hash of the labels set used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve a disk.",
3803          "type": "string",
3804          "format": "byte"
3805        },
3806        "region": {
3807          "description": "[Output Only] URL of the region where the disk resides. Only applicable for regional resources. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
3808          "type": "string"
3809        },
3810        "replicaZones": {
3811          "description": "URLs of the zones where the disk should be replicated to. Only applicable for regional resources.",
3812          "type": "array",
3813          "items": {
3814            "type": "string"
3815          }
3816        },
3817        "licenseCodes": {
3818          "description": "Integer license codes indicating which licenses are attached to this disk.",
3819          "type": "array",
3820          "items": {
3821            "type": "string",
3822            "format": "int64"
3823          }
3824        },
3825        "physicalBlockSizeBytes": {
3826          "description": "Physical block size of the persistent disk, in bytes. If not present in a request, a default value is used. The currently supported size is 4096, other sizes may be added in the future. If an unsupported value is requested, the error message will list the supported values for the caller's project.",
3827          "type": "string",
3828          "format": "int64"
3829        },
3830        "resourcePolicies": {
3831          "description": "Resource policies applied to this disk for automatic snapshot creations.",
3832          "type": "array",
3833          "items": {
3834            "type": "string"
3835          }
3836        },
3837        "sourceDisk": {
3838          "description": "The source disk used to create this disk. You can provide this as a partial or full URL to the resource. For example, the following are valid values: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /disks/disk - https://www.googleapis.com/compute/v1/projects/project/regions/region /disks/disk - projects/project/zones/zone/disks/disk - projects/project/regions/region/disks/disk - zones/zone/disks/disk - regions/region/disks/disk ",
3839          "type": "string"
3840        },
3841        "sourceDiskId": {
3842          "description": "[Output Only] The unique ID of the disk used to create this disk. This value identifies the exact disk that was used to create this persistent disk. For example, if you created the persistent disk from a disk that was later deleted and recreated under the same name, the source disk ID would identify the exact version of the disk that was used.",
3843          "type": "string"
3844        },
3845        "provisionedIops": {
3846          "description": "Indicates how many IOPS to provision for the disk. This sets the number of I/O operations per second that the disk can handle. Values must be between 10,000 and 120,000. For more details, see the Extreme persistent disk documentation.",
3847          "type": "string",
3848          "format": "int64"
3849        },
3850        "provisionedThroughput": {
3851          "description": "Indicates how much throughput to provision for the disk. This sets the number of throughput mb per second that the disk can handle. Values must be greater than or equal to 1.",
3852          "type": "string",
3853          "format": "int64"
3854        },
3855        "enableConfidentialCompute": {
3856          "description": "Whether this disk is using confidential compute mode.",
3857          "type": "boolean"
3858        },
3859        "sourceInstantSnapshot": {
3860          "description": "The source instant snapshot used to create this disk. You can provide this as a partial or full URL to the resource. For example, the following are valid values: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /instantSnapshots/instantSnapshot - projects/project/zones/zone/instantSnapshots/instantSnapshot - zones/zone/instantSnapshots/instantSnapshot ",
3861          "type": "string"
3862        },
3863        "sourceInstantSnapshotId": {
3864          "description": "[Output Only] The unique ID of the instant snapshot used to create this disk. This value identifies the exact instant snapshot that was used to create this persistent disk. For example, if you created the persistent disk from an instant snapshot that was later deleted and recreated under the same name, the source instant snapshot ID would identify the exact version of the instant snapshot that was used.",
3865          "type": "string"
3866        },
3867        "satisfiesPzs": {
3868          "description": "[Output Only] Reserved for future use.",
3869          "type": "boolean"
3870        },
3871        "satisfiesPzi": {
3872          "description": "Output only. Reserved for future use.",
3873          "readOnly": true,
3874          "type": "boolean"
3875        },
3876        "locationHint": {
3877          "description": "An opaque location hint used to place the disk close to other resources. This field is for use by internal tools that use the public API.",
3878          "type": "string"
3879        },
3880        "asyncPrimaryDisk": {
3881          "description": "Disk asynchronously replicated into this disk.",
3882          "$ref": "DiskAsyncReplication"
3883        },
3884        "asyncSecondaryDisks": {
3885          "description": "[Output Only] A list of disks this disk is asynchronously replicated to.",
3886          "type": "object",
3887          "additionalProperties": {
3888            "$ref": "DiskAsyncReplicationList"
3889          }
3890        },
3891        "resourceStatus": {
3892          "description": "[Output Only] Status information for the disk resource.",
3893          "$ref": "DiskResourceStatus"
3894        },
3895        "sourceConsistencyGroupPolicy": {
3896          "description": "[Output Only] URL of the DiskConsistencyGroupPolicy for a secondary disk that was created using a consistency group.",
3897          "type": "string"
3898        },
3899        "sourceConsistencyGroupPolicyId": {
3900          "description": "[Output Only] ID of the DiskConsistencyGroupPolicy for a secondary disk that was created using a consistency group.",
3901          "type": "string"
3902        },
3903        "architecture": {
3904          "description": "The architecture of the disk. Valid values are ARM64 or X86_64.",
3905          "type": "string",
3906          "enumDescriptions": [
3907            "Default value indicating Architecture is not set.",
3908            "Machines with architecture ARM64",
3909            "Machines with architecture X86_64"
3910          ],
3911          "enum": [
3912            "ARCHITECTURE_UNSPECIFIED",
3913            "ARM64",
3914            "X86_64"
3915          ]
3916        },
3917        "params": {
3918          "description": "Input only. [Input Only] Additional params passed with the request, but not persisted as part of resource payload.",
3919          "$ref": "DiskParams"
3920        }
3921      }
3922    },
3923    "DiskAsyncReplication": {
3924      "id": "DiskAsyncReplication",
3925      "type": "object",
3926      "properties": {
3927        "disk": {
3928          "description": "The other disk asynchronously replicated to or from the current disk. You can provide this as a partial or full URL to the resource. For example, the following are valid values: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /disks/disk - projects/project/zones/zone/disks/disk - zones/zone/disks/disk ",
3929          "type": "string"
3930        },
3931        "diskId": {
3932          "description": "[Output Only] The unique ID of the other disk asynchronously replicated to or from the current disk. This value identifies the exact disk that was used to create this replication. For example, if you started replicating the persistent disk from a disk that was later deleted and recreated under the same name, the disk ID would identify the exact version of the disk that was used.",
3933          "type": "string"
3934        },
3935        "consistencyGroupPolicy": {
3936          "description": "[Output Only] URL of the DiskConsistencyGroupPolicy if replication was started on the disk as a member of a group.",
3937          "type": "string"
3938        },
3939        "consistencyGroupPolicyId": {
3940          "description": "[Output Only] ID of the DiskConsistencyGroupPolicy if replication was started on the disk as a member of a group.",
3941          "type": "string"
3942        }
3943      }
3944    },
3945    "DiskAsyncReplicationList": {
3946      "id": "DiskAsyncReplicationList",
3947      "type": "object",
3948      "properties": {
3949        "asyncReplicationDisk": {
3950          "$ref": "DiskAsyncReplication"
3951        }
3952      }
3953    },
3954    "DiskResourceStatus": {
3955      "id": "DiskResourceStatus",
3956      "type": "object",
3957      "properties": {
3958        "asyncPrimaryDisk": {
3959          "$ref": "DiskResourceStatusAsyncReplicationStatus"
3960        },
3961        "asyncSecondaryDisks": {
3962          "description": "Key: disk, value: AsyncReplicationStatus message",
3963          "type": "object",
3964          "additionalProperties": {
3965            "$ref": "DiskResourceStatusAsyncReplicationStatus"
3966          }
3967        }
3968      }
3969    },
3970    "DiskResourceStatusAsyncReplicationStatus": {
3971      "id": "DiskResourceStatusAsyncReplicationStatus",
3972      "type": "object",
3973      "properties": {
3974        "state": {
3975          "type": "string",
3976          "enumDescriptions": [
3977            "Replication is active.",
3978            "Secondary disk is created and is waiting for replication to start.",
3979            "Replication is starting.",
3980            "",
3981            "Replication is stopped.",
3982            "Replication is stopping."
3983          ],
3984          "enum": [
3985            "ACTIVE",
3986            "CREATED",
3987            "STARTING",
3988            "STATE_UNSPECIFIED",
3989            "STOPPED",
3990            "STOPPING"
3991          ]
3992        }
3993      }
3994    },
3995    "DiskParams": {
3996      "id": "DiskParams",
3997      "description": "Additional disk params.",
3998      "type": "object",
3999      "properties": {
4000        "resourceManagerTags": {
4001          "description": "Resource manager tags to be bound to the disk. Tag keys and values have the same definition as resource manager tags. Keys must be in the format `tagKeys/{tag_key_id}`, and values are in the format `tagValues/456`. The field is ignored (both PUT & PATCH) when empty.",
4002          "type": "object",
4003          "additionalProperties": {
4004            "type": "string"
4005          }
4006        }
4007      }
4008    },
4009    "DiskAggregatedList": {
4010      "id": "DiskAggregatedList",
4011      "type": "object",
4012      "properties": {
4013        "kind": {
4014          "description": "[Output Only] Type of resource. Always compute#diskAggregatedList for aggregated lists of persistent disks.",
4015          "default": "compute#diskAggregatedList",
4016          "type": "string"
4017        },
4018        "id": {
4019          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
4020          "type": "string"
4021        },
4022        "items": {
4023          "description": "A list of DisksScopedList resources.",
4024          "type": "object",
4025          "additionalProperties": {
4026            "description": "[Output Only] Name of the scope containing this set of disks.",
4027            "$ref": "DisksScopedList"
4028          }
4029        },
4030        "nextPageToken": {
4031          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
4032          "type": "string"
4033        },
4034        "selfLink": {
4035          "description": "[Output Only] Server-defined URL for this resource.",
4036          "type": "string"
4037        },
4038        "warning": {
4039          "description": "[Output Only] Informational warning message.",
4040          "type": "object",
4041          "properties": {
4042            "code": {
4043              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
4044              "type": "string",
4045              "enumDescriptions": [
4046                "Warning about failed cleanup of transient changes made by a failed operation.",
4047                "A link to a deprecated resource was created.",
4048                "When deploying and at least one of the resources has a type marked as deprecated",
4049                "The user created a boot disk that is larger than image size.",
4050                "When deploying and at least one of the resources has a type marked as experimental",
4051                "Warning that is present in an external api call",
4052                "Warning that value of a field has been overridden. Deprecated unused field.",
4053                "The operation involved use of an injected kernel, which is deprecated.",
4054                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
4055                "When deploying a deployment with a exceedingly large number of resources",
4056                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
4057                "A resource depends on a missing type",
4058                "The route's nextHopIp address is not assigned to an instance on the network.",
4059                "The route's next hop instance cannot ip forward.",
4060                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
4061                "The route's nextHopInstance URL refers to an instance that does not exist.",
4062                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
4063                "The route's next hop instance does not have a status of RUNNING.",
4064                "Error which is not critical. We decided to continue the process despite the mentioned error.",
4065                "No results are present on a particular list page.",
4066                "Success is reported, but some results may be missing due to errors",
4067                "The user attempted to use a resource that requires a TOS they have not accepted.",
4068                "Warning that a resource is in use.",
4069                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
4070                "When a resource schema validation is ignored.",
4071                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
4072                "When undeclared properties in the schema are present",
4073                "A given scope cannot be reached."
4074              ],
4075              "enumDeprecated": [
4076                false,
4077                false,
4078                false,
4079                false,
4080                false,
4081                false,
4082                true,
4083                false,
4084                false,
4085                false,
4086                false,
4087                false,
4088                false,
4089                false,
4090                false,
4091                false,
4092                false,
4093                false,
4094                false,
4095                false,
4096                false,
4097                false,
4098                false,
4099                false,
4100                false,
4101                false,
4102                false,
4103                false
4104              ],
4105              "enum": [
4106                "CLEANUP_FAILED",
4107                "DEPRECATED_RESOURCE_USED",
4108                "DEPRECATED_TYPE_USED",
4109                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
4110                "EXPERIMENTAL_TYPE_USED",
4111                "EXTERNAL_API_WARNING",
4112                "FIELD_VALUE_OVERRIDEN",
4113                "INJECTED_KERNELS_DEPRECATED",
4114                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
4115                "LARGE_DEPLOYMENT_WARNING",
4116                "LIST_OVERHEAD_QUOTA_EXCEED",
4117                "MISSING_TYPE_DEPENDENCY",
4118                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
4119                "NEXT_HOP_CANNOT_IP_FORWARD",
4120                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
4121                "NEXT_HOP_INSTANCE_NOT_FOUND",
4122                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
4123                "NEXT_HOP_NOT_RUNNING",
4124                "NOT_CRITICAL_ERROR",
4125                "NO_RESULTS_ON_PAGE",
4126                "PARTIAL_SUCCESS",
4127                "REQUIRED_TOS_AGREEMENT",
4128                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
4129                "RESOURCE_NOT_DELETED",
4130                "SCHEMA_VALIDATION_IGNORED",
4131                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
4132                "UNDECLARED_PROPERTIES",
4133                "UNREACHABLE"
4134              ]
4135            },
4136            "message": {
4137              "description": "[Output Only] A human-readable description of the warning code.",
4138              "type": "string"
4139            },
4140            "data": {
4141              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
4142              "type": "array",
4143              "items": {
4144                "type": "object",
4145                "properties": {
4146                  "key": {
4147                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
4148                    "type": "string"
4149                  },
4150                  "value": {
4151                    "description": "[Output Only] A warning data value corresponding to the key.",
4152                    "type": "string"
4153                  }
4154                }
4155              }
4156            }
4157          }
4158        },
4159        "unreachables": {
4160          "description": "[Output Only] Unreachable resources.",
4161          "type": "array",
4162          "items": {
4163            "type": "string"
4164          }
4165        }
4166      }
4167    },
4168    "DisksScopedList": {
4169      "id": "DisksScopedList",
4170      "type": "object",
4171      "properties": {
4172        "disks": {
4173          "description": "[Output Only] A list of disks contained in this scope.",
4174          "type": "array",
4175          "items": {
4176            "$ref": "Disk"
4177          }
4178        },
4179        "warning": {
4180          "description": "[Output Only] Informational warning which replaces the list of disks when the list is empty.",
4181          "type": "object",
4182          "properties": {
4183            "code": {
4184              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
4185              "type": "string",
4186              "enumDescriptions": [
4187                "Warning about failed cleanup of transient changes made by a failed operation.",
4188                "A link to a deprecated resource was created.",
4189                "When deploying and at least one of the resources has a type marked as deprecated",
4190                "The user created a boot disk that is larger than image size.",
4191                "When deploying and at least one of the resources has a type marked as experimental",
4192                "Warning that is present in an external api call",
4193                "Warning that value of a field has been overridden. Deprecated unused field.",
4194                "The operation involved use of an injected kernel, which is deprecated.",
4195                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
4196                "When deploying a deployment with a exceedingly large number of resources",
4197                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
4198                "A resource depends on a missing type",
4199                "The route's nextHopIp address is not assigned to an instance on the network.",
4200                "The route's next hop instance cannot ip forward.",
4201                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
4202                "The route's nextHopInstance URL refers to an instance that does not exist.",
4203                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
4204                "The route's next hop instance does not have a status of RUNNING.",
4205                "Error which is not critical. We decided to continue the process despite the mentioned error.",
4206                "No results are present on a particular list page.",
4207                "Success is reported, but some results may be missing due to errors",
4208                "The user attempted to use a resource that requires a TOS they have not accepted.",
4209                "Warning that a resource is in use.",
4210                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
4211                "When a resource schema validation is ignored.",
4212                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
4213                "When undeclared properties in the schema are present",
4214                "A given scope cannot be reached."
4215              ],
4216              "enumDeprecated": [
4217                false,
4218                false,
4219                false,
4220                false,
4221                false,
4222                false,
4223                true,
4224                false,
4225                false,
4226                false,
4227                false,
4228                false,
4229                false,
4230                false,
4231                false,
4232                false,
4233                false,
4234                false,
4235                false,
4236                false,
4237                false,
4238                false,
4239                false,
4240                false,
4241                false,
4242                false,
4243                false,
4244                false
4245              ],
4246              "enum": [
4247                "CLEANUP_FAILED",
4248                "DEPRECATED_RESOURCE_USED",
4249                "DEPRECATED_TYPE_USED",
4250                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
4251                "EXPERIMENTAL_TYPE_USED",
4252                "EXTERNAL_API_WARNING",
4253                "FIELD_VALUE_OVERRIDEN",
4254                "INJECTED_KERNELS_DEPRECATED",
4255                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
4256                "LARGE_DEPLOYMENT_WARNING",
4257                "LIST_OVERHEAD_QUOTA_EXCEED",
4258                "MISSING_TYPE_DEPENDENCY",
4259                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
4260                "NEXT_HOP_CANNOT_IP_FORWARD",
4261                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
4262                "NEXT_HOP_INSTANCE_NOT_FOUND",
4263                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
4264                "NEXT_HOP_NOT_RUNNING",
4265                "NOT_CRITICAL_ERROR",
4266                "NO_RESULTS_ON_PAGE",
4267                "PARTIAL_SUCCESS",
4268                "REQUIRED_TOS_AGREEMENT",
4269                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
4270                "RESOURCE_NOT_DELETED",
4271                "SCHEMA_VALIDATION_IGNORED",
4272                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
4273                "UNDECLARED_PROPERTIES",
4274                "UNREACHABLE"
4275              ]
4276            },
4277            "message": {
4278              "description": "[Output Only] A human-readable description of the warning code.",
4279              "type": "string"
4280            },
4281            "data": {
4282              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
4283              "type": "array",
4284              "items": {
4285                "type": "object",
4286                "properties": {
4287                  "key": {
4288                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
4289                    "type": "string"
4290                  },
4291                  "value": {
4292                    "description": "[Output Only] A warning data value corresponding to the key.",
4293                    "type": "string"
4294                  }
4295                }
4296              }
4297            }
4298          }
4299        }
4300      }
4301    },
4302    "ZoneSetLabelsRequest": {
4303      "id": "ZoneSetLabelsRequest",
4304      "type": "object",
4305      "properties": {
4306        "labels": {
4307          "description": "The labels to set for this resource.",
4308          "type": "object",
4309          "additionalProperties": {
4310            "type": "string"
4311          }
4312        },
4313        "labelFingerprint": {
4314          "description": "The fingerprint of the previous set of labels for this resource, used to detect conflicts. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels. Make a get() request to the resource to get the latest fingerprint.",
4315          "type": "string",
4316          "format": "byte"
4317        }
4318      }
4319    },
4320    "DisksResizeRequest": {
4321      "id": "DisksResizeRequest",
4322      "type": "object",
4323      "properties": {
4324        "sizeGb": {
4325          "description": "The new size of the persistent disk, which is specified in GB.",
4326          "type": "string",
4327          "format": "int64"
4328        }
4329      }
4330    },
4331    "DisksAddResourcePoliciesRequest": {
4332      "id": "DisksAddResourcePoliciesRequest",
4333      "type": "object",
4334      "properties": {
4335        "resourcePolicies": {
4336          "description": "Full or relative path to the resource policy to be added to this disk. You can only specify one resource policy.",
4337          "type": "array",
4338          "items": {
4339            "type": "string"
4340          }
4341        }
4342      }
4343    },
4344    "DisksRemoveResourcePoliciesRequest": {
4345      "id": "DisksRemoveResourcePoliciesRequest",
4346      "type": "object",
4347      "properties": {
4348        "resourcePolicies": {
4349          "description": "Resource policies to be removed from this disk.",
4350          "type": "array",
4351          "items": {
4352            "type": "string"
4353          }
4354        }
4355      }
4356    },
4357    "ZoneSetPolicyRequest": {
4358      "id": "ZoneSetPolicyRequest",
4359      "type": "object",
4360      "properties": {
4361        "policy": {
4362          "description": "REQUIRED: The complete policy to be applied to the 'resource'. The size of the policy is limited to a few 10s of KB. An empty policy is in general a valid policy but certain services (like Projects) might reject them.",
4363          "$ref": "Policy"
4364        },
4365        "bindings": {
4366          "description": "Flatten Policy to create a backwacd compatible wire-format. Deprecated. Use 'policy' to specify bindings.",
4367          "type": "array",
4368          "items": {
4369            "$ref": "Binding"
4370          }
4371        },
4372        "etag": {
4373          "description": "Flatten Policy to create a backward compatible wire-format. Deprecated. Use 'policy' to specify the etag.",
4374          "type": "string",
4375          "format": "byte"
4376        }
4377      }
4378    },
4379    "DisksStartAsyncReplicationRequest": {
4380      "id": "DisksStartAsyncReplicationRequest",
4381      "type": "object",
4382      "properties": {
4383        "asyncSecondaryDisk": {
4384          "description": "The secondary disk to start asynchronous replication to. You can provide this as a partial or full URL to the resource. For example, the following are valid values: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /disks/disk - https://www.googleapis.com/compute/v1/projects/project/regions/region /disks/disk - projects/project/zones/zone/disks/disk - projects/project/regions/region/disks/disk - zones/zone/disks/disk - regions/region/disks/disk ",
4385          "type": "string"
4386        }
4387      }
4388    },
4389    "DisksStopGroupAsyncReplicationResource": {
4390      "id": "DisksStopGroupAsyncReplicationResource",
4391      "description": "A transient resource used in compute.disks.stopGroupAsyncReplication and compute.regionDisks.stopGroupAsyncReplication. It is only used to process requests and is not persisted.",
4392      "type": "object",
4393      "properties": {
4394        "resourcePolicy": {
4395          "description": "The URL of the DiskConsistencyGroupPolicy for the group of disks to stop. This may be a full or partial URL, such as: - https://www.googleapis.com/compute/v1/projects/project/regions/region /resourcePolicies/resourcePolicy - projects/project/regions/region/resourcePolicies/resourcePolicy - regions/region/resourcePolicies/resourcePolicy ",
4396          "type": "string"
4397        }
4398      }
4399    },
4400    "BulkInsertDiskResource": {
4401      "id": "BulkInsertDiskResource",
4402      "description": "A transient resource used in compute.disks.bulkInsert and compute.regionDisks.bulkInsert. It is only used to process requests and is not persisted.",
4403      "type": "object",
4404      "properties": {
4405        "sourceConsistencyGroupPolicy": {
4406          "description": "The URL of the DiskConsistencyGroupPolicy for the group of disks to clone. This may be a full or partial URL, such as: - https://www.googleapis.com/compute/v1/projects/project/regions/region /resourcePolicies/resourcePolicy - projects/project/regions/region/resourcePolicies/resourcePolicy - regions/region/resourcePolicies/resourcePolicy ",
4407          "type": "string"
4408        }
4409      }
4410    },
4411    "RegionDisksResizeRequest": {
4412      "id": "RegionDisksResizeRequest",
4413      "type": "object",
4414      "properties": {
4415        "sizeGb": {
4416          "description": "The new size of the regional persistent disk, which is specified in GB.",
4417          "type": "string",
4418          "format": "int64"
4419        }
4420      }
4421    },
4422    "RegionDisksAddResourcePoliciesRequest": {
4423      "id": "RegionDisksAddResourcePoliciesRequest",
4424      "type": "object",
4425      "properties": {
4426        "resourcePolicies": {
4427          "description": "Resource policies to be added to this disk.",
4428          "type": "array",
4429          "items": {
4430            "type": "string"
4431          }
4432        }
4433      }
4434    },
4435    "RegionDisksRemoveResourcePoliciesRequest": {
4436      "id": "RegionDisksRemoveResourcePoliciesRequest",
4437      "type": "object",
4438      "properties": {
4439        "resourcePolicies": {
4440          "description": "Resource policies to be removed from this disk.",
4441          "type": "array",
4442          "items": {
4443            "type": "string"
4444          }
4445        }
4446      }
4447    },
4448    "RegionSetPolicyRequest": {
4449      "id": "RegionSetPolicyRequest",
4450      "type": "object",
4451      "properties": {
4452        "policy": {
4453          "description": "REQUIRED: The complete policy to be applied to the 'resource'. The size of the policy is limited to a few 10s of KB. An empty policy is in general a valid policy but certain services (like Projects) might reject them.",
4454          "$ref": "Policy"
4455        },
4456        "bindings": {
4457          "description": "Flatten Policy to create a backwacd compatible wire-format. Deprecated. Use 'policy' to specify bindings.",
4458          "type": "array",
4459          "items": {
4460            "$ref": "Binding"
4461          }
4462        },
4463        "etag": {
4464          "description": "Flatten Policy to create a backward compatible wire-format. Deprecated. Use 'policy' to specify the etag.",
4465          "type": "string",
4466          "format": "byte"
4467        }
4468      }
4469    },
4470    "RegionDisksStartAsyncReplicationRequest": {
4471      "id": "RegionDisksStartAsyncReplicationRequest",
4472      "type": "object",
4473      "properties": {
4474        "asyncSecondaryDisk": {
4475          "description": "The secondary disk to start asynchronous replication to. You can provide this as a partial or full URL to the resource. For example, the following are valid values: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /disks/disk - https://www.googleapis.com/compute/v1/projects/project/regions/region /disks/disk - projects/project/zones/zone/disks/disk - projects/project/regions/region/disks/disk - zones/zone/disks/disk - regions/region/disks/disk ",
4476          "type": "string"
4477        }
4478      }
4479    },
4480    "FirewallList": {
4481      "id": "FirewallList",
4482      "description": "Contains a list of firewalls.",
4483      "type": "object",
4484      "properties": {
4485        "kind": {
4486          "description": "[Output Only] Type of resource. Always compute#firewallList for lists of firewalls.",
4487          "default": "compute#firewallList",
4488          "type": "string"
4489        },
4490        "id": {
4491          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
4492          "type": "string"
4493        },
4494        "items": {
4495          "description": "A list of Firewall resources.",
4496          "type": "array",
4497          "items": {
4498            "$ref": "Firewall"
4499          }
4500        },
4501        "nextPageToken": {
4502          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
4503          "type": "string"
4504        },
4505        "selfLink": {
4506          "description": "[Output Only] Server-defined URL for this resource.",
4507          "type": "string"
4508        },
4509        "warning": {
4510          "description": "[Output Only] Informational warning message.",
4511          "type": "object",
4512          "properties": {
4513            "code": {
4514              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
4515              "type": "string",
4516              "enumDescriptions": [
4517                "Warning about failed cleanup of transient changes made by a failed operation.",
4518                "A link to a deprecated resource was created.",
4519                "When deploying and at least one of the resources has a type marked as deprecated",
4520                "The user created a boot disk that is larger than image size.",
4521                "When deploying and at least one of the resources has a type marked as experimental",
4522                "Warning that is present in an external api call",
4523                "Warning that value of a field has been overridden. Deprecated unused field.",
4524                "The operation involved use of an injected kernel, which is deprecated.",
4525                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
4526                "When deploying a deployment with a exceedingly large number of resources",
4527                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
4528                "A resource depends on a missing type",
4529                "The route's nextHopIp address is not assigned to an instance on the network.",
4530                "The route's next hop instance cannot ip forward.",
4531                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
4532                "The route's nextHopInstance URL refers to an instance that does not exist.",
4533                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
4534                "The route's next hop instance does not have a status of RUNNING.",
4535                "Error which is not critical. We decided to continue the process despite the mentioned error.",
4536                "No results are present on a particular list page.",
4537                "Success is reported, but some results may be missing due to errors",
4538                "The user attempted to use a resource that requires a TOS they have not accepted.",
4539                "Warning that a resource is in use.",
4540                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
4541                "When a resource schema validation is ignored.",
4542                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
4543                "When undeclared properties in the schema are present",
4544                "A given scope cannot be reached."
4545              ],
4546              "enumDeprecated": [
4547                false,
4548                false,
4549                false,
4550                false,
4551                false,
4552                false,
4553                true,
4554                false,
4555                false,
4556                false,
4557                false,
4558                false,
4559                false,
4560                false,
4561                false,
4562                false,
4563                false,
4564                false,
4565                false,
4566                false,
4567                false,
4568                false,
4569                false,
4570                false,
4571                false,
4572                false,
4573                false,
4574                false
4575              ],
4576              "enum": [
4577                "CLEANUP_FAILED",
4578                "DEPRECATED_RESOURCE_USED",
4579                "DEPRECATED_TYPE_USED",
4580                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
4581                "EXPERIMENTAL_TYPE_USED",
4582                "EXTERNAL_API_WARNING",
4583                "FIELD_VALUE_OVERRIDEN",
4584                "INJECTED_KERNELS_DEPRECATED",
4585                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
4586                "LARGE_DEPLOYMENT_WARNING",
4587                "LIST_OVERHEAD_QUOTA_EXCEED",
4588                "MISSING_TYPE_DEPENDENCY",
4589                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
4590                "NEXT_HOP_CANNOT_IP_FORWARD",
4591                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
4592                "NEXT_HOP_INSTANCE_NOT_FOUND",
4593                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
4594                "NEXT_HOP_NOT_RUNNING",
4595                "NOT_CRITICAL_ERROR",
4596                "NO_RESULTS_ON_PAGE",
4597                "PARTIAL_SUCCESS",
4598                "REQUIRED_TOS_AGREEMENT",
4599                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
4600                "RESOURCE_NOT_DELETED",
4601                "SCHEMA_VALIDATION_IGNORED",
4602                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
4603                "UNDECLARED_PROPERTIES",
4604                "UNREACHABLE"
4605              ]
4606            },
4607            "message": {
4608              "description": "[Output Only] A human-readable description of the warning code.",
4609              "type": "string"
4610            },
4611            "data": {
4612              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
4613              "type": "array",
4614              "items": {
4615                "type": "object",
4616                "properties": {
4617                  "key": {
4618                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
4619                    "type": "string"
4620                  },
4621                  "value": {
4622                    "description": "[Output Only] A warning data value corresponding to the key.",
4623                    "type": "string"
4624                  }
4625                }
4626              }
4627            }
4628          }
4629        }
4630      }
4631    },
4632    "Firewall": {
4633      "id": "Firewall",
4634      "description": "Represents a Firewall Rule resource. Firewall rules allow or deny ingress traffic to, and egress traffic from your instances. For more information, read Firewall rules.",
4635      "type": "object",
4636      "properties": {
4637        "kind": {
4638          "description": "[Output Only] Type of the resource. Always compute#firewall for firewall rules.",
4639          "default": "compute#firewall",
4640          "type": "string"
4641        },
4642        "id": {
4643          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
4644          "type": "string",
4645          "format": "uint64"
4646        },
4647        "creationTimestamp": {
4648          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
4649          "type": "string"
4650        },
4651        "name": {
4652          "description": "Name of the resource; provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?`. The first character must be a lowercase letter, and all following characters (except for the last character) must be a dash, lowercase letter, or digit. The last character must be a lowercase letter or digit.",
4653          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
4654          "annotations": {
4655            "required": [
4656              "compute.firewalls.insert",
4657              "compute.firewalls.patch"
4658            ]
4659          },
4660          "type": "string"
4661        },
4662        "description": {
4663          "description": "An optional description of this resource. Provide this field when you create the resource.",
4664          "type": "string"
4665        },
4666        "network": {
4667          "description": "URL of the network resource for this firewall rule. If not specified when creating a firewall rule, the default network is used: global/networks/default If you choose to specify this field, you can specify the network as a full or partial URL. For example, the following are all valid URLs: - https://www.googleapis.com/compute/v1/projects/myproject/global/networks/my-network - projects/myproject/global/networks/my-network - global/networks/default ",
4668          "type": "string"
4669        },
4670        "priority": {
4671          "description": "Priority for this rule. This is an integer between `0` and `65535`, both inclusive. The default value is `1000`. Relative priorities determine which rule takes effect if multiple rules apply. Lower values indicate higher priority. For example, a rule with priority `0` has higher precedence than a rule with priority `1`. DENY rules take precedence over ALLOW rules if they have equal priority. Note that VPC networks have implied rules with a priority of `65535`. To avoid conflicts with the implied rules, use a priority number less than `65535`.",
4672          "type": "integer",
4673          "format": "int32"
4674        },
4675        "sourceRanges": {
4676          "description": "If source ranges are specified, the firewall rule applies only to traffic that has a source IP address in these ranges. These ranges must be expressed in CIDR format. One or both of sourceRanges and sourceTags may be set. If both fields are set, the rule applies to traffic that has a source IP address within sourceRanges OR a source IP from a resource with a matching tag listed in the sourceTags field. The connection does not need to match both fields for the rule to apply. Both IPv4 and IPv6 are supported.",
4677          "type": "array",
4678          "items": {
4679            "type": "string"
4680          }
4681        },
4682        "destinationRanges": {
4683          "description": "If destination ranges are specified, the firewall rule applies only to traffic that has destination IP address in these ranges. These ranges must be expressed in CIDR format. Both IPv4 and IPv6 are supported.",
4684          "type": "array",
4685          "items": {
4686            "type": "string"
4687          }
4688        },
4689        "sourceTags": {
4690          "description": "If source tags are specified, the firewall rule applies only to traffic with source IPs that match the primary network interfaces of VM instances that have the tag and are in the same VPC network. Source tags cannot be used to control traffic to an instance's external IP address, it only applies to traffic between instances in the same virtual network. Because tags are associated with instances, not IP addresses. One or both of sourceRanges and sourceTags may be set. If both fields are set, the firewall applies to traffic that has a source IP address within sourceRanges OR a source IP from a resource with a matching tag listed in the sourceTags field. The connection does not need to match both fields for the firewall to apply.",
4691          "type": "array",
4692          "items": {
4693            "type": "string"
4694          }
4695        },
4696        "targetTags": {
4697          "description": "A list of tags that controls which instances the firewall rule applies to. If targetTags are specified, then the firewall rule applies only to instances in the VPC network that have one of those tags. If no targetTags are specified, the firewall rule applies to all instances on the specified network.",
4698          "type": "array",
4699          "items": {
4700            "type": "string"
4701          }
4702        },
4703        "sourceServiceAccounts": {
4704          "description": "If source service accounts are specified, the firewall rules apply only to traffic originating from an instance with a service account in this list. Source service accounts cannot be used to control traffic to an instance's external IP address because service accounts are associated with an instance, not an IP address. sourceRanges can be set at the same time as sourceServiceAccounts. If both are set, the firewall applies to traffic that has a source IP address within the sourceRanges OR a source IP that belongs to an instance with service account listed in sourceServiceAccount. The connection does not need to match both fields for the firewall to apply. sourceServiceAccounts cannot be used at the same time as sourceTags or targetTags.",
4705          "type": "array",
4706          "items": {
4707            "type": "string"
4708          }
4709        },
4710        "targetServiceAccounts": {
4711          "description": "A list of service accounts indicating sets of instances located in the network that may make network connections as specified in allowed[]. targetServiceAccounts cannot be used at the same time as targetTags or sourceTags. If neither targetServiceAccounts nor targetTags are specified, the firewall rule applies to all instances on the specified network.",
4712          "type": "array",
4713          "items": {
4714            "type": "string"
4715          }
4716        },
4717        "allowed": {
4718          "description": "The list of ALLOW rules specified by this firewall. Each rule specifies a protocol and port-range tuple that describes a permitted connection.",
4719          "type": "array",
4720          "items": {
4721            "type": "object",
4722            "properties": {
4723              "IPProtocol": {
4724                "description": "The IP protocol to which this rule applies. The protocol type is required when creating a firewall rule. This value can either be one of the following well known protocol strings (tcp, udp, icmp, esp, ah, ipip, sctp) or the IP protocol number.",
4725                "type": "string"
4726              },
4727              "ports": {
4728                "description": "An optional list of ports to which this rule applies. This field is only applicable for the UDP or TCP protocol. Each entry must be either an integer or a range. If not specified, this rule applies to connections through any port. Example inputs include: [\"22\"], [\"80\",\"443\"], and [\"12345-12349\"].",
4729                "type": "array",
4730                "items": {
4731                  "type": "string"
4732                }
4733              }
4734            }
4735          }
4736        },
4737        "denied": {
4738          "description": "The list of DENY rules specified by this firewall. Each rule specifies a protocol and port-range tuple that describes a denied connection.",
4739          "type": "array",
4740          "items": {
4741            "type": "object",
4742            "properties": {
4743              "IPProtocol": {
4744                "description": "The IP protocol to which this rule applies. The protocol type is required when creating a firewall rule. This value can either be one of the following well known protocol strings (tcp, udp, icmp, esp, ah, ipip, sctp) or the IP protocol number.",
4745                "type": "string"
4746              },
4747              "ports": {
4748                "description": "An optional list of ports to which this rule applies. This field is only applicable for the UDP or TCP protocol. Each entry must be either an integer or a range. If not specified, this rule applies to connections through any port. Example inputs include: [\"22\"], [\"80\",\"443\"], and [\"12345-12349\"].",
4749                "type": "array",
4750                "items": {
4751                  "type": "string"
4752                }
4753              }
4754            }
4755          }
4756        },
4757        "direction": {
4758          "description": "Direction of traffic to which this firewall applies, either `INGRESS` or `EGRESS`. The default is `INGRESS`. For `EGRESS` traffic, you cannot specify the sourceTags fields.",
4759          "type": "string",
4760          "enumDescriptions": [
4761            "Indicates that firewall should apply to outgoing traffic.",
4762            "Indicates that firewall should apply to incoming traffic."
4763          ],
4764          "enum": [
4765            "EGRESS",
4766            "INGRESS"
4767          ]
4768        },
4769        "logConfig": {
4770          "description": "This field denotes the logging options for a particular firewall rule. If logging is enabled, logs will be exported to Cloud Logging.",
4771          "$ref": "FirewallLogConfig"
4772        },
4773        "disabled": {
4774          "description": "Denotes whether the firewall rule is disabled. When set to true, the firewall rule is not enforced and the network behaves as if it did not exist. If this is unspecified, the firewall rule will be enabled.",
4775          "type": "boolean"
4776        },
4777        "selfLink": {
4778          "description": "[Output Only] Server-defined URL for the resource.",
4779          "type": "string"
4780        }
4781      }
4782    },
4783    "FirewallLogConfig": {
4784      "id": "FirewallLogConfig",
4785      "description": "The available logging options for a firewall rule.",
4786      "type": "object",
4787      "properties": {
4788        "enable": {
4789          "description": "This field denotes whether to enable logging for a particular firewall rule.",
4790          "type": "boolean"
4791        },
4792        "metadata": {
4793          "description": "This field can only be specified for a particular firewall rule if logging is enabled for that rule. This field denotes whether to include or exclude metadata for firewall logs.",
4794          "type": "string",
4795          "enumDescriptions": [
4796            "",
4797            ""
4798          ],
4799          "enum": [
4800            "EXCLUDE_ALL_METADATA",
4801            "INCLUDE_ALL_METADATA"
4802          ]
4803        }
4804      }
4805    },
4806    "FirewallPolicyList": {
4807      "id": "FirewallPolicyList",
4808      "type": "object",
4809      "properties": {
4810        "kind": {
4811          "description": "[Output Only] Type of resource. Always compute#firewallPolicyList for listsof FirewallPolicies",
4812          "default": "compute#firewallPolicyList",
4813          "type": "string"
4814        },
4815        "id": {
4816          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
4817          "type": "string"
4818        },
4819        "items": {
4820          "description": "A list of FirewallPolicy resources.",
4821          "type": "array",
4822          "items": {
4823            "$ref": "FirewallPolicy"
4824          }
4825        },
4826        "nextPageToken": {
4827          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
4828          "type": "string"
4829        },
4830        "warning": {
4831          "description": "[Output Only] Informational warning message.",
4832          "type": "object",
4833          "properties": {
4834            "code": {
4835              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
4836              "type": "string",
4837              "enumDescriptions": [
4838                "Warning about failed cleanup of transient changes made by a failed operation.",
4839                "A link to a deprecated resource was created.",
4840                "When deploying and at least one of the resources has a type marked as deprecated",
4841                "The user created a boot disk that is larger than image size.",
4842                "When deploying and at least one of the resources has a type marked as experimental",
4843                "Warning that is present in an external api call",
4844                "Warning that value of a field has been overridden. Deprecated unused field.",
4845                "The operation involved use of an injected kernel, which is deprecated.",
4846                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
4847                "When deploying a deployment with a exceedingly large number of resources",
4848                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
4849                "A resource depends on a missing type",
4850                "The route's nextHopIp address is not assigned to an instance on the network.",
4851                "The route's next hop instance cannot ip forward.",
4852                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
4853                "The route's nextHopInstance URL refers to an instance that does not exist.",
4854                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
4855                "The route's next hop instance does not have a status of RUNNING.",
4856                "Error which is not critical. We decided to continue the process despite the mentioned error.",
4857                "No results are present on a particular list page.",
4858                "Success is reported, but some results may be missing due to errors",
4859                "The user attempted to use a resource that requires a TOS they have not accepted.",
4860                "Warning that a resource is in use.",
4861                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
4862                "When a resource schema validation is ignored.",
4863                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
4864                "When undeclared properties in the schema are present",
4865                "A given scope cannot be reached."
4866              ],
4867              "enumDeprecated": [
4868                false,
4869                false,
4870                false,
4871                false,
4872                false,
4873                false,
4874                true,
4875                false,
4876                false,
4877                false,
4878                false,
4879                false,
4880                false,
4881                false,
4882                false,
4883                false,
4884                false,
4885                false,
4886                false,
4887                false,
4888                false,
4889                false,
4890                false,
4891                false,
4892                false,
4893                false,
4894                false,
4895                false
4896              ],
4897              "enum": [
4898                "CLEANUP_FAILED",
4899                "DEPRECATED_RESOURCE_USED",
4900                "DEPRECATED_TYPE_USED",
4901                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
4902                "EXPERIMENTAL_TYPE_USED",
4903                "EXTERNAL_API_WARNING",
4904                "FIELD_VALUE_OVERRIDEN",
4905                "INJECTED_KERNELS_DEPRECATED",
4906                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
4907                "LARGE_DEPLOYMENT_WARNING",
4908                "LIST_OVERHEAD_QUOTA_EXCEED",
4909                "MISSING_TYPE_DEPENDENCY",
4910                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
4911                "NEXT_HOP_CANNOT_IP_FORWARD",
4912                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
4913                "NEXT_HOP_INSTANCE_NOT_FOUND",
4914                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
4915                "NEXT_HOP_NOT_RUNNING",
4916                "NOT_CRITICAL_ERROR",
4917                "NO_RESULTS_ON_PAGE",
4918                "PARTIAL_SUCCESS",
4919                "REQUIRED_TOS_AGREEMENT",
4920                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
4921                "RESOURCE_NOT_DELETED",
4922                "SCHEMA_VALIDATION_IGNORED",
4923                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
4924                "UNDECLARED_PROPERTIES",
4925                "UNREACHABLE"
4926              ]
4927            },
4928            "message": {
4929              "description": "[Output Only] A human-readable description of the warning code.",
4930              "type": "string"
4931            },
4932            "data": {
4933              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
4934              "type": "array",
4935              "items": {
4936                "type": "object",
4937                "properties": {
4938                  "key": {
4939                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
4940                    "type": "string"
4941                  },
4942                  "value": {
4943                    "description": "[Output Only] A warning data value corresponding to the key.",
4944                    "type": "string"
4945                  }
4946                }
4947              }
4948            }
4949          }
4950        }
4951      }
4952    },
4953    "FirewallPolicy": {
4954      "id": "FirewallPolicy",
4955      "description": "Represents a Firewall Policy resource.",
4956      "type": "object",
4957      "properties": {
4958        "kind": {
4959          "description": "[Output only] Type of the resource. Always compute#firewallPolicyfor firewall policies",
4960          "default": "compute#firewallPolicy",
4961          "type": "string"
4962        },
4963        "id": {
4964          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
4965          "type": "string",
4966          "format": "uint64"
4967        },
4968        "creationTimestamp": {
4969          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
4970          "type": "string"
4971        },
4972        "name": {
4973          "description": "Name of the resource. For Organization Firewall Policies it's a [Output Only] numeric ID allocated by Google Cloud which uniquely identifies the Organization Firewall Policy.",
4974          "type": "string"
4975        },
4976        "description": {
4977          "description": "An optional description of this resource. Provide this property when you create the resource.",
4978          "type": "string"
4979        },
4980        "rules": {
4981          "description": "A list of rules that belong to this policy. There must always be a default rule (rule with priority 2147483647 and match \"*\"). If no rules are provided when creating a firewall policy, a default rule with action \"allow\" will be added.",
4982          "type": "array",
4983          "items": {
4984            "$ref": "FirewallPolicyRule"
4985          }
4986        },
4987        "fingerprint": {
4988          "description": "Specifies a fingerprint for this resource, which is essentially a hash of the metadata's contents and used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update metadata. You must always provide an up-to-date fingerprint hash in order to update or change metadata, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make get() request to the firewall policy.",
4989          "type": "string",
4990          "format": "byte"
4991        },
4992        "selfLink": {
4993          "description": "[Output Only] Server-defined URL for the resource.",
4994          "type": "string"
4995        },
4996        "selfLinkWithId": {
4997          "description": "[Output Only] Server-defined URL for this resource with the resource id.",
4998          "type": "string"
4999        },
5000        "associations": {
5001          "description": "A list of associations that belong to this firewall policy.",
5002          "type": "array",
5003          "items": {
5004            "$ref": "FirewallPolicyAssociation"
5005          }
5006        },
5007        "ruleTupleCount": {
5008          "description": "[Output Only] Total count of all firewall policy rule tuples. A firewall policy can not exceed a set number of tuples.",
5009          "type": "integer",
5010          "format": "int32"
5011        },
5012        "shortName": {
5013          "description": "User-provided name of the Organization firewall policy. The name should be unique in the organization in which the firewall policy is created. This field is not applicable to network firewall policies. This name must be set on creation and cannot be changed. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
5014          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
5015          "type": "string"
5016        },
5017        "displayName": {
5018          "description": "Deprecated, please use short name instead. User-provided name of the Organization firewall policy. The name should be unique in the organization in which the firewall policy is created. This field is not applicable to network firewall policies. This name must be set on creation and cannot be changed. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
5019          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
5020          "deprecated": true,
5021          "type": "string"
5022        },
5023        "parent": {
5024          "description": "[Output Only] The parent of the firewall policy. This field is not applicable to network firewall policies.",
5025          "type": "string"
5026        },
5027        "region": {
5028          "description": "[Output Only] URL of the region where the regional firewall policy resides. This field is not applicable to global firewall policies. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
5029          "type": "string"
5030        }
5031      }
5032    },
5033    "FirewallPolicyRule": {
5034      "id": "FirewallPolicyRule",
5035      "description": "Represents a rule that describes one or more match conditions along with the action to be taken when traffic matches this condition (allow or deny).",
5036      "type": "object",
5037      "properties": {
5038        "kind": {
5039          "description": "[Output only] Type of the resource. Always compute#firewallPolicyRule for firewall policy rules",
5040          "default": "compute#firewallPolicyRule",
5041          "type": "string"
5042        },
5043        "ruleName": {
5044          "description": "An optional name for the rule. This field is not a unique identifier and can be updated.",
5045          "type": "string"
5046        },
5047        "description": {
5048          "description": "An optional description for this resource.",
5049          "type": "string"
5050        },
5051        "priority": {
5052          "description": "An integer indicating the priority of a rule in the list. The priority must be a positive value between 0 and 2147483647. Rules are evaluated from highest to lowest priority where 0 is the highest priority and 2147483647 is the lowest prority.",
5053          "type": "integer",
5054          "format": "int32"
5055        },
5056        "match": {
5057          "description": "A match condition that incoming traffic is evaluated against. If it evaluates to true, the corresponding 'action' is enforced.",
5058          "$ref": "FirewallPolicyRuleMatcher"
5059        },
5060        "action": {
5061          "description": "The Action to perform when the client connection triggers the rule. Valid actions are \"allow\", \"deny\" and \"goto_next\".",
5062          "type": "string"
5063        },
5064        "securityProfileGroup": {
5065          "description": "A fully-qualified URL of a SecurityProfile resource instance. Example: https://networksecurity.googleapis.com/v1/projects/{project}/locations/{location}/securityProfileGroups/my-security-profile-group Must be specified if action = 'apply_security_profile_group' and cannot be specified for other actions.",
5066          "type": "string"
5067        },
5068        "tlsInspect": {
5069          "description": "Boolean flag indicating if the traffic should be TLS decrypted. Can be set only if action = 'apply_security_profile_group' and cannot be set for other actions.",
5070          "type": "boolean"
5071        },
5072        "direction": {
5073          "description": "The direction in which this rule applies.",
5074          "type": "string",
5075          "enumDescriptions": [
5076            "",
5077            ""
5078          ],
5079          "enum": [
5080            "EGRESS",
5081            "INGRESS"
5082          ]
5083        },
5084        "targetResources": {
5085          "description": "A list of network resource URLs to which this rule applies. This field allows you to control which network's VMs get this rule. If this field is left blank, all VMs within the organization will receive the rule.",
5086          "type": "array",
5087          "items": {
5088            "type": "string"
5089          }
5090        },
5091        "enableLogging": {
5092          "description": "Denotes whether to enable logging for a particular rule. If logging is enabled, logs will be exported to the configured export destination in Stackdriver. Logs may be exported to BigQuery or Pub/Sub. Note: you cannot enable logging on \"goto_next\" rules.",
5093          "type": "boolean"
5094        },
5095        "ruleTupleCount": {
5096          "description": "[Output Only] Calculation of the complexity of a single firewall policy rule.",
5097          "type": "integer",
5098          "format": "int32"
5099        },
5100        "targetServiceAccounts": {
5101          "description": "A list of service accounts indicating the sets of instances that are applied with this rule.",
5102          "type": "array",
5103          "items": {
5104            "type": "string"
5105          }
5106        },
5107        "targetSecureTags": {
5108          "description": "A list of secure tags that controls which instances the firewall rule applies to. If targetSecureTag are specified, then the firewall rule applies only to instances in the VPC network that have one of those EFFECTIVE secure tags, if all the target_secure_tag are in INEFFECTIVE state, then this rule will be ignored. targetSecureTag may not be set at the same time as targetServiceAccounts. If neither targetServiceAccounts nor targetSecureTag are specified, the firewall rule applies to all instances on the specified network. Maximum number of target label tags allowed is 256.",
5109          "type": "array",
5110          "items": {
5111            "$ref": "FirewallPolicyRuleSecureTag"
5112          }
5113        },
5114        "disabled": {
5115          "description": "Denotes whether the firewall policy rule is disabled. When set to true, the firewall policy rule is not enforced and traffic behaves as if it did not exist. If this is unspecified, the firewall policy rule will be enabled.",
5116          "type": "boolean"
5117        }
5118      }
5119    },
5120    "FirewallPolicyRuleMatcher": {
5121      "id": "FirewallPolicyRuleMatcher",
5122      "description": "Represents a match condition that incoming traffic is evaluated against. Exactly one field must be specified.",
5123      "type": "object",
5124      "properties": {
5125        "srcIpRanges": {
5126          "description": "CIDR IP address range. Maximum number of source CIDR IP ranges allowed is 5000.",
5127          "type": "array",
5128          "items": {
5129            "type": "string"
5130          }
5131        },
5132        "destIpRanges": {
5133          "description": "CIDR IP address range. Maximum number of destination CIDR IP ranges allowed is 5000.",
5134          "type": "array",
5135          "items": {
5136            "type": "string"
5137          }
5138        },
5139        "layer4Configs": {
5140          "description": "Pairs of IP protocols and ports that the rule should match.",
5141          "type": "array",
5142          "items": {
5143            "$ref": "FirewallPolicyRuleMatcherLayer4Config"
5144          }
5145        },
5146        "srcSecureTags": {
5147          "description": "List of secure tag values, which should be matched at the source of the traffic. For INGRESS rule, if all the srcSecureTag are INEFFECTIVE, and there is no srcIpRange, this rule will be ignored. Maximum number of source tag values allowed is 256.",
5148          "type": "array",
5149          "items": {
5150            "$ref": "FirewallPolicyRuleSecureTag"
5151          }
5152        },
5153        "destAddressGroups": {
5154          "description": "Address groups which should be matched against the traffic destination. Maximum number of destination address groups is 10.",
5155          "type": "array",
5156          "items": {
5157            "type": "string"
5158          }
5159        },
5160        "srcAddressGroups": {
5161          "description": "Address groups which should be matched against the traffic source. Maximum number of source address groups is 10.",
5162          "type": "array",
5163          "items": {
5164            "type": "string"
5165          }
5166        },
5167        "srcFqdns": {
5168          "description": "Fully Qualified Domain Name (FQDN) which should be matched against traffic source. Maximum number of source fqdn allowed is 100.",
5169          "type": "array",
5170          "items": {
5171            "type": "string"
5172          }
5173        },
5174        "destFqdns": {
5175          "description": "Fully Qualified Domain Name (FQDN) which should be matched against traffic destination. Maximum number of destination fqdn allowed is 100.",
5176          "type": "array",
5177          "items": {
5178            "type": "string"
5179          }
5180        },
5181        "srcRegionCodes": {
5182          "description": "Region codes whose IP addresses will be used to match for source of traffic. Should be specified as 2 letter country code defined as per ISO 3166 alpha-2 country codes. ex.\"US\" Maximum number of source region codes allowed is 5000.",
5183          "type": "array",
5184          "items": {
5185            "type": "string"
5186          }
5187        },
5188        "destRegionCodes": {
5189          "description": "Region codes whose IP addresses will be used to match for destination of traffic. Should be specified as 2 letter country code defined as per ISO 3166 alpha-2 country codes. ex.\"US\" Maximum number of dest region codes allowed is 5000.",
5190          "type": "array",
5191          "items": {
5192            "type": "string"
5193          }
5194        },
5195        "destThreatIntelligences": {
5196          "description": "Names of Network Threat Intelligence lists. The IPs in these lists will be matched against traffic destination.",
5197          "type": "array",
5198          "items": {
5199            "type": "string"
5200          }
5201        },
5202        "srcThreatIntelligences": {
5203          "description": "Names of Network Threat Intelligence lists. The IPs in these lists will be matched against traffic source.",
5204          "type": "array",
5205          "items": {
5206            "type": "string"
5207          }
5208        }
5209      }
5210    },
5211    "FirewallPolicyRuleMatcherLayer4Config": {
5212      "id": "FirewallPolicyRuleMatcherLayer4Config",
5213      "type": "object",
5214      "properties": {
5215        "ipProtocol": {
5216          "description": "The IP protocol to which this rule applies. The protocol type is required when creating a firewall rule. This value can either be one of the following well known protocol strings (tcp, udp, icmp, esp, ah, ipip, sctp), or the IP protocol number.",
5217          "type": "string"
5218        },
5219        "ports": {
5220          "description": "An optional list of ports to which this rule applies. This field is only applicable for UDP or TCP protocol. Each entry must be either an integer or a range. If not specified, this rule applies to connections through any port. Example inputs include: [\"22\"], [\"80\",\"443\"], and [\"12345-12349\"].",
5221          "type": "array",
5222          "items": {
5223            "type": "string"
5224          }
5225        }
5226      }
5227    },
5228    "FirewallPolicyRuleSecureTag": {
5229      "id": "FirewallPolicyRuleSecureTag",
5230      "type": "object",
5231      "properties": {
5232        "name": {
5233          "description": "Name of the secure tag, created with TagManager's TagValue API.",
5234          "pattern": "tagValues/[0-9]+",
5235          "type": "string"
5236        },
5237        "state": {
5238          "description": "[Output Only] State of the secure tag, either `EFFECTIVE` or `INEFFECTIVE`. A secure tag is `INEFFECTIVE` when it is deleted or its network is deleted.",
5239          "type": "string",
5240          "enumDescriptions": [
5241            "",
5242            ""
5243          ],
5244          "enum": [
5245            "EFFECTIVE",
5246            "INEFFECTIVE"
5247          ]
5248        }
5249      }
5250    },
5251    "FirewallPolicyAssociation": {
5252      "id": "FirewallPolicyAssociation",
5253      "type": "object",
5254      "properties": {
5255        "name": {
5256          "description": "The name for an association.",
5257          "type": "string"
5258        },
5259        "attachmentTarget": {
5260          "description": "The target that the firewall policy is attached to.",
5261          "type": "string"
5262        },
5263        "firewallPolicyId": {
5264          "description": "[Output Only] The firewall policy ID of the association.",
5265          "type": "string"
5266        },
5267        "shortName": {
5268          "description": "[Output Only] The short name of the firewall policy of the association.",
5269          "type": "string"
5270        },
5271        "displayName": {
5272          "description": "[Output Only] Deprecated, please use short name instead. The display name of the firewall policy of the association.",
5273          "deprecated": true,
5274          "type": "string"
5275        }
5276      }
5277    },
5278    "FirewallPoliciesListAssociationsResponse": {
5279      "id": "FirewallPoliciesListAssociationsResponse",
5280      "type": "object",
5281      "properties": {
5282        "kind": {
5283          "description": "[Output Only] Type of firewallPolicy associations. Always compute#FirewallPoliciesListAssociations for lists of firewallPolicy associations.",
5284          "default": "compute#firewallPoliciesListAssociationsResponse",
5285          "type": "string"
5286        },
5287        "associations": {
5288          "description": "A list of associations.",
5289          "type": "array",
5290          "items": {
5291            "$ref": "FirewallPolicyAssociation"
5292          }
5293        }
5294      }
5295    },
5296    "GlobalOrganizationSetPolicyRequest": {
5297      "id": "GlobalOrganizationSetPolicyRequest",
5298      "type": "object",
5299      "properties": {
5300        "policy": {
5301          "description": "REQUIRED: The complete policy to be applied to the 'resource'. The size of the policy is limited to a few 10s of KB. An empty policy is in general a valid policy but certain services (like Projects) might reject them.",
5302          "$ref": "Policy"
5303        },
5304        "bindings": {
5305          "description": "Flatten Policy to create a backward compatible wire-format. Deprecated. Use 'policy' to specify bindings.",
5306          "type": "array",
5307          "items": {
5308            "$ref": "Binding"
5309          }
5310        },
5311        "etag": {
5312          "description": "Flatten Policy to create a backward compatible wire-format. Deprecated. Use 'policy' to specify the etag.",
5313          "type": "string",
5314          "format": "byte"
5315        }
5316      }
5317    },
5318    "RegionNetworkFirewallPoliciesGetEffectiveFirewallsResponse": {
5319      "id": "RegionNetworkFirewallPoliciesGetEffectiveFirewallsResponse",
5320      "type": "object",
5321      "properties": {
5322        "firewalls": {
5323          "description": "Effective firewalls on the network.",
5324          "type": "array",
5325          "items": {
5326            "$ref": "Firewall"
5327          }
5328        },
5329        "firewallPolicys": {
5330          "description": "Effective firewalls from firewall policy.",
5331          "type": "array",
5332          "items": {
5333            "$ref": "RegionNetworkFirewallPoliciesGetEffectiveFirewallsResponseEffectiveFirewallPolicy"
5334          }
5335        }
5336      }
5337    },
5338    "RegionNetworkFirewallPoliciesGetEffectiveFirewallsResponseEffectiveFirewallPolicy": {
5339      "id": "RegionNetworkFirewallPoliciesGetEffectiveFirewallsResponseEffectiveFirewallPolicy",
5340      "type": "object",
5341      "properties": {
5342        "name": {
5343          "description": "[Output Only] The name of the firewall policy.",
5344          "type": "string"
5345        },
5346        "type": {
5347          "description": "[Output Only] The type of the firewall policy. Can be one of HIERARCHY, NETWORK, NETWORK_REGIONAL.",
5348          "type": "string",
5349          "enumDescriptions": [
5350            "",
5351            "",
5352            "",
5353            ""
5354          ],
5355          "enum": [
5356            "HIERARCHY",
5357            "NETWORK",
5358            "NETWORK_REGIONAL",
5359            "UNSPECIFIED"
5360          ]
5361        },
5362        "displayName": {
5363          "description": "[Output Only] The display name of the firewall policy.",
5364          "type": "string"
5365        },
5366        "rules": {
5367          "description": "The rules that apply to the network.",
5368          "type": "array",
5369          "items": {
5370            "$ref": "FirewallPolicyRule"
5371          }
5372        }
5373      }
5374    },
5375    "SecurityPolicyList": {
5376      "id": "SecurityPolicyList",
5377      "type": "object",
5378      "properties": {
5379        "kind": {
5380          "description": "[Output Only] Type of resource. Always compute#securityPolicyList for listsof securityPolicies",
5381          "default": "compute#securityPolicyList",
5382          "type": "string"
5383        },
5384        "id": {
5385          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
5386          "type": "string"
5387        },
5388        "items": {
5389          "description": "A list of SecurityPolicy resources.",
5390          "type": "array",
5391          "items": {
5392            "$ref": "SecurityPolicy"
5393          }
5394        },
5395        "nextPageToken": {
5396          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
5397          "type": "string"
5398        },
5399        "warning": {
5400          "description": "[Output Only] Informational warning message.",
5401          "type": "object",
5402          "properties": {
5403            "code": {
5404              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
5405              "type": "string",
5406              "enumDescriptions": [
5407                "Warning about failed cleanup of transient changes made by a failed operation.",
5408                "A link to a deprecated resource was created.",
5409                "When deploying and at least one of the resources has a type marked as deprecated",
5410                "The user created a boot disk that is larger than image size.",
5411                "When deploying and at least one of the resources has a type marked as experimental",
5412                "Warning that is present in an external api call",
5413                "Warning that value of a field has been overridden. Deprecated unused field.",
5414                "The operation involved use of an injected kernel, which is deprecated.",
5415                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
5416                "When deploying a deployment with a exceedingly large number of resources",
5417                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
5418                "A resource depends on a missing type",
5419                "The route's nextHopIp address is not assigned to an instance on the network.",
5420                "The route's next hop instance cannot ip forward.",
5421                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
5422                "The route's nextHopInstance URL refers to an instance that does not exist.",
5423                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
5424                "The route's next hop instance does not have a status of RUNNING.",
5425                "Error which is not critical. We decided to continue the process despite the mentioned error.",
5426                "No results are present on a particular list page.",
5427                "Success is reported, but some results may be missing due to errors",
5428                "The user attempted to use a resource that requires a TOS they have not accepted.",
5429                "Warning that a resource is in use.",
5430                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
5431                "When a resource schema validation is ignored.",
5432                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
5433                "When undeclared properties in the schema are present",
5434                "A given scope cannot be reached."
5435              ],
5436              "enumDeprecated": [
5437                false,
5438                false,
5439                false,
5440                false,
5441                false,
5442                false,
5443                true,
5444                false,
5445                false,
5446                false,
5447                false,
5448                false,
5449                false,
5450                false,
5451                false,
5452                false,
5453                false,
5454                false,
5455                false,
5456                false,
5457                false,
5458                false,
5459                false,
5460                false,
5461                false,
5462                false,
5463                false,
5464                false
5465              ],
5466              "enum": [
5467                "CLEANUP_FAILED",
5468                "DEPRECATED_RESOURCE_USED",
5469                "DEPRECATED_TYPE_USED",
5470                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
5471                "EXPERIMENTAL_TYPE_USED",
5472                "EXTERNAL_API_WARNING",
5473                "FIELD_VALUE_OVERRIDEN",
5474                "INJECTED_KERNELS_DEPRECATED",
5475                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
5476                "LARGE_DEPLOYMENT_WARNING",
5477                "LIST_OVERHEAD_QUOTA_EXCEED",
5478                "MISSING_TYPE_DEPENDENCY",
5479                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
5480                "NEXT_HOP_CANNOT_IP_FORWARD",
5481                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
5482                "NEXT_HOP_INSTANCE_NOT_FOUND",
5483                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
5484                "NEXT_HOP_NOT_RUNNING",
5485                "NOT_CRITICAL_ERROR",
5486                "NO_RESULTS_ON_PAGE",
5487                "PARTIAL_SUCCESS",
5488                "REQUIRED_TOS_AGREEMENT",
5489                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
5490                "RESOURCE_NOT_DELETED",
5491                "SCHEMA_VALIDATION_IGNORED",
5492                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
5493                "UNDECLARED_PROPERTIES",
5494                "UNREACHABLE"
5495              ]
5496            },
5497            "message": {
5498              "description": "[Output Only] A human-readable description of the warning code.",
5499              "type": "string"
5500            },
5501            "data": {
5502              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
5503              "type": "array",
5504              "items": {
5505                "type": "object",
5506                "properties": {
5507                  "key": {
5508                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
5509                    "type": "string"
5510                  },
5511                  "value": {
5512                    "description": "[Output Only] A warning data value corresponding to the key.",
5513                    "type": "string"
5514                  }
5515                }
5516              }
5517            }
5518          }
5519        }
5520      }
5521    },
5522    "SecurityPolicy": {
5523      "id": "SecurityPolicy",
5524      "description": "Represents a Google Cloud Armor security policy resource. Only external backend services that use load balancers can reference a security policy. For more information, see Google Cloud Armor security policy overview.",
5525      "type": "object",
5526      "properties": {
5527        "userDefinedFields": {
5528          "description": "Definitions of user-defined fields for CLOUD_ARMOR_NETWORK policies. A user-defined field consists of up to 4 bytes extracted from a fixed offset in the packet, relative to the IPv4, IPv6, TCP, or UDP header, with an optional mask to select certain bits. Rules may then specify matching values for these fields. Example: userDefinedFields: - name: \"ipv4_fragment_offset\" base: IPV4 offset: 6 size: 2 mask: \"0x1fff\"",
5529          "type": "array",
5530          "items": {
5531            "$ref": "SecurityPolicyUserDefinedField"
5532          }
5533        },
5534        "kind": {
5535          "description": "[Output only] Type of the resource. Always compute#securityPolicyfor security policies",
5536          "default": "compute#securityPolicy",
5537          "type": "string"
5538        },
5539        "id": {
5540          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
5541          "type": "string",
5542          "format": "uint64"
5543        },
5544        "creationTimestamp": {
5545          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
5546          "type": "string"
5547        },
5548        "name": {
5549          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
5550          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
5551          "type": "string"
5552        },
5553        "description": {
5554          "description": "An optional description of this resource. Provide this property when you create the resource.",
5555          "type": "string"
5556        },
5557        "rules": {
5558          "description": "A list of rules that belong to this policy. There must always be a default rule which is a rule with priority 2147483647 and match all condition (for the match condition this means match \"*\" for srcIpRanges and for the networkMatch condition every field must be either match \"*\" or not set). If no rules are provided when creating a security policy, a default rule with action \"allow\" will be added.",
5559          "type": "array",
5560          "items": {
5561            "$ref": "SecurityPolicyRule"
5562          }
5563        },
5564        "adaptiveProtectionConfig": {
5565          "$ref": "SecurityPolicyAdaptiveProtectionConfig"
5566        },
5567        "ddosProtectionConfig": {
5568          "$ref": "SecurityPolicyDdosProtectionConfig"
5569        },
5570        "advancedOptionsConfig": {
5571          "$ref": "SecurityPolicyAdvancedOptionsConfig"
5572        },
5573        "recaptchaOptionsConfig": {
5574          "$ref": "SecurityPolicyRecaptchaOptionsConfig"
5575        },
5576        "fingerprint": {
5577          "description": "Specifies a fingerprint for this resource, which is essentially a hash of the metadata's contents and used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update metadata. You must always provide an up-to-date fingerprint hash in order to update or change metadata, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make get() request to the security policy.",
5578          "type": "string",
5579          "format": "byte"
5580        },
5581        "selfLink": {
5582          "description": "[Output Only] Server-defined URL for the resource.",
5583          "type": "string"
5584        },
5585        "type": {
5586          "description": "The type indicates the intended use of the security policy. - CLOUD_ARMOR: Cloud Armor backend security policies can be configured to filter incoming HTTP requests targeting backend services. They filter requests before they hit the origin servers. - CLOUD_ARMOR_EDGE: Cloud Armor edge security policies can be configured to filter incoming HTTP requests targeting backend services (including Cloud CDN-enabled) as well as backend buckets (Cloud Storage). They filter requests before the request is served from Google's cache. - CLOUD_ARMOR_INTERNAL_SERVICE: Cloud Armor internal service policies can be configured to filter HTTP requests targeting services managed by Traffic Director in a service mesh. They filter requests before the request is served from the application. - CLOUD_ARMOR_NETWORK: Cloud Armor network policies can be configured to filter packets targeting network load balancing resources such as backend services, target pools, target instances, and instances with external IPs. They filter requests before the request is served from the application. This field can be set only at resource creation time.",
5587          "type": "string",
5588          "enumDescriptions": [
5589            "",
5590            "",
5591            ""
5592          ],
5593          "enum": [
5594            "CLOUD_ARMOR",
5595            "CLOUD_ARMOR_EDGE",
5596            "CLOUD_ARMOR_NETWORK"
5597          ]
5598        },
5599        "labels": {
5600          "description": "Labels for this resource. These can only be added or modified by the setLabels method. Each label key/value pair must comply with RFC1035. Label values may be empty.",
5601          "type": "object",
5602          "additionalProperties": {
5603            "type": "string"
5604          }
5605        },
5606        "labelFingerprint": {
5607          "description": "A fingerprint for the labels being applied to this security policy, which is essentially a hash of the labels set used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels. To see the latest fingerprint, make get() request to the security policy.",
5608          "type": "string",
5609          "format": "byte"
5610        },
5611        "region": {
5612          "description": "[Output Only] URL of the region where the regional security policy resides. This field is not applicable to global security policies.",
5613          "type": "string"
5614        }
5615      }
5616    },
5617    "SecurityPolicyUserDefinedField": {
5618      "id": "SecurityPolicyUserDefinedField",
5619      "type": "object",
5620      "properties": {
5621        "name": {
5622          "description": "The name of this field. Must be unique within the policy.",
5623          "type": "string"
5624        },
5625        "base": {
5626          "description": "The base relative to which 'offset' is measured. Possible values are: - IPV4: Points to the beginning of the IPv4 header. - IPV6: Points to the beginning of the IPv6 header. - TCP: Points to the beginning of the TCP header, skipping over any IPv4 options or IPv6 extension headers. Not present for non-first fragments. - UDP: Points to the beginning of the UDP header, skipping over any IPv4 options or IPv6 extension headers. Not present for non-first fragments. required",
5627          "type": "string",
5628          "enumDescriptions": [
5629            "",
5630            "",
5631            "",
5632            ""
5633          ],
5634          "enum": [
5635            "IPV4",
5636            "IPV6",
5637            "TCP",
5638            "UDP"
5639          ]
5640        },
5641        "offset": {
5642          "description": "Offset of the first byte of the field (in network byte order) relative to 'base'.",
5643          "type": "integer",
5644          "format": "int32"
5645        },
5646        "size": {
5647          "description": "Size of the field in bytes. Valid values: 1-4.",
5648          "type": "integer",
5649          "format": "int32"
5650        },
5651        "mask": {
5652          "description": "If specified, apply this mask (bitwise AND) to the field to ignore bits before matching. Encoded as a hexadecimal number (starting with \"0x\"). The last byte of the field (in network byte order) corresponds to the least significant byte of the mask.",
5653          "type": "string"
5654        }
5655      }
5656    },
5657    "SecurityPolicyRule": {
5658      "id": "SecurityPolicyRule",
5659      "description": "Represents a rule that describes one or more match conditions along with the action to be taken when traffic matches this condition (allow or deny).",
5660      "type": "object",
5661      "properties": {
5662        "kind": {
5663          "description": "[Output only] Type of the resource. Always compute#securityPolicyRule for security policy rules",
5664          "default": "compute#securityPolicyRule",
5665          "type": "string"
5666        },
5667        "description": {
5668          "description": "An optional description of this resource. Provide this property when you create the resource.",
5669          "type": "string"
5670        },
5671        "priority": {
5672          "description": "An integer indicating the priority of a rule in the list. The priority must be a positive value between 0 and 2147483647. Rules are evaluated from highest to lowest priority where 0 is the highest priority and 2147483647 is the lowest priority.",
5673          "type": "integer",
5674          "format": "int32"
5675        },
5676        "match": {
5677          "description": "A match condition that incoming traffic is evaluated against. If it evaluates to true, the corresponding 'action' is enforced.",
5678          "$ref": "SecurityPolicyRuleMatcher"
5679        },
5680        "networkMatch": {
5681          "description": "A match condition that incoming packets are evaluated against for CLOUD_ARMOR_NETWORK security policies. If it matches, the corresponding 'action' is enforced. The match criteria for a rule consists of built-in match fields (like 'srcIpRanges') and potentially multiple user-defined match fields ('userDefinedFields'). Field values may be extracted directly from the packet or derived from it (e.g. 'srcRegionCodes'). Some fields may not be present in every packet (e.g. 'srcPorts'). A user-defined field is only present if the base header is found in the packet and the entire field is in bounds. Each match field may specify which values can match it, listing one or more ranges, prefixes, or exact values that are considered a match for the field. A field value must be present in order to match a specified match field. If no match values are specified for a match field, then any field value is considered to match it, and it's not required to be present. For strings specifying '*' is also equivalent to match all. For a packet to match a rule, all specified match fields must match the corresponding field values derived from the packet. Example: networkMatch: srcIpRanges: - \"192.0.2.0/24\" - \"198.51.100.0/24\" userDefinedFields: - name: \"ipv4_fragment_offset\" values: - \"1-0x1fff\" The above match condition matches packets with a source IP in 192.0.2.0/24 or 198.51.100.0/24 and a user-defined field named \"ipv4_fragment_offset\" with a value between 1 and 0x1fff inclusive.",
5682          "$ref": "SecurityPolicyRuleNetworkMatcher"
5683        },
5684        "action": {
5685          "description": "The Action to perform when the rule is matched. The following are the valid actions: - allow: allow access to target. - deny(STATUS): deny access to target, returns the HTTP response code specified. Valid values for `STATUS` are 403, 404, and 502. - rate_based_ban: limit client traffic to the configured threshold and ban the client if the traffic exceeds the threshold. Configure parameters for this action in RateLimitOptions. Requires rate_limit_options to be set. - redirect: redirect to a different target. This can either be an internal reCAPTCHA redirect, or an external URL-based redirect via a 302 response. Parameters for this action can be configured via redirectOptions. This action is only supported in Global Security Policies of type CLOUD_ARMOR. - throttle: limit client traffic to the configured threshold. Configure parameters for this action in rateLimitOptions. Requires rate_limit_options to be set for this. ",
5686          "type": "string"
5687        },
5688        "preview": {
5689          "description": "If set to true, the specified action is not enforced.",
5690          "type": "boolean"
5691        },
5692        "rateLimitOptions": {
5693          "description": "Must be specified if the action is \"rate_based_ban\" or \"throttle\". Cannot be specified for any other actions.",
5694          "$ref": "SecurityPolicyRuleRateLimitOptions"
5695        },
5696        "headerAction": {
5697          "description": "Optional, additional actions that are performed on headers. This field is only supported in Global Security Policies of type CLOUD_ARMOR.",
5698          "$ref": "SecurityPolicyRuleHttpHeaderAction"
5699        },
5700        "redirectOptions": {
5701          "description": "Parameters defining the redirect action. Cannot be specified for any other actions. This field is only supported in Global Security Policies of type CLOUD_ARMOR.",
5702          "$ref": "SecurityPolicyRuleRedirectOptions"
5703        },
5704        "preconfiguredWafConfig": {
5705          "description": "Preconfigured WAF configuration to be applied for the rule. If the rule does not evaluate preconfigured WAF rules, i.e., if evaluatePreconfiguredWaf() is not used, this field will have no effect.",
5706          "$ref": "SecurityPolicyRulePreconfiguredWafConfig"
5707        }
5708      }
5709    },
5710    "SecurityPolicyRuleMatcher": {
5711      "id": "SecurityPolicyRuleMatcher",
5712      "description": "Represents a match condition that incoming traffic is evaluated against. Exactly one field must be specified.",
5713      "type": "object",
5714      "properties": {
5715        "expr": {
5716          "description": "User defined CEVAL expression. A CEVAL expression is used to specify match criteria such as origin.ip, source.region_code and contents in the request header. Expressions containing `evaluateThreatIntelligence` require Cloud Armor Managed Protection Plus tier and are not supported in Edge Policies nor in Regional Policies. Expressions containing `evaluatePreconfiguredExpr('sourceiplist-*')` require Cloud Armor Managed Protection Plus tier and are only supported in Global Security Policies.",
5717          "$ref": "Expr"
5718        },
5719        "exprOptions": {
5720          "description": "The configuration options available when specifying a user defined CEVAL expression (i.e., 'expr').",
5721          "$ref": "SecurityPolicyRuleMatcherExprOptions"
5722        },
5723        "versionedExpr": {
5724          "description": "Preconfigured versioned expression. If this field is specified, config must also be specified. Available preconfigured expressions along with their requirements are: SRC_IPS_V1 - must specify the corresponding src_ip_range field in config.",
5725          "type": "string",
5726          "enumDescriptions": [
5727            "Matches the source IP address of a request to the IP ranges supplied in config."
5728          ],
5729          "enum": [
5730            "SRC_IPS_V1"
5731          ]
5732        },
5733        "config": {
5734          "description": "The configuration options available when specifying versioned_expr. This field must be specified if versioned_expr is specified and cannot be specified if versioned_expr is not specified.",
5735          "$ref": "SecurityPolicyRuleMatcherConfig"
5736        }
5737      }
5738    },
5739    "SecurityPolicyRuleMatcherExprOptions": {
5740      "id": "SecurityPolicyRuleMatcherExprOptions",
5741      "type": "object",
5742      "properties": {
5743        "recaptchaOptions": {
5744          "description": "reCAPTCHA configuration options to be applied for the rule. If the rule does not evaluate reCAPTCHA tokens, this field has no effect.",
5745          "$ref": "SecurityPolicyRuleMatcherExprOptionsRecaptchaOptions"
5746        }
5747      }
5748    },
5749    "SecurityPolicyRuleMatcherExprOptionsRecaptchaOptions": {
5750      "id": "SecurityPolicyRuleMatcherExprOptionsRecaptchaOptions",
5751      "type": "object",
5752      "properties": {
5753        "actionTokenSiteKeys": {
5754          "description": "A list of site keys to be used during the validation of reCAPTCHA action-tokens. The provided site keys need to be created from reCAPTCHA API under the same project where the security policy is created.",
5755          "type": "array",
5756          "items": {
5757            "type": "string"
5758          }
5759        },
5760        "sessionTokenSiteKeys": {
5761          "description": "A list of site keys to be used during the validation of reCAPTCHA session-tokens. The provided site keys need to be created from reCAPTCHA API under the same project where the security policy is created.",
5762          "type": "array",
5763          "items": {
5764            "type": "string"
5765          }
5766        }
5767      }
5768    },
5769    "SecurityPolicyRuleMatcherConfig": {
5770      "id": "SecurityPolicyRuleMatcherConfig",
5771      "type": "object",
5772      "properties": {
5773        "srcIpRanges": {
5774          "description": "CIDR IP address range. Maximum number of src_ip_ranges allowed is 10.",
5775          "type": "array",
5776          "items": {
5777            "type": "string"
5778          }
5779        }
5780      }
5781    },
5782    "SecurityPolicyRuleNetworkMatcher": {
5783      "id": "SecurityPolicyRuleNetworkMatcher",
5784      "description": "Represents a match condition that incoming network traffic is evaluated against.",
5785      "type": "object",
5786      "properties": {
5787        "userDefinedFields": {
5788          "description": "User-defined fields. Each element names a defined field and lists the matching values for that field.",
5789          "type": "array",
5790          "items": {
5791            "$ref": "SecurityPolicyRuleNetworkMatcherUserDefinedFieldMatch"
5792          }
5793        },
5794        "srcIpRanges": {
5795          "description": "Source IPv4/IPv6 addresses or CIDR prefixes, in standard text format.",
5796          "type": "array",
5797          "items": {
5798            "type": "string"
5799          }
5800        },
5801        "destIpRanges": {
5802          "description": "Destination IPv4/IPv6 addresses or CIDR prefixes, in standard text format.",
5803          "type": "array",
5804          "items": {
5805            "type": "string"
5806          }
5807        },
5808        "ipProtocols": {
5809          "description": "IPv4 protocol / IPv6 next header (after extension headers). Each element can be an 8-bit unsigned decimal number (e.g. \"6\"), range (e.g. \"253-254\"), or one of the following protocol names: \"tcp\", \"udp\", \"icmp\", \"esp\", \"ah\", \"ipip\", or \"sctp\".",
5810          "type": "array",
5811          "items": {
5812            "type": "string"
5813          }
5814        },
5815        "srcPorts": {
5816          "description": "Source port numbers for TCP/UDP/SCTP. Each element can be a 16-bit unsigned decimal number (e.g. \"80\") or range (e.g. \"0-1023\").",
5817          "type": "array",
5818          "items": {
5819            "type": "string"
5820          }
5821        },
5822        "destPorts": {
5823          "description": "Destination port numbers for TCP/UDP/SCTP. Each element can be a 16-bit unsigned decimal number (e.g. \"80\") or range (e.g. \"0-1023\").",
5824          "type": "array",
5825          "items": {
5826            "type": "string"
5827          }
5828        },
5829        "srcRegionCodes": {
5830          "description": "Two-letter ISO 3166-1 alpha-2 country code associated with the source IP address.",
5831          "type": "array",
5832          "items": {
5833            "type": "string"
5834          }
5835        },
5836        "srcAsns": {
5837          "description": "BGP Autonomous System Number associated with the source IP address.",
5838          "type": "array",
5839          "items": {
5840            "type": "integer",
5841            "format": "uint32"
5842          }
5843        }
5844      }
5845    },
5846    "SecurityPolicyRuleNetworkMatcherUserDefinedFieldMatch": {
5847      "id": "SecurityPolicyRuleNetworkMatcherUserDefinedFieldMatch",
5848      "type": "object",
5849      "properties": {
5850        "name": {
5851          "description": "Name of the user-defined field, as given in the definition.",
5852          "type": "string"
5853        },
5854        "values": {
5855          "description": "Matching values of the field. Each element can be a 32-bit unsigned decimal or hexadecimal (starting with \"0x\") number (e.g. \"64\") or range (e.g. \"0x400-0x7ff\").",
5856          "type": "array",
5857          "items": {
5858            "type": "string"
5859          }
5860        }
5861      }
5862    },
5863    "SecurityPolicyRuleRateLimitOptions": {
5864      "id": "SecurityPolicyRuleRateLimitOptions",
5865      "type": "object",
5866      "properties": {
5867        "rateLimitThreshold": {
5868          "description": "Threshold at which to begin ratelimiting.",
5869          "$ref": "SecurityPolicyRuleRateLimitOptionsThreshold"
5870        },
5871        "conformAction": {
5872          "description": "Action to take for requests that are under the configured rate limit threshold. Valid option is \"allow\" only.",
5873          "type": "string"
5874        },
5875        "exceedAction": {
5876          "description": "Action to take for requests that are above the configured rate limit threshold, to either deny with a specified HTTP response code, or redirect to a different endpoint. Valid options are `deny(STATUS)`, where valid values for `STATUS` are 403, 404, 429, and 502, and `redirect`, where the redirect parameters come from `exceedRedirectOptions` below. The `redirect` action is only supported in Global Security Policies of type CLOUD_ARMOR.",
5877          "type": "string"
5878        },
5879        "exceedRedirectOptions": {
5880          "description": "Parameters defining the redirect action that is used as the exceed action. Cannot be specified if the exceed action is not redirect. This field is only supported in Global Security Policies of type CLOUD_ARMOR.",
5881          "$ref": "SecurityPolicyRuleRedirectOptions"
5882        },
5883        "enforceOnKey": {
5884          "description": "Determines the key to enforce the rate_limit_threshold on. Possible values are: - ALL: A single rate limit threshold is applied to all the requests matching this rule. This is the default value if \"enforceOnKey\" is not configured. - IP: The source IP address of the request is the key. Each IP has this limit enforced separately. - HTTP_HEADER: The value of the HTTP header whose name is configured under \"enforceOnKeyName\". The key value is truncated to the first 128 bytes of the header value. If no such header is present in the request, the key type defaults to ALL. - XFF_IP: The first IP address (i.e. the originating client IP address) specified in the list of IPs under X-Forwarded-For HTTP header. If no such header is present or the value is not a valid IP, the key defaults to the source IP address of the request i.e. key type IP. - HTTP_COOKIE: The value of the HTTP cookie whose name is configured under \"enforceOnKeyName\". The key value is truncated to the first 128 bytes of the cookie value. If no such cookie is present in the request, the key type defaults to ALL. - HTTP_PATH: The URL path of the HTTP request. The key value is truncated to the first 128 bytes. - SNI: Server name indication in the TLS session of the HTTPS request. The key value is truncated to the first 128 bytes. The key type defaults to ALL on a HTTP session. - REGION_CODE: The country/region from which the request originates. - TLS_JA3_FINGERPRINT: JA3 TLS/SSL fingerprint if the client connects using HTTPS, HTTP/2 or HTTP/3. If not available, the key type defaults to ALL. - USER_IP: The IP address of the originating client, which is resolved based on \"userIpRequestHeaders\" configured with the security policy. If there is no \"userIpRequestHeaders\" configuration or an IP address cannot be resolved from it, the key type defaults to IP. ",
5885          "type": "string",
5886          "enumDescriptions": [
5887            "",
5888            "",
5889            "",
5890            "",
5891            "",
5892            "",
5893            "",
5894            "",
5895            "",
5896            ""
5897          ],
5898          "enum": [
5899            "ALL",
5900            "HTTP_COOKIE",
5901            "HTTP_HEADER",
5902            "HTTP_PATH",
5903            "IP",
5904            "REGION_CODE",
5905            "SNI",
5906            "TLS_JA3_FINGERPRINT",
5907            "USER_IP",
5908            "XFF_IP"
5909          ]
5910        },
5911        "enforceOnKeyName": {
5912          "description": "Rate limit key name applicable only for the following key types: HTTP_HEADER -- Name of the HTTP header whose value is taken as the key value. HTTP_COOKIE -- Name of the HTTP cookie whose value is taken as the key value.",
5913          "type": "string"
5914        },
5915        "enforceOnKeyConfigs": {
5916          "description": "If specified, any combination of values of enforce_on_key_type/enforce_on_key_name is treated as the key on which ratelimit threshold/action is enforced. You can specify up to 3 enforce_on_key_configs. If enforce_on_key_configs is specified, enforce_on_key must not be specified.",
5917          "type": "array",
5918          "items": {
5919            "$ref": "SecurityPolicyRuleRateLimitOptionsEnforceOnKeyConfig"
5920          }
5921        },
5922        "banThreshold": {
5923          "description": "Can only be specified if the action for the rule is \"rate_based_ban\". If specified, the key will be banned for the configured 'ban_duration_sec' when the number of requests that exceed the 'rate_limit_threshold' also exceed this 'ban_threshold'.",
5924          "$ref": "SecurityPolicyRuleRateLimitOptionsThreshold"
5925        },
5926        "banDurationSec": {
5927          "description": "Can only be specified if the action for the rule is \"rate_based_ban\". If specified, determines the time (in seconds) the traffic will continue to be banned by the rate limit after the rate falls below the threshold.",
5928          "type": "integer",
5929          "format": "int32"
5930        }
5931      }
5932    },
5933    "SecurityPolicyRuleRateLimitOptionsThreshold": {
5934      "id": "SecurityPolicyRuleRateLimitOptionsThreshold",
5935      "type": "object",
5936      "properties": {
5937        "count": {
5938          "description": "Number of HTTP(S) requests for calculating the threshold.",
5939          "type": "integer",
5940          "format": "int32"
5941        },
5942        "intervalSec": {
5943          "description": "Interval over which the threshold is computed.",
5944          "type": "integer",
5945          "format": "int32"
5946        }
5947      }
5948    },
5949    "SecurityPolicyRuleRedirectOptions": {
5950      "id": "SecurityPolicyRuleRedirectOptions",
5951      "type": "object",
5952      "properties": {
5953        "type": {
5954          "description": "Type of the redirect action.",
5955          "type": "string",
5956          "enumDescriptions": [
5957            "",
5958            ""
5959          ],
5960          "enum": [
5961            "EXTERNAL_302",
5962            "GOOGLE_RECAPTCHA"
5963          ]
5964        },
5965        "target": {
5966          "description": "Target for the redirect action. This is required if the type is EXTERNAL_302 and cannot be specified for GOOGLE_RECAPTCHA.",
5967          "type": "string"
5968        }
5969      }
5970    },
5971    "SecurityPolicyRuleRateLimitOptionsEnforceOnKeyConfig": {
5972      "id": "SecurityPolicyRuleRateLimitOptionsEnforceOnKeyConfig",
5973      "type": "object",
5974      "properties": {
5975        "enforceOnKeyType": {
5976          "description": "Determines the key to enforce the rate_limit_threshold on. Possible values are: - ALL: A single rate limit threshold is applied to all the requests matching this rule. This is the default value if \"enforceOnKeyConfigs\" is not configured. - IP: The source IP address of the request is the key. Each IP has this limit enforced separately. - HTTP_HEADER: The value of the HTTP header whose name is configured under \"enforceOnKeyName\". The key value is truncated to the first 128 bytes of the header value. If no such header is present in the request, the key type defaults to ALL. - XFF_IP: The first IP address (i.e. the originating client IP address) specified in the list of IPs under X-Forwarded-For HTTP header. If no such header is present or the value is not a valid IP, the key defaults to the source IP address of the request i.e. key type IP. - HTTP_COOKIE: The value of the HTTP cookie whose name is configured under \"enforceOnKeyName\". The key value is truncated to the first 128 bytes of the cookie value. If no such cookie is present in the request, the key type defaults to ALL. - HTTP_PATH: The URL path of the HTTP request. The key value is truncated to the first 128 bytes. - SNI: Server name indication in the TLS session of the HTTPS request. The key value is truncated to the first 128 bytes. The key type defaults to ALL on a HTTP session. - REGION_CODE: The country/region from which the request originates. - TLS_JA3_FINGERPRINT: JA3 TLS/SSL fingerprint if the client connects using HTTPS, HTTP/2 or HTTP/3. If not available, the key type defaults to ALL. - USER_IP: The IP address of the originating client, which is resolved based on \"userIpRequestHeaders\" configured with the security policy. If there is no \"userIpRequestHeaders\" configuration or an IP address cannot be resolved from it, the key type defaults to IP. ",
5977          "type": "string",
5978          "enumDescriptions": [
5979            "",
5980            "",
5981            "",
5982            "",
5983            "",
5984            "",
5985            "",
5986            "",
5987            "",
5988            ""
5989          ],
5990          "enum": [
5991            "ALL",
5992            "HTTP_COOKIE",
5993            "HTTP_HEADER",
5994            "HTTP_PATH",
5995            "IP",
5996            "REGION_CODE",
5997            "SNI",
5998            "TLS_JA3_FINGERPRINT",
5999            "USER_IP",
6000            "XFF_IP"
6001          ]
6002        },
6003        "enforceOnKeyName": {
6004          "description": "Rate limit key name applicable only for the following key types: HTTP_HEADER -- Name of the HTTP header whose value is taken as the key value. HTTP_COOKIE -- Name of the HTTP cookie whose value is taken as the key value.",
6005          "type": "string"
6006        }
6007      }
6008    },
6009    "SecurityPolicyRuleHttpHeaderAction": {
6010      "id": "SecurityPolicyRuleHttpHeaderAction",
6011      "type": "object",
6012      "properties": {
6013        "requestHeadersToAdds": {
6014          "description": "The list of request headers to add or overwrite if they're already present.",
6015          "type": "array",
6016          "items": {
6017            "$ref": "SecurityPolicyRuleHttpHeaderActionHttpHeaderOption"
6018          }
6019        }
6020      }
6021    },
6022    "SecurityPolicyRuleHttpHeaderActionHttpHeaderOption": {
6023      "id": "SecurityPolicyRuleHttpHeaderActionHttpHeaderOption",
6024      "type": "object",
6025      "properties": {
6026        "headerName": {
6027          "description": "The name of the header to set.",
6028          "type": "string"
6029        },
6030        "headerValue": {
6031          "description": "The value to set the named header to.",
6032          "type": "string"
6033        }
6034      }
6035    },
6036    "SecurityPolicyRulePreconfiguredWafConfig": {
6037      "id": "SecurityPolicyRulePreconfiguredWafConfig",
6038      "type": "object",
6039      "properties": {
6040        "exclusions": {
6041          "description": "A list of exclusions to apply during preconfigured WAF evaluation.",
6042          "type": "array",
6043          "items": {
6044            "$ref": "SecurityPolicyRulePreconfiguredWafConfigExclusion"
6045          }
6046        }
6047      }
6048    },
6049    "SecurityPolicyRulePreconfiguredWafConfigExclusion": {
6050      "id": "SecurityPolicyRulePreconfiguredWafConfigExclusion",
6051      "type": "object",
6052      "properties": {
6053        "targetRuleSet": {
6054          "description": "Target WAF rule set to apply the preconfigured WAF exclusion.",
6055          "type": "string"
6056        },
6057        "targetRuleIds": {
6058          "description": "A list of target rule IDs under the WAF rule set to apply the preconfigured WAF exclusion. If omitted, it refers to all the rule IDs under the WAF rule set.",
6059          "type": "array",
6060          "items": {
6061            "type": "string"
6062          }
6063        },
6064        "requestHeadersToExclude": {
6065          "description": "A list of request header names whose value will be excluded from inspection during preconfigured WAF evaluation.",
6066          "type": "array",
6067          "items": {
6068            "$ref": "SecurityPolicyRulePreconfiguredWafConfigExclusionFieldParams"
6069          }
6070        },
6071        "requestCookiesToExclude": {
6072          "description": "A list of request cookie names whose value will be excluded from inspection during preconfigured WAF evaluation.",
6073          "type": "array",
6074          "items": {
6075            "$ref": "SecurityPolicyRulePreconfiguredWafConfigExclusionFieldParams"
6076          }
6077        },
6078        "requestQueryParamsToExclude": {
6079          "description": "A list of request query parameter names whose value will be excluded from inspection during preconfigured WAF evaluation. Note that the parameter can be in the query string or in the POST body.",
6080          "type": "array",
6081          "items": {
6082            "$ref": "SecurityPolicyRulePreconfiguredWafConfigExclusionFieldParams"
6083          }
6084        },
6085        "requestUrisToExclude": {
6086          "description": "A list of request URIs from the request line to be excluded from inspection during preconfigured WAF evaluation. When specifying this field, the query or fragment part should be excluded.",
6087          "type": "array",
6088          "items": {
6089            "$ref": "SecurityPolicyRulePreconfiguredWafConfigExclusionFieldParams"
6090          }
6091        }
6092      }
6093    },
6094    "SecurityPolicyRulePreconfiguredWafConfigExclusionFieldParams": {
6095      "id": "SecurityPolicyRulePreconfiguredWafConfigExclusionFieldParams",
6096      "type": "object",
6097      "properties": {
6098        "val": {
6099          "description": "The value of the field.",
6100          "type": "string"
6101        },
6102        "op": {
6103          "description": "The match operator for the field.",
6104          "type": "string",
6105          "enumDescriptions": [
6106            "The operator matches if the field value contains the specified value.",
6107            "The operator matches if the field value ends with the specified value.",
6108            "The operator matches if the field value equals the specified value.",
6109            "The operator matches if the field value is any value.",
6110            "The operator matches if the field value starts with the specified value."
6111          ],
6112          "enum": [
6113            "CONTAINS",
6114            "ENDS_WITH",
6115            "EQUALS",
6116            "EQUALS_ANY",
6117            "STARTS_WITH"
6118          ]
6119        }
6120      }
6121    },
6122    "SecurityPolicyAdaptiveProtectionConfig": {
6123      "id": "SecurityPolicyAdaptiveProtectionConfig",
6124      "description": "Configuration options for Cloud Armor Adaptive Protection (CAAP).",
6125      "type": "object",
6126      "properties": {
6127        "layer7DdosDefenseConfig": {
6128          "description": "If set to true, enables Cloud Armor Machine Learning.",
6129          "$ref": "SecurityPolicyAdaptiveProtectionConfigLayer7DdosDefenseConfig"
6130        }
6131      }
6132    },
6133    "SecurityPolicyAdaptiveProtectionConfigLayer7DdosDefenseConfig": {
6134      "id": "SecurityPolicyAdaptiveProtectionConfigLayer7DdosDefenseConfig",
6135      "description": "Configuration options for L7 DDoS detection. This field is only supported in Global Security Policies of type CLOUD_ARMOR.",
6136      "type": "object",
6137      "properties": {
6138        "enable": {
6139          "description": "If set to true, enables CAAP for L7 DDoS detection. This field is only supported in Global Security Policies of type CLOUD_ARMOR.",
6140          "type": "boolean"
6141        },
6142        "ruleVisibility": {
6143          "description": "Rule visibility can be one of the following: STANDARD - opaque rules. (default) PREMIUM - transparent rules. This field is only supported in Global Security Policies of type CLOUD_ARMOR.",
6144          "type": "string",
6145          "enumDescriptions": [
6146            "",
6147            ""
6148          ],
6149          "enum": [
6150            "PREMIUM",
6151            "STANDARD"
6152          ]
6153        },
6154        "thresholdConfigs": {
6155          "description": "Configuration options for layer7 adaptive protection for various customizable thresholds.",
6156          "type": "array",
6157          "items": {
6158            "$ref": "SecurityPolicyAdaptiveProtectionConfigLayer7DdosDefenseConfigThresholdConfig"
6159          }
6160        }
6161      }
6162    },
6163    "SecurityPolicyAdaptiveProtectionConfigLayer7DdosDefenseConfigThresholdConfig": {
6164      "id": "SecurityPolicyAdaptiveProtectionConfigLayer7DdosDefenseConfigThresholdConfig",
6165      "type": "object",
6166      "properties": {
6167        "name": {
6168          "description": "The name must be 1-63 characters long, and comply with RFC1035. The name must be unique within the security policy.",
6169          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
6170          "type": "string"
6171        },
6172        "autoDeployLoadThreshold": {
6173          "type": "number",
6174          "format": "float"
6175        },
6176        "autoDeployConfidenceThreshold": {
6177          "type": "number",
6178          "format": "float"
6179        },
6180        "autoDeployImpactedBaselineThreshold": {
6181          "type": "number",
6182          "format": "float"
6183        },
6184        "autoDeployExpirationSec": {
6185          "type": "integer",
6186          "format": "int32"
6187        }
6188      }
6189    },
6190    "SecurityPolicyDdosProtectionConfig": {
6191      "id": "SecurityPolicyDdosProtectionConfig",
6192      "type": "object",
6193      "properties": {
6194        "ddosProtection": {
6195          "type": "string",
6196          "enumDescriptions": [
6197            "",
6198            ""
6199          ],
6200          "enum": [
6201            "ADVANCED",
6202            "STANDARD"
6203          ]
6204        }
6205      }
6206    },
6207    "SecurityPolicyAdvancedOptionsConfig": {
6208      "id": "SecurityPolicyAdvancedOptionsConfig",
6209      "type": "object",
6210      "properties": {
6211        "jsonParsing": {
6212          "type": "string",
6213          "enumDescriptions": [
6214            "",
6215            "",
6216            ""
6217          ],
6218          "enum": [
6219            "DISABLED",
6220            "STANDARD",
6221            "STANDARD_WITH_GRAPHQL"
6222          ]
6223        },
6224        "jsonCustomConfig": {
6225          "description": "Custom configuration to apply the JSON parsing. Only applicable when json_parsing is set to STANDARD.",
6226          "$ref": "SecurityPolicyAdvancedOptionsConfigJsonCustomConfig"
6227        },
6228        "logLevel": {
6229          "type": "string",
6230          "enumDescriptions": [
6231            "",
6232            ""
6233          ],
6234          "enum": [
6235            "NORMAL",
6236            "VERBOSE"
6237          ]
6238        },
6239        "userIpRequestHeaders": {
6240          "description": "An optional list of case-insensitive request header names to use for resolving the callers client IP address.",
6241          "type": "array",
6242          "items": {
6243            "type": "string"
6244          }
6245        }
6246      }
6247    },
6248    "SecurityPolicyAdvancedOptionsConfigJsonCustomConfig": {
6249      "id": "SecurityPolicyAdvancedOptionsConfigJsonCustomConfig",
6250      "type": "object",
6251      "properties": {
6252        "contentTypes": {
6253          "description": "A list of custom Content-Type header values to apply the JSON parsing. As per RFC 1341, a Content-Type header value has the following format: Content-Type := type \"/\" subtype *[\";\" parameter] When configuring a custom Content-Type header value, only the type/subtype needs to be specified, and the parameters should be excluded.",
6254          "type": "array",
6255          "items": {
6256            "type": "string"
6257          }
6258        }
6259      }
6260    },
6261    "SecurityPolicyRecaptchaOptionsConfig": {
6262      "id": "SecurityPolicyRecaptchaOptionsConfig",
6263      "type": "object",
6264      "properties": {
6265        "redirectSiteKey": {
6266          "description": "An optional field to supply a reCAPTCHA site key to be used for all the rules using the redirect action with the type of GOOGLE_RECAPTCHA under the security policy. The specified site key needs to be created from the reCAPTCHA API. The user is responsible for the validity of the specified site key. If not specified, a Google-managed site key is used. This field is only supported in Global Security Policies of type CLOUD_ARMOR.",
6267          "type": "string"
6268        }
6269      }
6270    },
6271    "SecurityPoliciesListPreconfiguredExpressionSetsResponse": {
6272      "id": "SecurityPoliciesListPreconfiguredExpressionSetsResponse",
6273      "type": "object",
6274      "properties": {
6275        "preconfiguredExpressionSets": {
6276          "$ref": "SecurityPoliciesWafConfig"
6277        }
6278      }
6279    },
6280    "SecurityPoliciesWafConfig": {
6281      "id": "SecurityPoliciesWafConfig",
6282      "type": "object",
6283      "properties": {
6284        "wafRules": {
6285          "$ref": "PreconfiguredWafSet"
6286        }
6287      }
6288    },
6289    "PreconfiguredWafSet": {
6290      "id": "PreconfiguredWafSet",
6291      "type": "object",
6292      "properties": {
6293        "expressionSets": {
6294          "description": "List of entities that are currently supported for WAF rules.",
6295          "type": "array",
6296          "items": {
6297            "$ref": "WafExpressionSet"
6298          }
6299        }
6300      }
6301    },
6302    "WafExpressionSet": {
6303      "id": "WafExpressionSet",
6304      "type": "object",
6305      "properties": {
6306        "id": {
6307          "description": "Google specified expression set ID. The format should be: - E.g. XSS-20170329 required",
6308          "type": "string"
6309        },
6310        "aliases": {
6311          "description": "A list of alternate IDs. The format should be: - E.g. XSS-stable Generic suffix like \"stable\" is particularly useful if a policy likes to avail newer set of expressions without having to change the policy. A given alias name can't be used for more than one entity set.",
6312          "type": "array",
6313          "items": {
6314            "type": "string"
6315          }
6316        },
6317        "expressions": {
6318          "description": "List of available expressions.",
6319          "type": "array",
6320          "items": {
6321            "$ref": "WafExpressionSetExpression"
6322          }
6323        }
6324      }
6325    },
6326    "WafExpressionSetExpression": {
6327      "id": "WafExpressionSetExpression",
6328      "type": "object",
6329      "properties": {
6330        "id": {
6331          "description": "Expression ID should uniquely identify the origin of the expression. E.g. owasp-crs-v020901-id973337 identifies Owasp core rule set version 2.9.1 rule id 973337. The ID could be used to determine the individual attack definition that has been detected. It could also be used to exclude it from the policy in case of false positive. required",
6332          "type": "string"
6333        },
6334        "sensitivity": {
6335          "description": "The sensitivity value associated with the WAF rule ID. This corresponds to the ModSecurity paranoia level, ranging from 1 to 4. 0 is reserved for opt-in only rules.",
6336          "type": "integer",
6337          "format": "int32"
6338        }
6339      }
6340    },
6341    "SecurityPoliciesAggregatedList": {
6342      "id": "SecurityPoliciesAggregatedList",
6343      "type": "object",
6344      "properties": {
6345        "kind": {
6346          "description": "[Output Only] Type of resource. Always compute#securityPolicyAggregatedList for lists of Security Policies.",
6347          "default": "compute#securityPoliciesAggregatedList",
6348          "type": "string"
6349        },
6350        "id": {
6351          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
6352          "type": "string"
6353        },
6354        "items": {
6355          "description": "A list of SecurityPoliciesScopedList resources.",
6356          "type": "object",
6357          "additionalProperties": {
6358            "description": "Name of the scope containing this set of security policies.",
6359            "$ref": "SecurityPoliciesScopedList"
6360          }
6361        },
6362        "nextPageToken": {
6363          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
6364          "type": "string"
6365        },
6366        "selfLink": {
6367          "description": "[Output Only] Server-defined URL for this resource.",
6368          "type": "string"
6369        },
6370        "warning": {
6371          "description": "[Output Only] Informational warning message.",
6372          "type": "object",
6373          "properties": {
6374            "code": {
6375              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
6376              "type": "string",
6377              "enumDescriptions": [
6378                "Warning about failed cleanup of transient changes made by a failed operation.",
6379                "A link to a deprecated resource was created.",
6380                "When deploying and at least one of the resources has a type marked as deprecated",
6381                "The user created a boot disk that is larger than image size.",
6382                "When deploying and at least one of the resources has a type marked as experimental",
6383                "Warning that is present in an external api call",
6384                "Warning that value of a field has been overridden. Deprecated unused field.",
6385                "The operation involved use of an injected kernel, which is deprecated.",
6386                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
6387                "When deploying a deployment with a exceedingly large number of resources",
6388                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
6389                "A resource depends on a missing type",
6390                "The route's nextHopIp address is not assigned to an instance on the network.",
6391                "The route's next hop instance cannot ip forward.",
6392                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
6393                "The route's nextHopInstance URL refers to an instance that does not exist.",
6394                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
6395                "The route's next hop instance does not have a status of RUNNING.",
6396                "Error which is not critical. We decided to continue the process despite the mentioned error.",
6397                "No results are present on a particular list page.",
6398                "Success is reported, but some results may be missing due to errors",
6399                "The user attempted to use a resource that requires a TOS they have not accepted.",
6400                "Warning that a resource is in use.",
6401                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
6402                "When a resource schema validation is ignored.",
6403                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
6404                "When undeclared properties in the schema are present",
6405                "A given scope cannot be reached."
6406              ],
6407              "enumDeprecated": [
6408                false,
6409                false,
6410                false,
6411                false,
6412                false,
6413                false,
6414                true,
6415                false,
6416                false,
6417                false,
6418                false,
6419                false,
6420                false,
6421                false,
6422                false,
6423                false,
6424                false,
6425                false,
6426                false,
6427                false,
6428                false,
6429                false,
6430                false,
6431                false,
6432                false,
6433                false,
6434                false,
6435                false
6436              ],
6437              "enum": [
6438                "CLEANUP_FAILED",
6439                "DEPRECATED_RESOURCE_USED",
6440                "DEPRECATED_TYPE_USED",
6441                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
6442                "EXPERIMENTAL_TYPE_USED",
6443                "EXTERNAL_API_WARNING",
6444                "FIELD_VALUE_OVERRIDEN",
6445                "INJECTED_KERNELS_DEPRECATED",
6446                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
6447                "LARGE_DEPLOYMENT_WARNING",
6448                "LIST_OVERHEAD_QUOTA_EXCEED",
6449                "MISSING_TYPE_DEPENDENCY",
6450                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
6451                "NEXT_HOP_CANNOT_IP_FORWARD",
6452                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
6453                "NEXT_HOP_INSTANCE_NOT_FOUND",
6454                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
6455                "NEXT_HOP_NOT_RUNNING",
6456                "NOT_CRITICAL_ERROR",
6457                "NO_RESULTS_ON_PAGE",
6458                "PARTIAL_SUCCESS",
6459                "REQUIRED_TOS_AGREEMENT",
6460                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
6461                "RESOURCE_NOT_DELETED",
6462                "SCHEMA_VALIDATION_IGNORED",
6463                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
6464                "UNDECLARED_PROPERTIES",
6465                "UNREACHABLE"
6466              ]
6467            },
6468            "message": {
6469              "description": "[Output Only] A human-readable description of the warning code.",
6470              "type": "string"
6471            },
6472            "data": {
6473              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
6474              "type": "array",
6475              "items": {
6476                "type": "object",
6477                "properties": {
6478                  "key": {
6479                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
6480                    "type": "string"
6481                  },
6482                  "value": {
6483                    "description": "[Output Only] A warning data value corresponding to the key.",
6484                    "type": "string"
6485                  }
6486                }
6487              }
6488            }
6489          }
6490        },
6491        "etag": {
6492          "type": "string"
6493        },
6494        "unreachables": {
6495          "description": "[Output Only] Unreachable resources.",
6496          "type": "array",
6497          "items": {
6498            "type": "string"
6499          }
6500        }
6501      }
6502    },
6503    "SecurityPoliciesScopedList": {
6504      "id": "SecurityPoliciesScopedList",
6505      "type": "object",
6506      "properties": {
6507        "securityPolicies": {
6508          "description": "A list of SecurityPolicies contained in this scope.",
6509          "type": "array",
6510          "items": {
6511            "$ref": "SecurityPolicy"
6512          }
6513        },
6514        "warning": {
6515          "description": "Informational warning which replaces the list of security policies when the list is empty.",
6516          "type": "object",
6517          "properties": {
6518            "code": {
6519              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
6520              "type": "string",
6521              "enumDescriptions": [
6522                "Warning about failed cleanup of transient changes made by a failed operation.",
6523                "A link to a deprecated resource was created.",
6524                "When deploying and at least one of the resources has a type marked as deprecated",
6525                "The user created a boot disk that is larger than image size.",
6526                "When deploying and at least one of the resources has a type marked as experimental",
6527                "Warning that is present in an external api call",
6528                "Warning that value of a field has been overridden. Deprecated unused field.",
6529                "The operation involved use of an injected kernel, which is deprecated.",
6530                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
6531                "When deploying a deployment with a exceedingly large number of resources",
6532                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
6533                "A resource depends on a missing type",
6534                "The route's nextHopIp address is not assigned to an instance on the network.",
6535                "The route's next hop instance cannot ip forward.",
6536                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
6537                "The route's nextHopInstance URL refers to an instance that does not exist.",
6538                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
6539                "The route's next hop instance does not have a status of RUNNING.",
6540                "Error which is not critical. We decided to continue the process despite the mentioned error.",
6541                "No results are present on a particular list page.",
6542                "Success is reported, but some results may be missing due to errors",
6543                "The user attempted to use a resource that requires a TOS they have not accepted.",
6544                "Warning that a resource is in use.",
6545                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
6546                "When a resource schema validation is ignored.",
6547                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
6548                "When undeclared properties in the schema are present",
6549                "A given scope cannot be reached."
6550              ],
6551              "enumDeprecated": [
6552                false,
6553                false,
6554                false,
6555                false,
6556                false,
6557                false,
6558                true,
6559                false,
6560                false,
6561                false,
6562                false,
6563                false,
6564                false,
6565                false,
6566                false,
6567                false,
6568                false,
6569                false,
6570                false,
6571                false,
6572                false,
6573                false,
6574                false,
6575                false,
6576                false,
6577                false,
6578                false,
6579                false
6580              ],
6581              "enum": [
6582                "CLEANUP_FAILED",
6583                "DEPRECATED_RESOURCE_USED",
6584                "DEPRECATED_TYPE_USED",
6585                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
6586                "EXPERIMENTAL_TYPE_USED",
6587                "EXTERNAL_API_WARNING",
6588                "FIELD_VALUE_OVERRIDEN",
6589                "INJECTED_KERNELS_DEPRECATED",
6590                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
6591                "LARGE_DEPLOYMENT_WARNING",
6592                "LIST_OVERHEAD_QUOTA_EXCEED",
6593                "MISSING_TYPE_DEPENDENCY",
6594                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
6595                "NEXT_HOP_CANNOT_IP_FORWARD",
6596                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
6597                "NEXT_HOP_INSTANCE_NOT_FOUND",
6598                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
6599                "NEXT_HOP_NOT_RUNNING",
6600                "NOT_CRITICAL_ERROR",
6601                "NO_RESULTS_ON_PAGE",
6602                "PARTIAL_SUCCESS",
6603                "REQUIRED_TOS_AGREEMENT",
6604                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
6605                "RESOURCE_NOT_DELETED",
6606                "SCHEMA_VALIDATION_IGNORED",
6607                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
6608                "UNDECLARED_PROPERTIES",
6609                "UNREACHABLE"
6610              ]
6611            },
6612            "message": {
6613              "description": "[Output Only] A human-readable description of the warning code.",
6614              "type": "string"
6615            },
6616            "data": {
6617              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
6618              "type": "array",
6619              "items": {
6620                "type": "object",
6621                "properties": {
6622                  "key": {
6623                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
6624                    "type": "string"
6625                  },
6626                  "value": {
6627                    "description": "[Output Only] A warning data value corresponding to the key.",
6628                    "type": "string"
6629                  }
6630                }
6631              }
6632            }
6633          }
6634        }
6635      }
6636    },
6637    "InstanceList": {
6638      "id": "InstanceList",
6639      "description": "Contains a list of instances.",
6640      "type": "object",
6641      "properties": {
6642        "kind": {
6643          "description": "[Output Only] Type of resource. Always compute#instanceList for lists of Instance resources.",
6644          "default": "compute#instanceList",
6645          "type": "string"
6646        },
6647        "id": {
6648          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
6649          "type": "string"
6650        },
6651        "items": {
6652          "description": "A list of Instance resources.",
6653          "type": "array",
6654          "items": {
6655            "$ref": "Instance"
6656          }
6657        },
6658        "nextPageToken": {
6659          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
6660          "type": "string"
6661        },
6662        "selfLink": {
6663          "description": "[Output Only] Server-defined URL for this resource.",
6664          "type": "string"
6665        },
6666        "warning": {
6667          "description": "[Output Only] Informational warning message.",
6668          "type": "object",
6669          "properties": {
6670            "code": {
6671              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
6672              "type": "string",
6673              "enumDescriptions": [
6674                "Warning about failed cleanup of transient changes made by a failed operation.",
6675                "A link to a deprecated resource was created.",
6676                "When deploying and at least one of the resources has a type marked as deprecated",
6677                "The user created a boot disk that is larger than image size.",
6678                "When deploying and at least one of the resources has a type marked as experimental",
6679                "Warning that is present in an external api call",
6680                "Warning that value of a field has been overridden. Deprecated unused field.",
6681                "The operation involved use of an injected kernel, which is deprecated.",
6682                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
6683                "When deploying a deployment with a exceedingly large number of resources",
6684                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
6685                "A resource depends on a missing type",
6686                "The route's nextHopIp address is not assigned to an instance on the network.",
6687                "The route's next hop instance cannot ip forward.",
6688                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
6689                "The route's nextHopInstance URL refers to an instance that does not exist.",
6690                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
6691                "The route's next hop instance does not have a status of RUNNING.",
6692                "Error which is not critical. We decided to continue the process despite the mentioned error.",
6693                "No results are present on a particular list page.",
6694                "Success is reported, but some results may be missing due to errors",
6695                "The user attempted to use a resource that requires a TOS they have not accepted.",
6696                "Warning that a resource is in use.",
6697                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
6698                "When a resource schema validation is ignored.",
6699                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
6700                "When undeclared properties in the schema are present",
6701                "A given scope cannot be reached."
6702              ],
6703              "enumDeprecated": [
6704                false,
6705                false,
6706                false,
6707                false,
6708                false,
6709                false,
6710                true,
6711                false,
6712                false,
6713                false,
6714                false,
6715                false,
6716                false,
6717                false,
6718                false,
6719                false,
6720                false,
6721                false,
6722                false,
6723                false,
6724                false,
6725                false,
6726                false,
6727                false,
6728                false,
6729                false,
6730                false,
6731                false
6732              ],
6733              "enum": [
6734                "CLEANUP_FAILED",
6735                "DEPRECATED_RESOURCE_USED",
6736                "DEPRECATED_TYPE_USED",
6737                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
6738                "EXPERIMENTAL_TYPE_USED",
6739                "EXTERNAL_API_WARNING",
6740                "FIELD_VALUE_OVERRIDEN",
6741                "INJECTED_KERNELS_DEPRECATED",
6742                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
6743                "LARGE_DEPLOYMENT_WARNING",
6744                "LIST_OVERHEAD_QUOTA_EXCEED",
6745                "MISSING_TYPE_DEPENDENCY",
6746                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
6747                "NEXT_HOP_CANNOT_IP_FORWARD",
6748                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
6749                "NEXT_HOP_INSTANCE_NOT_FOUND",
6750                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
6751                "NEXT_HOP_NOT_RUNNING",
6752                "NOT_CRITICAL_ERROR",
6753                "NO_RESULTS_ON_PAGE",
6754                "PARTIAL_SUCCESS",
6755                "REQUIRED_TOS_AGREEMENT",
6756                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
6757                "RESOURCE_NOT_DELETED",
6758                "SCHEMA_VALIDATION_IGNORED",
6759                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
6760                "UNDECLARED_PROPERTIES",
6761                "UNREACHABLE"
6762              ]
6763            },
6764            "message": {
6765              "description": "[Output Only] A human-readable description of the warning code.",
6766              "type": "string"
6767            },
6768            "data": {
6769              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
6770              "type": "array",
6771              "items": {
6772                "type": "object",
6773                "properties": {
6774                  "key": {
6775                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
6776                    "type": "string"
6777                  },
6778                  "value": {
6779                    "description": "[Output Only] A warning data value corresponding to the key.",
6780                    "type": "string"
6781                  }
6782                }
6783              }
6784            }
6785          }
6786        }
6787      }
6788    },
6789    "Instance": {
6790      "id": "Instance",
6791      "description": "Represents an Instance resource. An instance is a virtual machine that is hosted on Google Cloud Platform. For more information, read Virtual Machine Instances.",
6792      "type": "object",
6793      "properties": {
6794        "kind": {
6795          "description": "[Output Only] Type of the resource. Always compute#instance for instances.",
6796          "default": "compute#instance",
6797          "type": "string"
6798        },
6799        "id": {
6800          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
6801          "type": "string",
6802          "format": "uint64"
6803        },
6804        "creationTimestamp": {
6805          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
6806          "type": "string"
6807        },
6808        "name": {
6809          "description": "The name of the resource, provided by the client when initially creating the resource. The resource name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
6810          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
6811          "annotations": {
6812            "required": [
6813              "compute.instances.insert"
6814            ]
6815          },
6816          "type": "string"
6817        },
6818        "description": {
6819          "description": "An optional description of this resource. Provide this property when you create the resource.",
6820          "type": "string"
6821        },
6822        "tags": {
6823          "description": "Tags to apply to this instance. Tags are used to identify valid sources or targets for network firewalls and are specified by the client during instance creation. The tags can be later modified by the setTags method. Each tag within the list must comply with RFC1035. Multiple tags can be specified via the 'tags.items' field.",
6824          "$ref": "Tags"
6825        },
6826        "machineType": {
6827          "description": "Full or partial URL of the machine type resource to use for this instance, in the format: zones/zone/machineTypes/machine-type. This is provided by the client when the instance is created. For example, the following is a valid partial url to a predefined machine type: zones/us-central1-f/machineTypes/n1-standard-1 To create a custom machine type, provide a URL to a machine type in the following format, where CPUS is 1 or an even number up to 32 (2, 4, 6, ... 24, etc), and MEMORY is the total memory for this instance. Memory must be a multiple of 256 MB and must be supplied in MB (e.g. 5 GB of memory is 5120 MB): zones/zone/machineTypes/custom-CPUS-MEMORY For example: zones/us-central1-f/machineTypes/custom-4-5120 For a full list of restrictions, read the Specifications for custom machine types.",
6828          "type": "string"
6829        },
6830        "status": {
6831          "description": "[Output Only] The status of the instance. One of the following values: PROVISIONING, STAGING, RUNNING, STOPPING, SUSPENDING, SUSPENDED, REPAIRING, and TERMINATED. For more information about the status of the instance, see Instance life cycle.",
6832          "type": "string",
6833          "enumDescriptions": [
6834            "The instance is halted and we are performing tear down tasks like network deprogramming, releasing quota, IP, tearing down disks etc.",
6835            "Resources are being allocated for the instance.",
6836            "The instance is in repair.",
6837            "The instance is running.",
6838            "All required resources have been allocated and the instance is being started.",
6839            "The instance has stopped successfully.",
6840            "The instance is currently stopping (either being deleted or killed).",
6841            "The instance has suspended.",
6842            "The instance is suspending.",
6843            "The instance has stopped (either by explicit action or underlying failure)."
6844          ],
6845          "enum": [
6846            "DEPROVISIONING",
6847            "PROVISIONING",
6848            "REPAIRING",
6849            "RUNNING",
6850            "STAGING",
6851            "STOPPED",
6852            "STOPPING",
6853            "SUSPENDED",
6854            "SUSPENDING",
6855            "TERMINATED"
6856          ]
6857        },
6858        "statusMessage": {
6859          "description": "[Output Only] An optional, human-readable explanation of the status.",
6860          "type": "string"
6861        },
6862        "zone": {
6863          "description": "[Output Only] URL of the zone where the instance resides. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
6864          "type": "string"
6865        },
6866        "canIpForward": {
6867          "description": "Allows this instance to send and receive packets with non-matching destination or source IPs. This is required if you plan to use this instance to forward routes. For more information, see Enabling IP Forwarding .",
6868          "type": "boolean"
6869        },
6870        "networkInterfaces": {
6871          "description": "An array of network configurations for this instance. These specify how interfaces are configured to interact with other network services, such as connecting to the internet. Multiple interfaces are supported per instance.",
6872          "type": "array",
6873          "items": {
6874            "$ref": "NetworkInterface"
6875          }
6876        },
6877        "disks": {
6878          "description": "Array of disks associated with this instance. Persistent disks must be created before you can assign them.",
6879          "type": "array",
6880          "items": {
6881            "$ref": "AttachedDisk"
6882          }
6883        },
6884        "metadata": {
6885          "description": "The metadata key/value pairs assigned to this instance. This includes custom metadata and predefined keys.",
6886          "$ref": "Metadata"
6887        },
6888        "serviceAccounts": {
6889          "description": "A list of service accounts, with their specified scopes, authorized for this instance. Only one service account per VM instance is supported. Service accounts generate access tokens that can be accessed through the metadata server and used to authenticate applications on the instance. See Service Accounts for more information.",
6890          "type": "array",
6891          "items": {
6892            "$ref": "ServiceAccount"
6893          }
6894        },
6895        "selfLink": {
6896          "description": "[Output Only] Server-defined URL for this resource.",
6897          "type": "string"
6898        },
6899        "scheduling": {
6900          "description": "Sets the scheduling options for this instance.",
6901          "$ref": "Scheduling"
6902        },
6903        "cpuPlatform": {
6904          "description": "[Output Only] The CPU platform used by this instance.",
6905          "type": "string"
6906        },
6907        "labels": {
6908          "description": "Labels to apply to this instance. These can be later modified by the setLabels method.",
6909          "type": "object",
6910          "additionalProperties": {
6911            "type": "string"
6912          }
6913        },
6914        "params": {
6915          "description": "Input only. [Input Only] Additional params passed with the request, but not persisted as part of resource payload.",
6916          "$ref": "InstanceParams"
6917        },
6918        "labelFingerprint": {
6919          "description": "A fingerprint for this request, which is essentially a hash of the label's contents and used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels. To see the latest fingerprint, make get() request to the instance.",
6920          "type": "string",
6921          "format": "byte"
6922        },
6923        "instanceEncryptionKey": {
6924          "description": "Encrypts suspended data for an instance with a customer-managed encryption key. If you are creating a new instance, this field will encrypt the local SSD and in-memory contents of the instance during the suspend operation. If you do not provide an encryption key when creating the instance, then the local SSD and in-memory contents will be encrypted using an automatically generated key during the suspend operation.",
6925          "$ref": "CustomerEncryptionKey"
6926        },
6927        "minCpuPlatform": {
6928          "description": "Specifies a minimum CPU platform for the VM instance. Applicable values are the friendly names of CPU platforms, such as minCpuPlatform: \"Intel Haswell\" or minCpuPlatform: \"Intel Sandy Bridge\".",
6929          "type": "string"
6930        },
6931        "guestAccelerators": {
6932          "description": "A list of the type and count of accelerator cards attached to the instance.",
6933          "type": "array",
6934          "items": {
6935            "$ref": "AcceleratorConfig"
6936          }
6937        },
6938        "startRestricted": {
6939          "description": "[Output Only] Whether a VM has been restricted for start because Compute Engine has detected suspicious activity.",
6940          "type": "boolean"
6941        },
6942        "deletionProtection": {
6943          "description": "Whether the resource should be protected against deletion.",
6944          "type": "boolean"
6945        },
6946        "resourcePolicies": {
6947          "description": "Resource policies applied to this instance.",
6948          "type": "array",
6949          "items": {
6950            "type": "string"
6951          }
6952        },
6953        "sourceMachineImage": {
6954          "description": "Source machine image",
6955          "type": "string"
6956        },
6957        "reservationAffinity": {
6958          "description": "Specifies the reservations that this instance can consume from.",
6959          "$ref": "ReservationAffinity"
6960        },
6961        "hostname": {
6962          "description": "Specifies the hostname of the instance. The specified hostname must be RFC1035 compliant. If hostname is not specified, the default hostname is [INSTANCE_NAME].c.[PROJECT_ID].internal when using the global DNS, and [INSTANCE_NAME].[ZONE].c.[PROJECT_ID].internal when using zonal DNS.",
6963          "type": "string"
6964        },
6965        "displayDevice": {
6966          "description": "Enables display device for the instance.",
6967          "$ref": "DisplayDevice"
6968        },
6969        "shieldedInstanceConfig": {
6970          "$ref": "ShieldedInstanceConfig"
6971        },
6972        "shieldedInstanceIntegrityPolicy": {
6973          "$ref": "ShieldedInstanceIntegrityPolicy"
6974        },
6975        "sourceMachineImageEncryptionKey": {
6976          "description": "Source machine image encryption key when creating an instance from a machine image.",
6977          "$ref": "CustomerEncryptionKey"
6978        },
6979        "confidentialInstanceConfig": {
6980          "$ref": "ConfidentialInstanceConfig"
6981        },
6982        "fingerprint": {
6983          "description": "Specifies a fingerprint for this resource, which is essentially a hash of the instance's contents and used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update the instance. You must always provide an up-to-date fingerprint hash in order to update the instance. To see the latest fingerprint, make get() request to the instance.",
6984          "type": "string",
6985          "format": "byte"
6986        },
6987        "privateIpv6GoogleAccess": {
6988          "description": "The private IPv6 google access type for the VM. If not specified, use INHERIT_FROM_SUBNETWORK as default.",
6989          "type": "string",
6990          "enumDescriptions": [
6991            "Bidirectional private IPv6 access to/from Google services. If specified, the subnetwork who is attached to the instance's default network interface will be assigned an internal IPv6 prefix if it doesn't have before.",
6992            "Outbound private IPv6 access from VMs in this subnet to Google services. If specified, the subnetwork who is attached to the instance's default network interface will be assigned an internal IPv6 prefix if it doesn't have before.",
6993            "Each network interface inherits PrivateIpv6GoogleAccess from its subnetwork."
6994          ],
6995          "enum": [
6996            "ENABLE_BIDIRECTIONAL_ACCESS_TO_GOOGLE",
6997            "ENABLE_OUTBOUND_VM_ACCESS_TO_GOOGLE",
6998            "INHERIT_FROM_SUBNETWORK"
6999          ]
7000        },
7001        "advancedMachineFeatures": {
7002          "description": "Controls for advanced machine-related behavior features.",
7003          "$ref": "AdvancedMachineFeatures"
7004        },
7005        "lastStartTimestamp": {
7006          "description": "[Output Only] Last start timestamp in RFC3339 text format.",
7007          "type": "string"
7008        },
7009        "lastStopTimestamp": {
7010          "description": "[Output Only] Last stop timestamp in RFC3339 text format.",
7011          "type": "string"
7012        },
7013        "lastSuspendedTimestamp": {
7014          "description": "[Output Only] Last suspended timestamp in RFC3339 text format.",
7015          "type": "string"
7016        },
7017        "satisfiesPzs": {
7018          "description": "[Output Only] Reserved for future use.",
7019          "type": "boolean"
7020        },
7021        "satisfiesPzi": {
7022          "description": "[Output Only] Reserved for future use.",
7023          "type": "boolean"
7024        },
7025        "resourceStatus": {
7026          "description": "[Output Only] Specifies values set for instance attributes as compared to the values requested by user in the corresponding input only field.",
7027          "$ref": "ResourceStatus"
7028        },
7029        "networkPerformanceConfig": {
7030          "$ref": "NetworkPerformanceConfig"
7031        },
7032        "keyRevocationActionType": {
7033          "description": "KeyRevocationActionType of the instance. Supported options are \"STOP\" and \"NONE\". The default value is \"NONE\" if it is not specified.",
7034          "type": "string",
7035          "enumDescriptions": [
7036            "Default value. This value is unused.",
7037            "Indicates user chose no operation.",
7038            "Indicates user chose to opt for VM shutdown on key revocation."
7039          ],
7040          "enum": [
7041            "KEY_REVOCATION_ACTION_TYPE_UNSPECIFIED",
7042            "NONE",
7043            "STOP"
7044          ]
7045        }
7046      }
7047    },
7048    "Tags": {
7049      "id": "Tags",
7050      "description": "A set of instance tags.",
7051      "type": "object",
7052      "properties": {
7053        "items": {
7054          "description": "An array of tags. Each tag must be 1-63 characters long, and comply with RFC1035.",
7055          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
7056          "type": "array",
7057          "items": {
7058            "type": "string"
7059          }
7060        },
7061        "fingerprint": {
7062          "description": "Specifies a fingerprint for this request, which is essentially a hash of the tags' contents and used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update tags. You must always provide an up-to-date fingerprint hash in order to update or change tags. To see the latest fingerprint, make get() request to the instance.",
7063          "type": "string",
7064          "format": "byte"
7065        }
7066      }
7067    },
7068    "NetworkInterface": {
7069      "id": "NetworkInterface",
7070      "description": "A network interface resource attached to an instance.",
7071      "type": "object",
7072      "properties": {
7073        "kind": {
7074          "description": "[Output Only] Type of the resource. Always compute#networkInterface for network interfaces.",
7075          "default": "compute#networkInterface",
7076          "type": "string"
7077        },
7078        "network": {
7079          "description": "URL of the VPC network resource for this instance. When creating an instance, if neither the network nor the subnetwork is specified, the default network global/networks/default is used. If the selected project doesn't have the default network, you must specify a network or subnet. If the network is not specified but the subnetwork is specified, the network is inferred. If you specify this property, you can specify the network as a full or partial URL. For example, the following are all valid URLs: - https://www.googleapis.com/compute/v1/projects/project/global/networks/ network - projects/project/global/networks/network - global/networks/default ",
7080          "type": "string"
7081        },
7082        "subnetwork": {
7083          "description": "The URL of the Subnetwork resource for this instance. If the network resource is in legacy mode, do not specify this field. If the network is in auto subnet mode, specifying the subnetwork is optional. If the network is in custom subnet mode, specifying the subnetwork is required. If you specify this field, you can specify the subnetwork as a full or partial URL. For example, the following are all valid URLs: - https://www.googleapis.com/compute/v1/projects/project/regions/region /subnetworks/subnetwork - regions/region/subnetworks/subnetwork ",
7084          "type": "string"
7085        },
7086        "networkIP": {
7087          "description": "An IPv4 internal IP address to assign to the instance for this network interface. If not specified by the user, an unused internal IP is assigned by the system.",
7088          "type": "string"
7089        },
7090        "ipv6Address": {
7091          "description": "An IPv6 internal network address for this network interface. To use a static internal IP address, it must be unused and in the same region as the instance's zone. If not specified, Google Cloud will automatically assign an internal IPv6 address from the instance's subnetwork.",
7092          "type": "string"
7093        },
7094        "internalIpv6PrefixLength": {
7095          "description": "The prefix length of the primary internal IPv6 range.",
7096          "type": "integer",
7097          "format": "int32"
7098        },
7099        "name": {
7100          "description": "[Output Only] The name of the network interface, which is generated by the server. For a VM, the network interface uses the nicN naming format. Where N is a value between 0 and 7. The default interface value is nic0.",
7101          "type": "string"
7102        },
7103        "accessConfigs": {
7104          "description": "An array of configurations for this interface. Currently, only one access config, ONE_TO_ONE_NAT, is supported. If there are no accessConfigs specified, then this instance will have no external internet access.",
7105          "type": "array",
7106          "items": {
7107            "$ref": "AccessConfig"
7108          }
7109        },
7110        "ipv6AccessConfigs": {
7111          "description": "An array of IPv6 access configurations for this interface. Currently, only one IPv6 access config, DIRECT_IPV6, is supported. If there is no ipv6AccessConfig specified, then this instance will have no external IPv6 Internet access.",
7112          "type": "array",
7113          "items": {
7114            "$ref": "AccessConfig"
7115          }
7116        },
7117        "aliasIpRanges": {
7118          "description": "An array of alias IP ranges for this network interface. You can only specify this field for network interfaces in VPC networks.",
7119          "type": "array",
7120          "items": {
7121            "$ref": "AliasIpRange"
7122          }
7123        },
7124        "fingerprint": {
7125          "description": "Fingerprint hash of contents stored in this network interface. This field will be ignored when inserting an Instance or adding a NetworkInterface. An up-to-date fingerprint must be provided in order to update the NetworkInterface. The request will fail with error 400 Bad Request if the fingerprint is not provided, or 412 Precondition Failed if the fingerprint is out of date.",
7126          "type": "string",
7127          "format": "byte"
7128        },
7129        "stackType": {
7130          "description": "The stack type for this network interface. To assign only IPv4 addresses, use IPV4_ONLY. To assign both IPv4 and IPv6 addresses, use IPV4_IPV6. If not specified, IPV4_ONLY is used. This field can be both set at instance creation and update network interface operations.",
7131          "type": "string",
7132          "enumDescriptions": [
7133            "The network interface can have both IPv4 and IPv6 addresses.",
7134            "The network interface will be assigned IPv4 address."
7135          ],
7136          "enum": [
7137            "IPV4_IPV6",
7138            "IPV4_ONLY"
7139          ]
7140        },
7141        "ipv6AccessType": {
7142          "description": "[Output Only] One of EXTERNAL, INTERNAL to indicate whether the IP can be accessed from the Internet. This field is always inherited from its subnetwork. Valid only if stackType is IPV4_IPV6.",
7143          "type": "string",
7144          "enumDescriptions": [
7145            "This network interface can have external IPv6.",
7146            "This network interface can have internal IPv6."
7147          ],
7148          "enum": [
7149            "EXTERNAL",
7150            "INTERNAL"
7151          ]
7152        },
7153        "queueCount": {
7154          "description": "The networking queue count that's specified by users for the network interface. Both Rx and Tx queues will be set to this number. It'll be empty if not specified by the users.",
7155          "type": "integer",
7156          "format": "int32"
7157        },
7158        "nicType": {
7159          "description": "The type of vNIC to be used on this interface. This may be gVNIC or VirtioNet.",
7160          "type": "string",
7161          "enumDescriptions": [
7162            "GVNIC",
7163            "No type specified.",
7164            "VIRTIO"
7165          ],
7166          "enum": [
7167            "GVNIC",
7168            "UNSPECIFIED_NIC_TYPE",
7169            "VIRTIO_NET"
7170          ]
7171        },
7172        "networkAttachment": {
7173          "description": "The URL of the network attachment that this interface should connect to in the following format: projects/{project_number}/regions/{region_name}/networkAttachments/{network_attachment_name}.",
7174          "type": "string"
7175        }
7176      }
7177    },
7178    "AccessConfig": {
7179      "id": "AccessConfig",
7180      "description": "An access configuration attached to an instance's network interface. Only one access config per instance is supported.",
7181      "type": "object",
7182      "properties": {
7183        "kind": {
7184          "description": "[Output Only] Type of the resource. Always compute#accessConfig for access configs.",
7185          "default": "compute#accessConfig",
7186          "type": "string"
7187        },
7188        "type": {
7189          "description": "The type of configuration. In accessConfigs (IPv4), the default and only option is ONE_TO_ONE_NAT. In ipv6AccessConfigs, the default and only option is DIRECT_IPV6.",
7190          "type": "string",
7191          "enumDescriptions": [
7192            "",
7193            ""
7194          ],
7195          "enum": [
7196            "DIRECT_IPV6",
7197            "ONE_TO_ONE_NAT"
7198          ]
7199        },
7200        "name": {
7201          "description": "The name of this access configuration. In accessConfigs (IPv4), the default and recommended name is External NAT, but you can use any arbitrary string, such as My external IP or Network Access. In ipv6AccessConfigs, the recommend name is External IPv6.",
7202          "type": "string"
7203        },
7204        "natIP": {
7205          "description": "Applies to accessConfigs (IPv4) only. An external IP address associated with this instance. Specify an unused static external IP address available to the project or leave this field undefined to use an IP from a shared ephemeral IP address pool. If you specify a static external IP address, it must live in the same region as the zone of the instance.",
7206          "type": "string"
7207        },
7208        "externalIpv6": {
7209          "description": "Applies to ipv6AccessConfigs only. The first IPv6 address of the external IPv6 range associated with this instance, prefix length is stored in externalIpv6PrefixLength in ipv6AccessConfig. To use a static external IP address, it must be unused and in the same region as the instance's zone. If not specified, Google Cloud will automatically assign an external IPv6 address from the instance's subnetwork.",
7210          "type": "string"
7211        },
7212        "externalIpv6PrefixLength": {
7213          "description": "Applies to ipv6AccessConfigs only. The prefix length of the external IPv6 range.",
7214          "type": "integer",
7215          "format": "int32"
7216        },
7217        "setPublicPtr": {
7218          "description": "Specifies whether a public DNS 'PTR' record should be created to map the external IP address of the instance to a DNS domain name. This field is not used in ipv6AccessConfig. A default PTR record will be created if the VM has external IPv6 range associated.",
7219          "type": "boolean"
7220        },
7221        "publicPtrDomainName": {
7222          "description": "The DNS domain name for the public PTR record. You can set this field only if the `setPublicPtr` field is enabled in accessConfig. If this field is unspecified in ipv6AccessConfig, a default PTR record will be createc for first IP in associated external IPv6 range.",
7223          "type": "string"
7224        },
7225        "networkTier": {
7226          "description": "This signifies the networking tier used for configuring this access configuration and can only take the following values: PREMIUM, STANDARD. If an AccessConfig is specified without a valid external IP address, an ephemeral IP will be created with this networkTier. If an AccessConfig with a valid external IP address is specified, it must match that of the networkTier associated with the Address resource owning that IP.",
7227          "type": "string",
7228          "enumDescriptions": [
7229            "Public internet quality with fixed bandwidth.",
7230            "High quality, Google-grade network tier, support for all networking products.",
7231            "Public internet quality, only limited support for other networking products.",
7232            "(Output only) Temporary tier for FIXED_STANDARD when fixed standard tier is expired or not configured."
7233          ],
7234          "enum": [
7235            "FIXED_STANDARD",
7236            "PREMIUM",
7237            "STANDARD",
7238            "STANDARD_OVERRIDES_FIXED_STANDARD"
7239          ]
7240        },
7241        "securityPolicy": {
7242          "description": "[Output Only] The resource URL for the security policy associated with this access config.",
7243          "type": "string"
7244        }
7245      }
7246    },
7247    "AliasIpRange": {
7248      "id": "AliasIpRange",
7249      "description": "An alias IP range attached to an instance's network interface.",
7250      "type": "object",
7251      "properties": {
7252        "ipCidrRange": {
7253          "description": "The IP alias ranges to allocate for this interface. This IP CIDR range must belong to the specified subnetwork and cannot contain IP addresses reserved by system or used by other network interfaces. This range may be a single IP address (such as 10.2.3.4), a netmask (such as /24) or a CIDR-formatted string (such as 10.1.2.0/24).",
7254          "type": "string"
7255        },
7256        "subnetworkRangeName": {
7257          "description": "The name of a subnetwork secondary IP range from which to allocate an IP alias range. If not specified, the primary range of the subnetwork is used.",
7258          "type": "string"
7259        }
7260      }
7261    },
7262    "AttachedDisk": {
7263      "id": "AttachedDisk",
7264      "description": "An instance-attached disk resource.",
7265      "type": "object",
7266      "properties": {
7267        "kind": {
7268          "description": "[Output Only] Type of the resource. Always compute#attachedDisk for attached disks.",
7269          "default": "compute#attachedDisk",
7270          "type": "string"
7271        },
7272        "type": {
7273          "description": "Specifies the type of the disk, either SCRATCH or PERSISTENT. If not specified, the default is PERSISTENT.",
7274          "type": "string",
7275          "enumDescriptions": [
7276            "",
7277            ""
7278          ],
7279          "enum": [
7280            "PERSISTENT",
7281            "SCRATCH"
7282          ]
7283        },
7284        "mode": {
7285          "description": "The mode in which to attach this disk, either READ_WRITE or READ_ONLY. If not specified, the default is to attach the disk in READ_WRITE mode.",
7286          "type": "string",
7287          "enumDescriptions": [
7288            "Attaches this disk in read-only mode. Multiple virtual machines can use a disk in read-only mode at a time.",
7289            "*[Default]* Attaches this disk in read-write mode. Only one virtual machine at a time can be attached to a disk in read-write mode."
7290          ],
7291          "enum": [
7292            "READ_ONLY",
7293            "READ_WRITE"
7294          ]
7295        },
7296        "savedState": {
7297          "description": "For LocalSSD disks on VM Instances in STOPPED or SUSPENDED state, this field is set to PRESERVED if the LocalSSD data has been saved to a persistent location by customer request. (see the discard_local_ssd option on Stop/Suspend). Read-only in the api.",
7298          "type": "string",
7299          "enumDescriptions": [
7300            "*[Default]* Disk state has not been preserved.",
7301            "Disk state has been preserved."
7302          ],
7303          "enum": [
7304            "DISK_SAVED_STATE_UNSPECIFIED",
7305            "PRESERVED"
7306          ]
7307        },
7308        "source": {
7309          "description": "Specifies a valid partial or full URL to an existing Persistent Disk resource. When creating a new instance, one of initializeParams.sourceImage or initializeParams.sourceSnapshot or disks.source is required except for local SSD. If desired, you can also attach existing non-root persistent disks using this property. This field is only applicable for persistent disks. Note that for InstanceTemplate, specify the disk name for zonal disk, and the URL for regional disk.",
7310          "type": "string"
7311        },
7312        "deviceName": {
7313          "description": "Specifies a unique device name of your choice that is reflected into the /dev/disk/by-id/google-* tree of a Linux operating system running within the instance. This name can be used to reference the device for mounting, resizing, and so on, from within the instance. If not specified, the server chooses a default device name to apply to this disk, in the form persistent-disk-x, where x is a number assigned by Google Compute Engine. This field is only applicable for persistent disks.",
7314          "type": "string"
7315        },
7316        "index": {
7317          "description": "[Output Only] A zero-based index to this disk, where 0 is reserved for the boot disk. If you have many disks attached to an instance, each disk would have a unique index number.",
7318          "type": "integer",
7319          "format": "int32"
7320        },
7321        "boot": {
7322          "description": "Indicates that this is a boot disk. The virtual machine will use the first partition of the disk for its root filesystem.",
7323          "type": "boolean"
7324        },
7325        "initializeParams": {
7326          "description": "[Input Only] Specifies the parameters for a new disk that will be created alongside the new instance. Use initialization parameters to create boot disks or local SSDs attached to the new instance. This property is mutually exclusive with the source property; you can only define one or the other, but not both.",
7327          "$ref": "AttachedDiskInitializeParams"
7328        },
7329        "autoDelete": {
7330          "description": "Specifies whether the disk will be auto-deleted when the instance is deleted (but not when the disk is detached from the instance).",
7331          "type": "boolean"
7332        },
7333        "licenses": {
7334          "description": "[Output Only] Any valid publicly visible licenses.",
7335          "type": "array",
7336          "items": {
7337            "type": "string"
7338          }
7339        },
7340        "interface": {
7341          "description": "Specifies the disk interface to use for attaching this disk, which is either SCSI or NVME. For most machine types, the default is SCSI. Local SSDs can use either NVME or SCSI. In certain configurations, persistent disks can use NVMe. For more information, see About persistent disks.",
7342          "type": "string",
7343          "enumDescriptions": [
7344            "",
7345            ""
7346          ],
7347          "enum": [
7348            "NVME",
7349            "SCSI"
7350          ]
7351        },
7352        "guestOsFeatures": {
7353          "description": "A list of features to enable on the guest operating system. Applicable only for bootable images. Read Enabling guest operating system features to see a list of available options.",
7354          "type": "array",
7355          "items": {
7356            "$ref": "GuestOsFeature"
7357          }
7358        },
7359        "diskEncryptionKey": {
7360          "description": "Encrypts or decrypts a disk using a customer-supplied encryption key. If you are creating a new disk, this field encrypts the new disk using an encryption key that you provide. If you are attaching an existing disk that is already encrypted, this field decrypts the disk using the customer-supplied encryption key. If you encrypt a disk using a customer-supplied key, you must provide the same key again when you attempt to use this resource at a later time. For example, you must provide the key when you create a snapshot or an image from the disk or when you attach the disk to a virtual machine instance. If you do not provide an encryption key, then the disk will be encrypted using an automatically generated key and you do not need to provide a key to use the disk later. Instance templates do not store customer-supplied encryption keys, so you cannot use your own keys to encrypt disks in a managed instance group.",
7361          "$ref": "CustomerEncryptionKey"
7362        },
7363        "diskSizeGb": {
7364          "description": "The size of the disk in GB.",
7365          "type": "string",
7366          "format": "int64"
7367        },
7368        "shieldedInstanceInitialState": {
7369          "description": "[Output Only] shielded vm initial state stored on disk",
7370          "$ref": "InitialStateConfig"
7371        },
7372        "forceAttach": {
7373          "description": "[Input Only] Whether to force attach the regional disk even if it's currently attached to another instance. If you try to force attach a zonal disk to an instance, you will receive an error.",
7374          "type": "boolean"
7375        },
7376        "architecture": {
7377          "description": "[Output Only] The architecture of the attached disk. Valid values are ARM64 or X86_64.",
7378          "type": "string",
7379          "enumDescriptions": [
7380            "Default value indicating Architecture is not set.",
7381            "Machines with architecture ARM64",
7382            "Machines with architecture X86_64"
7383          ],
7384          "enum": [
7385            "ARCHITECTURE_UNSPECIFIED",
7386            "ARM64",
7387            "X86_64"
7388          ]
7389        }
7390      }
7391    },
7392    "AttachedDiskInitializeParams": {
7393      "id": "AttachedDiskInitializeParams",
7394      "description": "[Input Only] Specifies the parameters for a new disk that will be created alongside the new instance. Use initialization parameters to create boot disks or local SSDs attached to the new instance. This field is persisted and returned for instanceTemplate and not returned in the context of instance. This property is mutually exclusive with the source property; you can only define one or the other, but not both.",
7395      "type": "object",
7396      "properties": {
7397        "diskName": {
7398          "description": "Specifies the disk name. If not specified, the default is to use the name of the instance. If a disk with the same name already exists in the given region, the existing disk is attached to the new instance and the new disk is not created.",
7399          "type": "string"
7400        },
7401        "sourceImage": {
7402          "description": "The source image to create this disk. When creating a new instance, one of initializeParams.sourceImage or initializeParams.sourceSnapshot or disks.source is required except for local SSD. To create a disk with one of the public operating system images, specify the image by its family name. For example, specify family/debian-9 to use the latest Debian 9 image: projects/debian-cloud/global/images/family/debian-9 Alternatively, use a specific version of a public operating system image: projects/debian-cloud/global/images/debian-9-stretch-vYYYYMMDD To create a disk with a custom image that you created, specify the image name in the following format: global/images/my-custom-image You can also specify a custom image by its image family, which returns the latest version of the image in that family. Replace the image name with family/family-name: global/images/family/my-image-family If the source image is deleted later, this field will not be set.",
7403          "type": "string"
7404        },
7405        "diskSizeGb": {
7406          "description": "Specifies the size of the disk in base-2 GB. The size must be at least 10 GB. If you specify a sourceImage, which is required for boot disks, the default size is the size of the sourceImage. If you do not specify a sourceImage, the default disk size is 500 GB.",
7407          "type": "string",
7408          "format": "int64"
7409        },
7410        "diskType": {
7411          "description": "Specifies the disk type to use to create the instance. If not specified, the default is pd-standard, specified using the full URL. For example: https://www.googleapis.com/compute/v1/projects/project/zones/zone /diskTypes/pd-standard For a full list of acceptable values, see Persistent disk types. If you specify this field when creating a VM, you can provide either the full or partial URL. For example, the following values are valid: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /diskTypes/diskType - projects/project/zones/zone/diskTypes/diskType - zones/zone/diskTypes/diskType If you specify this field when creating or updating an instance template or all-instances configuration, specify the type of the disk, not the URL. For example: pd-standard.",
7412          "type": "string"
7413        },
7414        "sourceImageEncryptionKey": {
7415          "description": "The customer-supplied encryption key of the source image. Required if the source image is protected by a customer-supplied encryption key. InstanceTemplate and InstancePropertiesPatch do not store customer-supplied encryption keys, so you cannot create disks for instances in a managed instance group if the source images are encrypted with your own keys.",
7416          "$ref": "CustomerEncryptionKey"
7417        },
7418        "labels": {
7419          "description": "Labels to apply to this disk. These can be later modified by the disks.setLabels method. This field is only applicable for persistent disks.",
7420          "type": "object",
7421          "additionalProperties": {
7422            "type": "string"
7423          }
7424        },
7425        "sourceSnapshot": {
7426          "description": "The source snapshot to create this disk. When creating a new instance, one of initializeParams.sourceSnapshot or initializeParams.sourceImage or disks.source is required except for local SSD. To create a disk with a snapshot that you created, specify the snapshot name in the following format: global/snapshots/my-backup If the source snapshot is deleted later, this field will not be set.",
7427          "type": "string"
7428        },
7429        "sourceSnapshotEncryptionKey": {
7430          "description": "The customer-supplied encryption key of the source snapshot.",
7431          "$ref": "CustomerEncryptionKey"
7432        },
7433        "description": {
7434          "description": "An optional description. Provide this property when creating the disk.",
7435          "type": "string"
7436        },
7437        "replicaZones": {
7438          "description": "Required for each regional disk associated with the instance. Specify the URLs of the zones where the disk should be replicated to. You must provide exactly two replica zones, and one zone must be the same as the instance zone.",
7439          "type": "array",
7440          "items": {
7441            "type": "string"
7442          }
7443        },
7444        "resourcePolicies": {
7445          "description": "Resource policies applied to this disk for automatic snapshot creations. Specified using the full or partial URL. For instance template, specify only the resource policy name.",
7446          "type": "array",
7447          "items": {
7448            "type": "string"
7449          }
7450        },
7451        "onUpdateAction": {
7452          "description": "Specifies which action to take on instance update with this disk. Default is to use the existing disk.",
7453          "type": "string",
7454          "enumDescriptions": [
7455            "Always recreate the disk.",
7456            "Recreate the disk if source (image, snapshot) of this disk is different from source of existing disk.",
7457            "Use the existing disk, this is the default behaviour."
7458          ],
7459          "enum": [
7460            "RECREATE_DISK",
7461            "RECREATE_DISK_IF_SOURCE_CHANGED",
7462            "USE_EXISTING_DISK"
7463          ]
7464        },
7465        "provisionedIops": {
7466          "description": "Indicates how many IOPS to provision for the disk. This sets the number of I/O operations per second that the disk can handle. Values must be between 10,000 and 120,000. For more details, see the Extreme persistent disk documentation.",
7467          "type": "string",
7468          "format": "int64"
7469        },
7470        "licenses": {
7471          "description": "A list of publicly visible licenses. Reserved for Google's use.",
7472          "type": "array",
7473          "items": {
7474            "type": "string"
7475          }
7476        },
7477        "architecture": {
7478          "description": "The architecture of the attached disk. Valid values are arm64 or x86_64.",
7479          "type": "string",
7480          "enumDescriptions": [
7481            "Default value indicating Architecture is not set.",
7482            "Machines with architecture ARM64",
7483            "Machines with architecture X86_64"
7484          ],
7485          "enum": [
7486            "ARCHITECTURE_UNSPECIFIED",
7487            "ARM64",
7488            "X86_64"
7489          ]
7490        },
7491        "resourceManagerTags": {
7492          "description": "Resource manager tags to be bound to the disk. Tag keys and values have the same definition as resource manager tags. Keys must be in the format `tagKeys/{tag_key_id}`, and values are in the format `tagValues/456`. The field is ignored (both PUT & PATCH) when empty.",
7493          "type": "object",
7494          "additionalProperties": {
7495            "type": "string"
7496          }
7497        },
7498        "provisionedThroughput": {
7499          "description": "Indicates how much throughput to provision for the disk. This sets the number of throughput mb per second that the disk can handle. Values must greater than or equal to 1.",
7500          "type": "string",
7501          "format": "int64"
7502        },
7503        "enableConfidentialCompute": {
7504          "description": "Whether this disk is using confidential compute mode.",
7505          "type": "boolean"
7506        }
7507      }
7508    },
7509    "Metadata": {
7510      "id": "Metadata",
7511      "description": "A metadata key/value entry.",
7512      "type": "object",
7513      "properties": {
7514        "kind": {
7515          "description": "[Output Only] Type of the resource. Always compute#metadata for metadata.",
7516          "default": "compute#metadata",
7517          "type": "string"
7518        },
7519        "fingerprint": {
7520          "description": "Specifies a fingerprint for this request, which is essentially a hash of the metadata's contents and used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update metadata. You must always provide an up-to-date fingerprint hash in order to update or change metadata, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve the resource.",
7521          "type": "string",
7522          "format": "byte"
7523        },
7524        "items": {
7525          "description": "Array of key/value pairs. The total size of all keys and values must be less than 512 KB.",
7526          "type": "array",
7527          "items": {
7528            "description": "Metadata",
7529            "type": "object",
7530            "properties": {
7531              "key": {
7532                "description": "Key for the metadata entry. Keys must conform to the following regexp: [a-zA-Z0-9-_]+, and be less than 128 bytes in length. This is reflected as part of a URL in the metadata server. Additionally, to avoid ambiguity, keys must not conflict with any other metadata keys for the project.",
7533                "pattern": "[a-zA-Z0-9-_]{1,128}",
7534                "annotations": {
7535                  "required": [
7536                    "compute.instances.insert",
7537                    "compute.projects.setCommonInstanceMetadata"
7538                  ]
7539                },
7540                "type": "string"
7541              },
7542              "value": {
7543                "description": "Value for the metadata entry. These are free-form strings, and only have meaning as interpreted by the image running in the instance. The only restriction placed on values is that their size must be less than or equal to 262144 bytes (256 KiB).",
7544                "annotations": {
7545                  "required": [
7546                    "compute.instances.insert",
7547                    "compute.projects.setCommonInstanceMetadata"
7548                  ]
7549                },
7550                "type": "string"
7551              }
7552            }
7553          }
7554        }
7555      }
7556    },
7557    "ServiceAccount": {
7558      "id": "ServiceAccount",
7559      "description": "A service account.",
7560      "type": "object",
7561      "properties": {
7562        "email": {
7563          "description": "Email address of the service account.",
7564          "type": "string"
7565        },
7566        "scopes": {
7567          "description": "The list of scopes to be made available for this service account.",
7568          "type": "array",
7569          "items": {
7570            "type": "string"
7571          }
7572        }
7573      }
7574    },
7575    "Scheduling": {
7576      "id": "Scheduling",
7577      "description": "Sets the scheduling options for an Instance.",
7578      "type": "object",
7579      "properties": {
7580        "onHostMaintenance": {
7581          "description": "Defines the maintenance behavior for this instance. For standard instances, the default behavior is MIGRATE. For preemptible instances, the default and only possible behavior is TERMINATE. For more information, see Set VM host maintenance policy.",
7582          "type": "string",
7583          "enumDescriptions": [
7584            "*[Default]* Allows Compute Engine to automatically migrate instances out of the way of maintenance events.",
7585            "Tells Compute Engine to terminate and (optionally) restart the instance away from the maintenance activity. If you would like your instance to be restarted, set the automaticRestart flag to true. Your instance may be restarted more than once, and it may be restarted outside the window of maintenance events."
7586          ],
7587          "enum": [
7588            "MIGRATE",
7589            "TERMINATE"
7590          ]
7591        },
7592        "automaticRestart": {
7593          "description": "Specifies whether the instance should be automatically restarted if it is terminated by Compute Engine (not terminated by a user). You can only set the automatic restart option for standard instances. Preemptible instances cannot be automatically restarted. By default, this is set to true so an instance is automatically restarted if it is terminated by Compute Engine.",
7594          "type": "boolean"
7595        },
7596        "preemptible": {
7597          "description": "Defines whether the instance is preemptible. This can only be set during instance creation or while the instance is stopped and therefore, in a `TERMINATED` state. See Instance Life Cycle for more information on the possible instance states.",
7598          "type": "boolean"
7599        },
7600        "nodeAffinities": {
7601          "description": "A set of node affinity and anti-affinity configurations. Refer to Configuring node affinity for more information. Overrides reservationAffinity.",
7602          "type": "array",
7603          "items": {
7604            "$ref": "SchedulingNodeAffinity"
7605          }
7606        },
7607        "minNodeCpus": {
7608          "description": "The minimum number of virtual CPUs this instance will consume when running on a sole-tenant node.",
7609          "type": "integer",
7610          "format": "int32"
7611        },
7612        "locationHint": {
7613          "description": "An opaque location hint used to place the instance close to other resources. This field is for use by internal tools that use the public API.",
7614          "type": "string"
7615        },
7616        "provisioningModel": {
7617          "description": "Specifies the provisioning model of the instance.",
7618          "type": "string",
7619          "enumDescriptions": [
7620            "Heavily discounted, no guaranteed runtime.",
7621            "Standard provisioning with user controlled runtime, no discounts."
7622          ],
7623          "enum": [
7624            "SPOT",
7625            "STANDARD"
7626          ]
7627        },
7628        "instanceTerminationAction": {
7629          "description": "Specifies the termination action for the instance.",
7630          "type": "string",
7631          "enumDescriptions": [
7632            "Delete the VM.",
7633            "Default value. This value is unused.",
7634            "Stop the VM without storing in-memory content. default action."
7635          ],
7636          "enum": [
7637            "DELETE",
7638            "INSTANCE_TERMINATION_ACTION_UNSPECIFIED",
7639            "STOP"
7640          ]
7641        },
7642        "localSsdRecoveryTimeout": {
7643          "description": "Specifies the maximum amount of time a Local Ssd Vm should wait while recovery of the Local Ssd state is attempted. Its value should be in between 0 and 168 hours with hour granularity and the default value being 1 hour.",
7644          "$ref": "Duration"
7645        }
7646      }
7647    },
7648    "SchedulingNodeAffinity": {
7649      "id": "SchedulingNodeAffinity",
7650      "description": "Node Affinity: the configuration of desired nodes onto which this Instance could be scheduled.",
7651      "type": "object",
7652      "properties": {
7653        "key": {
7654          "description": "Corresponds to the label key of Node resource.",
7655          "type": "string"
7656        },
7657        "operator": {
7658          "description": "Defines the operation of node selection. Valid operators are IN for affinity and NOT_IN for anti-affinity.",
7659          "type": "string",
7660          "enumDescriptions": [
7661            "Requires Compute Engine to seek for matched nodes.",
7662            "Requires Compute Engine to avoid certain nodes.",
7663            ""
7664          ],
7665          "enum": [
7666            "IN",
7667            "NOT_IN",
7668            "OPERATOR_UNSPECIFIED"
7669          ]
7670        },
7671        "values": {
7672          "description": "Corresponds to the label values of Node resource.",
7673          "type": "array",
7674          "items": {
7675            "type": "string"
7676          }
7677        }
7678      }
7679    },
7680    "Duration": {
7681      "id": "Duration",
7682      "description": "A Duration represents a fixed-length span of time represented as a count of seconds and fractions of seconds at nanosecond resolution. It is independent of any calendar and concepts like \"day\" or \"month\". Range is approximately 10,000 years.",
7683      "type": "object",
7684      "properties": {
7685        "seconds": {
7686          "description": "Span of time at a resolution of a second. Must be from 0 to 315,576,000,000 inclusive. Note: these bounds are computed from: 60 sec/min * 60 min/hr * 24 hr/day * 365.25 days/year * 10000 years",
7687          "type": "string",
7688          "format": "int64"
7689        },
7690        "nanos": {
7691          "description": "Span of time that's a fraction of a second at nanosecond resolution. Durations less than one second are represented with a 0 `seconds` field and a positive `nanos` field. Must be from 0 to 999,999,999 inclusive.",
7692          "type": "integer",
7693          "format": "int32"
7694        }
7695      }
7696    },
7697    "InstanceParams": {
7698      "id": "InstanceParams",
7699      "description": "Additional instance params.",
7700      "type": "object",
7701      "properties": {
7702        "resourceManagerTags": {
7703          "description": "Resource manager tags to be bound to the instance. Tag keys and values have the same definition as resource manager tags. Keys must be in the format `tagKeys/{tag_key_id}`, and values are in the format `tagValues/456`. The field is ignored (both PUT & PATCH) when empty.",
7704          "type": "object",
7705          "additionalProperties": {
7706            "type": "string"
7707          }
7708        }
7709      }
7710    },
7711    "AcceleratorConfig": {
7712      "id": "AcceleratorConfig",
7713      "description": "A specification of the type and number of accelerator cards attached to the instance.",
7714      "type": "object",
7715      "properties": {
7716        "acceleratorType": {
7717          "description": "Full or partial URL of the accelerator type resource to attach to this instance. For example: projects/my-project/zones/us-central1-c/acceleratorTypes/nvidia-tesla-p100 If you are creating an instance template, specify only the accelerator name. See GPUs on Compute Engine for a full list of accelerator types.",
7718          "type": "string"
7719        },
7720        "acceleratorCount": {
7721          "description": "The number of the guest accelerator cards exposed to this instance.",
7722          "type": "integer",
7723          "format": "int32"
7724        }
7725      }
7726    },
7727    "ReservationAffinity": {
7728      "id": "ReservationAffinity",
7729      "description": "Specifies the reservations that this instance can consume from.",
7730      "type": "object",
7731      "properties": {
7732        "consumeReservationType": {
7733          "description": "Specifies the type of reservation from which this instance can consume resources: ANY_RESERVATION (default), SPECIFIC_RESERVATION, or NO_RESERVATION. See Consuming reserved instances for examples.",
7734          "type": "string",
7735          "enumDescriptions": [
7736            "Consume any allocation available.",
7737            "Do not consume from any allocated capacity.",
7738            "Must consume from a specific reservation. Must specify key value fields for specifying the reservations.",
7739            ""
7740          ],
7741          "enum": [
7742            "ANY_RESERVATION",
7743            "NO_RESERVATION",
7744            "SPECIFIC_RESERVATION",
7745            "UNSPECIFIED"
7746          ]
7747        },
7748        "key": {
7749          "description": "Corresponds to the label key of a reservation resource. To target a SPECIFIC_RESERVATION by name, specify googleapis.com/reservation-name as the key and specify the name of your reservation as its value.",
7750          "type": "string"
7751        },
7752        "values": {
7753          "description": "Corresponds to the label values of a reservation resource. This can be either a name to a reservation in the same project or \"projects/different-project/reservations/some-reservation-name\" to target a shared reservation in the same zone but in a different project.",
7754          "type": "array",
7755          "items": {
7756            "type": "string"
7757          }
7758        }
7759      }
7760    },
7761    "DisplayDevice": {
7762      "id": "DisplayDevice",
7763      "description": "A set of Display Device options",
7764      "type": "object",
7765      "properties": {
7766        "enableDisplay": {
7767          "description": "Defines whether the instance has Display enabled.",
7768          "type": "boolean"
7769        }
7770      }
7771    },
7772    "ShieldedInstanceConfig": {
7773      "id": "ShieldedInstanceConfig",
7774      "description": "A set of Shielded Instance options.",
7775      "type": "object",
7776      "properties": {
7777        "enableSecureBoot": {
7778          "description": "Defines whether the instance has Secure Boot enabled. Disabled by default.",
7779          "type": "boolean"
7780        },
7781        "enableVtpm": {
7782          "description": "Defines whether the instance has the vTPM enabled. Enabled by default.",
7783          "type": "boolean"
7784        },
7785        "enableIntegrityMonitoring": {
7786          "description": "Defines whether the instance has integrity monitoring enabled. Enabled by default.",
7787          "type": "boolean"
7788        }
7789      }
7790    },
7791    "ShieldedInstanceIntegrityPolicy": {
7792      "id": "ShieldedInstanceIntegrityPolicy",
7793      "description": "The policy describes the baseline against which Instance boot integrity is measured.",
7794      "type": "object",
7795      "properties": {
7796        "updateAutoLearnPolicy": {
7797          "description": "Updates the integrity policy baseline using the measurements from the VM instance's most recent boot.",
7798          "type": "boolean"
7799        }
7800      }
7801    },
7802    "ConfidentialInstanceConfig": {
7803      "id": "ConfidentialInstanceConfig",
7804      "description": "A set of Confidential Instance options.",
7805      "type": "object",
7806      "properties": {
7807        "enableConfidentialCompute": {
7808          "description": "Defines whether the instance should have confidential compute enabled.",
7809          "type": "boolean"
7810        }
7811      }
7812    },
7813    "AdvancedMachineFeatures": {
7814      "id": "AdvancedMachineFeatures",
7815      "description": "Specifies options for controlling advanced machine features. Options that would traditionally be configured in a BIOS belong here. Features that require operating system support may have corresponding entries in the GuestOsFeatures of an Image (e.g., whether or not the OS in the Image supports nested virtualization being enabled or disabled).",
7816      "type": "object",
7817      "properties": {
7818        "enableNestedVirtualization": {
7819          "description": "Whether to enable nested virtualization or not (default is false).",
7820          "type": "boolean"
7821        },
7822        "threadsPerCore": {
7823          "description": "The number of threads per physical core. To disable simultaneous multithreading (SMT) set this to 1. If unset, the maximum number of threads supported per core by the underlying processor is assumed.",
7824          "type": "integer",
7825          "format": "int32"
7826        },
7827        "visibleCoreCount": {
7828          "description": "The number of physical cores to expose to an instance. Multiply by the number of threads per core to compute the total number of virtual CPUs to expose to the instance. If unset, the number of cores is inferred from the instance's nominal CPU count and the underlying platform's SMT width.",
7829          "type": "integer",
7830          "format": "int32"
7831        },
7832        "enableUefiNetworking": {
7833          "description": "Whether to enable UEFI networking for instance creation.",
7834          "type": "boolean"
7835        }
7836      }
7837    },
7838    "ResourceStatus": {
7839      "id": "ResourceStatus",
7840      "description": "Contains output only fields. Use this sub-message for actual values set on Instance attributes as compared to the value requested by the user (intent) in their instance CRUD calls.",
7841      "type": "object",
7842      "properties": {
7843        "upcomingMaintenance": {
7844          "$ref": "UpcomingMaintenance"
7845        },
7846        "physicalHost": {
7847          "description": "[Output Only] An opaque ID of the host on which the VM is running.",
7848          "type": "string"
7849        }
7850      }
7851    },
7852    "UpcomingMaintenance": {
7853      "id": "UpcomingMaintenance",
7854      "description": "Upcoming Maintenance notification information.",
7855      "type": "object",
7856      "properties": {
7857        "type": {
7858          "description": "Defines the type of maintenance.",
7859          "type": "string",
7860          "enumDescriptions": [
7861            "Scheduled maintenance (e.g. maintenance after uptime guarantee is complete).",
7862            "No type specified. Do not use this value.",
7863            "Unscheduled maintenance (e.g. emergency maintenance during uptime guarantee)."
7864          ],
7865          "enum": [
7866            "SCHEDULED",
7867            "UNKNOWN_TYPE",
7868            "UNSCHEDULED"
7869          ]
7870        },
7871        "canReschedule": {
7872          "description": "Indicates if the maintenance can be customer triggered.",
7873          "type": "boolean"
7874        },
7875        "windowStartTime": {
7876          "description": "The current start time of the maintenance window. This timestamp value is in RFC3339 text format.",
7877          "type": "string"
7878        },
7879        "windowEndTime": {
7880          "description": "The time by which the maintenance disruption will be completed. This timestamp value is in RFC3339 text format.",
7881          "type": "string"
7882        },
7883        "latestWindowStartTime": {
7884          "description": "The latest time for the planned maintenance window to start. This timestamp value is in RFC3339 text format.",
7885          "type": "string"
7886        },
7887        "maintenanceStatus": {
7888          "type": "string",
7889          "enumDescriptions": [
7890            "There is ongoing maintenance on this VM.",
7891            "There is pending maintenance.",
7892            "Unknown maintenance status. Do not use this value."
7893          ],
7894          "enum": [
7895            "ONGOING",
7896            "PENDING",
7897            "UNKNOWN"
7898          ]
7899        }
7900      }
7901    },
7902    "NetworkPerformanceConfig": {
7903      "id": "NetworkPerformanceConfig",
7904      "type": "object",
7905      "properties": {
7906        "totalEgressBandwidthTier": {
7907          "type": "string",
7908          "enumDescriptions": [
7909            "",
7910            ""
7911          ],
7912          "enum": [
7913            "DEFAULT",
7914            "TIER_1"
7915          ]
7916        }
7917      }
7918    },
7919    "InstanceAggregatedList": {
7920      "id": "InstanceAggregatedList",
7921      "type": "object",
7922      "properties": {
7923        "kind": {
7924          "description": "[Output Only] Type of resource. Always compute#instanceAggregatedList for aggregated lists of Instance resources.",
7925          "default": "compute#instanceAggregatedList",
7926          "type": "string"
7927        },
7928        "id": {
7929          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
7930          "type": "string"
7931        },
7932        "items": {
7933          "description": "An object that contains a list of instances scoped by zone.",
7934          "type": "object",
7935          "additionalProperties": {
7936            "description": "[Output Only] Name of the scope containing this set of instances.",
7937            "$ref": "InstancesScopedList"
7938          }
7939        },
7940        "nextPageToken": {
7941          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
7942          "type": "string"
7943        },
7944        "selfLink": {
7945          "description": "[Output Only] Server-defined URL for this resource.",
7946          "type": "string"
7947        },
7948        "warning": {
7949          "description": "[Output Only] Informational warning message.",
7950          "type": "object",
7951          "properties": {
7952            "code": {
7953              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
7954              "type": "string",
7955              "enumDescriptions": [
7956                "Warning about failed cleanup of transient changes made by a failed operation.",
7957                "A link to a deprecated resource was created.",
7958                "When deploying and at least one of the resources has a type marked as deprecated",
7959                "The user created a boot disk that is larger than image size.",
7960                "When deploying and at least one of the resources has a type marked as experimental",
7961                "Warning that is present in an external api call",
7962                "Warning that value of a field has been overridden. Deprecated unused field.",
7963                "The operation involved use of an injected kernel, which is deprecated.",
7964                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
7965                "When deploying a deployment with a exceedingly large number of resources",
7966                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
7967                "A resource depends on a missing type",
7968                "The route's nextHopIp address is not assigned to an instance on the network.",
7969                "The route's next hop instance cannot ip forward.",
7970                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
7971                "The route's nextHopInstance URL refers to an instance that does not exist.",
7972                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
7973                "The route's next hop instance does not have a status of RUNNING.",
7974                "Error which is not critical. We decided to continue the process despite the mentioned error.",
7975                "No results are present on a particular list page.",
7976                "Success is reported, but some results may be missing due to errors",
7977                "The user attempted to use a resource that requires a TOS they have not accepted.",
7978                "Warning that a resource is in use.",
7979                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
7980                "When a resource schema validation is ignored.",
7981                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
7982                "When undeclared properties in the schema are present",
7983                "A given scope cannot be reached."
7984              ],
7985              "enumDeprecated": [
7986                false,
7987                false,
7988                false,
7989                false,
7990                false,
7991                false,
7992                true,
7993                false,
7994                false,
7995                false,
7996                false,
7997                false,
7998                false,
7999                false,
8000                false,
8001                false,
8002                false,
8003                false,
8004                false,
8005                false,
8006                false,
8007                false,
8008                false,
8009                false,
8010                false,
8011                false,
8012                false,
8013                false
8014              ],
8015              "enum": [
8016                "CLEANUP_FAILED",
8017                "DEPRECATED_RESOURCE_USED",
8018                "DEPRECATED_TYPE_USED",
8019                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
8020                "EXPERIMENTAL_TYPE_USED",
8021                "EXTERNAL_API_WARNING",
8022                "FIELD_VALUE_OVERRIDEN",
8023                "INJECTED_KERNELS_DEPRECATED",
8024                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
8025                "LARGE_DEPLOYMENT_WARNING",
8026                "LIST_OVERHEAD_QUOTA_EXCEED",
8027                "MISSING_TYPE_DEPENDENCY",
8028                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
8029                "NEXT_HOP_CANNOT_IP_FORWARD",
8030                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
8031                "NEXT_HOP_INSTANCE_NOT_FOUND",
8032                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
8033                "NEXT_HOP_NOT_RUNNING",
8034                "NOT_CRITICAL_ERROR",
8035                "NO_RESULTS_ON_PAGE",
8036                "PARTIAL_SUCCESS",
8037                "REQUIRED_TOS_AGREEMENT",
8038                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
8039                "RESOURCE_NOT_DELETED",
8040                "SCHEMA_VALIDATION_IGNORED",
8041                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
8042                "UNDECLARED_PROPERTIES",
8043                "UNREACHABLE"
8044              ]
8045            },
8046            "message": {
8047              "description": "[Output Only] A human-readable description of the warning code.",
8048              "type": "string"
8049            },
8050            "data": {
8051              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
8052              "type": "array",
8053              "items": {
8054                "type": "object",
8055                "properties": {
8056                  "key": {
8057                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
8058                    "type": "string"
8059                  },
8060                  "value": {
8061                    "description": "[Output Only] A warning data value corresponding to the key.",
8062                    "type": "string"
8063                  }
8064                }
8065              }
8066            }
8067          }
8068        },
8069        "unreachables": {
8070          "description": "[Output Only] Unreachable resources.",
8071          "type": "array",
8072          "items": {
8073            "type": "string"
8074          }
8075        }
8076      }
8077    },
8078    "InstancesScopedList": {
8079      "id": "InstancesScopedList",
8080      "type": "object",
8081      "properties": {
8082        "instances": {
8083          "description": "[Output Only] A list of instances contained in this scope.",
8084          "type": "array",
8085          "items": {
8086            "$ref": "Instance"
8087          }
8088        },
8089        "warning": {
8090          "description": "[Output Only] Informational warning which replaces the list of instances when the list is empty.",
8091          "type": "object",
8092          "properties": {
8093            "code": {
8094              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
8095              "type": "string",
8096              "enumDescriptions": [
8097                "Warning about failed cleanup of transient changes made by a failed operation.",
8098                "A link to a deprecated resource was created.",
8099                "When deploying and at least one of the resources has a type marked as deprecated",
8100                "The user created a boot disk that is larger than image size.",
8101                "When deploying and at least one of the resources has a type marked as experimental",
8102                "Warning that is present in an external api call",
8103                "Warning that value of a field has been overridden. Deprecated unused field.",
8104                "The operation involved use of an injected kernel, which is deprecated.",
8105                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
8106                "When deploying a deployment with a exceedingly large number of resources",
8107                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
8108                "A resource depends on a missing type",
8109                "The route's nextHopIp address is not assigned to an instance on the network.",
8110                "The route's next hop instance cannot ip forward.",
8111                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
8112                "The route's nextHopInstance URL refers to an instance that does not exist.",
8113                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
8114                "The route's next hop instance does not have a status of RUNNING.",
8115                "Error which is not critical. We decided to continue the process despite the mentioned error.",
8116                "No results are present on a particular list page.",
8117                "Success is reported, but some results may be missing due to errors",
8118                "The user attempted to use a resource that requires a TOS they have not accepted.",
8119                "Warning that a resource is in use.",
8120                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
8121                "When a resource schema validation is ignored.",
8122                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
8123                "When undeclared properties in the schema are present",
8124                "A given scope cannot be reached."
8125              ],
8126              "enumDeprecated": [
8127                false,
8128                false,
8129                false,
8130                false,
8131                false,
8132                false,
8133                true,
8134                false,
8135                false,
8136                false,
8137                false,
8138                false,
8139                false,
8140                false,
8141                false,
8142                false,
8143                false,
8144                false,
8145                false,
8146                false,
8147                false,
8148                false,
8149                false,
8150                false,
8151                false,
8152                false,
8153                false,
8154                false
8155              ],
8156              "enum": [
8157                "CLEANUP_FAILED",
8158                "DEPRECATED_RESOURCE_USED",
8159                "DEPRECATED_TYPE_USED",
8160                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
8161                "EXPERIMENTAL_TYPE_USED",
8162                "EXTERNAL_API_WARNING",
8163                "FIELD_VALUE_OVERRIDEN",
8164                "INJECTED_KERNELS_DEPRECATED",
8165                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
8166                "LARGE_DEPLOYMENT_WARNING",
8167                "LIST_OVERHEAD_QUOTA_EXCEED",
8168                "MISSING_TYPE_DEPENDENCY",
8169                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
8170                "NEXT_HOP_CANNOT_IP_FORWARD",
8171                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
8172                "NEXT_HOP_INSTANCE_NOT_FOUND",
8173                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
8174                "NEXT_HOP_NOT_RUNNING",
8175                "NOT_CRITICAL_ERROR",
8176                "NO_RESULTS_ON_PAGE",
8177                "PARTIAL_SUCCESS",
8178                "REQUIRED_TOS_AGREEMENT",
8179                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
8180                "RESOURCE_NOT_DELETED",
8181                "SCHEMA_VALIDATION_IGNORED",
8182                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
8183                "UNDECLARED_PROPERTIES",
8184                "UNREACHABLE"
8185              ]
8186            },
8187            "message": {
8188              "description": "[Output Only] A human-readable description of the warning code.",
8189              "type": "string"
8190            },
8191            "data": {
8192              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
8193              "type": "array",
8194              "items": {
8195                "type": "object",
8196                "properties": {
8197                  "key": {
8198                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
8199                    "type": "string"
8200                  },
8201                  "value": {
8202                    "description": "[Output Only] A warning data value corresponding to the key.",
8203                    "type": "string"
8204                  }
8205                }
8206              }
8207            }
8208          }
8209        }
8210      }
8211    },
8212    "InstanceListReferrers": {
8213      "id": "InstanceListReferrers",
8214      "description": "Contains a list of instance referrers.",
8215      "type": "object",
8216      "properties": {
8217        "kind": {
8218          "description": "[Output Only] Type of resource. Always compute#instanceListReferrers for lists of Instance referrers.",
8219          "default": "compute#instanceListReferrers",
8220          "type": "string"
8221        },
8222        "id": {
8223          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
8224          "type": "string"
8225        },
8226        "items": {
8227          "description": "A list of Reference resources.",
8228          "type": "array",
8229          "items": {
8230            "$ref": "Reference"
8231          }
8232        },
8233        "nextPageToken": {
8234          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
8235          "type": "string"
8236        },
8237        "selfLink": {
8238          "description": "[Output Only] Server-defined URL for this resource.",
8239          "type": "string"
8240        },
8241        "warning": {
8242          "description": "[Output Only] Informational warning message.",
8243          "type": "object",
8244          "properties": {
8245            "code": {
8246              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
8247              "type": "string",
8248              "enumDescriptions": [
8249                "Warning about failed cleanup of transient changes made by a failed operation.",
8250                "A link to a deprecated resource was created.",
8251                "When deploying and at least one of the resources has a type marked as deprecated",
8252                "The user created a boot disk that is larger than image size.",
8253                "When deploying and at least one of the resources has a type marked as experimental",
8254                "Warning that is present in an external api call",
8255                "Warning that value of a field has been overridden. Deprecated unused field.",
8256                "The operation involved use of an injected kernel, which is deprecated.",
8257                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
8258                "When deploying a deployment with a exceedingly large number of resources",
8259                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
8260                "A resource depends on a missing type",
8261                "The route's nextHopIp address is not assigned to an instance on the network.",
8262                "The route's next hop instance cannot ip forward.",
8263                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
8264                "The route's nextHopInstance URL refers to an instance that does not exist.",
8265                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
8266                "The route's next hop instance does not have a status of RUNNING.",
8267                "Error which is not critical. We decided to continue the process despite the mentioned error.",
8268                "No results are present on a particular list page.",
8269                "Success is reported, but some results may be missing due to errors",
8270                "The user attempted to use a resource that requires a TOS they have not accepted.",
8271                "Warning that a resource is in use.",
8272                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
8273                "When a resource schema validation is ignored.",
8274                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
8275                "When undeclared properties in the schema are present",
8276                "A given scope cannot be reached."
8277              ],
8278              "enumDeprecated": [
8279                false,
8280                false,
8281                false,
8282                false,
8283                false,
8284                false,
8285                true,
8286                false,
8287                false,
8288                false,
8289                false,
8290                false,
8291                false,
8292                false,
8293                false,
8294                false,
8295                false,
8296                false,
8297                false,
8298                false,
8299                false,
8300                false,
8301                false,
8302                false,
8303                false,
8304                false,
8305                false,
8306                false
8307              ],
8308              "enum": [
8309                "CLEANUP_FAILED",
8310                "DEPRECATED_RESOURCE_USED",
8311                "DEPRECATED_TYPE_USED",
8312                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
8313                "EXPERIMENTAL_TYPE_USED",
8314                "EXTERNAL_API_WARNING",
8315                "FIELD_VALUE_OVERRIDEN",
8316                "INJECTED_KERNELS_DEPRECATED",
8317                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
8318                "LARGE_DEPLOYMENT_WARNING",
8319                "LIST_OVERHEAD_QUOTA_EXCEED",
8320                "MISSING_TYPE_DEPENDENCY",
8321                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
8322                "NEXT_HOP_CANNOT_IP_FORWARD",
8323                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
8324                "NEXT_HOP_INSTANCE_NOT_FOUND",
8325                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
8326                "NEXT_HOP_NOT_RUNNING",
8327                "NOT_CRITICAL_ERROR",
8328                "NO_RESULTS_ON_PAGE",
8329                "PARTIAL_SUCCESS",
8330                "REQUIRED_TOS_AGREEMENT",
8331                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
8332                "RESOURCE_NOT_DELETED",
8333                "SCHEMA_VALIDATION_IGNORED",
8334                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
8335                "UNDECLARED_PROPERTIES",
8336                "UNREACHABLE"
8337              ]
8338            },
8339            "message": {
8340              "description": "[Output Only] A human-readable description of the warning code.",
8341              "type": "string"
8342            },
8343            "data": {
8344              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
8345              "type": "array",
8346              "items": {
8347                "type": "object",
8348                "properties": {
8349                  "key": {
8350                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
8351                    "type": "string"
8352                  },
8353                  "value": {
8354                    "description": "[Output Only] A warning data value corresponding to the key.",
8355                    "type": "string"
8356                  }
8357                }
8358              }
8359            }
8360          }
8361        }
8362      }
8363    },
8364    "Reference": {
8365      "id": "Reference",
8366      "description": "Represents a reference to a resource.",
8367      "type": "object",
8368      "properties": {
8369        "kind": {
8370          "description": "[Output Only] Type of the resource. Always compute#reference for references.",
8371          "default": "compute#reference",
8372          "type": "string"
8373        },
8374        "target": {
8375          "description": "URL of the resource to which this reference points.",
8376          "type": "string"
8377        },
8378        "referenceType": {
8379          "description": "A description of the reference type with no implied semantics. Possible values include: 1. MEMBER_OF ",
8380          "type": "string"
8381        },
8382        "referrer": {
8383          "description": "URL of the resource which refers to the target.",
8384          "type": "string"
8385        }
8386      }
8387    },
8388    "SerialPortOutput": {
8389      "id": "SerialPortOutput",
8390      "description": "An instance serial console output.",
8391      "type": "object",
8392      "properties": {
8393        "kind": {
8394          "description": "[Output Only] Type of the resource. Always compute#serialPortOutput for serial port output.",
8395          "default": "compute#serialPortOutput",
8396          "type": "string"
8397        },
8398        "contents": {
8399          "description": "[Output Only] The contents of the console output.",
8400          "type": "string"
8401        },
8402        "start": {
8403          "description": "The starting byte position of the output that was returned. This should match the start parameter sent with the request. If the serial console output exceeds the size of the buffer (1 MB), older output is overwritten by newer content. The output start value will indicate the byte position of the output that was returned, which might be different than the `start` value that was specified in the request.",
8404          "type": "string",
8405          "format": "int64"
8406        },
8407        "next": {
8408          "description": "[Output Only] The position of the next byte of content, regardless of whether the content exists, following the output returned in the `contents` property. Use this value in the next request as the start parameter.",
8409          "type": "string",
8410          "format": "int64"
8411        },
8412        "selfLink": {
8413          "description": "[Output Only] Server-defined URL for this resource.",
8414          "type": "string"
8415        }
8416      }
8417    },
8418    "Screenshot": {
8419      "id": "Screenshot",
8420      "description": "An instance's screenshot.",
8421      "type": "object",
8422      "properties": {
8423        "kind": {
8424          "description": "[Output Only] Type of the resource. Always compute#screenshot for the screenshots.",
8425          "default": "compute#screenshot",
8426          "type": "string"
8427        },
8428        "contents": {
8429          "description": "[Output Only] The Base64-encoded screenshot data.",
8430          "type": "string"
8431        }
8432      }
8433    },
8434    "GuestAttributes": {
8435      "id": "GuestAttributes",
8436      "description": "A guest attributes entry.",
8437      "type": "object",
8438      "properties": {
8439        "kind": {
8440          "description": "[Output Only] Type of the resource. Always compute#guestAttributes for guest attributes entry.",
8441          "default": "compute#guestAttributes",
8442          "type": "string"
8443        },
8444        "variableKey": {
8445          "description": "The key to search for.",
8446          "type": "string"
8447        },
8448        "variableValue": {
8449          "description": "[Output Only] The value found for the requested key.",
8450          "type": "string"
8451        },
8452        "queryPath": {
8453          "description": "The path to be queried. This can be the default namespace ('') or a nested namespace ('\\/') or a specified key ('\\/\\').",
8454          "type": "string"
8455        },
8456        "queryValue": {
8457          "description": "[Output Only] The value of the requested queried path.",
8458          "$ref": "GuestAttributesValue"
8459        },
8460        "selfLink": {
8461          "description": "[Output Only] Server-defined URL for this resource.",
8462          "type": "string"
8463        }
8464      }
8465    },
8466    "GuestAttributesValue": {
8467      "id": "GuestAttributesValue",
8468      "description": "Array of guest attribute namespace/key/value tuples.",
8469      "type": "object",
8470      "properties": {
8471        "items": {
8472          "type": "array",
8473          "items": {
8474            "$ref": "GuestAttributesEntry"
8475          }
8476        }
8477      }
8478    },
8479    "GuestAttributesEntry": {
8480      "id": "GuestAttributesEntry",
8481      "description": "A guest attributes namespace/key/value entry.",
8482      "type": "object",
8483      "properties": {
8484        "namespace": {
8485          "description": "Namespace for the guest attribute entry.",
8486          "type": "string"
8487        },
8488        "key": {
8489          "description": "Key for the guest attribute entry.",
8490          "type": "string"
8491        },
8492        "value": {
8493          "description": "Value for the guest attribute entry.",
8494          "type": "string"
8495        }
8496      }
8497    },
8498    "InstancesSetMachineResourcesRequest": {
8499      "id": "InstancesSetMachineResourcesRequest",
8500      "type": "object",
8501      "properties": {
8502        "guestAccelerators": {
8503          "description": "A list of the type and count of accelerator cards attached to the instance.",
8504          "type": "array",
8505          "items": {
8506            "$ref": "AcceleratorConfig"
8507          }
8508        }
8509      }
8510    },
8511    "InstancesSetMachineTypeRequest": {
8512      "id": "InstancesSetMachineTypeRequest",
8513      "type": "object",
8514      "properties": {
8515        "machineType": {
8516          "description": "Full or partial URL of the machine type resource. See Machine Types for a full list of machine types. For example: zones/us-central1-f/machineTypes/n1-standard-1",
8517          "type": "string"
8518        }
8519      }
8520    },
8521    "InstancesSetMinCpuPlatformRequest": {
8522      "id": "InstancesSetMinCpuPlatformRequest",
8523      "type": "object",
8524      "properties": {
8525        "minCpuPlatform": {
8526          "description": "Minimum cpu/platform this instance should be started at.",
8527          "type": "string"
8528        }
8529      }
8530    },
8531    "InstancesSetLabelsRequest": {
8532      "id": "InstancesSetLabelsRequest",
8533      "type": "object",
8534      "properties": {
8535        "labels": {
8536          "type": "object",
8537          "additionalProperties": {
8538            "type": "string"
8539          }
8540        },
8541        "labelFingerprint": {
8542          "description": "Fingerprint of the previous set of labels for this resource, used to prevent conflicts. Provide the latest fingerprint value when making a request to add or change labels.",
8543          "type": "string",
8544          "format": "byte"
8545        }
8546      }
8547    },
8548    "InstancesSetNameRequest": {
8549      "id": "InstancesSetNameRequest",
8550      "type": "object",
8551      "properties": {
8552        "name": {
8553          "description": "The name to be applied to the instance. Needs to be RFC 1035 compliant.",
8554          "type": "string"
8555        },
8556        "currentName": {
8557          "description": "The current name of this resource, used to prevent conflicts. Provide the latest name when making a request to change name.",
8558          "type": "string"
8559        }
8560      }
8561    },
8562    "InstancesStartWithEncryptionKeyRequest": {
8563      "id": "InstancesStartWithEncryptionKeyRequest",
8564      "type": "object",
8565      "properties": {
8566        "disks": {
8567          "description": "Array of disks associated with this instance that are protected with a customer-supplied encryption key. In order to start the instance, the disk url and its corresponding key must be provided. If the disk is not protected with a customer-supplied encryption key it should not be specified.",
8568          "type": "array",
8569          "items": {
8570            "$ref": "CustomerEncryptionKeyProtectedDisk"
8571          }
8572        }
8573      }
8574    },
8575    "CustomerEncryptionKeyProtectedDisk": {
8576      "id": "CustomerEncryptionKeyProtectedDisk",
8577      "type": "object",
8578      "properties": {
8579        "source": {
8580          "description": "Specifies a valid partial or full URL to an existing Persistent Disk resource. This field is only applicable for persistent disks. For example: \"source\": \"/compute/v1/projects/project_id/zones/zone/disks/ disk_name ",
8581          "type": "string"
8582        },
8583        "diskEncryptionKey": {
8584          "description": "Decrypts data associated with the disk with a customer-supplied encryption key.",
8585          "$ref": "CustomerEncryptionKey"
8586        }
8587      }
8588    },
8589    "InstancesSetServiceAccountRequest": {
8590      "id": "InstancesSetServiceAccountRequest",
8591      "type": "object",
8592      "properties": {
8593        "email": {
8594          "description": "Email address of the service account.",
8595          "type": "string"
8596        },
8597        "scopes": {
8598          "description": "The list of scopes to be made available for this service account.",
8599          "type": "array",
8600          "items": {
8601            "type": "string"
8602          }
8603        }
8604      }
8605    },
8606    "InstancesAddResourcePoliciesRequest": {
8607      "id": "InstancesAddResourcePoliciesRequest",
8608      "type": "object",
8609      "properties": {
8610        "resourcePolicies": {
8611          "description": "Resource policies to be added to this instance.",
8612          "type": "array",
8613          "items": {
8614            "type": "string"
8615          }
8616        }
8617      }
8618    },
8619    "InstancesRemoveResourcePoliciesRequest": {
8620      "id": "InstancesRemoveResourcePoliciesRequest",
8621      "type": "object",
8622      "properties": {
8623        "resourcePolicies": {
8624          "description": "Resource policies to be removed from this instance.",
8625          "type": "array",
8626          "items": {
8627            "type": "string"
8628          }
8629        }
8630      }
8631    },
8632    "InstancesSetSecurityPolicyRequest": {
8633      "id": "InstancesSetSecurityPolicyRequest",
8634      "type": "object",
8635      "properties": {
8636        "securityPolicy": {
8637          "description": "A full or partial URL to a security policy to add to this instance. If this field is set to an empty string it will remove the associated security policy.",
8638          "type": "string"
8639        },
8640        "networkInterfaces": {
8641          "description": "The network interfaces that the security policy will be applied to. Network interfaces use the nicN naming format. You can only set a security policy for network interfaces with an access config.",
8642          "type": "array",
8643          "items": {
8644            "type": "string"
8645          }
8646        }
8647      }
8648    },
8649    "ShieldedInstanceIdentity": {
8650      "id": "ShieldedInstanceIdentity",
8651      "description": "A Shielded Instance Identity.",
8652      "type": "object",
8653      "properties": {
8654        "kind": {
8655          "description": "[Output Only] Type of the resource. Always compute#shieldedInstanceIdentity for shielded Instance identity entry.",
8656          "default": "compute#shieldedInstanceIdentity",
8657          "type": "string"
8658        },
8659        "signingKey": {
8660          "description": "An Attestation Key (AK) made by the RSA 2048 algorithm issued to the Shielded Instance's vTPM.",
8661          "$ref": "ShieldedInstanceIdentityEntry"
8662        },
8663        "encryptionKey": {
8664          "description": "An Endorsement Key (EK) made by the RSA 2048 algorithm issued to the Shielded Instance's vTPM.",
8665          "$ref": "ShieldedInstanceIdentityEntry"
8666        }
8667      }
8668    },
8669    "ShieldedInstanceIdentityEntry": {
8670      "id": "ShieldedInstanceIdentityEntry",
8671      "description": "A Shielded Instance Identity Entry.",
8672      "type": "object",
8673      "properties": {
8674        "ekCert": {
8675          "description": "A PEM-encoded X.509 certificate. This field can be empty.",
8676          "type": "string"
8677        },
8678        "ekPub": {
8679          "description": "A PEM-encoded public key.",
8680          "type": "string"
8681        }
8682      }
8683    },
8684    "BulkInsertInstanceResource": {
8685      "id": "BulkInsertInstanceResource",
8686      "description": "A transient resource used in compute.instances.bulkInsert and compute.regionInstances.bulkInsert . This resource is not persisted anywhere, it is used only for processing the requests.",
8687      "type": "object",
8688      "properties": {
8689        "count": {
8690          "description": "The maximum number of instances to create.",
8691          "type": "string",
8692          "format": "int64"
8693        },
8694        "minCount": {
8695          "description": "The minimum number of instances to create. If no min_count is specified then count is used as the default value. If min_count instances cannot be created, then no instances will be created and instances already created will be deleted.",
8696          "type": "string",
8697          "format": "int64"
8698        },
8699        "namePattern": {
8700          "description": "The string pattern used for the names of the VMs. Either name_pattern or per_instance_properties must be set. The pattern must contain one continuous sequence of placeholder hash characters (#) with each character corresponding to one digit of the generated instance name. Example: a name_pattern of inst-#### generates instance names such as inst-0001 and inst-0002. If existing instances in the same project and zone have names that match the name pattern then the generated instance numbers start after the biggest existing number. For example, if there exists an instance with name inst-0050, then instance names generated using the pattern inst-#### begin with inst-0051. The name pattern placeholder #...# can contain up to 18 characters.",
8701          "type": "string"
8702        },
8703        "perInstanceProperties": {
8704          "description": "Per-instance properties to be set on individual instances. Keys of this map specify requested instance names. Can be empty if name_pattern is used.",
8705          "type": "object",
8706          "additionalProperties": {
8707            "$ref": "BulkInsertInstanceResourcePerInstanceProperties"
8708          }
8709        },
8710        "sourceInstanceTemplate": {
8711          "description": "Specifies the instance template from which to create instances. You may combine sourceInstanceTemplate with instanceProperties to override specific values from an existing instance template. Bulk API follows the semantics of JSON Merge Patch described by RFC 7396. It can be a full or partial URL. For example, the following are all valid URLs to an instance template: - https://www.googleapis.com/compute/v1/projects/project /global/instanceTemplates/instanceTemplate - projects/project/global/instanceTemplates/instanceTemplate - global/instanceTemplates/instanceTemplate This field is optional.",
8712          "type": "string"
8713        },
8714        "instanceProperties": {
8715          "description": "The instance properties defining the VM instances to be created. Required if sourceInstanceTemplate is not provided.",
8716          "$ref": "InstanceProperties"
8717        },
8718        "locationPolicy": {
8719          "description": "Policy for chosing target zone. For more information, see Create VMs in bulk .",
8720          "$ref": "LocationPolicy"
8721        }
8722      }
8723    },
8724    "BulkInsertInstanceResourcePerInstanceProperties": {
8725      "id": "BulkInsertInstanceResourcePerInstanceProperties",
8726      "description": "Per-instance properties to be set on individual instances. To be extended in the future.",
8727      "type": "object",
8728      "properties": {
8729        "name": {
8730          "description": "This field is only temporary. It will be removed. Do not use it.",
8731          "type": "string"
8732        },
8733        "hostname": {
8734          "description": "Specifies the hostname of the instance. More details in: https://cloud.google.com/compute/docs/instances/custom-hostname-vm#naming_convention",
8735          "type": "string"
8736        }
8737      }
8738    },
8739    "InstanceProperties": {
8740      "id": "InstanceProperties",
8741      "type": "object",
8742      "properties": {
8743        "description": {
8744          "description": "An optional text description for the instances that are created from these properties.",
8745          "type": "string"
8746        },
8747        "tags": {
8748          "description": "A list of tags to apply to the instances that are created from these properties. The tags identify valid sources or targets for network firewalls. The setTags method can modify this list of tags. Each tag within the list must comply with RFC1035.",
8749          "$ref": "Tags"
8750        },
8751        "resourceManagerTags": {
8752          "description": "Resource manager tags to be bound to the instance. Tag keys and values have the same definition as resource manager tags. Keys must be in the format `tagKeys/{tag_key_id}`, and values are in the format `tagValues/456`. The field is ignored (both PUT & PATCH) when empty.",
8753          "type": "object",
8754          "additionalProperties": {
8755            "type": "string"
8756          }
8757        },
8758        "machineType": {
8759          "description": "The machine type to use for instances that are created from these properties.",
8760          "annotations": {
8761            "required": [
8762              "compute.instanceTemplates.insert"
8763            ]
8764          },
8765          "type": "string"
8766        },
8767        "canIpForward": {
8768          "description": "Enables instances created based on these properties to send packets with source IP addresses other than their own and receive packets with destination IP addresses other than their own. If these instances will be used as an IP gateway or it will be set as the next-hop in a Route resource, specify true. If unsure, leave this set to false. See the Enable IP forwarding documentation for more information.",
8769          "type": "boolean"
8770        },
8771        "networkInterfaces": {
8772          "description": "An array of network access configurations for this interface.",
8773          "type": "array",
8774          "items": {
8775            "$ref": "NetworkInterface"
8776          }
8777        },
8778        "disks": {
8779          "description": "An array of disks that are associated with the instances that are created from these properties.",
8780          "type": "array",
8781          "items": {
8782            "$ref": "AttachedDisk"
8783          }
8784        },
8785        "metadata": {
8786          "description": "The metadata key/value pairs to assign to instances that are created from these properties. These pairs can consist of custom metadata or predefined keys. See Project and instance metadata for more information.",
8787          "$ref": "Metadata"
8788        },
8789        "serviceAccounts": {
8790          "description": "A list of service accounts with specified scopes. Access tokens for these service accounts are available to the instances that are created from these properties. Use metadata queries to obtain the access tokens for these instances.",
8791          "type": "array",
8792          "items": {
8793            "$ref": "ServiceAccount"
8794          }
8795        },
8796        "scheduling": {
8797          "description": "Specifies the scheduling options for the instances that are created from these properties.",
8798          "$ref": "Scheduling"
8799        },
8800        "labels": {
8801          "description": "Labels to apply to instances that are created from these properties.",
8802          "type": "object",
8803          "additionalProperties": {
8804            "type": "string"
8805          }
8806        },
8807        "guestAccelerators": {
8808          "description": "A list of guest accelerator cards' type and count to use for instances created from these properties.",
8809          "type": "array",
8810          "items": {
8811            "$ref": "AcceleratorConfig"
8812          }
8813        },
8814        "minCpuPlatform": {
8815          "description": "Minimum cpu/platform to be used by instances. The instance may be scheduled on the specified or newer cpu/platform. Applicable values are the friendly names of CPU platforms, such as minCpuPlatform: \"Intel Haswell\" or minCpuPlatform: \"Intel Sandy Bridge\". For more information, read Specifying a Minimum CPU Platform.",
8816          "type": "string"
8817        },
8818        "reservationAffinity": {
8819          "description": "Specifies the reservations that instances can consume from. Note that for MachineImage, this is not supported yet.",
8820          "$ref": "ReservationAffinity"
8821        },
8822        "shieldedInstanceConfig": {
8823          "description": "Note that for MachineImage, this is not supported yet.",
8824          "$ref": "ShieldedInstanceConfig"
8825        },
8826        "resourcePolicies": {
8827          "description": "Resource policies (names, not URLs) applied to instances created from these properties. Note that for MachineImage, this is not supported yet.",
8828          "type": "array",
8829          "items": {
8830            "type": "string"
8831          }
8832        },
8833        "confidentialInstanceConfig": {
8834          "description": "Specifies the Confidential Instance options. Note that for MachineImage, this is not supported yet.",
8835          "$ref": "ConfidentialInstanceConfig"
8836        },
8837        "privateIpv6GoogleAccess": {
8838          "description": "The private IPv6 google access type for VMs. If not specified, use INHERIT_FROM_SUBNETWORK as default. Note that for MachineImage, this is not supported yet.",
8839          "type": "string",
8840          "enumDescriptions": [
8841            "Bidirectional private IPv6 access to/from Google services. If specified, the subnetwork who is attached to the instance's default network interface will be assigned an internal IPv6 prefix if it doesn't have before.",
8842            "Outbound private IPv6 access from VMs in this subnet to Google services. If specified, the subnetwork who is attached to the instance's default network interface will be assigned an internal IPv6 prefix if it doesn't have before.",
8843            "Each network interface inherits PrivateIpv6GoogleAccess from its subnetwork."
8844          ],
8845          "enum": [
8846            "ENABLE_BIDIRECTIONAL_ACCESS_TO_GOOGLE",
8847            "ENABLE_OUTBOUND_VM_ACCESS_TO_GOOGLE",
8848            "INHERIT_FROM_SUBNETWORK"
8849          ]
8850        },
8851        "advancedMachineFeatures": {
8852          "description": "Controls for advanced machine-related behavior features. Note that for MachineImage, this is not supported yet.",
8853          "$ref": "AdvancedMachineFeatures"
8854        },
8855        "networkPerformanceConfig": {
8856          "description": "Note that for MachineImage, this is not supported yet.",
8857          "$ref": "NetworkPerformanceConfig"
8858        },
8859        "keyRevocationActionType": {
8860          "description": "KeyRevocationActionType of the instance. Supported options are \"STOP\" and \"NONE\". The default value is \"NONE\" if it is not specified.",
8861          "type": "string",
8862          "enumDescriptions": [
8863            "Default value. This value is unused.",
8864            "Indicates user chose no operation.",
8865            "Indicates user chose to opt for VM shutdown on key revocation."
8866          ],
8867          "enum": [
8868            "KEY_REVOCATION_ACTION_TYPE_UNSPECIFIED",
8869            "NONE",
8870            "STOP"
8871          ]
8872        }
8873      }
8874    },
8875    "LocationPolicy": {
8876      "id": "LocationPolicy",
8877      "description": "Configuration for location policy among multiple possible locations (e.g. preferences for zone selection among zones in a single region).",
8878      "type": "object",
8879      "properties": {
8880        "locations": {
8881          "description": "Location configurations mapped by location name. Currently only zone names are supported and must be represented as valid internal URLs, such as zones/us-central1-a.",
8882          "type": "object",
8883          "additionalProperties": {
8884            "$ref": "LocationPolicyLocation"
8885          }
8886        },
8887        "targetShape": {
8888          "description": "Strategy for distributing VMs across zones in a region.",
8889          "type": "string",
8890          "enumDescriptions": [
8891            "GCE picks zones for creating VM instances to fulfill the requested number of VMs within present resource constraints and to maximize utilization of unused zonal reservations. Recommended for batch workloads that do not require high availability.",
8892            "GCE always selects a single zone for all the VMs, optimizing for resource quotas, available reservations and general capacity. Recommended for batch workloads that cannot tollerate distribution over multiple zones. This the default shape in Bulk Insert and Capacity Advisor APIs.",
8893            "GCE prioritizes acquisition of resources, scheduling VMs in zones where resources are available while distributing VMs as evenly as possible across allowed zones to minimize the impact of zonal failure. Recommended for highly available serving workloads."
8894          ],
8895          "enum": [
8896            "ANY",
8897            "ANY_SINGLE_ZONE",
8898            "BALANCED"
8899          ]
8900        }
8901      }
8902    },
8903    "LocationPolicyLocation": {
8904      "id": "LocationPolicyLocation",
8905      "type": "object",
8906      "properties": {
8907        "preference": {
8908          "description": "Preference for a given location. Set to either ALLOW or DENY.",
8909          "type": "string",
8910          "enumDescriptions": [
8911            "Location is allowed for use.",
8912            "Location is prohibited.",
8913            "Default value, unused."
8914          ],
8915          "enum": [
8916            "ALLOW",
8917            "DENY",
8918            "PREFERENCE_UNSPECIFIED"
8919          ]
8920        },
8921        "constraints": {
8922          "description": "Constraints that the caller requires on the result distribution in this zone.",
8923          "$ref": "LocationPolicyLocationConstraints"
8924        }
8925      }
8926    },
8927    "LocationPolicyLocationConstraints": {
8928      "id": "LocationPolicyLocationConstraints",
8929      "description": "Per-zone constraints on location policy for this zone.",
8930      "type": "object",
8931      "properties": {
8932        "maxCount": {
8933          "description": "Maximum number of items that are allowed to be placed in this zone. The value must be non-negative.",
8934          "type": "integer",
8935          "format": "int32"
8936        }
8937      }
8938    },
8939    "InstancesGetEffectiveFirewallsResponse": {
8940      "id": "InstancesGetEffectiveFirewallsResponse",
8941      "type": "object",
8942      "properties": {
8943        "firewalls": {
8944          "description": "Effective firewalls on the instance.",
8945          "type": "array",
8946          "items": {
8947            "$ref": "Firewall"
8948          }
8949        },
8950        "firewallPolicys": {
8951          "description": "Effective firewalls from firewall policies.",
8952          "type": "array",
8953          "items": {
8954            "$ref": "InstancesGetEffectiveFirewallsResponseEffectiveFirewallPolicy"
8955          }
8956        }
8957      }
8958    },
8959    "InstancesGetEffectiveFirewallsResponseEffectiveFirewallPolicy": {
8960      "id": "InstancesGetEffectiveFirewallsResponseEffectiveFirewallPolicy",
8961      "type": "object",
8962      "properties": {
8963        "name": {
8964          "description": "[Output Only] The name of the firewall policy.",
8965          "type": "string"
8966        },
8967        "type": {
8968          "description": "[Output Only] The type of the firewall policy. Can be one of HIERARCHY, NETWORK, NETWORK_REGIONAL.",
8969          "type": "string",
8970          "enumDescriptions": [
8971            "",
8972            "",
8973            "",
8974            ""
8975          ],
8976          "enum": [
8977            "HIERARCHY",
8978            "NETWORK",
8979            "NETWORK_REGIONAL",
8980            "UNSPECIFIED"
8981          ]
8982        },
8983        "shortName": {
8984          "description": "[Output Only] The short name of the firewall policy.",
8985          "type": "string"
8986        },
8987        "displayName": {
8988          "description": "[Output Only] Deprecated, please use short name instead. The display name of the firewall policy.",
8989          "deprecated": true,
8990          "type": "string"
8991        },
8992        "rules": {
8993          "description": "The rules that apply to the network.",
8994          "type": "array",
8995          "items": {
8996            "$ref": "FirewallPolicyRule"
8997          }
8998        }
8999      }
9000    },
9001    "ReservationList": {
9002      "id": "ReservationList",
9003      "type": "object",
9004      "properties": {
9005        "kind": {
9006          "description": "[Output Only] Type of resource.Always compute#reservationsList for listsof reservations",
9007          "default": "compute#reservationList",
9008          "type": "string"
9009        },
9010        "id": {
9011          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
9012          "type": "string"
9013        },
9014        "items": {
9015          "description": "[Output Only] A list of Allocation resources.",
9016          "type": "array",
9017          "items": {
9018            "$ref": "Reservation"
9019          }
9020        },
9021        "nextPageToken": {
9022          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
9023          "type": "string"
9024        },
9025        "warning": {
9026          "description": "[Output Only] Informational warning message.",
9027          "type": "object",
9028          "properties": {
9029            "code": {
9030              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
9031              "type": "string",
9032              "enumDescriptions": [
9033                "Warning about failed cleanup of transient changes made by a failed operation.",
9034                "A link to a deprecated resource was created.",
9035                "When deploying and at least one of the resources has a type marked as deprecated",
9036                "The user created a boot disk that is larger than image size.",
9037                "When deploying and at least one of the resources has a type marked as experimental",
9038                "Warning that is present in an external api call",
9039                "Warning that value of a field has been overridden. Deprecated unused field.",
9040                "The operation involved use of an injected kernel, which is deprecated.",
9041                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
9042                "When deploying a deployment with a exceedingly large number of resources",
9043                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
9044                "A resource depends on a missing type",
9045                "The route's nextHopIp address is not assigned to an instance on the network.",
9046                "The route's next hop instance cannot ip forward.",
9047                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
9048                "The route's nextHopInstance URL refers to an instance that does not exist.",
9049                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
9050                "The route's next hop instance does not have a status of RUNNING.",
9051                "Error which is not critical. We decided to continue the process despite the mentioned error.",
9052                "No results are present on a particular list page.",
9053                "Success is reported, but some results may be missing due to errors",
9054                "The user attempted to use a resource that requires a TOS they have not accepted.",
9055                "Warning that a resource is in use.",
9056                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
9057                "When a resource schema validation is ignored.",
9058                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
9059                "When undeclared properties in the schema are present",
9060                "A given scope cannot be reached."
9061              ],
9062              "enumDeprecated": [
9063                false,
9064                false,
9065                false,
9066                false,
9067                false,
9068                false,
9069                true,
9070                false,
9071                false,
9072                false,
9073                false,
9074                false,
9075                false,
9076                false,
9077                false,
9078                false,
9079                false,
9080                false,
9081                false,
9082                false,
9083                false,
9084                false,
9085                false,
9086                false,
9087                false,
9088                false,
9089                false,
9090                false
9091              ],
9092              "enum": [
9093                "CLEANUP_FAILED",
9094                "DEPRECATED_RESOURCE_USED",
9095                "DEPRECATED_TYPE_USED",
9096                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
9097                "EXPERIMENTAL_TYPE_USED",
9098                "EXTERNAL_API_WARNING",
9099                "FIELD_VALUE_OVERRIDEN",
9100                "INJECTED_KERNELS_DEPRECATED",
9101                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
9102                "LARGE_DEPLOYMENT_WARNING",
9103                "LIST_OVERHEAD_QUOTA_EXCEED",
9104                "MISSING_TYPE_DEPENDENCY",
9105                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
9106                "NEXT_HOP_CANNOT_IP_FORWARD",
9107                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
9108                "NEXT_HOP_INSTANCE_NOT_FOUND",
9109                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
9110                "NEXT_HOP_NOT_RUNNING",
9111                "NOT_CRITICAL_ERROR",
9112                "NO_RESULTS_ON_PAGE",
9113                "PARTIAL_SUCCESS",
9114                "REQUIRED_TOS_AGREEMENT",
9115                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
9116                "RESOURCE_NOT_DELETED",
9117                "SCHEMA_VALIDATION_IGNORED",
9118                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
9119                "UNDECLARED_PROPERTIES",
9120                "UNREACHABLE"
9121              ]
9122            },
9123            "message": {
9124              "description": "[Output Only] A human-readable description of the warning code.",
9125              "type": "string"
9126            },
9127            "data": {
9128              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
9129              "type": "array",
9130              "items": {
9131                "type": "object",
9132                "properties": {
9133                  "key": {
9134                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
9135                    "type": "string"
9136                  },
9137                  "value": {
9138                    "description": "[Output Only] A warning data value corresponding to the key.",
9139                    "type": "string"
9140                  }
9141                }
9142              }
9143            }
9144          }
9145        },
9146        "selfLink": {
9147          "description": "[Output Only] Server-defined URL for this resource.",
9148          "type": "string"
9149        }
9150      }
9151    },
9152    "Reservation": {
9153      "id": "Reservation",
9154      "description": "Represents a reservation resource. A reservation ensures that capacity is held in a specific zone even if the reserved VMs are not running. For more information, read Reserving zonal resources.",
9155      "type": "object",
9156      "properties": {
9157        "kind": {
9158          "description": "[Output Only] Type of the resource. Always compute#reservations for reservations.",
9159          "default": "compute#reservation",
9160          "type": "string"
9161        },
9162        "id": {
9163          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
9164          "type": "string",
9165          "format": "uint64"
9166        },
9167        "creationTimestamp": {
9168          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
9169          "type": "string"
9170        },
9171        "selfLink": {
9172          "description": "[Output Only] Server-defined fully-qualified URL for this resource.",
9173          "type": "string"
9174        },
9175        "zone": {
9176          "description": "Zone in which the reservation resides. A zone must be provided if the reservation is created within a commitment.",
9177          "type": "string"
9178        },
9179        "description": {
9180          "description": "An optional description of this resource. Provide this property when you create the resource.",
9181          "type": "string"
9182        },
9183        "name": {
9184          "description": "The name of the resource, provided by the client when initially creating the resource. The resource name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
9185          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
9186          "annotations": {
9187            "required": [
9188              "compute.instances.insert"
9189            ]
9190          },
9191          "type": "string"
9192        },
9193        "specificReservation": {
9194          "description": "Reservation for instances with specific machine shapes.",
9195          "$ref": "AllocationSpecificSKUReservation"
9196        },
9197        "aggregateReservation": {
9198          "description": "Reservation for aggregated resources, providing shape flexibility.",
9199          "$ref": "AllocationAggregateReservation"
9200        },
9201        "commitment": {
9202          "description": "[Output Only] Full or partial URL to a parent commitment. This field displays for reservations that are tied to a commitment.",
9203          "type": "string"
9204        },
9205        "specificReservationRequired": {
9206          "description": "Indicates whether the reservation can be consumed by VMs with affinity for \"any\" reservation. If the field is set, then only VMs that target the reservation by name can consume from this reservation.",
9207          "type": "boolean"
9208        },
9209        "status": {
9210          "description": "[Output Only] The status of the reservation.",
9211          "type": "string",
9212          "enumDescriptions": [
9213            "Resources are being allocated for the reservation.",
9214            "Reservation is currently being deleted.",
9215            "",
9216            "Reservation has allocated all its resources.",
9217            "Reservation is currently being resized."
9218          ],
9219          "enum": [
9220            "CREATING",
9221            "DELETING",
9222            "INVALID",
9223            "READY",
9224            "UPDATING"
9225          ]
9226        },
9227        "shareSettings": {
9228          "description": "Specify share-settings to create a shared reservation. This property is optional. For more information about the syntax and options for this field and its subfields, see the guide for creating a shared reservation.",
9229          "$ref": "ShareSettings"
9230        },
9231        "satisfiesPzs": {
9232          "description": "[Output Only] Reserved for future use.",
9233          "type": "boolean"
9234        },
9235        "resourcePolicies": {
9236          "description": "Resource policies to be added to this reservation. The key is defined by user, and the value is resource policy url. This is to define placement policy with reservation.",
9237          "type": "object",
9238          "additionalProperties": {
9239            "type": "string"
9240          }
9241        },
9242        "resourceStatus": {
9243          "description": "[Output Only] Status information for Reservation resource.",
9244          "$ref": "AllocationResourceStatus"
9245        }
9246      }
9247    },
9248    "AllocationSpecificSKUReservation": {
9249      "id": "AllocationSpecificSKUReservation",
9250      "description": "This reservation type allows to pre allocate specific instance configuration. Next ID: 6",
9251      "type": "object",
9252      "properties": {
9253        "instanceProperties": {
9254          "description": "The instance properties for the reservation.",
9255          "$ref": "AllocationSpecificSKUAllocationReservedInstanceProperties"
9256        },
9257        "count": {
9258          "description": "Specifies the number of resources that are allocated.",
9259          "type": "string",
9260          "format": "int64"
9261        },
9262        "inUseCount": {
9263          "description": "[Output Only] Indicates how many instances are in use.",
9264          "type": "string",
9265          "format": "int64"
9266        },
9267        "assuredCount": {
9268          "description": "[Output Only] Indicates how many instances are actually usable currently.",
9269          "type": "string",
9270          "format": "int64"
9271        },
9272        "sourceInstanceTemplate": {
9273          "description": "Specifies the instance template to create the reservation. If you use this field, you must exclude the instanceProperties field. This field is optional, and it can be a full or partial URL. For example, the following are all valid URLs to an instance template: - https://www.googleapis.com/compute/v1/projects/project /global/instanceTemplates/instanceTemplate - projects/project/global/instanceTemplates/instanceTemplate - global/instanceTemplates/instanceTemplate ",
9274          "type": "string"
9275        }
9276      }
9277    },
9278    "AllocationSpecificSKUAllocationReservedInstanceProperties": {
9279      "id": "AllocationSpecificSKUAllocationReservedInstanceProperties",
9280      "description": "Properties of the SKU instances being reserved. Next ID: 9",
9281      "type": "object",
9282      "properties": {
9283        "machineType": {
9284          "description": "Specifies type of machine (name only) which has fixed number of vCPUs and fixed amount of memory. This also includes specifying custom machine type following custom-NUMBER_OF_CPUS-AMOUNT_OF_MEMORY pattern.",
9285          "type": "string"
9286        },
9287        "guestAccelerators": {
9288          "description": "Specifies accelerator type and count.",
9289          "type": "array",
9290          "items": {
9291            "$ref": "AcceleratorConfig"
9292          }
9293        },
9294        "minCpuPlatform": {
9295          "description": "Minimum cpu platform the reservation.",
9296          "type": "string"
9297        },
9298        "localSsds": {
9299          "description": "Specifies amount of local ssd to reserve with each instance. The type of disk is local-ssd.",
9300          "type": "array",
9301          "items": {
9302            "$ref": "AllocationSpecificSKUAllocationAllocatedInstancePropertiesReservedDisk"
9303          }
9304        },
9305        "locationHint": {
9306          "description": "An opaque location hint used to place the allocation close to other resources. This field is for use by internal tools that use the public API.",
9307          "type": "string"
9308        }
9309      }
9310    },
9311    "AllocationSpecificSKUAllocationAllocatedInstancePropertiesReservedDisk": {
9312      "id": "AllocationSpecificSKUAllocationAllocatedInstancePropertiesReservedDisk",
9313      "type": "object",
9314      "properties": {
9315        "diskSizeGb": {
9316          "description": "Specifies the size of the disk in base-2 GB.",
9317          "type": "string",
9318          "format": "int64"
9319        },
9320        "interface": {
9321          "description": "Specifies the disk interface to use for attaching this disk, which is either SCSI or NVME. The default is SCSI. For performance characteristics of SCSI over NVMe, see Local SSD performance.",
9322          "type": "string",
9323          "enumDescriptions": [
9324            "",
9325            ""
9326          ],
9327          "enum": [
9328            "NVME",
9329            "SCSI"
9330          ]
9331        }
9332      }
9333    },
9334    "AllocationAggregateReservation": {
9335      "id": "AllocationAggregateReservation",
9336      "description": "This reservation type is specified by total resource amounts (e.g. total count of CPUs) and can account for multiple instance SKUs. In other words, one can create instances of varying shapes against this reservation.",
9337      "type": "object",
9338      "properties": {
9339        "vmFamily": {
9340          "description": "The VM family that all instances scheduled against this reservation must belong to.",
9341          "type": "string",
9342          "enumDescriptions": [
9343            "",
9344            "",
9345            ""
9346          ],
9347          "enum": [
9348            "VM_FAMILY_CLOUD_TPU_LITE_DEVICE_CT5L",
9349            "VM_FAMILY_CLOUD_TPU_LITE_POD_SLICE_CT5LP",
9350            "VM_FAMILY_CLOUD_TPU_POD_SLICE_CT4P"
9351          ]
9352        },
9353        "reservedResources": {
9354          "description": "List of reserved resources (CPUs, memory, accelerators).",
9355          "type": "array",
9356          "items": {
9357            "$ref": "AllocationAggregateReservationReservedResourceInfo"
9358          }
9359        },
9360        "inUseResources": {
9361          "description": "[Output only] List of resources currently in use.",
9362          "type": "array",
9363          "items": {
9364            "$ref": "AllocationAggregateReservationReservedResourceInfo"
9365          }
9366        },
9367        "workloadType": {
9368          "description": "The workload type of the instances that will target this reservation.",
9369          "type": "string",
9370          "enumDescriptions": [
9371            "Reserved resources will be optimized for BATCH workloads, such as ML training.",
9372            "Reserved resources will be optimized for SERVING workloads, such as ML inference.",
9373            ""
9374          ],
9375          "enum": [
9376            "BATCH",
9377            "SERVING",
9378            "UNSPECIFIED"
9379          ]
9380        }
9381      }
9382    },
9383    "AllocationAggregateReservationReservedResourceInfo": {
9384      "id": "AllocationAggregateReservationReservedResourceInfo",
9385      "type": "object",
9386      "properties": {
9387        "accelerator": {
9388          "description": "Properties of accelerator resources in this reservation.",
9389          "$ref": "AllocationAggregateReservationReservedResourceInfoAccelerator"
9390        }
9391      }
9392    },
9393    "AllocationAggregateReservationReservedResourceInfoAccelerator": {
9394      "id": "AllocationAggregateReservationReservedResourceInfoAccelerator",
9395      "type": "object",
9396      "properties": {
9397        "acceleratorCount": {
9398          "description": "Number of accelerators of specified type.",
9399          "type": "integer",
9400          "format": "int32"
9401        },
9402        "acceleratorType": {
9403          "description": "Full or partial URL to accelerator type. e.g. \"projects/{PROJECT}/zones/{ZONE}/acceleratorTypes/ct4l\"",
9404          "type": "string"
9405        }
9406      }
9407    },
9408    "ShareSettings": {
9409      "id": "ShareSettings",
9410      "description": "The share setting for reservations and sole tenancy node groups.",
9411      "type": "object",
9412      "properties": {
9413        "shareType": {
9414          "description": "Type of sharing for this shared-reservation",
9415          "type": "string",
9416          "enumDescriptions": [
9417            "Default value.",
9418            "Shared-reservation is open to entire Organization",
9419            "Default value. This value is unused.",
9420            "Shared-reservation is open to specific projects"
9421          ],
9422          "enum": [
9423            "LOCAL",
9424            "ORGANIZATION",
9425            "SHARE_TYPE_UNSPECIFIED",
9426            "SPECIFIC_PROJECTS"
9427          ]
9428        },
9429        "projectMap": {
9430          "description": "A map of project id and project config. This is only valid when share_type's value is SPECIFIC_PROJECTS.",
9431          "type": "object",
9432          "additionalProperties": {
9433            "$ref": "ShareSettingsProjectConfig"
9434          }
9435        }
9436      }
9437    },
9438    "ShareSettingsProjectConfig": {
9439      "id": "ShareSettingsProjectConfig",
9440      "description": "Config for each project in the share settings.",
9441      "type": "object",
9442      "properties": {
9443        "projectId": {
9444          "description": "The project ID, should be same as the key of this project config in the parent map.",
9445          "type": "string"
9446        }
9447      }
9448    },
9449    "AllocationResourceStatus": {
9450      "id": "AllocationResourceStatus",
9451      "description": "[Output Only] Contains output only fields.",
9452      "type": "object",
9453      "properties": {
9454        "specificSkuAllocation": {
9455          "description": "Allocation Properties of this reservation.",
9456          "$ref": "AllocationResourceStatusSpecificSKUAllocation"
9457        }
9458      }
9459    },
9460    "AllocationResourceStatusSpecificSKUAllocation": {
9461      "id": "AllocationResourceStatusSpecificSKUAllocation",
9462      "description": "Contains Properties set for the reservation.",
9463      "type": "object",
9464      "properties": {
9465        "sourceInstanceTemplateId": {
9466          "description": "ID of the instance template used to populate reservation properties.",
9467          "type": "string"
9468        }
9469      }
9470    },
9471    "ReservationAggregatedList": {
9472      "id": "ReservationAggregatedList",
9473      "description": "Contains a list of reservations.",
9474      "type": "object",
9475      "properties": {
9476        "kind": {
9477          "description": "Type of resource.",
9478          "default": "compute#reservationAggregatedList",
9479          "type": "string"
9480        },
9481        "id": {
9482          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
9483          "type": "string"
9484        },
9485        "items": {
9486          "description": "A list of Allocation resources.",
9487          "type": "object",
9488          "additionalProperties": {
9489            "description": "Name of the scope containing this set of reservations.",
9490            "$ref": "ReservationsScopedList"
9491          }
9492        },
9493        "nextPageToken": {
9494          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
9495          "type": "string"
9496        },
9497        "selfLink": {
9498          "description": "[Output Only] Server-defined URL for this resource.",
9499          "type": "string"
9500        },
9501        "warning": {
9502          "description": "[Output Only] Informational warning message.",
9503          "type": "object",
9504          "properties": {
9505            "code": {
9506              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
9507              "type": "string",
9508              "enumDescriptions": [
9509                "Warning about failed cleanup of transient changes made by a failed operation.",
9510                "A link to a deprecated resource was created.",
9511                "When deploying and at least one of the resources has a type marked as deprecated",
9512                "The user created a boot disk that is larger than image size.",
9513                "When deploying and at least one of the resources has a type marked as experimental",
9514                "Warning that is present in an external api call",
9515                "Warning that value of a field has been overridden. Deprecated unused field.",
9516                "The operation involved use of an injected kernel, which is deprecated.",
9517                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
9518                "When deploying a deployment with a exceedingly large number of resources",
9519                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
9520                "A resource depends on a missing type",
9521                "The route's nextHopIp address is not assigned to an instance on the network.",
9522                "The route's next hop instance cannot ip forward.",
9523                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
9524                "The route's nextHopInstance URL refers to an instance that does not exist.",
9525                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
9526                "The route's next hop instance does not have a status of RUNNING.",
9527                "Error which is not critical. We decided to continue the process despite the mentioned error.",
9528                "No results are present on a particular list page.",
9529                "Success is reported, but some results may be missing due to errors",
9530                "The user attempted to use a resource that requires a TOS they have not accepted.",
9531                "Warning that a resource is in use.",
9532                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
9533                "When a resource schema validation is ignored.",
9534                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
9535                "When undeclared properties in the schema are present",
9536                "A given scope cannot be reached."
9537              ],
9538              "enumDeprecated": [
9539                false,
9540                false,
9541                false,
9542                false,
9543                false,
9544                false,
9545                true,
9546                false,
9547                false,
9548                false,
9549                false,
9550                false,
9551                false,
9552                false,
9553                false,
9554                false,
9555                false,
9556                false,
9557                false,
9558                false,
9559                false,
9560                false,
9561                false,
9562                false,
9563                false,
9564                false,
9565                false,
9566                false
9567              ],
9568              "enum": [
9569                "CLEANUP_FAILED",
9570                "DEPRECATED_RESOURCE_USED",
9571                "DEPRECATED_TYPE_USED",
9572                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
9573                "EXPERIMENTAL_TYPE_USED",
9574                "EXTERNAL_API_WARNING",
9575                "FIELD_VALUE_OVERRIDEN",
9576                "INJECTED_KERNELS_DEPRECATED",
9577                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
9578                "LARGE_DEPLOYMENT_WARNING",
9579                "LIST_OVERHEAD_QUOTA_EXCEED",
9580                "MISSING_TYPE_DEPENDENCY",
9581                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
9582                "NEXT_HOP_CANNOT_IP_FORWARD",
9583                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
9584                "NEXT_HOP_INSTANCE_NOT_FOUND",
9585                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
9586                "NEXT_HOP_NOT_RUNNING",
9587                "NOT_CRITICAL_ERROR",
9588                "NO_RESULTS_ON_PAGE",
9589                "PARTIAL_SUCCESS",
9590                "REQUIRED_TOS_AGREEMENT",
9591                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
9592                "RESOURCE_NOT_DELETED",
9593                "SCHEMA_VALIDATION_IGNORED",
9594                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
9595                "UNDECLARED_PROPERTIES",
9596                "UNREACHABLE"
9597              ]
9598            },
9599            "message": {
9600              "description": "[Output Only] A human-readable description of the warning code.",
9601              "type": "string"
9602            },
9603            "data": {
9604              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
9605              "type": "array",
9606              "items": {
9607                "type": "object",
9608                "properties": {
9609                  "key": {
9610                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
9611                    "type": "string"
9612                  },
9613                  "value": {
9614                    "description": "[Output Only] A warning data value corresponding to the key.",
9615                    "type": "string"
9616                  }
9617                }
9618              }
9619            }
9620          }
9621        },
9622        "unreachables": {
9623          "description": "[Output Only] Unreachable resources.",
9624          "type": "array",
9625          "items": {
9626            "type": "string"
9627          }
9628        }
9629      }
9630    },
9631    "ReservationsScopedList": {
9632      "id": "ReservationsScopedList",
9633      "type": "object",
9634      "properties": {
9635        "reservations": {
9636          "description": "A list of reservations contained in this scope.",
9637          "type": "array",
9638          "items": {
9639            "$ref": "Reservation"
9640          }
9641        },
9642        "warning": {
9643          "description": "Informational warning which replaces the list of reservations when the list is empty.",
9644          "type": "object",
9645          "properties": {
9646            "code": {
9647              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
9648              "type": "string",
9649              "enumDescriptions": [
9650                "Warning about failed cleanup of transient changes made by a failed operation.",
9651                "A link to a deprecated resource was created.",
9652                "When deploying and at least one of the resources has a type marked as deprecated",
9653                "The user created a boot disk that is larger than image size.",
9654                "When deploying and at least one of the resources has a type marked as experimental",
9655                "Warning that is present in an external api call",
9656                "Warning that value of a field has been overridden. Deprecated unused field.",
9657                "The operation involved use of an injected kernel, which is deprecated.",
9658                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
9659                "When deploying a deployment with a exceedingly large number of resources",
9660                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
9661                "A resource depends on a missing type",
9662                "The route's nextHopIp address is not assigned to an instance on the network.",
9663                "The route's next hop instance cannot ip forward.",
9664                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
9665                "The route's nextHopInstance URL refers to an instance that does not exist.",
9666                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
9667                "The route's next hop instance does not have a status of RUNNING.",
9668                "Error which is not critical. We decided to continue the process despite the mentioned error.",
9669                "No results are present on a particular list page.",
9670                "Success is reported, but some results may be missing due to errors",
9671                "The user attempted to use a resource that requires a TOS they have not accepted.",
9672                "Warning that a resource is in use.",
9673                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
9674                "When a resource schema validation is ignored.",
9675                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
9676                "When undeclared properties in the schema are present",
9677                "A given scope cannot be reached."
9678              ],
9679              "enumDeprecated": [
9680                false,
9681                false,
9682                false,
9683                false,
9684                false,
9685                false,
9686                true,
9687                false,
9688                false,
9689                false,
9690                false,
9691                false,
9692                false,
9693                false,
9694                false,
9695                false,
9696                false,
9697                false,
9698                false,
9699                false,
9700                false,
9701                false,
9702                false,
9703                false,
9704                false,
9705                false,
9706                false,
9707                false
9708              ],
9709              "enum": [
9710                "CLEANUP_FAILED",
9711                "DEPRECATED_RESOURCE_USED",
9712                "DEPRECATED_TYPE_USED",
9713                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
9714                "EXPERIMENTAL_TYPE_USED",
9715                "EXTERNAL_API_WARNING",
9716                "FIELD_VALUE_OVERRIDEN",
9717                "INJECTED_KERNELS_DEPRECATED",
9718                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
9719                "LARGE_DEPLOYMENT_WARNING",
9720                "LIST_OVERHEAD_QUOTA_EXCEED",
9721                "MISSING_TYPE_DEPENDENCY",
9722                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
9723                "NEXT_HOP_CANNOT_IP_FORWARD",
9724                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
9725                "NEXT_HOP_INSTANCE_NOT_FOUND",
9726                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
9727                "NEXT_HOP_NOT_RUNNING",
9728                "NOT_CRITICAL_ERROR",
9729                "NO_RESULTS_ON_PAGE",
9730                "PARTIAL_SUCCESS",
9731                "REQUIRED_TOS_AGREEMENT",
9732                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
9733                "RESOURCE_NOT_DELETED",
9734                "SCHEMA_VALIDATION_IGNORED",
9735                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
9736                "UNDECLARED_PROPERTIES",
9737                "UNREACHABLE"
9738              ]
9739            },
9740            "message": {
9741              "description": "[Output Only] A human-readable description of the warning code.",
9742              "type": "string"
9743            },
9744            "data": {
9745              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
9746              "type": "array",
9747              "items": {
9748                "type": "object",
9749                "properties": {
9750                  "key": {
9751                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
9752                    "type": "string"
9753                  },
9754                  "value": {
9755                    "description": "[Output Only] A warning data value corresponding to the key.",
9756                    "type": "string"
9757                  }
9758                }
9759              }
9760            }
9761          }
9762        }
9763      }
9764    },
9765    "ReservationsResizeRequest": {
9766      "id": "ReservationsResizeRequest",
9767      "type": "object",
9768      "properties": {
9769        "specificSkuCount": {
9770          "description": "Number of allocated resources can be resized with minimum = 1 and maximum = 1000.",
9771          "type": "string",
9772          "format": "int64"
9773        }
9774      }
9775    },
9776    "InstanceGroupList": {
9777      "id": "InstanceGroupList",
9778      "description": "A list of InstanceGroup resources.",
9779      "type": "object",
9780      "properties": {
9781        "kind": {
9782          "description": "[Output Only] The resource type, which is always compute#instanceGroupList for instance group lists.",
9783          "default": "compute#instanceGroupList",
9784          "type": "string"
9785        },
9786        "id": {
9787          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
9788          "type": "string"
9789        },
9790        "items": {
9791          "description": "A list of InstanceGroup resources.",
9792          "type": "array",
9793          "items": {
9794            "$ref": "InstanceGroup"
9795          }
9796        },
9797        "nextPageToken": {
9798          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
9799          "type": "string"
9800        },
9801        "selfLink": {
9802          "description": "[Output Only] Server-defined URL for this resource.",
9803          "type": "string"
9804        },
9805        "warning": {
9806          "description": "[Output Only] Informational warning message.",
9807          "type": "object",
9808          "properties": {
9809            "code": {
9810              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
9811              "type": "string",
9812              "enumDescriptions": [
9813                "Warning about failed cleanup of transient changes made by a failed operation.",
9814                "A link to a deprecated resource was created.",
9815                "When deploying and at least one of the resources has a type marked as deprecated",
9816                "The user created a boot disk that is larger than image size.",
9817                "When deploying and at least one of the resources has a type marked as experimental",
9818                "Warning that is present in an external api call",
9819                "Warning that value of a field has been overridden. Deprecated unused field.",
9820                "The operation involved use of an injected kernel, which is deprecated.",
9821                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
9822                "When deploying a deployment with a exceedingly large number of resources",
9823                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
9824                "A resource depends on a missing type",
9825                "The route's nextHopIp address is not assigned to an instance on the network.",
9826                "The route's next hop instance cannot ip forward.",
9827                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
9828                "The route's nextHopInstance URL refers to an instance that does not exist.",
9829                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
9830                "The route's next hop instance does not have a status of RUNNING.",
9831                "Error which is not critical. We decided to continue the process despite the mentioned error.",
9832                "No results are present on a particular list page.",
9833                "Success is reported, but some results may be missing due to errors",
9834                "The user attempted to use a resource that requires a TOS they have not accepted.",
9835                "Warning that a resource is in use.",
9836                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
9837                "When a resource schema validation is ignored.",
9838                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
9839                "When undeclared properties in the schema are present",
9840                "A given scope cannot be reached."
9841              ],
9842              "enumDeprecated": [
9843                false,
9844                false,
9845                false,
9846                false,
9847                false,
9848                false,
9849                true,
9850                false,
9851                false,
9852                false,
9853                false,
9854                false,
9855                false,
9856                false,
9857                false,
9858                false,
9859                false,
9860                false,
9861                false,
9862                false,
9863                false,
9864                false,
9865                false,
9866                false,
9867                false,
9868                false,
9869                false,
9870                false
9871              ],
9872              "enum": [
9873                "CLEANUP_FAILED",
9874                "DEPRECATED_RESOURCE_USED",
9875                "DEPRECATED_TYPE_USED",
9876                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
9877                "EXPERIMENTAL_TYPE_USED",
9878                "EXTERNAL_API_WARNING",
9879                "FIELD_VALUE_OVERRIDEN",
9880                "INJECTED_KERNELS_DEPRECATED",
9881                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
9882                "LARGE_DEPLOYMENT_WARNING",
9883                "LIST_OVERHEAD_QUOTA_EXCEED",
9884                "MISSING_TYPE_DEPENDENCY",
9885                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
9886                "NEXT_HOP_CANNOT_IP_FORWARD",
9887                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
9888                "NEXT_HOP_INSTANCE_NOT_FOUND",
9889                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
9890                "NEXT_HOP_NOT_RUNNING",
9891                "NOT_CRITICAL_ERROR",
9892                "NO_RESULTS_ON_PAGE",
9893                "PARTIAL_SUCCESS",
9894                "REQUIRED_TOS_AGREEMENT",
9895                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
9896                "RESOURCE_NOT_DELETED",
9897                "SCHEMA_VALIDATION_IGNORED",
9898                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
9899                "UNDECLARED_PROPERTIES",
9900                "UNREACHABLE"
9901              ]
9902            },
9903            "message": {
9904              "description": "[Output Only] A human-readable description of the warning code.",
9905              "type": "string"
9906            },
9907            "data": {
9908              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
9909              "type": "array",
9910              "items": {
9911                "type": "object",
9912                "properties": {
9913                  "key": {
9914                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
9915                    "type": "string"
9916                  },
9917                  "value": {
9918                    "description": "[Output Only] A warning data value corresponding to the key.",
9919                    "type": "string"
9920                  }
9921                }
9922              }
9923            }
9924          }
9925        }
9926      }
9927    },
9928    "InstanceGroup": {
9929      "id": "InstanceGroup",
9930      "description": "Represents an Instance Group resource. Instance Groups can be used to configure a target for load balancing. Instance groups can either be managed or unmanaged. To create managed instance groups, use the instanceGroupManager or regionInstanceGroupManager resource instead. Use zonal unmanaged instance groups if you need to apply load balancing to groups of heterogeneous instances or if you need to manage the instances yourself. You cannot create regional unmanaged instance groups. For more information, read Instance groups.",
9931      "type": "object",
9932      "properties": {
9933        "kind": {
9934          "description": "[Output Only] The resource type, which is always compute#instanceGroup for instance groups.",
9935          "default": "compute#instanceGroup",
9936          "type": "string"
9937        },
9938        "id": {
9939          "description": "[Output Only] A unique identifier for this instance group, generated by the server.",
9940          "type": "string",
9941          "format": "uint64"
9942        },
9943        "creationTimestamp": {
9944          "description": "[Output Only] The creation timestamp for this instance group in RFC3339 text format.",
9945          "type": "string"
9946        },
9947        "name": {
9948          "description": "The name of the instance group. The name must be 1-63 characters long, and comply with RFC1035.",
9949          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
9950          "annotations": {
9951            "required": [
9952              "compute.instanceGroups.insert"
9953            ]
9954          },
9955          "type": "string"
9956        },
9957        "description": {
9958          "description": "An optional description of this resource. Provide this property when you create the resource.",
9959          "type": "string"
9960        },
9961        "namedPorts": {
9962          "description": " Assigns a name to a port number. For example: {name: \"http\", port: 80} This allows the system to reference ports by the assigned name instead of a port number. Named ports can also contain multiple ports. For example: [{name: \"app1\", port: 8080}, {name: \"app1\", port: 8081}, {name: \"app2\", port: 8082}] Named ports apply to all instances in this instance group. ",
9963          "type": "array",
9964          "items": {
9965            "$ref": "NamedPort"
9966          }
9967        },
9968        "network": {
9969          "description": "[Output Only] The URL of the network to which all instances in the instance group belong. If your instance has multiple network interfaces, then the network and subnetwork fields only refer to the network and subnet used by your primary interface (nic0).",
9970          "type": "string"
9971        },
9972        "fingerprint": {
9973          "description": "[Output Only] The fingerprint of the named ports. The system uses this fingerprint to detect conflicts when multiple users change the named ports concurrently.",
9974          "type": "string",
9975          "format": "byte"
9976        },
9977        "zone": {
9978          "description": "[Output Only] The URL of the zone where the instance group is located (for zonal resources).",
9979          "type": "string"
9980        },
9981        "selfLink": {
9982          "description": "[Output Only] The URL for this instance group. The server generates this URL.",
9983          "type": "string"
9984        },
9985        "size": {
9986          "description": "[Output Only] The total number of instances in the instance group.",
9987          "type": "integer",
9988          "format": "int32"
9989        },
9990        "region": {
9991          "description": "[Output Only] The URL of the region where the instance group is located (for regional resources).",
9992          "type": "string"
9993        },
9994        "subnetwork": {
9995          "description": "[Output Only] The URL of the subnetwork to which all instances in the instance group belong. If your instance has multiple network interfaces, then the network and subnetwork fields only refer to the network and subnet used by your primary interface (nic0).",
9996          "type": "string"
9997        }
9998      }
9999    },
10000    "NamedPort": {
10001      "id": "NamedPort",
10002      "description": "The named port. For example: \u003c\"http\", 80\u003e.",
10003      "type": "object",
10004      "properties": {
10005        "name": {
10006          "description": "The name for this named port. The name must be 1-63 characters long, and comply with RFC1035.",
10007          "type": "string"
10008        },
10009        "port": {
10010          "description": "The port number, which can be a value between 1 and 65535.",
10011          "type": "integer",
10012          "format": "int32"
10013        }
10014      }
10015    },
10016    "InstanceGroupAggregatedList": {
10017      "id": "InstanceGroupAggregatedList",
10018      "type": "object",
10019      "properties": {
10020        "kind": {
10021          "description": "[Output Only] The resource type, which is always compute#instanceGroupAggregatedList for aggregated lists of instance groups.",
10022          "default": "compute#instanceGroupAggregatedList",
10023          "type": "string"
10024        },
10025        "id": {
10026          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
10027          "type": "string"
10028        },
10029        "items": {
10030          "description": "A list of InstanceGroupsScopedList resources.",
10031          "type": "object",
10032          "additionalProperties": {
10033            "description": "The name of the scope that contains this set of instance groups.",
10034            "$ref": "InstanceGroupsScopedList"
10035          }
10036        },
10037        "nextPageToken": {
10038          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
10039          "type": "string"
10040        },
10041        "selfLink": {
10042          "description": "[Output Only] Server-defined URL for this resource.",
10043          "type": "string"
10044        },
10045        "warning": {
10046          "description": "[Output Only] Informational warning message.",
10047          "type": "object",
10048          "properties": {
10049            "code": {
10050              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
10051              "type": "string",
10052              "enumDescriptions": [
10053                "Warning about failed cleanup of transient changes made by a failed operation.",
10054                "A link to a deprecated resource was created.",
10055                "When deploying and at least one of the resources has a type marked as deprecated",
10056                "The user created a boot disk that is larger than image size.",
10057                "When deploying and at least one of the resources has a type marked as experimental",
10058                "Warning that is present in an external api call",
10059                "Warning that value of a field has been overridden. Deprecated unused field.",
10060                "The operation involved use of an injected kernel, which is deprecated.",
10061                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
10062                "When deploying a deployment with a exceedingly large number of resources",
10063                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
10064                "A resource depends on a missing type",
10065                "The route's nextHopIp address is not assigned to an instance on the network.",
10066                "The route's next hop instance cannot ip forward.",
10067                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
10068                "The route's nextHopInstance URL refers to an instance that does not exist.",
10069                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
10070                "The route's next hop instance does not have a status of RUNNING.",
10071                "Error which is not critical. We decided to continue the process despite the mentioned error.",
10072                "No results are present on a particular list page.",
10073                "Success is reported, but some results may be missing due to errors",
10074                "The user attempted to use a resource that requires a TOS they have not accepted.",
10075                "Warning that a resource is in use.",
10076                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
10077                "When a resource schema validation is ignored.",
10078                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
10079                "When undeclared properties in the schema are present",
10080                "A given scope cannot be reached."
10081              ],
10082              "enumDeprecated": [
10083                false,
10084                false,
10085                false,
10086                false,
10087                false,
10088                false,
10089                true,
10090                false,
10091                false,
10092                false,
10093                false,
10094                false,
10095                false,
10096                false,
10097                false,
10098                false,
10099                false,
10100                false,
10101                false,
10102                false,
10103                false,
10104                false,
10105                false,
10106                false,
10107                false,
10108                false,
10109                false,
10110                false
10111              ],
10112              "enum": [
10113                "CLEANUP_FAILED",
10114                "DEPRECATED_RESOURCE_USED",
10115                "DEPRECATED_TYPE_USED",
10116                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
10117                "EXPERIMENTAL_TYPE_USED",
10118                "EXTERNAL_API_WARNING",
10119                "FIELD_VALUE_OVERRIDEN",
10120                "INJECTED_KERNELS_DEPRECATED",
10121                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
10122                "LARGE_DEPLOYMENT_WARNING",
10123                "LIST_OVERHEAD_QUOTA_EXCEED",
10124                "MISSING_TYPE_DEPENDENCY",
10125                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
10126                "NEXT_HOP_CANNOT_IP_FORWARD",
10127                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
10128                "NEXT_HOP_INSTANCE_NOT_FOUND",
10129                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
10130                "NEXT_HOP_NOT_RUNNING",
10131                "NOT_CRITICAL_ERROR",
10132                "NO_RESULTS_ON_PAGE",
10133                "PARTIAL_SUCCESS",
10134                "REQUIRED_TOS_AGREEMENT",
10135                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
10136                "RESOURCE_NOT_DELETED",
10137                "SCHEMA_VALIDATION_IGNORED",
10138                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
10139                "UNDECLARED_PROPERTIES",
10140                "UNREACHABLE"
10141              ]
10142            },
10143            "message": {
10144              "description": "[Output Only] A human-readable description of the warning code.",
10145              "type": "string"
10146            },
10147            "data": {
10148              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
10149              "type": "array",
10150              "items": {
10151                "type": "object",
10152                "properties": {
10153                  "key": {
10154                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
10155                    "type": "string"
10156                  },
10157                  "value": {
10158                    "description": "[Output Only] A warning data value corresponding to the key.",
10159                    "type": "string"
10160                  }
10161                }
10162              }
10163            }
10164          }
10165        },
10166        "unreachables": {
10167          "description": "[Output Only] Unreachable resources.",
10168          "type": "array",
10169          "items": {
10170            "type": "string"
10171          }
10172        }
10173      }
10174    },
10175    "InstanceGroupsScopedList": {
10176      "id": "InstanceGroupsScopedList",
10177      "type": "object",
10178      "properties": {
10179        "instanceGroups": {
10180          "description": "[Output Only] The list of instance groups that are contained in this scope.",
10181          "type": "array",
10182          "items": {
10183            "$ref": "InstanceGroup"
10184          }
10185        },
10186        "warning": {
10187          "description": "[Output Only] An informational warning that replaces the list of instance groups when the list is empty.",
10188          "type": "object",
10189          "properties": {
10190            "code": {
10191              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
10192              "type": "string",
10193              "enumDescriptions": [
10194                "Warning about failed cleanup of transient changes made by a failed operation.",
10195                "A link to a deprecated resource was created.",
10196                "When deploying and at least one of the resources has a type marked as deprecated",
10197                "The user created a boot disk that is larger than image size.",
10198                "When deploying and at least one of the resources has a type marked as experimental",
10199                "Warning that is present in an external api call",
10200                "Warning that value of a field has been overridden. Deprecated unused field.",
10201                "The operation involved use of an injected kernel, which is deprecated.",
10202                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
10203                "When deploying a deployment with a exceedingly large number of resources",
10204                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
10205                "A resource depends on a missing type",
10206                "The route's nextHopIp address is not assigned to an instance on the network.",
10207                "The route's next hop instance cannot ip forward.",
10208                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
10209                "The route's nextHopInstance URL refers to an instance that does not exist.",
10210                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
10211                "The route's next hop instance does not have a status of RUNNING.",
10212                "Error which is not critical. We decided to continue the process despite the mentioned error.",
10213                "No results are present on a particular list page.",
10214                "Success is reported, but some results may be missing due to errors",
10215                "The user attempted to use a resource that requires a TOS they have not accepted.",
10216                "Warning that a resource is in use.",
10217                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
10218                "When a resource schema validation is ignored.",
10219                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
10220                "When undeclared properties in the schema are present",
10221                "A given scope cannot be reached."
10222              ],
10223              "enumDeprecated": [
10224                false,
10225                false,
10226                false,
10227                false,
10228                false,
10229                false,
10230                true,
10231                false,
10232                false,
10233                false,
10234                false,
10235                false,
10236                false,
10237                false,
10238                false,
10239                false,
10240                false,
10241                false,
10242                false,
10243                false,
10244                false,
10245                false,
10246                false,
10247                false,
10248                false,
10249                false,
10250                false,
10251                false
10252              ],
10253              "enum": [
10254                "CLEANUP_FAILED",
10255                "DEPRECATED_RESOURCE_USED",
10256                "DEPRECATED_TYPE_USED",
10257                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
10258                "EXPERIMENTAL_TYPE_USED",
10259                "EXTERNAL_API_WARNING",
10260                "FIELD_VALUE_OVERRIDEN",
10261                "INJECTED_KERNELS_DEPRECATED",
10262                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
10263                "LARGE_DEPLOYMENT_WARNING",
10264                "LIST_OVERHEAD_QUOTA_EXCEED",
10265                "MISSING_TYPE_DEPENDENCY",
10266                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
10267                "NEXT_HOP_CANNOT_IP_FORWARD",
10268                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
10269                "NEXT_HOP_INSTANCE_NOT_FOUND",
10270                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
10271                "NEXT_HOP_NOT_RUNNING",
10272                "NOT_CRITICAL_ERROR",
10273                "NO_RESULTS_ON_PAGE",
10274                "PARTIAL_SUCCESS",
10275                "REQUIRED_TOS_AGREEMENT",
10276                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
10277                "RESOURCE_NOT_DELETED",
10278                "SCHEMA_VALIDATION_IGNORED",
10279                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
10280                "UNDECLARED_PROPERTIES",
10281                "UNREACHABLE"
10282              ]
10283            },
10284            "message": {
10285              "description": "[Output Only] A human-readable description of the warning code.",
10286              "type": "string"
10287            },
10288            "data": {
10289              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
10290              "type": "array",
10291              "items": {
10292                "type": "object",
10293                "properties": {
10294                  "key": {
10295                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
10296                    "type": "string"
10297                  },
10298                  "value": {
10299                    "description": "[Output Only] A warning data value corresponding to the key.",
10300                    "type": "string"
10301                  }
10302                }
10303              }
10304            }
10305          }
10306        }
10307      }
10308    },
10309    "InstanceGroupsAddInstancesRequest": {
10310      "id": "InstanceGroupsAddInstancesRequest",
10311      "type": "object",
10312      "properties": {
10313        "instances": {
10314          "description": "The list of instances to add to the instance group.",
10315          "type": "array",
10316          "items": {
10317            "$ref": "InstanceReference"
10318          }
10319        }
10320      }
10321    },
10322    "InstanceReference": {
10323      "id": "InstanceReference",
10324      "type": "object",
10325      "properties": {
10326        "instance": {
10327          "description": "The URL for a specific instance. @required compute.instancegroups.addInstances/removeInstances",
10328          "type": "string"
10329        }
10330      }
10331    },
10332    "InstanceGroupsRemoveInstancesRequest": {
10333      "id": "InstanceGroupsRemoveInstancesRequest",
10334      "type": "object",
10335      "properties": {
10336        "instances": {
10337          "description": "The list of instances to remove from the instance group.",
10338          "type": "array",
10339          "items": {
10340            "$ref": "InstanceReference"
10341          }
10342        }
10343      }
10344    },
10345    "InstanceGroupsListInstancesRequest": {
10346      "id": "InstanceGroupsListInstancesRequest",
10347      "type": "object",
10348      "properties": {
10349        "instanceState": {
10350          "description": "A filter for the state of the instances in the instance group. Valid options are ALL or RUNNING. If you do not specify this parameter the list includes all instances regardless of their state.",
10351          "type": "string",
10352          "enumDescriptions": [
10353            "Includes all instances in the generated list regardless of their state.",
10354            "Includes instances in the generated list only if they have a RUNNING state."
10355          ],
10356          "enum": [
10357            "ALL",
10358            "RUNNING"
10359          ]
10360        }
10361      }
10362    },
10363    "InstanceGroupsListInstances": {
10364      "id": "InstanceGroupsListInstances",
10365      "type": "object",
10366      "properties": {
10367        "kind": {
10368          "description": "[Output Only] The resource type, which is always compute#instanceGroupsListInstances for the list of instances in the specified instance group.",
10369          "default": "compute#instanceGroupsListInstances",
10370          "type": "string"
10371        },
10372        "id": {
10373          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
10374          "type": "string"
10375        },
10376        "items": {
10377          "description": "A list of InstanceWithNamedPorts resources.",
10378          "type": "array",
10379          "items": {
10380            "$ref": "InstanceWithNamedPorts"
10381          }
10382        },
10383        "nextPageToken": {
10384          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
10385          "type": "string"
10386        },
10387        "selfLink": {
10388          "description": "[Output Only] Server-defined URL for this resource.",
10389          "type": "string"
10390        },
10391        "warning": {
10392          "description": "[Output Only] Informational warning message.",
10393          "type": "object",
10394          "properties": {
10395            "code": {
10396              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
10397              "type": "string",
10398              "enumDescriptions": [
10399                "Warning about failed cleanup of transient changes made by a failed operation.",
10400                "A link to a deprecated resource was created.",
10401                "When deploying and at least one of the resources has a type marked as deprecated",
10402                "The user created a boot disk that is larger than image size.",
10403                "When deploying and at least one of the resources has a type marked as experimental",
10404                "Warning that is present in an external api call",
10405                "Warning that value of a field has been overridden. Deprecated unused field.",
10406                "The operation involved use of an injected kernel, which is deprecated.",
10407                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
10408                "When deploying a deployment with a exceedingly large number of resources",
10409                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
10410                "A resource depends on a missing type",
10411                "The route's nextHopIp address is not assigned to an instance on the network.",
10412                "The route's next hop instance cannot ip forward.",
10413                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
10414                "The route's nextHopInstance URL refers to an instance that does not exist.",
10415                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
10416                "The route's next hop instance does not have a status of RUNNING.",
10417                "Error which is not critical. We decided to continue the process despite the mentioned error.",
10418                "No results are present on a particular list page.",
10419                "Success is reported, but some results may be missing due to errors",
10420                "The user attempted to use a resource that requires a TOS they have not accepted.",
10421                "Warning that a resource is in use.",
10422                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
10423                "When a resource schema validation is ignored.",
10424                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
10425                "When undeclared properties in the schema are present",
10426                "A given scope cannot be reached."
10427              ],
10428              "enumDeprecated": [
10429                false,
10430                false,
10431                false,
10432                false,
10433                false,
10434                false,
10435                true,
10436                false,
10437                false,
10438                false,
10439                false,
10440                false,
10441                false,
10442                false,
10443                false,
10444                false,
10445                false,
10446                false,
10447                false,
10448                false,
10449                false,
10450                false,
10451                false,
10452                false,
10453                false,
10454                false,
10455                false,
10456                false
10457              ],
10458              "enum": [
10459                "CLEANUP_FAILED",
10460                "DEPRECATED_RESOURCE_USED",
10461                "DEPRECATED_TYPE_USED",
10462                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
10463                "EXPERIMENTAL_TYPE_USED",
10464                "EXTERNAL_API_WARNING",
10465                "FIELD_VALUE_OVERRIDEN",
10466                "INJECTED_KERNELS_DEPRECATED",
10467                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
10468                "LARGE_DEPLOYMENT_WARNING",
10469                "LIST_OVERHEAD_QUOTA_EXCEED",
10470                "MISSING_TYPE_DEPENDENCY",
10471                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
10472                "NEXT_HOP_CANNOT_IP_FORWARD",
10473                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
10474                "NEXT_HOP_INSTANCE_NOT_FOUND",
10475                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
10476                "NEXT_HOP_NOT_RUNNING",
10477                "NOT_CRITICAL_ERROR",
10478                "NO_RESULTS_ON_PAGE",
10479                "PARTIAL_SUCCESS",
10480                "REQUIRED_TOS_AGREEMENT",
10481                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
10482                "RESOURCE_NOT_DELETED",
10483                "SCHEMA_VALIDATION_IGNORED",
10484                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
10485                "UNDECLARED_PROPERTIES",
10486                "UNREACHABLE"
10487              ]
10488            },
10489            "message": {
10490              "description": "[Output Only] A human-readable description of the warning code.",
10491              "type": "string"
10492            },
10493            "data": {
10494              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
10495              "type": "array",
10496              "items": {
10497                "type": "object",
10498                "properties": {
10499                  "key": {
10500                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
10501                    "type": "string"
10502                  },
10503                  "value": {
10504                    "description": "[Output Only] A warning data value corresponding to the key.",
10505                    "type": "string"
10506                  }
10507                }
10508              }
10509            }
10510          }
10511        }
10512      }
10513    },
10514    "InstanceWithNamedPorts": {
10515      "id": "InstanceWithNamedPorts",
10516      "type": "object",
10517      "properties": {
10518        "instance": {
10519          "description": "[Output Only] The URL of the instance.",
10520          "type": "string"
10521        },
10522        "status": {
10523          "description": "[Output Only] The status of the instance.",
10524          "type": "string",
10525          "enumDescriptions": [
10526            "The instance is halted and we are performing tear down tasks like network deprogramming, releasing quota, IP, tearing down disks etc.",
10527            "Resources are being allocated for the instance.",
10528            "The instance is in repair.",
10529            "The instance is running.",
10530            "All required resources have been allocated and the instance is being started.",
10531            "The instance has stopped successfully.",
10532            "The instance is currently stopping (either being deleted or killed).",
10533            "The instance has suspended.",
10534            "The instance is suspending.",
10535            "The instance has stopped (either by explicit action or underlying failure)."
10536          ],
10537          "enum": [
10538            "DEPROVISIONING",
10539            "PROVISIONING",
10540            "REPAIRING",
10541            "RUNNING",
10542            "STAGING",
10543            "STOPPED",
10544            "STOPPING",
10545            "SUSPENDED",
10546            "SUSPENDING",
10547            "TERMINATED"
10548          ]
10549        },
10550        "namedPorts": {
10551          "description": "[Output Only] The named ports that belong to this instance group.",
10552          "type": "array",
10553          "items": {
10554            "$ref": "NamedPort"
10555          }
10556        }
10557      }
10558    },
10559    "InstanceGroupsSetNamedPortsRequest": {
10560      "id": "InstanceGroupsSetNamedPortsRequest",
10561      "type": "object",
10562      "properties": {
10563        "namedPorts": {
10564          "description": "The list of named ports to set for this instance group.",
10565          "type": "array",
10566          "items": {
10567            "$ref": "NamedPort"
10568          }
10569        },
10570        "fingerprint": {
10571          "description": "The fingerprint of the named ports information for this instance group. Use this optional property to prevent conflicts when multiple users change the named ports settings concurrently. Obtain the fingerprint with the instanceGroups.get method. Then, include the fingerprint in your request to ensure that you do not overwrite changes that were applied from another concurrent request. A request with an incorrect fingerprint will fail with error 412 conditionNotMet.",
10572          "type": "string",
10573          "format": "byte"
10574        }
10575      }
10576    },
10577    "RegionInstanceGroupList": {
10578      "id": "RegionInstanceGroupList",
10579      "description": "Contains a list of InstanceGroup resources.",
10580      "type": "object",
10581      "properties": {
10582        "kind": {
10583          "description": "The resource type.",
10584          "default": "compute#regionInstanceGroupList",
10585          "type": "string"
10586        },
10587        "id": {
10588          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
10589          "type": "string"
10590        },
10591        "items": {
10592          "description": "A list of InstanceGroup resources.",
10593          "type": "array",
10594          "items": {
10595            "$ref": "InstanceGroup"
10596          }
10597        },
10598        "nextPageToken": {
10599          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
10600          "type": "string"
10601        },
10602        "selfLink": {
10603          "description": "[Output Only] Server-defined URL for this resource.",
10604          "type": "string"
10605        },
10606        "warning": {
10607          "description": "[Output Only] Informational warning message.",
10608          "type": "object",
10609          "properties": {
10610            "code": {
10611              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
10612              "type": "string",
10613              "enumDescriptions": [
10614                "Warning about failed cleanup of transient changes made by a failed operation.",
10615                "A link to a deprecated resource was created.",
10616                "When deploying and at least one of the resources has a type marked as deprecated",
10617                "The user created a boot disk that is larger than image size.",
10618                "When deploying and at least one of the resources has a type marked as experimental",
10619                "Warning that is present in an external api call",
10620                "Warning that value of a field has been overridden. Deprecated unused field.",
10621                "The operation involved use of an injected kernel, which is deprecated.",
10622                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
10623                "When deploying a deployment with a exceedingly large number of resources",
10624                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
10625                "A resource depends on a missing type",
10626                "The route's nextHopIp address is not assigned to an instance on the network.",
10627                "The route's next hop instance cannot ip forward.",
10628                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
10629                "The route's nextHopInstance URL refers to an instance that does not exist.",
10630                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
10631                "The route's next hop instance does not have a status of RUNNING.",
10632                "Error which is not critical. We decided to continue the process despite the mentioned error.",
10633                "No results are present on a particular list page.",
10634                "Success is reported, but some results may be missing due to errors",
10635                "The user attempted to use a resource that requires a TOS they have not accepted.",
10636                "Warning that a resource is in use.",
10637                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
10638                "When a resource schema validation is ignored.",
10639                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
10640                "When undeclared properties in the schema are present",
10641                "A given scope cannot be reached."
10642              ],
10643              "enumDeprecated": [
10644                false,
10645                false,
10646                false,
10647                false,
10648                false,
10649                false,
10650                true,
10651                false,
10652                false,
10653                false,
10654                false,
10655                false,
10656                false,
10657                false,
10658                false,
10659                false,
10660                false,
10661                false,
10662                false,
10663                false,
10664                false,
10665                false,
10666                false,
10667                false,
10668                false,
10669                false,
10670                false,
10671                false
10672              ],
10673              "enum": [
10674                "CLEANUP_FAILED",
10675                "DEPRECATED_RESOURCE_USED",
10676                "DEPRECATED_TYPE_USED",
10677                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
10678                "EXPERIMENTAL_TYPE_USED",
10679                "EXTERNAL_API_WARNING",
10680                "FIELD_VALUE_OVERRIDEN",
10681                "INJECTED_KERNELS_DEPRECATED",
10682                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
10683                "LARGE_DEPLOYMENT_WARNING",
10684                "LIST_OVERHEAD_QUOTA_EXCEED",
10685                "MISSING_TYPE_DEPENDENCY",
10686                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
10687                "NEXT_HOP_CANNOT_IP_FORWARD",
10688                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
10689                "NEXT_HOP_INSTANCE_NOT_FOUND",
10690                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
10691                "NEXT_HOP_NOT_RUNNING",
10692                "NOT_CRITICAL_ERROR",
10693                "NO_RESULTS_ON_PAGE",
10694                "PARTIAL_SUCCESS",
10695                "REQUIRED_TOS_AGREEMENT",
10696                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
10697                "RESOURCE_NOT_DELETED",
10698                "SCHEMA_VALIDATION_IGNORED",
10699                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
10700                "UNDECLARED_PROPERTIES",
10701                "UNREACHABLE"
10702              ]
10703            },
10704            "message": {
10705              "description": "[Output Only] A human-readable description of the warning code.",
10706              "type": "string"
10707            },
10708            "data": {
10709              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
10710              "type": "array",
10711              "items": {
10712                "type": "object",
10713                "properties": {
10714                  "key": {
10715                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
10716                    "type": "string"
10717                  },
10718                  "value": {
10719                    "description": "[Output Only] A warning data value corresponding to the key.",
10720                    "type": "string"
10721                  }
10722                }
10723              }
10724            }
10725          }
10726        }
10727      }
10728    },
10729    "RegionInstanceGroupsListInstancesRequest": {
10730      "id": "RegionInstanceGroupsListInstancesRequest",
10731      "type": "object",
10732      "properties": {
10733        "instanceState": {
10734          "description": "Instances in which state should be returned. Valid options are: 'ALL', 'RUNNING'. By default, it lists all instances.",
10735          "type": "string",
10736          "enumDescriptions": [
10737            "Matches any status of the instances, running, non-running and others.",
10738            "Instance is in RUNNING state if it is running."
10739          ],
10740          "enum": [
10741            "ALL",
10742            "RUNNING"
10743          ]
10744        },
10745        "portName": {
10746          "description": "Name of port user is interested in. It is optional. If it is set, only information about this ports will be returned. If it is not set, all the named ports will be returned. Always lists all instances.",
10747          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
10748          "type": "string"
10749        }
10750      }
10751    },
10752    "RegionInstanceGroupsListInstances": {
10753      "id": "RegionInstanceGroupsListInstances",
10754      "type": "object",
10755      "properties": {
10756        "kind": {
10757          "description": "The resource type.",
10758          "default": "compute#regionInstanceGroupsListInstances",
10759          "type": "string"
10760        },
10761        "id": {
10762          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
10763          "type": "string"
10764        },
10765        "items": {
10766          "description": "A list of InstanceWithNamedPorts resources.",
10767          "type": "array",
10768          "items": {
10769            "$ref": "InstanceWithNamedPorts"
10770          }
10771        },
10772        "nextPageToken": {
10773          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
10774          "type": "string"
10775        },
10776        "selfLink": {
10777          "description": "[Output Only] Server-defined URL for this resource.",
10778          "type": "string"
10779        },
10780        "warning": {
10781          "description": "[Output Only] Informational warning message.",
10782          "type": "object",
10783          "properties": {
10784            "code": {
10785              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
10786              "type": "string",
10787              "enumDescriptions": [
10788                "Warning about failed cleanup of transient changes made by a failed operation.",
10789                "A link to a deprecated resource was created.",
10790                "When deploying and at least one of the resources has a type marked as deprecated",
10791                "The user created a boot disk that is larger than image size.",
10792                "When deploying and at least one of the resources has a type marked as experimental",
10793                "Warning that is present in an external api call",
10794                "Warning that value of a field has been overridden. Deprecated unused field.",
10795                "The operation involved use of an injected kernel, which is deprecated.",
10796                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
10797                "When deploying a deployment with a exceedingly large number of resources",
10798                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
10799                "A resource depends on a missing type",
10800                "The route's nextHopIp address is not assigned to an instance on the network.",
10801                "The route's next hop instance cannot ip forward.",
10802                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
10803                "The route's nextHopInstance URL refers to an instance that does not exist.",
10804                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
10805                "The route's next hop instance does not have a status of RUNNING.",
10806                "Error which is not critical. We decided to continue the process despite the mentioned error.",
10807                "No results are present on a particular list page.",
10808                "Success is reported, but some results may be missing due to errors",
10809                "The user attempted to use a resource that requires a TOS they have not accepted.",
10810                "Warning that a resource is in use.",
10811                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
10812                "When a resource schema validation is ignored.",
10813                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
10814                "When undeclared properties in the schema are present",
10815                "A given scope cannot be reached."
10816              ],
10817              "enumDeprecated": [
10818                false,
10819                false,
10820                false,
10821                false,
10822                false,
10823                false,
10824                true,
10825                false,
10826                false,
10827                false,
10828                false,
10829                false,
10830                false,
10831                false,
10832                false,
10833                false,
10834                false,
10835                false,
10836                false,
10837                false,
10838                false,
10839                false,
10840                false,
10841                false,
10842                false,
10843                false,
10844                false,
10845                false
10846              ],
10847              "enum": [
10848                "CLEANUP_FAILED",
10849                "DEPRECATED_RESOURCE_USED",
10850                "DEPRECATED_TYPE_USED",
10851                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
10852                "EXPERIMENTAL_TYPE_USED",
10853                "EXTERNAL_API_WARNING",
10854                "FIELD_VALUE_OVERRIDEN",
10855                "INJECTED_KERNELS_DEPRECATED",
10856                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
10857                "LARGE_DEPLOYMENT_WARNING",
10858                "LIST_OVERHEAD_QUOTA_EXCEED",
10859                "MISSING_TYPE_DEPENDENCY",
10860                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
10861                "NEXT_HOP_CANNOT_IP_FORWARD",
10862                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
10863                "NEXT_HOP_INSTANCE_NOT_FOUND",
10864                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
10865                "NEXT_HOP_NOT_RUNNING",
10866                "NOT_CRITICAL_ERROR",
10867                "NO_RESULTS_ON_PAGE",
10868                "PARTIAL_SUCCESS",
10869                "REQUIRED_TOS_AGREEMENT",
10870                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
10871                "RESOURCE_NOT_DELETED",
10872                "SCHEMA_VALIDATION_IGNORED",
10873                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
10874                "UNDECLARED_PROPERTIES",
10875                "UNREACHABLE"
10876              ]
10877            },
10878            "message": {
10879              "description": "[Output Only] A human-readable description of the warning code.",
10880              "type": "string"
10881            },
10882            "data": {
10883              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
10884              "type": "array",
10885              "items": {
10886                "type": "object",
10887                "properties": {
10888                  "key": {
10889                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
10890                    "type": "string"
10891                  },
10892                  "value": {
10893                    "description": "[Output Only] A warning data value corresponding to the key.",
10894                    "type": "string"
10895                  }
10896                }
10897              }
10898            }
10899          }
10900        }
10901      }
10902    },
10903    "RegionInstanceGroupsSetNamedPortsRequest": {
10904      "id": "RegionInstanceGroupsSetNamedPortsRequest",
10905      "type": "object",
10906      "properties": {
10907        "namedPorts": {
10908          "description": "The list of named ports to set for this instance group.",
10909          "type": "array",
10910          "items": {
10911            "$ref": "NamedPort"
10912          }
10913        },
10914        "fingerprint": {
10915          "description": "The fingerprint of the named ports information for this instance group. Use this optional property to prevent conflicts when multiple users change the named ports settings concurrently. Obtain the fingerprint with the instanceGroups.get method. Then, include the fingerprint in your request to ensure that you do not overwrite changes that were applied from another concurrent request.",
10916          "type": "string",
10917          "format": "byte"
10918        }
10919      }
10920    },
10921    "InstanceGroupManagerList": {
10922      "id": "InstanceGroupManagerList",
10923      "description": "[Output Only] A list of managed instance groups.",
10924      "type": "object",
10925      "properties": {
10926        "id": {
10927          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
10928          "type": "string"
10929        },
10930        "items": {
10931          "description": "A list of InstanceGroupManager resources.",
10932          "type": "array",
10933          "items": {
10934            "$ref": "InstanceGroupManager"
10935          }
10936        },
10937        "nextPageToken": {
10938          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
10939          "type": "string"
10940        },
10941        "selfLink": {
10942          "description": "[Output Only] Server-defined URL for this resource.",
10943          "type": "string"
10944        },
10945        "warning": {
10946          "description": "[Output Only] Informational warning message.",
10947          "type": "object",
10948          "properties": {
10949            "code": {
10950              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
10951              "type": "string",
10952              "enumDescriptions": [
10953                "Warning about failed cleanup of transient changes made by a failed operation.",
10954                "A link to a deprecated resource was created.",
10955                "When deploying and at least one of the resources has a type marked as deprecated",
10956                "The user created a boot disk that is larger than image size.",
10957                "When deploying and at least one of the resources has a type marked as experimental",
10958                "Warning that is present in an external api call",
10959                "Warning that value of a field has been overridden. Deprecated unused field.",
10960                "The operation involved use of an injected kernel, which is deprecated.",
10961                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
10962                "When deploying a deployment with a exceedingly large number of resources",
10963                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
10964                "A resource depends on a missing type",
10965                "The route's nextHopIp address is not assigned to an instance on the network.",
10966                "The route's next hop instance cannot ip forward.",
10967                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
10968                "The route's nextHopInstance URL refers to an instance that does not exist.",
10969                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
10970                "The route's next hop instance does not have a status of RUNNING.",
10971                "Error which is not critical. We decided to continue the process despite the mentioned error.",
10972                "No results are present on a particular list page.",
10973                "Success is reported, but some results may be missing due to errors",
10974                "The user attempted to use a resource that requires a TOS they have not accepted.",
10975                "Warning that a resource is in use.",
10976                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
10977                "When a resource schema validation is ignored.",
10978                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
10979                "When undeclared properties in the schema are present",
10980                "A given scope cannot be reached."
10981              ],
10982              "enumDeprecated": [
10983                false,
10984                false,
10985                false,
10986                false,
10987                false,
10988                false,
10989                true,
10990                false,
10991                false,
10992                false,
10993                false,
10994                false,
10995                false,
10996                false,
10997                false,
10998                false,
10999                false,
11000                false,
11001                false,
11002                false,
11003                false,
11004                false,
11005                false,
11006                false,
11007                false,
11008                false,
11009                false,
11010                false
11011              ],
11012              "enum": [
11013                "CLEANUP_FAILED",
11014                "DEPRECATED_RESOURCE_USED",
11015                "DEPRECATED_TYPE_USED",
11016                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
11017                "EXPERIMENTAL_TYPE_USED",
11018                "EXTERNAL_API_WARNING",
11019                "FIELD_VALUE_OVERRIDEN",
11020                "INJECTED_KERNELS_DEPRECATED",
11021                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
11022                "LARGE_DEPLOYMENT_WARNING",
11023                "LIST_OVERHEAD_QUOTA_EXCEED",
11024                "MISSING_TYPE_DEPENDENCY",
11025                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
11026                "NEXT_HOP_CANNOT_IP_FORWARD",
11027                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
11028                "NEXT_HOP_INSTANCE_NOT_FOUND",
11029                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
11030                "NEXT_HOP_NOT_RUNNING",
11031                "NOT_CRITICAL_ERROR",
11032                "NO_RESULTS_ON_PAGE",
11033                "PARTIAL_SUCCESS",
11034                "REQUIRED_TOS_AGREEMENT",
11035                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
11036                "RESOURCE_NOT_DELETED",
11037                "SCHEMA_VALIDATION_IGNORED",
11038                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
11039                "UNDECLARED_PROPERTIES",
11040                "UNREACHABLE"
11041              ]
11042            },
11043            "message": {
11044              "description": "[Output Only] A human-readable description of the warning code.",
11045              "type": "string"
11046            },
11047            "data": {
11048              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
11049              "type": "array",
11050              "items": {
11051                "type": "object",
11052                "properties": {
11053                  "key": {
11054                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
11055                    "type": "string"
11056                  },
11057                  "value": {
11058                    "description": "[Output Only] A warning data value corresponding to the key.",
11059                    "type": "string"
11060                  }
11061                }
11062              }
11063            }
11064          }
11065        },
11066        "kind": {
11067          "description": "[Output Only] The resource type, which is always compute#instanceGroupManagerList for a list of managed instance groups.",
11068          "default": "compute#instanceGroupManagerList",
11069          "type": "string"
11070        }
11071      }
11072    },
11073    "InstanceGroupManager": {
11074      "id": "InstanceGroupManager",
11075      "description": "Represents a Managed Instance Group resource. An instance group is a collection of VM instances that you can manage as a single entity. For more information, read Instance groups. For zonal Managed Instance Group, use the instanceGroupManagers resource. For regional Managed Instance Group, use the regionInstanceGroupManagers resource.",
11076      "type": "object",
11077      "properties": {
11078        "kind": {
11079          "description": "[Output Only] The resource type, which is always compute#instanceGroupManager for managed instance groups.",
11080          "default": "compute#instanceGroupManager",
11081          "type": "string"
11082        },
11083        "id": {
11084          "description": "[Output Only] A unique identifier for this resource type. The server generates this identifier.",
11085          "type": "string",
11086          "format": "uint64"
11087        },
11088        "creationTimestamp": {
11089          "description": "[Output Only] The creation timestamp for this managed instance group in RFC3339 text format.",
11090          "type": "string"
11091        },
11092        "name": {
11093          "description": "The name of the managed instance group. The name must be 1-63 characters long, and comply with RFC1035.",
11094          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
11095          "annotations": {
11096            "required": [
11097              "compute.instanceGroupManagers.insert",
11098              "compute.regionInstanceGroupManagers.insert"
11099            ]
11100          },
11101          "type": "string"
11102        },
11103        "description": {
11104          "description": "An optional description of this resource.",
11105          "type": "string"
11106        },
11107        "zone": {
11108          "description": "[Output Only] The URL of a zone where the managed instance group is located (for zonal resources).",
11109          "type": "string"
11110        },
11111        "region": {
11112          "description": "[Output Only] The URL of the region where the managed instance group resides (for regional resources).",
11113          "type": "string"
11114        },
11115        "distributionPolicy": {
11116          "description": "Policy specifying the intended distribution of managed instances across zones in a regional managed instance group.",
11117          "$ref": "DistributionPolicy"
11118        },
11119        "instanceTemplate": {
11120          "description": "The URL of the instance template that is specified for this managed instance group. The group uses this template to create all new instances in the managed instance group. The templates for existing instances in the group do not change unless you run recreateInstances, run applyUpdatesToInstances, or set the group's updatePolicy.type to PROACTIVE.",
11121          "type": "string"
11122        },
11123        "versions": {
11124          "description": "Specifies the instance templates used by this managed instance group to create instances. Each version is defined by an instanceTemplate and a name. Every version can appear at most once per instance group. This field overrides the top-level instanceTemplate field. Read more about the relationships between these fields. Exactly one version must leave the targetSize field unset. That version will be applied to all remaining instances. For more information, read about canary updates.",
11125          "type": "array",
11126          "items": {
11127            "$ref": "InstanceGroupManagerVersion"
11128          }
11129        },
11130        "allInstancesConfig": {
11131          "description": "Specifies configuration that overrides the instance template configuration for the group.",
11132          "$ref": "InstanceGroupManagerAllInstancesConfig"
11133        },
11134        "instanceGroup": {
11135          "description": "[Output Only] The URL of the Instance Group resource.",
11136          "type": "string"
11137        },
11138        "targetPools": {
11139          "description": "The URLs for all TargetPool resources to which instances in the instanceGroup field are added. The target pools automatically apply to all of the instances in the managed instance group.",
11140          "type": "array",
11141          "items": {
11142            "type": "string"
11143          }
11144        },
11145        "baseInstanceName": {
11146          "description": "The base instance name to use for instances in this group. The value must be 1-58 characters long. Instances are named by appending a hyphen and a random four-character string to the base instance name. The base instance name must comply with RFC1035.",
11147          "pattern": "[a-z][-a-z0-9]{0,57}",
11148          "type": "string"
11149        },
11150        "fingerprint": {
11151          "description": "Fingerprint of this resource. This field may be used in optimistic locking. It will be ignored when inserting an InstanceGroupManager. An up-to-date fingerprint must be provided in order to update the InstanceGroupManager, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve an InstanceGroupManager.",
11152          "type": "string",
11153          "format": "byte"
11154        },
11155        "currentActions": {
11156          "description": "[Output Only] The list of instance actions and the number of instances in this managed instance group that are scheduled for each of those actions.",
11157          "$ref": "InstanceGroupManagerActionsSummary"
11158        },
11159        "status": {
11160          "description": "[Output Only] The status of this managed instance group.",
11161          "$ref": "InstanceGroupManagerStatus"
11162        },
11163        "targetSize": {
11164          "description": "The target number of running instances for this managed instance group. You can reduce this number by using the instanceGroupManager deleteInstances or abandonInstances methods. Resizing the group also changes this number.",
11165          "annotations": {
11166            "required": [
11167              "compute.instanceGroupManagers.insert",
11168              "compute.regionInstanceGroupManagers.insert"
11169            ]
11170          },
11171          "type": "integer",
11172          "format": "int32"
11173        },
11174        "listManagedInstancesResults": {
11175          "description": "Pagination behavior of the listManagedInstances API method for this managed instance group.",
11176          "type": "string",
11177          "enumDescriptions": [
11178            "(Default) Pagination is disabled for the group's listManagedInstances API method. maxResults and pageToken query parameters are ignored and all instances are returned in a single response.",
11179            "Pagination is enabled for the group's listManagedInstances API method. maxResults and pageToken query parameters are respected."
11180          ],
11181          "enum": [
11182            "PAGELESS",
11183            "PAGINATED"
11184          ]
11185        },
11186        "selfLink": {
11187          "description": "[Output Only] The URL for this managed instance group. The server defines this URL.",
11188          "type": "string"
11189        },
11190        "autoHealingPolicies": {
11191          "description": "The autohealing policy for this managed instance group. You can specify only one value.",
11192          "type": "array",
11193          "items": {
11194            "$ref": "InstanceGroupManagerAutoHealingPolicy"
11195          }
11196        },
11197        "updatePolicy": {
11198          "description": "The update policy for this managed instance group.",
11199          "$ref": "InstanceGroupManagerUpdatePolicy"
11200        },
11201        "namedPorts": {
11202          "description": "Named ports configured for the Instance Groups complementary to this Instance Group Manager.",
11203          "type": "array",
11204          "items": {
11205            "$ref": "NamedPort"
11206          }
11207        },
11208        "statefulPolicy": {
11209          "description": "Stateful configuration for this Instanced Group Manager",
11210          "$ref": "StatefulPolicy"
11211        },
11212        "instanceLifecyclePolicy": {
11213          "description": "The repair policy for this managed instance group.",
11214          "$ref": "InstanceGroupManagerInstanceLifecyclePolicy"
11215        }
11216      }
11217    },
11218    "DistributionPolicy": {
11219      "id": "DistributionPolicy",
11220      "type": "object",
11221      "properties": {
11222        "zones": {
11223          "description": "Zones where the regional managed instance group will create and manage its instances.",
11224          "type": "array",
11225          "items": {
11226            "$ref": "DistributionPolicyZoneConfiguration"
11227          }
11228        },
11229        "targetShape": {
11230          "description": "The distribution shape to which the group converges either proactively or on resize events (depending on the value set in updatePolicy.instanceRedistributionType).",
11231          "type": "string",
11232          "enumDescriptions": [
11233            "The group picks zones for creating VM instances to fulfill the requested number of VMs within present resource constraints and to maximize utilization of unused zonal reservations. Recommended for batch workloads that do not require high availability.",
11234            "The group creates all VM instances within a single zone. The zone is selected based on the present resource constraints and to maximize utilization of unused zonal reservations. Recommended for batch workloads with heavy interprocess communication.",
11235            "The group prioritizes acquisition of resources, scheduling VMs in zones where resources are available while distributing VMs as evenly as possible across selected zones to minimize the impact of zonal failure. Recommended for highly available serving workloads.",
11236            "The group schedules VM instance creation and deletion to achieve and maintain an even number of managed instances across the selected zones. The distribution is even when the number of managed instances does not differ by more than 1 between any two zones. Recommended for highly available serving workloads."
11237          ],
11238          "enum": [
11239            "ANY",
11240            "ANY_SINGLE_ZONE",
11241            "BALANCED",
11242            "EVEN"
11243          ]
11244        }
11245      }
11246    },
11247    "DistributionPolicyZoneConfiguration": {
11248      "id": "DistributionPolicyZoneConfiguration",
11249      "type": "object",
11250      "properties": {
11251        "zone": {
11252          "description": "The URL of the zone. The zone must exist in the region where the managed instance group is located.",
11253          "annotations": {
11254            "required": [
11255              "compute.regionInstanceGroupManagers.insert"
11256            ]
11257          },
11258          "type": "string"
11259        }
11260      }
11261    },
11262    "InstanceGroupManagerVersion": {
11263      "id": "InstanceGroupManagerVersion",
11264      "type": "object",
11265      "properties": {
11266        "name": {
11267          "description": "Name of the version. Unique among all versions in the scope of this managed instance group.",
11268          "type": "string"
11269        },
11270        "instanceTemplate": {
11271          "description": "The URL of the instance template that is specified for this managed instance group. The group uses this template to create new instances in the managed instance group until the `targetSize` for this version is reached. The templates for existing instances in the group do not change unless you run recreateInstances, run applyUpdatesToInstances, or set the group's updatePolicy.type to PROACTIVE; in those cases, existing instances are updated until the `targetSize` for this version is reached.",
11272          "type": "string"
11273        },
11274        "targetSize": {
11275          "description": "Specifies the intended number of instances to be created from the instanceTemplate. The final number of instances created from the template will be equal to: - If expressed as a fixed number, the minimum of either targetSize.fixed or instanceGroupManager.targetSize is used. - if expressed as a percent, the targetSize would be (targetSize.percent/100 * InstanceGroupManager.targetSize) If there is a remainder, the number is rounded. If unset, this version will update any remaining instances not updated by another version. Read Starting a canary update for more information.",
11276          "$ref": "FixedOrPercent"
11277        }
11278      }
11279    },
11280    "FixedOrPercent": {
11281      "id": "FixedOrPercent",
11282      "description": "Encapsulates numeric value that can be either absolute or relative.",
11283      "type": "object",
11284      "properties": {
11285        "fixed": {
11286          "description": "Specifies a fixed number of VM instances. This must be a positive integer.",
11287          "type": "integer",
11288          "format": "int32"
11289        },
11290        "percent": {
11291          "description": "Specifies a percentage of instances between 0 to 100%, inclusive. For example, specify 80 for 80%.",
11292          "type": "integer",
11293          "format": "int32"
11294        },
11295        "calculated": {
11296          "description": "[Output Only] Absolute value of VM instances calculated based on the specific mode. - If the value is fixed, then the calculated value is equal to the fixed value. - If the value is a percent, then the calculated value is percent/100 * targetSize. For example, the calculated value of a 80% of a managed instance group with 150 instances would be (80/100 * 150) = 120 VM instances. If there is a remainder, the number is rounded. ",
11297          "type": "integer",
11298          "format": "int32"
11299        }
11300      }
11301    },
11302    "InstanceGroupManagerAllInstancesConfig": {
11303      "id": "InstanceGroupManagerAllInstancesConfig",
11304      "type": "object",
11305      "properties": {
11306        "properties": {
11307          "description": "Properties to set on all instances in the group. You can add or modify properties using the instanceGroupManagers.patch or regionInstanceGroupManagers.patch. After setting allInstancesConfig on the group, you must update the group's instances to apply the configuration. To apply the configuration, set the group's updatePolicy.type field to use proactive updates or use the applyUpdatesToInstances method.",
11308          "$ref": "InstancePropertiesPatch"
11309        }
11310      }
11311    },
11312    "InstancePropertiesPatch": {
11313      "id": "InstancePropertiesPatch",
11314      "description": "Represents the change that you want to make to the instance properties.",
11315      "type": "object",
11316      "properties": {
11317        "metadata": {
11318          "description": "The metadata key-value pairs that you want to patch onto the instance. For more information, see Project and instance metadata.",
11319          "type": "object",
11320          "additionalProperties": {
11321            "type": "string"
11322          }
11323        },
11324        "labels": {
11325          "description": "The label key-value pairs that you want to patch onto the instance.",
11326          "type": "object",
11327          "additionalProperties": {
11328            "type": "string"
11329          }
11330        }
11331      }
11332    },
11333    "InstanceGroupManagerActionsSummary": {
11334      "id": "InstanceGroupManagerActionsSummary",
11335      "type": "object",
11336      "properties": {
11337        "none": {
11338          "description": "[Output Only] The number of instances in the managed instance group that are running and have no scheduled actions.",
11339          "type": "integer",
11340          "format": "int32"
11341        },
11342        "creating": {
11343          "description": "[Output Only] The number of instances in the managed instance group that are scheduled to be created or are currently being created. If the group fails to create any of these instances, it tries again until it creates the instance successfully. If you have disabled creation retries, this field will not be populated; instead, the creatingWithoutRetries field will be populated.",
11344          "type": "integer",
11345          "format": "int32"
11346        },
11347        "creatingWithoutRetries": {
11348          "description": "[Output Only] The number of instances that the managed instance group will attempt to create. The group attempts to create each instance only once. If the group fails to create any of these instances, it decreases the group's targetSize value accordingly.",
11349          "type": "integer",
11350          "format": "int32"
11351        },
11352        "verifying": {
11353          "description": "[Output Only] The number of instances in the managed instance group that are being verified. See the managedInstances[].currentAction property in the listManagedInstances method documentation.",
11354          "type": "integer",
11355          "format": "int32"
11356        },
11357        "recreating": {
11358          "description": "[Output Only] The number of instances in the managed instance group that are scheduled to be recreated or are currently being being recreated. Recreating an instance deletes the existing root persistent disk and creates a new disk from the image that is defined in the instance template.",
11359          "type": "integer",
11360          "format": "int32"
11361        },
11362        "deleting": {
11363          "description": "[Output Only] The number of instances in the managed instance group that are scheduled to be deleted or are currently being deleted.",
11364          "type": "integer",
11365          "format": "int32"
11366        },
11367        "abandoning": {
11368          "description": "[Output Only] The total number of instances in the managed instance group that are scheduled to be abandoned. Abandoning an instance removes it from the managed instance group without deleting it.",
11369          "type": "integer",
11370          "format": "int32"
11371        },
11372        "restarting": {
11373          "description": "[Output Only] The number of instances in the managed instance group that are scheduled to be restarted or are currently being restarted.",
11374          "type": "integer",
11375          "format": "int32"
11376        },
11377        "refreshing": {
11378          "description": "[Output Only] The number of instances in the managed instance group that are being reconfigured with properties that do not require a restart or a recreate action. For example, setting or removing target pools for the instance.",
11379          "type": "integer",
11380          "format": "int32"
11381        },
11382        "suspending": {
11383          "description": "[Output Only] The number of instances in the managed instance group that are scheduled to be suspended or are currently being suspended.",
11384          "type": "integer",
11385          "format": "int32"
11386        },
11387        "resuming": {
11388          "description": "[Output Only] The number of instances in the managed instance group that are scheduled to be resumed or are currently being resumed.",
11389          "type": "integer",
11390          "format": "int32"
11391        },
11392        "stopping": {
11393          "description": "[Output Only] The number of instances in the managed instance group that are scheduled to be stopped or are currently being stopped.",
11394          "type": "integer",
11395          "format": "int32"
11396        },
11397        "starting": {
11398          "description": "[Output Only] The number of instances in the managed instance group that are scheduled to be started or are currently being started.",
11399          "type": "integer",
11400          "format": "int32"
11401        }
11402      }
11403    },
11404    "InstanceGroupManagerStatus": {
11405      "id": "InstanceGroupManagerStatus",
11406      "type": "object",
11407      "properties": {
11408        "isStable": {
11409          "description": "[Output Only] A bit indicating whether the managed instance group is in a stable state. A stable state means that: none of the instances in the managed instance group is currently undergoing any type of change (for example, creation, restart, or deletion); no future changes are scheduled for instances in the managed instance group; and the managed instance group itself is not being modified.",
11410          "type": "boolean"
11411        },
11412        "allInstancesConfig": {
11413          "description": "[Output only] Status of all-instances configuration on the group.",
11414          "$ref": "InstanceGroupManagerStatusAllInstancesConfig"
11415        },
11416        "versionTarget": {
11417          "description": "[Output Only] A status of consistency of Instances' versions with their target version specified by version field on Instance Group Manager.",
11418          "$ref": "InstanceGroupManagerStatusVersionTarget"
11419        },
11420        "stateful": {
11421          "description": "[Output Only] Stateful status of the given Instance Group Manager.",
11422          "$ref": "InstanceGroupManagerStatusStateful"
11423        },
11424        "autoscaler": {
11425          "description": "[Output Only] The URL of the Autoscaler that targets this instance group manager.",
11426          "type": "string"
11427        }
11428      }
11429    },
11430    "InstanceGroupManagerStatusAllInstancesConfig": {
11431      "id": "InstanceGroupManagerStatusAllInstancesConfig",
11432      "type": "object",
11433      "properties": {
11434        "effective": {
11435          "description": "[Output Only] A bit indicating whether this configuration has been applied to all managed instances in the group.",
11436          "type": "boolean"
11437        },
11438        "currentRevision": {
11439          "description": "[Output Only] Current all-instances configuration revision. This value is in RFC3339 text format.",
11440          "type": "string"
11441        }
11442      }
11443    },
11444    "InstanceGroupManagerStatusVersionTarget": {
11445      "id": "InstanceGroupManagerStatusVersionTarget",
11446      "type": "object",
11447      "properties": {
11448        "isReached": {
11449          "description": "[Output Only] A bit indicating whether version target has been reached in this managed instance group, i.e. all instances are in their target version. Instances' target version are specified by version field on Instance Group Manager.",
11450          "type": "boolean"
11451        }
11452      }
11453    },
11454    "InstanceGroupManagerStatusStateful": {
11455      "id": "InstanceGroupManagerStatusStateful",
11456      "type": "object",
11457      "properties": {
11458        "hasStatefulConfig": {
11459          "description": "[Output Only] A bit indicating whether the managed instance group has stateful configuration, that is, if you have configured any items in a stateful policy or in per-instance configs. The group might report that it has no stateful configuration even when there is still some preserved state on a managed instance, for example, if you have deleted all PICs but not yet applied those deletions.",
11460          "type": "boolean"
11461        },
11462        "perInstanceConfigs": {
11463          "description": "[Output Only] Status of per-instance configurations on the instance.",
11464          "$ref": "InstanceGroupManagerStatusStatefulPerInstanceConfigs"
11465        }
11466      }
11467    },
11468    "InstanceGroupManagerStatusStatefulPerInstanceConfigs": {
11469      "id": "InstanceGroupManagerStatusStatefulPerInstanceConfigs",
11470      "type": "object",
11471      "properties": {
11472        "allEffective": {
11473          "description": "A bit indicating if all of the group's per-instance configurations (listed in the output of a listPerInstanceConfigs API call) have status EFFECTIVE or there are no per-instance-configs.",
11474          "type": "boolean"
11475        }
11476      }
11477    },
11478    "InstanceGroupManagerAutoHealingPolicy": {
11479      "id": "InstanceGroupManagerAutoHealingPolicy",
11480      "type": "object",
11481      "properties": {
11482        "healthCheck": {
11483          "description": "The URL for the health check that signals autohealing.",
11484          "type": "string"
11485        },
11486        "initialDelaySec": {
11487          "description": "The initial delay is the number of seconds that a new VM takes to initialize and run its startup script. During a VM's initial delay period, the MIG ignores unsuccessful health checks because the VM might be in the startup process. This prevents the MIG from prematurely recreating a VM. If the health check receives a healthy response during the initial delay, it indicates that the startup process is complete and the VM is ready. The value of initial delay must be between 0 and 3600 seconds. The default value is 0.",
11488          "type": "integer",
11489          "format": "int32"
11490        }
11491      }
11492    },
11493    "InstanceGroupManagerUpdatePolicy": {
11494      "id": "InstanceGroupManagerUpdatePolicy",
11495      "type": "object",
11496      "properties": {
11497        "type": {
11498          "description": "The type of update process. You can specify either PROACTIVE so that the MIG automatically updates VMs to the latest configurations or OPPORTUNISTIC so that you can select the VMs that you want to update.",
11499          "type": "string",
11500          "enumDescriptions": [
11501            "MIG will apply new configurations to existing VMs only when you selectively target specific or all VMs to be updated.",
11502            "MIG will automatically apply new configurations to all or a subset of existing VMs and also to new VMs that are added to the group."
11503          ],
11504          "enum": [
11505            "OPPORTUNISTIC",
11506            "PROACTIVE"
11507          ]
11508        },
11509        "instanceRedistributionType": {
11510          "description": "The instance redistribution policy for regional managed instance groups. Valid values are: - PROACTIVE (default): The group attempts to maintain an even distribution of VM instances across zones in the region. - NONE: For non-autoscaled groups, proactive redistribution is disabled. ",
11511          "type": "string",
11512          "enumDescriptions": [
11513            "No action is being proactively performed in order to bring this IGM to its target instance distribution.",
11514            "This IGM will actively converge to its target instance distribution."
11515          ],
11516          "enum": [
11517            "NONE",
11518            "PROACTIVE"
11519          ]
11520        },
11521        "minimalAction": {
11522          "description": "Minimal action to be taken on an instance. Use this option to minimize disruption as much as possible or to apply a more disruptive action than is necessary. - To limit disruption as much as possible, set the minimal action to REFRESH. If your update requires a more disruptive action, Compute Engine performs the necessary action to execute the update. - To apply a more disruptive action than is strictly necessary, set the minimal action to RESTART or REPLACE. For example, Compute Engine does not need to restart a VM to change its metadata. But if your application reads instance metadata only when a VM is restarted, you can set the minimal action to RESTART in order to pick up metadata changes. ",
11523          "type": "string",
11524          "enumDescriptions": [
11525            "Do not perform any action.",
11526            "Do not stop the instance.",
11527            "(Default.) Replace the instance according to the replacement method option.",
11528            "Stop the instance and start it again."
11529          ],
11530          "enum": [
11531            "NONE",
11532            "REFRESH",
11533            "REPLACE",
11534            "RESTART"
11535          ]
11536        },
11537        "mostDisruptiveAllowedAction": {
11538          "description": "Most disruptive action that is allowed to be taken on an instance. You can specify either NONE to forbid any actions, REFRESH to avoid restarting the VM and to limit disruption as much as possible. RESTART to allow actions that can be applied without instance replacing or REPLACE to allow all possible actions. If the Updater determines that the minimal update action needed is more disruptive than most disruptive allowed action you specify it will not perform the update at all.",
11539          "type": "string",
11540          "enumDescriptions": [
11541            "Do not perform any action.",
11542            "Do not stop the instance.",
11543            "(Default.) Replace the instance according to the replacement method option.",
11544            "Stop the instance and start it again."
11545          ],
11546          "enum": [
11547            "NONE",
11548            "REFRESH",
11549            "REPLACE",
11550            "RESTART"
11551          ]
11552        },
11553        "maxSurge": {
11554          "description": "The maximum number of instances that can be created above the specified targetSize during the update process. This value can be either a fixed number or, if the group has 10 or more instances, a percentage. If you set a percentage, the number of instances is rounded if necessary. The default value for maxSurge is a fixed value equal to the number of zones in which the managed instance group operates. At least one of either maxSurge or maxUnavailable must be greater than 0. Learn more about maxSurge.",
11555          "$ref": "FixedOrPercent"
11556        },
11557        "maxUnavailable": {
11558          "description": "The maximum number of instances that can be unavailable during the update process. An instance is considered available if all of the following conditions are satisfied: - The instance's status is RUNNING. - If there is a health check on the instance group, the instance's health check status must be HEALTHY at least once. If there is no health check on the group, then the instance only needs to have a status of RUNNING to be considered available. This value can be either a fixed number or, if the group has 10 or more instances, a percentage. If you set a percentage, the number of instances is rounded if necessary. The default value for maxUnavailable is a fixed value equal to the number of zones in which the managed instance group operates. At least one of either maxSurge or maxUnavailable must be greater than 0. Learn more about maxUnavailable.",
11559          "$ref": "FixedOrPercent"
11560        },
11561        "replacementMethod": {
11562          "description": "What action should be used to replace instances. See minimal_action.REPLACE",
11563          "type": "string",
11564          "enumDescriptions": [
11565            "Instances will be recreated (with the same name)",
11566            "Default option: instances will be deleted and created (with a new name)"
11567          ],
11568          "enum": [
11569            "RECREATE",
11570            "SUBSTITUTE"
11571          ]
11572        }
11573      }
11574    },
11575    "StatefulPolicy": {
11576      "id": "StatefulPolicy",
11577      "type": "object",
11578      "properties": {
11579        "preservedState": {
11580          "$ref": "StatefulPolicyPreservedState"
11581        }
11582      }
11583    },
11584    "StatefulPolicyPreservedState": {
11585      "id": "StatefulPolicyPreservedState",
11586      "description": "Configuration of preserved resources.",
11587      "type": "object",
11588      "properties": {
11589        "disks": {
11590          "description": "Disks created on the instances that will be preserved on instance delete, update, etc. This map is keyed with the device names of the disks.",
11591          "type": "object",
11592          "additionalProperties": {
11593            "$ref": "StatefulPolicyPreservedStateDiskDevice"
11594          }
11595        },
11596        "internalIPs": {
11597          "description": "Internal network IPs assigned to the instances that will be preserved on instance delete, update, etc. This map is keyed with the network interface name.",
11598          "type": "object",
11599          "additionalProperties": {
11600            "$ref": "StatefulPolicyPreservedStateNetworkIp"
11601          }
11602        },
11603        "externalIPs": {
11604          "description": "External network IPs assigned to the instances that will be preserved on instance delete, update, etc. This map is keyed with the network interface name.",
11605          "type": "object",
11606          "additionalProperties": {
11607            "$ref": "StatefulPolicyPreservedStateNetworkIp"
11608          }
11609        }
11610      }
11611    },
11612    "StatefulPolicyPreservedStateDiskDevice": {
11613      "id": "StatefulPolicyPreservedStateDiskDevice",
11614      "type": "object",
11615      "properties": {
11616        "autoDelete": {
11617          "description": "These stateful disks will never be deleted during autohealing, update or VM instance recreate operations. This flag is used to configure if the disk should be deleted after it is no longer used by the group, e.g. when the given instance or the whole group is deleted. Note: disks attached in READ_ONLY mode cannot be auto-deleted.",
11618          "type": "string",
11619          "enumDescriptions": [
11620            "",
11621            ""
11622          ],
11623          "enum": [
11624            "NEVER",
11625            "ON_PERMANENT_INSTANCE_DELETION"
11626          ]
11627        }
11628      }
11629    },
11630    "StatefulPolicyPreservedStateNetworkIp": {
11631      "id": "StatefulPolicyPreservedStateNetworkIp",
11632      "type": "object",
11633      "properties": {
11634        "autoDelete": {
11635          "description": "These stateful IPs will never be released during autohealing, update or VM instance recreate operations. This flag is used to configure if the IP reservation should be deleted after it is no longer used by the group, e.g. when the given instance or the whole group is deleted.",
11636          "type": "string",
11637          "enumDescriptions": [
11638            "",
11639            ""
11640          ],
11641          "enum": [
11642            "NEVER",
11643            "ON_PERMANENT_INSTANCE_DELETION"
11644          ]
11645        }
11646      }
11647    },
11648    "InstanceGroupManagerInstanceLifecyclePolicy": {
11649      "id": "InstanceGroupManagerInstanceLifecyclePolicy",
11650      "type": "object",
11651      "properties": {
11652        "forceUpdateOnRepair": {
11653          "description": "A bit indicating whether to forcefully apply the group's latest configuration when repairing a VM. Valid options are: - NO (default): If configuration updates are available, they are not forcefully applied during repair. Instead, configuration updates are applied according to the group's update policy. - YES: If configuration updates are available, they are applied during repair. ",
11654          "type": "string",
11655          "enumDescriptions": [
11656            "",
11657            ""
11658          ],
11659          "enum": [
11660            "NO",
11661            "YES"
11662          ]
11663        },
11664        "defaultActionOnFailure": {
11665          "description": "The action that a MIG performs on a failed or an unhealthy VM. A VM is marked as unhealthy when the application running on that VM fails a health check. Valid values are - REPAIR (default): MIG automatically repairs a failed or an unhealthy VM by recreating it. For more information, see About repairing VMs in a MIG. - DO_NOTHING: MIG does not repair a failed or an unhealthy VM. ",
11666          "type": "string",
11667          "enumDescriptions": [
11668            "MIG does not repair a failed or an unhealthy VM.",
11669            "(Default) MIG automatically repairs a failed or an unhealthy VM by recreating it. For more information, see About repairing VMs in a MIG."
11670          ],
11671          "enum": [
11672            "DO_NOTHING",
11673            "REPAIR"
11674          ]
11675        }
11676      }
11677    },
11678    "InstanceGroupManagerAggregatedList": {
11679      "id": "InstanceGroupManagerAggregatedList",
11680      "type": "object",
11681      "properties": {
11682        "kind": {
11683          "description": "[Output Only] The resource type, which is always compute#instanceGroupManagerAggregatedList for an aggregated list of managed instance groups.",
11684          "default": "compute#instanceGroupManagerAggregatedList",
11685          "type": "string"
11686        },
11687        "id": {
11688          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
11689          "type": "string"
11690        },
11691        "items": {
11692          "description": "A list of InstanceGroupManagersScopedList resources.",
11693          "type": "object",
11694          "additionalProperties": {
11695            "description": "[Output Only] The name of the scope that contains this set of managed instance groups.",
11696            "$ref": "InstanceGroupManagersScopedList"
11697          }
11698        },
11699        "nextPageToken": {
11700          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
11701          "type": "string"
11702        },
11703        "selfLink": {
11704          "description": "[Output Only] Server-defined URL for this resource.",
11705          "type": "string"
11706        },
11707        "warning": {
11708          "description": "[Output Only] Informational warning message.",
11709          "type": "object",
11710          "properties": {
11711            "code": {
11712              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
11713              "type": "string",
11714              "enumDescriptions": [
11715                "Warning about failed cleanup of transient changes made by a failed operation.",
11716                "A link to a deprecated resource was created.",
11717                "When deploying and at least one of the resources has a type marked as deprecated",
11718                "The user created a boot disk that is larger than image size.",
11719                "When deploying and at least one of the resources has a type marked as experimental",
11720                "Warning that is present in an external api call",
11721                "Warning that value of a field has been overridden. Deprecated unused field.",
11722                "The operation involved use of an injected kernel, which is deprecated.",
11723                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
11724                "When deploying a deployment with a exceedingly large number of resources",
11725                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
11726                "A resource depends on a missing type",
11727                "The route's nextHopIp address is not assigned to an instance on the network.",
11728                "The route's next hop instance cannot ip forward.",
11729                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
11730                "The route's nextHopInstance URL refers to an instance that does not exist.",
11731                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
11732                "The route's next hop instance does not have a status of RUNNING.",
11733                "Error which is not critical. We decided to continue the process despite the mentioned error.",
11734                "No results are present on a particular list page.",
11735                "Success is reported, but some results may be missing due to errors",
11736                "The user attempted to use a resource that requires a TOS they have not accepted.",
11737                "Warning that a resource is in use.",
11738                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
11739                "When a resource schema validation is ignored.",
11740                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
11741                "When undeclared properties in the schema are present",
11742                "A given scope cannot be reached."
11743              ],
11744              "enumDeprecated": [
11745                false,
11746                false,
11747                false,
11748                false,
11749                false,
11750                false,
11751                true,
11752                false,
11753                false,
11754                false,
11755                false,
11756                false,
11757                false,
11758                false,
11759                false,
11760                false,
11761                false,
11762                false,
11763                false,
11764                false,
11765                false,
11766                false,
11767                false,
11768                false,
11769                false,
11770                false,
11771                false,
11772                false
11773              ],
11774              "enum": [
11775                "CLEANUP_FAILED",
11776                "DEPRECATED_RESOURCE_USED",
11777                "DEPRECATED_TYPE_USED",
11778                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
11779                "EXPERIMENTAL_TYPE_USED",
11780                "EXTERNAL_API_WARNING",
11781                "FIELD_VALUE_OVERRIDEN",
11782                "INJECTED_KERNELS_DEPRECATED",
11783                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
11784                "LARGE_DEPLOYMENT_WARNING",
11785                "LIST_OVERHEAD_QUOTA_EXCEED",
11786                "MISSING_TYPE_DEPENDENCY",
11787                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
11788                "NEXT_HOP_CANNOT_IP_FORWARD",
11789                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
11790                "NEXT_HOP_INSTANCE_NOT_FOUND",
11791                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
11792                "NEXT_HOP_NOT_RUNNING",
11793                "NOT_CRITICAL_ERROR",
11794                "NO_RESULTS_ON_PAGE",
11795                "PARTIAL_SUCCESS",
11796                "REQUIRED_TOS_AGREEMENT",
11797                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
11798                "RESOURCE_NOT_DELETED",
11799                "SCHEMA_VALIDATION_IGNORED",
11800                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
11801                "UNDECLARED_PROPERTIES",
11802                "UNREACHABLE"
11803              ]
11804            },
11805            "message": {
11806              "description": "[Output Only] A human-readable description of the warning code.",
11807              "type": "string"
11808            },
11809            "data": {
11810              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
11811              "type": "array",
11812              "items": {
11813                "type": "object",
11814                "properties": {
11815                  "key": {
11816                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
11817                    "type": "string"
11818                  },
11819                  "value": {
11820                    "description": "[Output Only] A warning data value corresponding to the key.",
11821                    "type": "string"
11822                  }
11823                }
11824              }
11825            }
11826          }
11827        },
11828        "unreachables": {
11829          "description": "[Output Only] Unreachable resources.",
11830          "type": "array",
11831          "items": {
11832            "type": "string"
11833          }
11834        }
11835      }
11836    },
11837    "InstanceGroupManagersScopedList": {
11838      "id": "InstanceGroupManagersScopedList",
11839      "type": "object",
11840      "properties": {
11841        "instanceGroupManagers": {
11842          "description": "[Output Only] The list of managed instance groups that are contained in the specified project and zone.",
11843          "type": "array",
11844          "items": {
11845            "$ref": "InstanceGroupManager"
11846          }
11847        },
11848        "warning": {
11849          "description": "[Output Only] The warning that replaces the list of managed instance groups when the list is empty.",
11850          "type": "object",
11851          "properties": {
11852            "code": {
11853              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
11854              "type": "string",
11855              "enumDescriptions": [
11856                "Warning about failed cleanup of transient changes made by a failed operation.",
11857                "A link to a deprecated resource was created.",
11858                "When deploying and at least one of the resources has a type marked as deprecated",
11859                "The user created a boot disk that is larger than image size.",
11860                "When deploying and at least one of the resources has a type marked as experimental",
11861                "Warning that is present in an external api call",
11862                "Warning that value of a field has been overridden. Deprecated unused field.",
11863                "The operation involved use of an injected kernel, which is deprecated.",
11864                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
11865                "When deploying a deployment with a exceedingly large number of resources",
11866                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
11867                "A resource depends on a missing type",
11868                "The route's nextHopIp address is not assigned to an instance on the network.",
11869                "The route's next hop instance cannot ip forward.",
11870                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
11871                "The route's nextHopInstance URL refers to an instance that does not exist.",
11872                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
11873                "The route's next hop instance does not have a status of RUNNING.",
11874                "Error which is not critical. We decided to continue the process despite the mentioned error.",
11875                "No results are present on a particular list page.",
11876                "Success is reported, but some results may be missing due to errors",
11877                "The user attempted to use a resource that requires a TOS they have not accepted.",
11878                "Warning that a resource is in use.",
11879                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
11880                "When a resource schema validation is ignored.",
11881                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
11882                "When undeclared properties in the schema are present",
11883                "A given scope cannot be reached."
11884              ],
11885              "enumDeprecated": [
11886                false,
11887                false,
11888                false,
11889                false,
11890                false,
11891                false,
11892                true,
11893                false,
11894                false,
11895                false,
11896                false,
11897                false,
11898                false,
11899                false,
11900                false,
11901                false,
11902                false,
11903                false,
11904                false,
11905                false,
11906                false,
11907                false,
11908                false,
11909                false,
11910                false,
11911                false,
11912                false,
11913                false
11914              ],
11915              "enum": [
11916                "CLEANUP_FAILED",
11917                "DEPRECATED_RESOURCE_USED",
11918                "DEPRECATED_TYPE_USED",
11919                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
11920                "EXPERIMENTAL_TYPE_USED",
11921                "EXTERNAL_API_WARNING",
11922                "FIELD_VALUE_OVERRIDEN",
11923                "INJECTED_KERNELS_DEPRECATED",
11924                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
11925                "LARGE_DEPLOYMENT_WARNING",
11926                "LIST_OVERHEAD_QUOTA_EXCEED",
11927                "MISSING_TYPE_DEPENDENCY",
11928                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
11929                "NEXT_HOP_CANNOT_IP_FORWARD",
11930                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
11931                "NEXT_HOP_INSTANCE_NOT_FOUND",
11932                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
11933                "NEXT_HOP_NOT_RUNNING",
11934                "NOT_CRITICAL_ERROR",
11935                "NO_RESULTS_ON_PAGE",
11936                "PARTIAL_SUCCESS",
11937                "REQUIRED_TOS_AGREEMENT",
11938                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
11939                "RESOURCE_NOT_DELETED",
11940                "SCHEMA_VALIDATION_IGNORED",
11941                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
11942                "UNDECLARED_PROPERTIES",
11943                "UNREACHABLE"
11944              ]
11945            },
11946            "message": {
11947              "description": "[Output Only] A human-readable description of the warning code.",
11948              "type": "string"
11949            },
11950            "data": {
11951              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
11952              "type": "array",
11953              "items": {
11954                "type": "object",
11955                "properties": {
11956                  "key": {
11957                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
11958                    "type": "string"
11959                  },
11960                  "value": {
11961                    "description": "[Output Only] A warning data value corresponding to the key.",
11962                    "type": "string"
11963                  }
11964                }
11965              }
11966            }
11967          }
11968        }
11969      }
11970    },
11971    "InstanceGroupManagersDeleteInstancesRequest": {
11972      "id": "InstanceGroupManagersDeleteInstancesRequest",
11973      "type": "object",
11974      "properties": {
11975        "instances": {
11976          "description": "The URLs of one or more instances to delete. This can be a full URL or a partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME]. Queued instances do not have URL and can be deleted only by name. One cannot specify both URLs and names in a single request.",
11977          "type": "array",
11978          "items": {
11979            "type": "string"
11980          }
11981        },
11982        "skipInstancesOnValidationError": {
11983          "description": "Specifies whether the request should proceed despite the inclusion of instances that are not members of the group or that are already in the process of being deleted or abandoned. If this field is set to `false` and such an instance is specified in the request, the operation fails. The operation always fails if the request contains a malformed instance URL or a reference to an instance that exists in a zone or region other than the group's zone or region.",
11984          "type": "boolean"
11985        }
11986      }
11987    },
11988    "InstanceGroupManagersAbandonInstancesRequest": {
11989      "id": "InstanceGroupManagersAbandonInstancesRequest",
11990      "type": "object",
11991      "properties": {
11992        "instances": {
11993          "description": "The URLs of one or more instances to abandon. This can be a full URL or a partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].",
11994          "type": "array",
11995          "items": {
11996            "type": "string"
11997          }
11998        }
11999      }
12000    },
12001    "InstanceGroupManagersRecreateInstancesRequest": {
12002      "id": "InstanceGroupManagersRecreateInstancesRequest",
12003      "type": "object",
12004      "properties": {
12005        "instances": {
12006          "description": "The URLs of one or more instances to recreate. This can be a full URL or a partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].",
12007          "type": "array",
12008          "items": {
12009            "type": "string"
12010          }
12011        }
12012      }
12013    },
12014    "InstanceGroupManagersSetInstanceTemplateRequest": {
12015      "id": "InstanceGroupManagersSetInstanceTemplateRequest",
12016      "type": "object",
12017      "properties": {
12018        "instanceTemplate": {
12019          "description": "The URL of the instance template that is specified for this managed instance group. The group uses this template to create all new instances in the managed instance group. The templates for existing instances in the group do not change unless you run recreateInstances, run applyUpdatesToInstances, or set the group's updatePolicy.type to PROACTIVE.",
12020          "type": "string"
12021        }
12022      }
12023    },
12024    "InstanceGroupManagersSetTargetPoolsRequest": {
12025      "id": "InstanceGroupManagersSetTargetPoolsRequest",
12026      "type": "object",
12027      "properties": {
12028        "targetPools": {
12029          "description": "The list of target pool URLs that instances in this managed instance group belong to. The managed instance group applies these target pools to all of the instances in the group. Existing instances and new instances in the group all receive these target pool settings.",
12030          "type": "array",
12031          "items": {
12032            "type": "string"
12033          }
12034        },
12035        "fingerprint": {
12036          "description": "The fingerprint of the target pools information. Use this optional property to prevent conflicts when multiple users change the target pools settings concurrently. Obtain the fingerprint with the instanceGroupManagers.get method. Then, include the fingerprint in your request to ensure that you do not overwrite changes that were applied from another concurrent request.",
12037          "type": "string",
12038          "format": "byte"
12039        }
12040      }
12041    },
12042    "InstanceGroupManagersListManagedInstancesResponse": {
12043      "id": "InstanceGroupManagersListManagedInstancesResponse",
12044      "type": "object",
12045      "properties": {
12046        "managedInstances": {
12047          "description": "[Output Only] The list of instances in the managed instance group.",
12048          "type": "array",
12049          "items": {
12050            "$ref": "ManagedInstance"
12051          }
12052        },
12053        "nextPageToken": {
12054          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
12055          "type": "string"
12056        }
12057      }
12058    },
12059    "ManagedInstance": {
12060      "id": "ManagedInstance",
12061      "description": "A Managed Instance resource.",
12062      "type": "object",
12063      "properties": {
12064        "name": {
12065          "description": "[Output Only] The name of the instance. The name always exists even if the instance has not yet been created.",
12066          "type": "string"
12067        },
12068        "instance": {
12069          "description": "[Output Only] The URL of the instance. The URL can exist even if the instance has not yet been created.",
12070          "type": "string"
12071        },
12072        "id": {
12073          "description": "[Output only] The unique identifier for this resource. This field is empty when instance does not exist.",
12074          "type": "string",
12075          "format": "uint64"
12076        },
12077        "instanceStatus": {
12078          "description": "[Output Only] The status of the instance. This field is empty when the instance does not exist.",
12079          "type": "string",
12080          "enumDescriptions": [
12081            "The instance is halted and we are performing tear down tasks like network deprogramming, releasing quota, IP, tearing down disks etc.",
12082            "Resources are being allocated for the instance.",
12083            "The instance is in repair.",
12084            "The instance is running.",
12085            "All required resources have been allocated and the instance is being started.",
12086            "The instance has stopped successfully.",
12087            "The instance is currently stopping (either being deleted or killed).",
12088            "The instance has suspended.",
12089            "The instance is suspending.",
12090            "The instance has stopped (either by explicit action or underlying failure)."
12091          ],
12092          "enum": [
12093            "DEPROVISIONING",
12094            "PROVISIONING",
12095            "REPAIRING",
12096            "RUNNING",
12097            "STAGING",
12098            "STOPPED",
12099            "STOPPING",
12100            "SUSPENDED",
12101            "SUSPENDING",
12102            "TERMINATED"
12103          ]
12104        },
12105        "version": {
12106          "description": "[Output Only] Intended version of this instance.",
12107          "$ref": "ManagedInstanceVersion"
12108        },
12109        "preservedStateFromPolicy": {
12110          "description": "[Output Only] Preserved state generated based on stateful policy for this instance.",
12111          "$ref": "PreservedState"
12112        },
12113        "preservedStateFromConfig": {
12114          "description": "[Output Only] Preserved state applied from per-instance config for this instance.",
12115          "$ref": "PreservedState"
12116        },
12117        "currentAction": {
12118          "description": "[Output Only] The current action that the managed instance group has scheduled for the instance. Possible values: - NONE The instance is running, and the managed instance group does not have any scheduled actions for this instance. - CREATING The managed instance group is creating this instance. If the group fails to create this instance, it will try again until it is successful. - CREATING_WITHOUT_RETRIES The managed instance group is attempting to create this instance only once. If the group fails to create this instance, it does not try again and the group's targetSize value is decreased instead. - RECREATING The managed instance group is recreating this instance. - DELETING The managed instance group is permanently deleting this instance. - ABANDONING The managed instance group is abandoning this instance. The instance will be removed from the instance group and from any target pools that are associated with this group. - RESTARTING The managed instance group is restarting the instance. - REFRESHING The managed instance group is applying configuration changes to the instance without stopping it. For example, the group can update the target pool list for an instance without stopping that instance. - VERIFYING The managed instance group has created the instance and it is in the process of being verified. ",
12119          "type": "string",
12120          "enumDescriptions": [
12121            "The managed instance group is abandoning this instance. The instance will be removed from the instance group and from any target pools that are associated with this group.",
12122            "The managed instance group is creating this instance. If the group fails to create this instance, it will try again until it is successful.",
12123            "The managed instance group is attempting to create this instance only once. If the group fails to create this instance, it does not try again and the group's targetSize value is decreased.",
12124            "The managed instance group is permanently deleting this instance.",
12125            "The managed instance group has not scheduled any actions for this instance.",
12126            "The managed instance group is recreating this instance.",
12127            "The managed instance group is applying configuration changes to the instance without stopping it. For example, the group can update the target pool list for an instance without stopping that instance.",
12128            "The managed instance group is restarting this instance.",
12129            "The managed instance group is resuming this instance.",
12130            "The managed instance group is starting this instance.",
12131            "The managed instance group is stopping this instance.",
12132            "The managed instance group is suspending this instance.",
12133            "The managed instance group is verifying this already created instance. Verification happens every time the instance is (re)created or restarted and consists of: 1. Waiting until health check specified as part of this managed instance group's autohealing policy reports HEALTHY. Note: Applies only if autohealing policy has a health check specified 2. Waiting for addition verification steps performed as post-instance creation (subject to future extensions)."
12134          ],
12135          "enum": [
12136            "ABANDONING",
12137            "CREATING",
12138            "CREATING_WITHOUT_RETRIES",
12139            "DELETING",
12140            "NONE",
12141            "RECREATING",
12142            "REFRESHING",
12143            "RESTARTING",
12144            "RESUMING",
12145            "STARTING",
12146            "STOPPING",
12147            "SUSPENDING",
12148            "VERIFYING"
12149          ]
12150        },
12151        "instanceHealth": {
12152          "description": "[Output Only] Health state of the instance per health-check.",
12153          "type": "array",
12154          "items": {
12155            "$ref": "ManagedInstanceInstanceHealth"
12156          }
12157        },
12158        "lastAttempt": {
12159          "description": "[Output Only] Information about the last attempt to create or delete the instance.",
12160          "$ref": "ManagedInstanceLastAttempt"
12161        }
12162      }
12163    },
12164    "ManagedInstanceVersion": {
12165      "id": "ManagedInstanceVersion",
12166      "type": "object",
12167      "properties": {
12168        "name": {
12169          "description": "[Output Only] Name of the version.",
12170          "type": "string"
12171        },
12172        "instanceTemplate": {
12173          "description": "[Output Only] The intended template of the instance. This field is empty when current_action is one of { DELETING, ABANDONING }.",
12174          "type": "string"
12175        }
12176      }
12177    },
12178    "PreservedState": {
12179      "id": "PreservedState",
12180      "description": "Preserved state for a given instance.",
12181      "type": "object",
12182      "properties": {
12183        "disks": {
12184          "description": "Preserved disks defined for this instance. This map is keyed with the device names of the disks.",
12185          "type": "object",
12186          "additionalProperties": {
12187            "$ref": "PreservedStatePreservedDisk"
12188          }
12189        },
12190        "metadata": {
12191          "description": "Preserved metadata defined for this instance.",
12192          "type": "object",
12193          "additionalProperties": {
12194            "type": "string"
12195          }
12196        },
12197        "internalIPs": {
12198          "description": "Preserved internal IPs defined for this instance. This map is keyed with the name of the network interface.",
12199          "type": "object",
12200          "additionalProperties": {
12201            "$ref": "PreservedStatePreservedNetworkIp"
12202          }
12203        },
12204        "externalIPs": {
12205          "description": "Preserved external IPs defined for this instance. This map is keyed with the name of the network interface.",
12206          "type": "object",
12207          "additionalProperties": {
12208            "$ref": "PreservedStatePreservedNetworkIp"
12209          }
12210        }
12211      }
12212    },
12213    "PreservedStatePreservedDisk": {
12214      "id": "PreservedStatePreservedDisk",
12215      "type": "object",
12216      "properties": {
12217        "source": {
12218          "description": "The URL of the disk resource that is stateful and should be attached to the VM instance.",
12219          "type": "string"
12220        },
12221        "mode": {
12222          "description": "The mode in which to attach this disk, either READ_WRITE or READ_ONLY. If not specified, the default is to attach the disk in READ_WRITE mode.",
12223          "type": "string",
12224          "enumDescriptions": [
12225            "Attaches this disk in read-only mode. Multiple VM instances can use a disk in READ_ONLY mode at a time.",
12226            "*[Default]* Attaches this disk in READ_WRITE mode. Only one VM instance at a time can be attached to a disk in READ_WRITE mode."
12227          ],
12228          "enum": [
12229            "READ_ONLY",
12230            "READ_WRITE"
12231          ]
12232        },
12233        "autoDelete": {
12234          "description": "These stateful disks will never be deleted during autohealing, update, instance recreate operations. This flag is used to configure if the disk should be deleted after it is no longer used by the group, e.g. when the given instance or the whole MIG is deleted. Note: disks attached in READ_ONLY mode cannot be auto-deleted.",
12235          "type": "string",
12236          "enumDescriptions": [
12237            "",
12238            ""
12239          ],
12240          "enum": [
12241            "NEVER",
12242            "ON_PERMANENT_INSTANCE_DELETION"
12243          ]
12244        }
12245      }
12246    },
12247    "PreservedStatePreservedNetworkIp": {
12248      "id": "PreservedStatePreservedNetworkIp",
12249      "type": "object",
12250      "properties": {
12251        "autoDelete": {
12252          "description": "These stateful IPs will never be released during autohealing, update or VM instance recreate operations. This flag is used to configure if the IP reservation should be deleted after it is no longer used by the group, e.g. when the given instance or the whole group is deleted.",
12253          "type": "string",
12254          "enumDescriptions": [
12255            "",
12256            ""
12257          ],
12258          "enum": [
12259            "NEVER",
12260            "ON_PERMANENT_INSTANCE_DELETION"
12261          ]
12262        },
12263        "ipAddress": {
12264          "description": "Ip address representation",
12265          "$ref": "PreservedStatePreservedNetworkIpIpAddress"
12266        }
12267      }
12268    },
12269    "PreservedStatePreservedNetworkIpIpAddress": {
12270      "id": "PreservedStatePreservedNetworkIpIpAddress",
12271      "type": "object",
12272      "properties": {
12273        "literal": {
12274          "description": "An IPv4 internal network address to assign to the instance for this network interface.",
12275          "type": "string"
12276        },
12277        "address": {
12278          "description": "The URL of the reservation for this IP address.",
12279          "type": "string"
12280        }
12281      }
12282    },
12283    "ManagedInstanceInstanceHealth": {
12284      "id": "ManagedInstanceInstanceHealth",
12285      "type": "object",
12286      "properties": {
12287        "healthCheck": {
12288          "description": "[Output Only] The URL for the health check that verifies whether the instance is healthy.",
12289          "type": "string"
12290        },
12291        "detailedHealthState": {
12292          "description": "[Output Only] The current detailed instance health state.",
12293          "type": "string",
12294          "enumDescriptions": [
12295            "The instance is being drained. The existing connections to the instance have time to complete, but the new ones are being refused.",
12296            "The instance is reachable i.e. a connection to the application health checking endpoint can be established, and conforms to the requirements defined by the health check.",
12297            "The instance is unreachable i.e. a connection to the application health checking endpoint cannot be established, or the server does not respond within the specified timeout.",
12298            "The instance is reachable, but does not conform to the requirements defined by the health check.",
12299            "The health checking system is aware of the instance but its health is not known at the moment."
12300          ],
12301          "enum": [
12302            "DRAINING",
12303            "HEALTHY",
12304            "TIMEOUT",
12305            "UNHEALTHY",
12306            "UNKNOWN"
12307          ]
12308        }
12309      }
12310    },
12311    "ManagedInstanceLastAttempt": {
12312      "id": "ManagedInstanceLastAttempt",
12313      "type": "object",
12314      "properties": {
12315        "errors": {
12316          "description": "[Output Only] Encountered errors during the last attempt to create or delete the instance.",
12317          "type": "object",
12318          "properties": {
12319            "errors": {
12320              "description": "[Output Only] The array of errors encountered while processing this operation.",
12321              "type": "array",
12322              "items": {
12323                "type": "object",
12324                "properties": {
12325                  "code": {
12326                    "description": "[Output Only] The error type identifier for this error.",
12327                    "type": "string"
12328                  },
12329                  "location": {
12330                    "description": "[Output Only] Indicates the field in the request that caused the error. This property is optional.",
12331                    "type": "string"
12332                  },
12333                  "message": {
12334                    "description": "[Output Only] An optional, human-readable error message.",
12335                    "type": "string"
12336                  },
12337                  "errorDetails": {
12338                    "description": "[Output Only] An optional list of messages that contain the error details. There is a set of defined message types to use for providing details.The syntax depends on the error code. For example, QuotaExceededInfo will have details when the error code is QUOTA_EXCEEDED.",
12339                    "type": "array",
12340                    "items": {
12341                      "type": "object",
12342                      "properties": {
12343                        "errorInfo": {
12344                          "$ref": "ErrorInfo"
12345                        },
12346                        "quotaInfo": {
12347                          "$ref": "QuotaExceededInfo"
12348                        },
12349                        "help": {
12350                          "$ref": "Help"
12351                        },
12352                        "localizedMessage": {
12353                          "$ref": "LocalizedMessage"
12354                        }
12355                      }
12356                    }
12357                  }
12358                }
12359              }
12360            }
12361          }
12362        }
12363      }
12364    },
12365    "InstanceGroupManagersListErrorsResponse": {
12366      "id": "InstanceGroupManagersListErrorsResponse",
12367      "type": "object",
12368      "properties": {
12369        "items": {
12370          "description": "[Output Only] The list of errors of the managed instance group.",
12371          "type": "array",
12372          "items": {
12373            "$ref": "InstanceManagedByIgmError"
12374          }
12375        },
12376        "nextPageToken": {
12377          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
12378          "type": "string"
12379        }
12380      }
12381    },
12382    "InstanceManagedByIgmError": {
12383      "id": "InstanceManagedByIgmError",
12384      "type": "object",
12385      "properties": {
12386        "error": {
12387          "description": "[Output Only] Contents of the error.",
12388          "$ref": "InstanceManagedByIgmErrorManagedInstanceError"
12389        },
12390        "timestamp": {
12391          "description": "[Output Only] The time that this error occurred. This value is in RFC3339 text format.",
12392          "type": "string"
12393        },
12394        "instanceActionDetails": {
12395          "description": "[Output Only] Details of the instance action that triggered this error. May be null, if the error was not caused by an action on an instance. This field is optional.",
12396          "$ref": "InstanceManagedByIgmErrorInstanceActionDetails"
12397        }
12398      }
12399    },
12400    "InstanceManagedByIgmErrorManagedInstanceError": {
12401      "id": "InstanceManagedByIgmErrorManagedInstanceError",
12402      "type": "object",
12403      "properties": {
12404        "code": {
12405          "description": "[Output Only] Error code.",
12406          "type": "string"
12407        },
12408        "message": {
12409          "description": "[Output Only] Error message.",
12410          "type": "string"
12411        }
12412      }
12413    },
12414    "InstanceManagedByIgmErrorInstanceActionDetails": {
12415      "id": "InstanceManagedByIgmErrorInstanceActionDetails",
12416      "type": "object",
12417      "properties": {
12418        "action": {
12419          "description": "[Output Only] Action that managed instance group was executing on the instance when the error occurred. Possible values:",
12420          "type": "string",
12421          "enumDescriptions": [
12422            "The managed instance group is abandoning this instance. The instance will be removed from the instance group and from any target pools that are associated with this group.",
12423            "The managed instance group is creating this instance. If the group fails to create this instance, it will try again until it is successful.",
12424            "The managed instance group is attempting to create this instance only once. If the group fails to create this instance, it does not try again and the group's targetSize value is decreased.",
12425            "The managed instance group is permanently deleting this instance.",
12426            "The managed instance group has not scheduled any actions for this instance.",
12427            "The managed instance group is recreating this instance.",
12428            "The managed instance group is applying configuration changes to the instance without stopping it. For example, the group can update the target pool list for an instance without stopping that instance.",
12429            "The managed instance group is restarting this instance.",
12430            "The managed instance group is resuming this instance.",
12431            "The managed instance group is starting this instance.",
12432            "The managed instance group is stopping this instance.",
12433            "The managed instance group is suspending this instance.",
12434            "The managed instance group is verifying this already created instance. Verification happens every time the instance is (re)created or restarted and consists of: 1. Waiting until health check specified as part of this managed instance group's autohealing policy reports HEALTHY. Note: Applies only if autohealing policy has a health check specified 2. Waiting for addition verification steps performed as post-instance creation (subject to future extensions)."
12435          ],
12436          "enum": [
12437            "ABANDONING",
12438            "CREATING",
12439            "CREATING_WITHOUT_RETRIES",
12440            "DELETING",
12441            "NONE",
12442            "RECREATING",
12443            "REFRESHING",
12444            "RESTARTING",
12445            "RESUMING",
12446            "STARTING",
12447            "STOPPING",
12448            "SUSPENDING",
12449            "VERIFYING"
12450          ]
12451        },
12452        "instance": {
12453          "description": "[Output Only] The URL of the instance. The URL can be set even if the instance has not yet been created.",
12454          "type": "string"
12455        },
12456        "version": {
12457          "description": "[Output Only] Version this instance was created from, or was being created from, but the creation failed. Corresponds to one of the versions that were set on the Instance Group Manager resource at the time this instance was being created.",
12458          "$ref": "ManagedInstanceVersion"
12459        }
12460      }
12461    },
12462    "InstanceGroupManagersListPerInstanceConfigsResp": {
12463      "id": "InstanceGroupManagersListPerInstanceConfigsResp",
12464      "type": "object",
12465      "properties": {
12466        "items": {
12467          "description": "[Output Only] The list of PerInstanceConfig.",
12468          "type": "array",
12469          "items": {
12470            "$ref": "PerInstanceConfig"
12471          }
12472        },
12473        "nextPageToken": {
12474          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
12475          "type": "string"
12476        },
12477        "warning": {
12478          "description": "[Output Only] Informational warning message.",
12479          "type": "object",
12480          "properties": {
12481            "code": {
12482              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
12483              "type": "string",
12484              "enumDescriptions": [
12485                "Warning about failed cleanup of transient changes made by a failed operation.",
12486                "A link to a deprecated resource was created.",
12487                "When deploying and at least one of the resources has a type marked as deprecated",
12488                "The user created a boot disk that is larger than image size.",
12489                "When deploying and at least one of the resources has a type marked as experimental",
12490                "Warning that is present in an external api call",
12491                "Warning that value of a field has been overridden. Deprecated unused field.",
12492                "The operation involved use of an injected kernel, which is deprecated.",
12493                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
12494                "When deploying a deployment with a exceedingly large number of resources",
12495                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
12496                "A resource depends on a missing type",
12497                "The route's nextHopIp address is not assigned to an instance on the network.",
12498                "The route's next hop instance cannot ip forward.",
12499                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
12500                "The route's nextHopInstance URL refers to an instance that does not exist.",
12501                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
12502                "The route's next hop instance does not have a status of RUNNING.",
12503                "Error which is not critical. We decided to continue the process despite the mentioned error.",
12504                "No results are present on a particular list page.",
12505                "Success is reported, but some results may be missing due to errors",
12506                "The user attempted to use a resource that requires a TOS they have not accepted.",
12507                "Warning that a resource is in use.",
12508                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
12509                "When a resource schema validation is ignored.",
12510                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
12511                "When undeclared properties in the schema are present",
12512                "A given scope cannot be reached."
12513              ],
12514              "enumDeprecated": [
12515                false,
12516                false,
12517                false,
12518                false,
12519                false,
12520                false,
12521                true,
12522                false,
12523                false,
12524                false,
12525                false,
12526                false,
12527                false,
12528                false,
12529                false,
12530                false,
12531                false,
12532                false,
12533                false,
12534                false,
12535                false,
12536                false,
12537                false,
12538                false,
12539                false,
12540                false,
12541                false,
12542                false
12543              ],
12544              "enum": [
12545                "CLEANUP_FAILED",
12546                "DEPRECATED_RESOURCE_USED",
12547                "DEPRECATED_TYPE_USED",
12548                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
12549                "EXPERIMENTAL_TYPE_USED",
12550                "EXTERNAL_API_WARNING",
12551                "FIELD_VALUE_OVERRIDEN",
12552                "INJECTED_KERNELS_DEPRECATED",
12553                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
12554                "LARGE_DEPLOYMENT_WARNING",
12555                "LIST_OVERHEAD_QUOTA_EXCEED",
12556                "MISSING_TYPE_DEPENDENCY",
12557                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
12558                "NEXT_HOP_CANNOT_IP_FORWARD",
12559                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
12560                "NEXT_HOP_INSTANCE_NOT_FOUND",
12561                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
12562                "NEXT_HOP_NOT_RUNNING",
12563                "NOT_CRITICAL_ERROR",
12564                "NO_RESULTS_ON_PAGE",
12565                "PARTIAL_SUCCESS",
12566                "REQUIRED_TOS_AGREEMENT",
12567                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
12568                "RESOURCE_NOT_DELETED",
12569                "SCHEMA_VALIDATION_IGNORED",
12570                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
12571                "UNDECLARED_PROPERTIES",
12572                "UNREACHABLE"
12573              ]
12574            },
12575            "message": {
12576              "description": "[Output Only] A human-readable description of the warning code.",
12577              "type": "string"
12578            },
12579            "data": {
12580              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
12581              "type": "array",
12582              "items": {
12583                "type": "object",
12584                "properties": {
12585                  "key": {
12586                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
12587                    "type": "string"
12588                  },
12589                  "value": {
12590                    "description": "[Output Only] A warning data value corresponding to the key.",
12591                    "type": "string"
12592                  }
12593                }
12594              }
12595            }
12596          }
12597        }
12598      }
12599    },
12600    "PerInstanceConfig": {
12601      "id": "PerInstanceConfig",
12602      "type": "object",
12603      "properties": {
12604        "name": {
12605          "description": "The name of a per-instance configuration and its corresponding instance. Serves as a merge key during UpdatePerInstanceConfigs operations, that is, if a per-instance configuration with the same name exists then it will be updated, otherwise a new one will be created for the VM instance with the same name. An attempt to create a per-instance configconfiguration for a VM instance that either doesn't exist or is not part of the group will result in an error.",
12606          "type": "string"
12607        },
12608        "preservedState": {
12609          "description": "The intended preserved state for the given instance. Does not contain preserved state generated from a stateful policy.",
12610          "$ref": "PreservedState"
12611        },
12612        "status": {
12613          "description": "The status of applying this per-instance configuration on the corresponding managed instance.",
12614          "type": "string",
12615          "enumDescriptions": [
12616            "The per-instance configuration is being applied to the instance, but is not yet effective, possibly waiting for the instance to, for example, REFRESH.",
12617            "The per-instance configuration deletion is being applied on the instance, possibly waiting for the instance to, for example, REFRESH.",
12618            "The per-instance configuration is effective on the instance, meaning that all disks, ips and metadata specified in this configuration are attached or set on the instance.",
12619            "*[Default]* The default status, when no per-instance configuration exists.",
12620            "The per-instance configuration is set on an instance but not been applied yet.",
12621            "The per-instance configuration has been deleted, but the deletion is not yet applied."
12622          ],
12623          "enum": [
12624            "APPLYING",
12625            "DELETING",
12626            "EFFECTIVE",
12627            "NONE",
12628            "UNAPPLIED",
12629            "UNAPPLIED_DELETION"
12630          ]
12631        },
12632        "fingerprint": {
12633          "description": "Fingerprint of this per-instance config. This field can be used in optimistic locking. It is ignored when inserting a per-instance config. An up-to-date fingerprint must be provided in order to update an existing per-instance configuration or the field needs to be unset.",
12634          "type": "string",
12635          "format": "byte"
12636        }
12637      }
12638    },
12639    "InstanceGroupManagersUpdatePerInstanceConfigsReq": {
12640      "id": "InstanceGroupManagersUpdatePerInstanceConfigsReq",
12641      "description": "InstanceGroupManagers.updatePerInstanceConfigs",
12642      "type": "object",
12643      "properties": {
12644        "perInstanceConfigs": {
12645          "description": "The list of per-instance configurations to insert or patch on this managed instance group.",
12646          "type": "array",
12647          "items": {
12648            "$ref": "PerInstanceConfig"
12649          }
12650        }
12651      }
12652    },
12653    "InstanceGroupManagersPatchPerInstanceConfigsReq": {
12654      "id": "InstanceGroupManagersPatchPerInstanceConfigsReq",
12655      "description": "InstanceGroupManagers.patchPerInstanceConfigs",
12656      "type": "object",
12657      "properties": {
12658        "perInstanceConfigs": {
12659          "description": "The list of per-instance configurations to insert or patch on this managed instance group.",
12660          "type": "array",
12661          "items": {
12662            "$ref": "PerInstanceConfig"
12663          }
12664        }
12665      }
12666    },
12667    "InstanceGroupManagersDeletePerInstanceConfigsReq": {
12668      "id": "InstanceGroupManagersDeletePerInstanceConfigsReq",
12669      "description": "InstanceGroupManagers.deletePerInstanceConfigs",
12670      "type": "object",
12671      "properties": {
12672        "names": {
12673          "description": "The list of instance names for which we want to delete per-instance configs on this managed instance group.",
12674          "type": "array",
12675          "items": {
12676            "type": "string"
12677          }
12678        }
12679      }
12680    },
12681    "InstanceGroupManagersApplyUpdatesRequest": {
12682      "id": "InstanceGroupManagersApplyUpdatesRequest",
12683      "description": "InstanceGroupManagers.applyUpdatesToInstances",
12684      "type": "object",
12685      "properties": {
12686        "instances": {
12687          "description": "The list of URLs of one or more instances for which you want to apply updates. Each URL can be a full URL or a partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].",
12688          "type": "array",
12689          "items": {
12690            "type": "string"
12691          }
12692        },
12693        "minimalAction": {
12694          "description": "The minimal action that you want to perform on each instance during the update: - REPLACE: At minimum, delete the instance and create it again. - RESTART: Stop the instance and start it again. - REFRESH: Do not stop the instance and limit disruption as much as possible. - NONE: Do not disrupt the instance at all. By default, the minimum action is NONE. If your update requires a more disruptive action than you set with this flag, the necessary action is performed to execute the update.",
12695          "type": "string",
12696          "enumDescriptions": [
12697            "Do not perform any action.",
12698            "Do not stop the instance.",
12699            "(Default.) Replace the instance according to the replacement method option.",
12700            "Stop the instance and start it again."
12701          ],
12702          "enum": [
12703            "NONE",
12704            "REFRESH",
12705            "REPLACE",
12706            "RESTART"
12707          ]
12708        },
12709        "mostDisruptiveAllowedAction": {
12710          "description": "The most disruptive action that you want to perform on each instance during the update: - REPLACE: Delete the instance and create it again. - RESTART: Stop the instance and start it again. - REFRESH: Do not stop the instance and limit disruption as much as possible. - NONE: Do not disrupt the instance at all. By default, the most disruptive allowed action is REPLACE. If your update requires a more disruptive action than you set with this flag, the update request will fail.",
12711          "type": "string",
12712          "enumDescriptions": [
12713            "Do not perform any action.",
12714            "Do not stop the instance.",
12715            "(Default.) Replace the instance according to the replacement method option.",
12716            "Stop the instance and start it again."
12717          ],
12718          "enum": [
12719            "NONE",
12720            "REFRESH",
12721            "REPLACE",
12722            "RESTART"
12723          ]
12724        },
12725        "allInstances": {
12726          "description": "Flag to update all instances instead of specified list of “instances”. If the flag is set to true then the instances may not be specified in the request.",
12727          "type": "boolean"
12728        }
12729      }
12730    },
12731    "InstanceGroupManagersCreateInstancesRequest": {
12732      "id": "InstanceGroupManagersCreateInstancesRequest",
12733      "description": "InstanceGroupManagers.createInstances",
12734      "type": "object",
12735      "properties": {
12736        "instances": {
12737          "description": "[Required] List of specifications of per-instance configs.",
12738          "type": "array",
12739          "items": {
12740            "$ref": "PerInstanceConfig"
12741          }
12742        }
12743      }
12744    },
12745    "RegionInstanceGroupManagerList": {
12746      "id": "RegionInstanceGroupManagerList",
12747      "description": "Contains a list of managed instance groups.",
12748      "type": "object",
12749      "properties": {
12750        "kind": {
12751          "description": "[Output Only] The resource type, which is always compute#instanceGroupManagerList for a list of managed instance groups that exist in th regional scope.",
12752          "default": "compute#regionInstanceGroupManagerList",
12753          "type": "string"
12754        },
12755        "id": {
12756          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
12757          "type": "string"
12758        },
12759        "items": {
12760          "description": "A list of InstanceGroupManager resources.",
12761          "type": "array",
12762          "items": {
12763            "$ref": "InstanceGroupManager"
12764          }
12765        },
12766        "nextPageToken": {
12767          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
12768          "type": "string"
12769        },
12770        "selfLink": {
12771          "description": "[Output Only] Server-defined URL for this resource.",
12772          "type": "string"
12773        },
12774        "warning": {
12775          "description": "[Output Only] Informational warning message.",
12776          "type": "object",
12777          "properties": {
12778            "code": {
12779              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
12780              "type": "string",
12781              "enumDescriptions": [
12782                "Warning about failed cleanup of transient changes made by a failed operation.",
12783                "A link to a deprecated resource was created.",
12784                "When deploying and at least one of the resources has a type marked as deprecated",
12785                "The user created a boot disk that is larger than image size.",
12786                "When deploying and at least one of the resources has a type marked as experimental",
12787                "Warning that is present in an external api call",
12788                "Warning that value of a field has been overridden. Deprecated unused field.",
12789                "The operation involved use of an injected kernel, which is deprecated.",
12790                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
12791                "When deploying a deployment with a exceedingly large number of resources",
12792                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
12793                "A resource depends on a missing type",
12794                "The route's nextHopIp address is not assigned to an instance on the network.",
12795                "The route's next hop instance cannot ip forward.",
12796                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
12797                "The route's nextHopInstance URL refers to an instance that does not exist.",
12798                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
12799                "The route's next hop instance does not have a status of RUNNING.",
12800                "Error which is not critical. We decided to continue the process despite the mentioned error.",
12801                "No results are present on a particular list page.",
12802                "Success is reported, but some results may be missing due to errors",
12803                "The user attempted to use a resource that requires a TOS they have not accepted.",
12804                "Warning that a resource is in use.",
12805                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
12806                "When a resource schema validation is ignored.",
12807                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
12808                "When undeclared properties in the schema are present",
12809                "A given scope cannot be reached."
12810              ],
12811              "enumDeprecated": [
12812                false,
12813                false,
12814                false,
12815                false,
12816                false,
12817                false,
12818                true,
12819                false,
12820                false,
12821                false,
12822                false,
12823                false,
12824                false,
12825                false,
12826                false,
12827                false,
12828                false,
12829                false,
12830                false,
12831                false,
12832                false,
12833                false,
12834                false,
12835                false,
12836                false,
12837                false,
12838                false,
12839                false
12840              ],
12841              "enum": [
12842                "CLEANUP_FAILED",
12843                "DEPRECATED_RESOURCE_USED",
12844                "DEPRECATED_TYPE_USED",
12845                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
12846                "EXPERIMENTAL_TYPE_USED",
12847                "EXTERNAL_API_WARNING",
12848                "FIELD_VALUE_OVERRIDEN",
12849                "INJECTED_KERNELS_DEPRECATED",
12850                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
12851                "LARGE_DEPLOYMENT_WARNING",
12852                "LIST_OVERHEAD_QUOTA_EXCEED",
12853                "MISSING_TYPE_DEPENDENCY",
12854                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
12855                "NEXT_HOP_CANNOT_IP_FORWARD",
12856                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
12857                "NEXT_HOP_INSTANCE_NOT_FOUND",
12858                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
12859                "NEXT_HOP_NOT_RUNNING",
12860                "NOT_CRITICAL_ERROR",
12861                "NO_RESULTS_ON_PAGE",
12862                "PARTIAL_SUCCESS",
12863                "REQUIRED_TOS_AGREEMENT",
12864                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
12865                "RESOURCE_NOT_DELETED",
12866                "SCHEMA_VALIDATION_IGNORED",
12867                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
12868                "UNDECLARED_PROPERTIES",
12869                "UNREACHABLE"
12870              ]
12871            },
12872            "message": {
12873              "description": "[Output Only] A human-readable description of the warning code.",
12874              "type": "string"
12875            },
12876            "data": {
12877              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
12878              "type": "array",
12879              "items": {
12880                "type": "object",
12881                "properties": {
12882                  "key": {
12883                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
12884                    "type": "string"
12885                  },
12886                  "value": {
12887                    "description": "[Output Only] A warning data value corresponding to the key.",
12888                    "type": "string"
12889                  }
12890                }
12891              }
12892            }
12893          }
12894        }
12895      }
12896    },
12897    "RegionInstanceGroupManagersDeleteInstancesRequest": {
12898      "id": "RegionInstanceGroupManagersDeleteInstancesRequest",
12899      "type": "object",
12900      "properties": {
12901        "instances": {
12902          "description": "The URLs of one or more instances to delete. This can be a full URL or a partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].",
12903          "type": "array",
12904          "items": {
12905            "type": "string"
12906          }
12907        },
12908        "skipInstancesOnValidationError": {
12909          "description": "Specifies whether the request should proceed despite the inclusion of instances that are not members of the group or that are already in the process of being deleted or abandoned. If this field is set to `false` and such an instance is specified in the request, the operation fails. The operation always fails if the request contains a malformed instance URL or a reference to an instance that exists in a zone or region other than the group's zone or region.",
12910          "type": "boolean"
12911        }
12912      }
12913    },
12914    "RegionInstanceGroupManagersAbandonInstancesRequest": {
12915      "id": "RegionInstanceGroupManagersAbandonInstancesRequest",
12916      "type": "object",
12917      "properties": {
12918        "instances": {
12919          "description": "The URLs of one or more instances to abandon. This can be a full URL or a partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].",
12920          "type": "array",
12921          "items": {
12922            "type": "string"
12923          }
12924        }
12925      }
12926    },
12927    "RegionInstanceGroupManagersRecreateRequest": {
12928      "id": "RegionInstanceGroupManagersRecreateRequest",
12929      "type": "object",
12930      "properties": {
12931        "instances": {
12932          "description": "The URLs of one or more instances to recreate. This can be a full URL or a partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].",
12933          "type": "array",
12934          "items": {
12935            "type": "string"
12936          }
12937        }
12938      }
12939    },
12940    "RegionInstanceGroupManagersSetTemplateRequest": {
12941      "id": "RegionInstanceGroupManagersSetTemplateRequest",
12942      "type": "object",
12943      "properties": {
12944        "instanceTemplate": {
12945          "description": "URL of the InstanceTemplate resource from which all new instances will be created.",
12946          "type": "string"
12947        }
12948      }
12949    },
12950    "RegionInstanceGroupManagersSetTargetPoolsRequest": {
12951      "id": "RegionInstanceGroupManagersSetTargetPoolsRequest",
12952      "type": "object",
12953      "properties": {
12954        "targetPools": {
12955          "description": "The URL of all TargetPool resources to which instances in the instanceGroup field are added. The target pools automatically apply to all of the instances in the managed instance group.",
12956          "type": "array",
12957          "items": {
12958            "type": "string"
12959          }
12960        },
12961        "fingerprint": {
12962          "description": "Fingerprint of the target pools information, which is a hash of the contents. This field is used for optimistic locking when you update the target pool entries. This field is optional.",
12963          "type": "string",
12964          "format": "byte"
12965        }
12966      }
12967    },
12968    "RegionInstanceGroupManagersListInstancesResponse": {
12969      "id": "RegionInstanceGroupManagersListInstancesResponse",
12970      "type": "object",
12971      "properties": {
12972        "managedInstances": {
12973          "description": "A list of managed instances.",
12974          "type": "array",
12975          "items": {
12976            "$ref": "ManagedInstance"
12977          }
12978        },
12979        "nextPageToken": {
12980          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
12981          "type": "string"
12982        }
12983      }
12984    },
12985    "RegionInstanceGroupManagersListErrorsResponse": {
12986      "id": "RegionInstanceGroupManagersListErrorsResponse",
12987      "type": "object",
12988      "properties": {
12989        "items": {
12990          "description": "[Output Only] The list of errors of the managed instance group.",
12991          "type": "array",
12992          "items": {
12993            "$ref": "InstanceManagedByIgmError"
12994          }
12995        },
12996        "nextPageToken": {
12997          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
12998          "type": "string"
12999        }
13000      }
13001    },
13002    "RegionInstanceGroupManagersListInstanceConfigsResp": {
13003      "id": "RegionInstanceGroupManagersListInstanceConfigsResp",
13004      "type": "object",
13005      "properties": {
13006        "items": {
13007          "description": "[Output Only] The list of PerInstanceConfig.",
13008          "type": "array",
13009          "items": {
13010            "$ref": "PerInstanceConfig"
13011          }
13012        },
13013        "nextPageToken": {
13014          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
13015          "type": "string"
13016        },
13017        "warning": {
13018          "description": "[Output Only] Informational warning message.",
13019          "type": "object",
13020          "properties": {
13021            "code": {
13022              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
13023              "type": "string",
13024              "enumDescriptions": [
13025                "Warning about failed cleanup of transient changes made by a failed operation.",
13026                "A link to a deprecated resource was created.",
13027                "When deploying and at least one of the resources has a type marked as deprecated",
13028                "The user created a boot disk that is larger than image size.",
13029                "When deploying and at least one of the resources has a type marked as experimental",
13030                "Warning that is present in an external api call",
13031                "Warning that value of a field has been overridden. Deprecated unused field.",
13032                "The operation involved use of an injected kernel, which is deprecated.",
13033                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
13034                "When deploying a deployment with a exceedingly large number of resources",
13035                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
13036                "A resource depends on a missing type",
13037                "The route's nextHopIp address is not assigned to an instance on the network.",
13038                "The route's next hop instance cannot ip forward.",
13039                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
13040                "The route's nextHopInstance URL refers to an instance that does not exist.",
13041                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
13042                "The route's next hop instance does not have a status of RUNNING.",
13043                "Error which is not critical. We decided to continue the process despite the mentioned error.",
13044                "No results are present on a particular list page.",
13045                "Success is reported, but some results may be missing due to errors",
13046                "The user attempted to use a resource that requires a TOS they have not accepted.",
13047                "Warning that a resource is in use.",
13048                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
13049                "When a resource schema validation is ignored.",
13050                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
13051                "When undeclared properties in the schema are present",
13052                "A given scope cannot be reached."
13053              ],
13054              "enumDeprecated": [
13055                false,
13056                false,
13057                false,
13058                false,
13059                false,
13060                false,
13061                true,
13062                false,
13063                false,
13064                false,
13065                false,
13066                false,
13067                false,
13068                false,
13069                false,
13070                false,
13071                false,
13072                false,
13073                false,
13074                false,
13075                false,
13076                false,
13077                false,
13078                false,
13079                false,
13080                false,
13081                false,
13082                false
13083              ],
13084              "enum": [
13085                "CLEANUP_FAILED",
13086                "DEPRECATED_RESOURCE_USED",
13087                "DEPRECATED_TYPE_USED",
13088                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
13089                "EXPERIMENTAL_TYPE_USED",
13090                "EXTERNAL_API_WARNING",
13091                "FIELD_VALUE_OVERRIDEN",
13092                "INJECTED_KERNELS_DEPRECATED",
13093                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
13094                "LARGE_DEPLOYMENT_WARNING",
13095                "LIST_OVERHEAD_QUOTA_EXCEED",
13096                "MISSING_TYPE_DEPENDENCY",
13097                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
13098                "NEXT_HOP_CANNOT_IP_FORWARD",
13099                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
13100                "NEXT_HOP_INSTANCE_NOT_FOUND",
13101                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
13102                "NEXT_HOP_NOT_RUNNING",
13103                "NOT_CRITICAL_ERROR",
13104                "NO_RESULTS_ON_PAGE",
13105                "PARTIAL_SUCCESS",
13106                "REQUIRED_TOS_AGREEMENT",
13107                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
13108                "RESOURCE_NOT_DELETED",
13109                "SCHEMA_VALIDATION_IGNORED",
13110                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
13111                "UNDECLARED_PROPERTIES",
13112                "UNREACHABLE"
13113              ]
13114            },
13115            "message": {
13116              "description": "[Output Only] A human-readable description of the warning code.",
13117              "type": "string"
13118            },
13119            "data": {
13120              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
13121              "type": "array",
13122              "items": {
13123                "type": "object",
13124                "properties": {
13125                  "key": {
13126                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
13127                    "type": "string"
13128                  },
13129                  "value": {
13130                    "description": "[Output Only] A warning data value corresponding to the key.",
13131                    "type": "string"
13132                  }
13133                }
13134              }
13135            }
13136          }
13137        }
13138      }
13139    },
13140    "RegionInstanceGroupManagerUpdateInstanceConfigReq": {
13141      "id": "RegionInstanceGroupManagerUpdateInstanceConfigReq",
13142      "description": "RegionInstanceGroupManagers.updatePerInstanceConfigs",
13143      "type": "object",
13144      "properties": {
13145        "perInstanceConfigs": {
13146          "description": "The list of per-instance configurations to insert or patch on this managed instance group.",
13147          "type": "array",
13148          "items": {
13149            "$ref": "PerInstanceConfig"
13150          }
13151        }
13152      }
13153    },
13154    "RegionInstanceGroupManagerPatchInstanceConfigReq": {
13155      "id": "RegionInstanceGroupManagerPatchInstanceConfigReq",
13156      "description": "RegionInstanceGroupManagers.patchPerInstanceConfigs",
13157      "type": "object",
13158      "properties": {
13159        "perInstanceConfigs": {
13160          "description": "The list of per-instance configurations to insert or patch on this managed instance group.",
13161          "type": "array",
13162          "items": {
13163            "$ref": "PerInstanceConfig"
13164          }
13165        }
13166      }
13167    },
13168    "RegionInstanceGroupManagerDeleteInstanceConfigReq": {
13169      "id": "RegionInstanceGroupManagerDeleteInstanceConfigReq",
13170      "description": "RegionInstanceGroupManagers.deletePerInstanceConfigs",
13171      "type": "object",
13172      "properties": {
13173        "names": {
13174          "description": "The list of instance names for which we want to delete per-instance configs on this managed instance group.",
13175          "type": "array",
13176          "items": {
13177            "type": "string"
13178          }
13179        }
13180      }
13181    },
13182    "RegionInstanceGroupManagersApplyUpdatesRequest": {
13183      "id": "RegionInstanceGroupManagersApplyUpdatesRequest",
13184      "description": "RegionInstanceGroupManagers.applyUpdatesToInstances",
13185      "type": "object",
13186      "properties": {
13187        "instances": {
13188          "description": "The list of URLs of one or more instances for which you want to apply updates. Each URL can be a full URL or a partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].",
13189          "type": "array",
13190          "items": {
13191            "type": "string"
13192          }
13193        },
13194        "minimalAction": {
13195          "description": "The minimal action that you want to perform on each instance during the update: - REPLACE: At minimum, delete the instance and create it again. - RESTART: Stop the instance and start it again. - REFRESH: Do not stop the instance and limit disruption as much as possible. - NONE: Do not disrupt the instance at all. By default, the minimum action is NONE. If your update requires a more disruptive action than you set with this flag, the necessary action is performed to execute the update.",
13196          "type": "string",
13197          "enumDescriptions": [
13198            "Do not perform any action.",
13199            "Do not stop the instance.",
13200            "(Default.) Replace the instance according to the replacement method option.",
13201            "Stop the instance and start it again."
13202          ],
13203          "enum": [
13204            "NONE",
13205            "REFRESH",
13206            "REPLACE",
13207            "RESTART"
13208          ]
13209        },
13210        "mostDisruptiveAllowedAction": {
13211          "description": "The most disruptive action that you want to perform on each instance during the update: - REPLACE: Delete the instance and create it again. - RESTART: Stop the instance and start it again. - REFRESH: Do not stop the instance and limit disruption as much as possible. - NONE: Do not disrupt the instance at all. By default, the most disruptive allowed action is REPLACE. If your update requires a more disruptive action than you set with this flag, the update request will fail.",
13212          "type": "string",
13213          "enumDescriptions": [
13214            "Do not perform any action.",
13215            "Do not stop the instance.",
13216            "(Default.) Replace the instance according to the replacement method option.",
13217            "Stop the instance and start it again."
13218          ],
13219          "enum": [
13220            "NONE",
13221            "REFRESH",
13222            "REPLACE",
13223            "RESTART"
13224          ]
13225        },
13226        "allInstances": {
13227          "description": "Flag to update all instances instead of specified list of “instances”. If the flag is set to true then the instances may not be specified in the request.",
13228          "type": "boolean"
13229        }
13230      }
13231    },
13232    "RegionInstanceGroupManagersCreateInstancesRequest": {
13233      "id": "RegionInstanceGroupManagersCreateInstancesRequest",
13234      "description": "RegionInstanceGroupManagers.createInstances",
13235      "type": "object",
13236      "properties": {
13237        "instances": {
13238          "description": "[Required] List of specifications of per-instance configs.",
13239          "type": "array",
13240          "items": {
13241            "$ref": "PerInstanceConfig"
13242          }
13243        }
13244      }
13245    },
13246    "AutoscalerList": {
13247      "id": "AutoscalerList",
13248      "description": "Contains a list of Autoscaler resources.",
13249      "type": "object",
13250      "properties": {
13251        "kind": {
13252          "description": "[Output Only] Type of resource. Always compute#autoscalerList for lists of autoscalers.",
13253          "default": "compute#autoscalerList",
13254          "type": "string"
13255        },
13256        "id": {
13257          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
13258          "type": "string"
13259        },
13260        "items": {
13261          "description": "A list of Autoscaler resources.",
13262          "type": "array",
13263          "items": {
13264            "$ref": "Autoscaler"
13265          }
13266        },
13267        "nextPageToken": {
13268          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
13269          "type": "string"
13270        },
13271        "selfLink": {
13272          "description": "[Output Only] Server-defined URL for this resource.",
13273          "type": "string"
13274        },
13275        "warning": {
13276          "description": "[Output Only] Informational warning message.",
13277          "type": "object",
13278          "properties": {
13279            "code": {
13280              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
13281              "type": "string",
13282              "enumDescriptions": [
13283                "Warning about failed cleanup of transient changes made by a failed operation.",
13284                "A link to a deprecated resource was created.",
13285                "When deploying and at least one of the resources has a type marked as deprecated",
13286                "The user created a boot disk that is larger than image size.",
13287                "When deploying and at least one of the resources has a type marked as experimental",
13288                "Warning that is present in an external api call",
13289                "Warning that value of a field has been overridden. Deprecated unused field.",
13290                "The operation involved use of an injected kernel, which is deprecated.",
13291                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
13292                "When deploying a deployment with a exceedingly large number of resources",
13293                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
13294                "A resource depends on a missing type",
13295                "The route's nextHopIp address is not assigned to an instance on the network.",
13296                "The route's next hop instance cannot ip forward.",
13297                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
13298                "The route's nextHopInstance URL refers to an instance that does not exist.",
13299                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
13300                "The route's next hop instance does not have a status of RUNNING.",
13301                "Error which is not critical. We decided to continue the process despite the mentioned error.",
13302                "No results are present on a particular list page.",
13303                "Success is reported, but some results may be missing due to errors",
13304                "The user attempted to use a resource that requires a TOS they have not accepted.",
13305                "Warning that a resource is in use.",
13306                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
13307                "When a resource schema validation is ignored.",
13308                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
13309                "When undeclared properties in the schema are present",
13310                "A given scope cannot be reached."
13311              ],
13312              "enumDeprecated": [
13313                false,
13314                false,
13315                false,
13316                false,
13317                false,
13318                false,
13319                true,
13320                false,
13321                false,
13322                false,
13323                false,
13324                false,
13325                false,
13326                false,
13327                false,
13328                false,
13329                false,
13330                false,
13331                false,
13332                false,
13333                false,
13334                false,
13335                false,
13336                false,
13337                false,
13338                false,
13339                false,
13340                false
13341              ],
13342              "enum": [
13343                "CLEANUP_FAILED",
13344                "DEPRECATED_RESOURCE_USED",
13345                "DEPRECATED_TYPE_USED",
13346                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
13347                "EXPERIMENTAL_TYPE_USED",
13348                "EXTERNAL_API_WARNING",
13349                "FIELD_VALUE_OVERRIDEN",
13350                "INJECTED_KERNELS_DEPRECATED",
13351                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
13352                "LARGE_DEPLOYMENT_WARNING",
13353                "LIST_OVERHEAD_QUOTA_EXCEED",
13354                "MISSING_TYPE_DEPENDENCY",
13355                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
13356                "NEXT_HOP_CANNOT_IP_FORWARD",
13357                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
13358                "NEXT_HOP_INSTANCE_NOT_FOUND",
13359                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
13360                "NEXT_HOP_NOT_RUNNING",
13361                "NOT_CRITICAL_ERROR",
13362                "NO_RESULTS_ON_PAGE",
13363                "PARTIAL_SUCCESS",
13364                "REQUIRED_TOS_AGREEMENT",
13365                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
13366                "RESOURCE_NOT_DELETED",
13367                "SCHEMA_VALIDATION_IGNORED",
13368                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
13369                "UNDECLARED_PROPERTIES",
13370                "UNREACHABLE"
13371              ]
13372            },
13373            "message": {
13374              "description": "[Output Only] A human-readable description of the warning code.",
13375              "type": "string"
13376            },
13377            "data": {
13378              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
13379              "type": "array",
13380              "items": {
13381                "type": "object",
13382                "properties": {
13383                  "key": {
13384                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
13385                    "type": "string"
13386                  },
13387                  "value": {
13388                    "description": "[Output Only] A warning data value corresponding to the key.",
13389                    "type": "string"
13390                  }
13391                }
13392              }
13393            }
13394          }
13395        }
13396      }
13397    },
13398    "Autoscaler": {
13399      "id": "Autoscaler",
13400      "description": "Represents an Autoscaler resource. Google Compute Engine has two Autoscaler resources: * [Zonal](/compute/docs/reference/rest/v1/autoscalers) * [Regional](/compute/docs/reference/rest/v1/regionAutoscalers) Use autoscalers to automatically add or delete instances from a managed instance group according to your defined autoscaling policy. For more information, read Autoscaling Groups of Instances. For zonal managed instance groups resource, use the autoscaler resource. For regional managed instance groups, use the regionAutoscalers resource.",
13401      "type": "object",
13402      "properties": {
13403        "kind": {
13404          "description": "[Output Only] Type of the resource. Always compute#autoscaler for autoscalers.",
13405          "default": "compute#autoscaler",
13406          "type": "string"
13407        },
13408        "id": {
13409          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
13410          "type": "string",
13411          "format": "uint64"
13412        },
13413        "creationTimestamp": {
13414          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
13415          "type": "string"
13416        },
13417        "name": {
13418          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
13419          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
13420          "annotations": {
13421            "required": [
13422              "compute.autoscalers.insert"
13423            ]
13424          },
13425          "type": "string"
13426        },
13427        "description": {
13428          "description": "An optional description of this resource. Provide this property when you create the resource.",
13429          "type": "string"
13430        },
13431        "target": {
13432          "description": "URL of the managed instance group that this autoscaler will scale. This field is required when creating an autoscaler.",
13433          "type": "string"
13434        },
13435        "autoscalingPolicy": {
13436          "description": "The configuration parameters for the autoscaling algorithm. You can define one or more signals for an autoscaler: cpuUtilization, customMetricUtilizations, and loadBalancingUtilization. If none of these are specified, the default will be to autoscale based on cpuUtilization to 0.6 or 60%.",
13437          "$ref": "AutoscalingPolicy"
13438        },
13439        "zone": {
13440          "description": "[Output Only] URL of the zone where the instance group resides (for autoscalers living in zonal scope).",
13441          "type": "string"
13442        },
13443        "region": {
13444          "description": "[Output Only] URL of the region where the instance group resides (for autoscalers living in regional scope).",
13445          "type": "string"
13446        },
13447        "selfLink": {
13448          "description": "[Output Only] Server-defined URL for the resource.",
13449          "type": "string"
13450        },
13451        "status": {
13452          "description": "[Output Only] The status of the autoscaler configuration. Current set of possible values: - PENDING: Autoscaler backend hasn't read new/updated configuration. - DELETING: Configuration is being deleted. - ACTIVE: Configuration is acknowledged to be effective. Some warnings might be present in the statusDetails field. - ERROR: Configuration has errors. Actionable for users. Details are present in the statusDetails field. New values might be added in the future.",
13453          "type": "string",
13454          "enumDescriptions": [
13455            "Configuration is acknowledged to be effective",
13456            "Configuration is being deleted",
13457            "Configuration has errors. Actionable for users.",
13458            "Autoscaler backend hasn't read new/updated configuration"
13459          ],
13460          "enum": [
13461            "ACTIVE",
13462            "DELETING",
13463            "ERROR",
13464            "PENDING"
13465          ]
13466        },
13467        "statusDetails": {
13468          "description": "[Output Only] Human-readable details about the current state of the autoscaler. Read the documentation for Commonly returned status messages for examples of status messages you might encounter.",
13469          "type": "array",
13470          "items": {
13471            "$ref": "AutoscalerStatusDetails"
13472          }
13473        },
13474        "recommendedSize": {
13475          "description": "[Output Only] Target recommended MIG size (number of instances) computed by autoscaler. Autoscaler calculates the recommended MIG size even when the autoscaling policy mode is different from ON. This field is empty when autoscaler is not connected to an existing managed instance group or autoscaler did not generate its prediction.",
13476          "type": "integer",
13477          "format": "int32"
13478        },
13479        "scalingScheduleStatus": {
13480          "description": "[Output Only] Status information of existing scaling schedules.",
13481          "type": "object",
13482          "additionalProperties": {
13483            "$ref": "ScalingScheduleStatus"
13484          }
13485        }
13486      }
13487    },
13488    "AutoscalingPolicy": {
13489      "id": "AutoscalingPolicy",
13490      "description": "Cloud Autoscaler policy.",
13491      "type": "object",
13492      "properties": {
13493        "minNumReplicas": {
13494          "description": "The minimum number of replicas that the autoscaler can scale in to. This cannot be less than 0. If not provided, autoscaler chooses a default value depending on maximum number of instances allowed.",
13495          "type": "integer",
13496          "format": "int32"
13497        },
13498        "maxNumReplicas": {
13499          "description": "The maximum number of instances that the autoscaler can scale out to. This is required when creating or updating an autoscaler. The maximum number of replicas must not be lower than minimal number of replicas.",
13500          "type": "integer",
13501          "format": "int32"
13502        },
13503        "scaleInControl": {
13504          "$ref": "AutoscalingPolicyScaleInControl"
13505        },
13506        "coolDownPeriodSec": {
13507          "description": "The number of seconds that your application takes to initialize on a VM instance. This is referred to as the [initialization period](/compute/docs/autoscaler#cool_down_period). Specifying an accurate initialization period improves autoscaler decisions. For example, when scaling out, the autoscaler ignores data from VMs that are still initializing because those VMs might not yet represent normal usage of your application. The default initialization period is 60 seconds. Initialization periods might vary because of numerous factors. We recommend that you test how long your application takes to initialize. To do this, create a VM and time your application's startup process.",
13508          "type": "integer",
13509          "format": "int32"
13510        },
13511        "cpuUtilization": {
13512          "description": "Defines the CPU utilization policy that allows the autoscaler to scale based on the average CPU utilization of a managed instance group.",
13513          "$ref": "AutoscalingPolicyCpuUtilization"
13514        },
13515        "customMetricUtilizations": {
13516          "description": "Configuration parameters of autoscaling based on a custom metric.",
13517          "type": "array",
13518          "items": {
13519            "$ref": "AutoscalingPolicyCustomMetricUtilization"
13520          }
13521        },
13522        "loadBalancingUtilization": {
13523          "description": "Configuration parameters of autoscaling based on load balancer.",
13524          "$ref": "AutoscalingPolicyLoadBalancingUtilization"
13525        },
13526        "mode": {
13527          "description": "Defines the operating mode for this policy. The following modes are available: - OFF: Disables the autoscaler but maintains its configuration. - ONLY_SCALE_OUT: Restricts the autoscaler to add VM instances only. - ON: Enables all autoscaler activities according to its policy. For more information, see \"Turning off or restricting an autoscaler\"",
13528          "type": "string",
13529          "enumDescriptions": [
13530            "Do not automatically scale the MIG in or out. The recommended_size field contains the size of MIG that would be set if the actuation mode was enabled.",
13531            "Automatically scale the MIG in and out according to the policy.",
13532            "Automatically create VMs according to the policy, but do not scale the MIG in.",
13533            "Automatically create VMs according to the policy, but do not scale the MIG in."
13534          ],
13535          "enum": [
13536            "OFF",
13537            "ON",
13538            "ONLY_SCALE_OUT",
13539            "ONLY_UP"
13540          ]
13541        },
13542        "scalingSchedules": {
13543          "description": "Scaling schedules defined for an autoscaler. Multiple schedules can be set on an autoscaler, and they can overlap. During overlapping periods the greatest min_required_replicas of all scaling schedules is applied. Up to 128 scaling schedules are allowed.",
13544          "type": "object",
13545          "additionalProperties": {
13546            "$ref": "AutoscalingPolicyScalingSchedule"
13547          }
13548        }
13549      }
13550    },
13551    "AutoscalingPolicyScaleInControl": {
13552      "id": "AutoscalingPolicyScaleInControl",
13553      "description": "Configuration that allows for slower scale in so that even if Autoscaler recommends an abrupt scale in of a MIG, it will be throttled as specified by the parameters below.",
13554      "type": "object",
13555      "properties": {
13556        "maxScaledInReplicas": {
13557          "description": "Maximum allowed number (or %) of VMs that can be deducted from the peak recommendation during the window autoscaler looks at when computing recommendations. Possibly all these VMs can be deleted at once so user service needs to be prepared to lose that many VMs in one step.",
13558          "$ref": "FixedOrPercent"
13559        },
13560        "timeWindowSec": {
13561          "description": "How far back autoscaling looks when computing recommendations to include directives regarding slower scale in, as described above.",
13562          "type": "integer",
13563          "format": "int32"
13564        }
13565      }
13566    },
13567    "AutoscalingPolicyCpuUtilization": {
13568      "id": "AutoscalingPolicyCpuUtilization",
13569      "description": "CPU utilization policy.",
13570      "type": "object",
13571      "properties": {
13572        "utilizationTarget": {
13573          "description": "The target CPU utilization that the autoscaler maintains. Must be a float value in the range (0, 1]. If not specified, the default is 0.6. If the CPU level is below the target utilization, the autoscaler scales in the number of instances until it reaches the minimum number of instances you specified or until the average CPU of your instances reaches the target utilization. If the average CPU is above the target utilization, the autoscaler scales out until it reaches the maximum number of instances you specified or until the average utilization reaches the target utilization.",
13574          "type": "number",
13575          "format": "double"
13576        },
13577        "predictiveMethod": {
13578          "description": "Indicates whether predictive autoscaling based on CPU metric is enabled. Valid values are: * NONE (default). No predictive method is used. The autoscaler scales the group to meet current demand based on real-time metrics. * OPTIMIZE_AVAILABILITY. Predictive autoscaling improves availability by monitoring daily and weekly load patterns and scaling out ahead of anticipated demand.",
13579          "type": "string",
13580          "enumDescriptions": [
13581            "No predictive method is used. The autoscaler scales the group to meet current demand based on real-time metrics",
13582            "Predictive autoscaling improves availability by monitoring daily and weekly load patterns and scaling out ahead of anticipated demand."
13583          ],
13584          "enum": [
13585            "NONE",
13586            "OPTIMIZE_AVAILABILITY"
13587          ]
13588        }
13589      }
13590    },
13591    "AutoscalingPolicyCustomMetricUtilization": {
13592      "id": "AutoscalingPolicyCustomMetricUtilization",
13593      "description": "Custom utilization metric policy.",
13594      "type": "object",
13595      "properties": {
13596        "metric": {
13597          "description": "The identifier (type) of the Stackdriver Monitoring metric. The metric cannot have negative values. The metric must have a value type of INT64 or DOUBLE.",
13598          "type": "string"
13599        },
13600        "filter": {
13601          "description": "A filter string, compatible with a Stackdriver Monitoring filter string for TimeSeries.list API call. This filter is used to select a specific TimeSeries for the purpose of autoscaling and to determine whether the metric is exporting per-instance or per-group data. For the filter to be valid for autoscaling purposes, the following rules apply: - You can only use the AND operator for joining selectors. - You can only use direct equality comparison operator (=) without any functions for each selector. - You can specify the metric in both the filter string and in the metric field. However, if specified in both places, the metric must be identical. - The monitored resource type determines what kind of values are expected for the metric. If it is a gce_instance, the autoscaler expects the metric to include a separate TimeSeries for each instance in a group. In such a case, you cannot filter on resource labels. If the resource type is any other value, the autoscaler expects this metric to contain values that apply to the entire autoscaled instance group and resource label filtering can be performed to point autoscaler at the correct TimeSeries to scale upon. This is called a *per-group metric* for the purpose of autoscaling. If not specified, the type defaults to gce_instance. Try to provide a filter that is selective enough to pick just one TimeSeries for the autoscaled group or for each of the instances (if you are using gce_instance resource type). If multiple TimeSeries are returned upon the query execution, the autoscaler will sum their respective values to obtain its scaling value.",
13602          "type": "string"
13603        },
13604        "utilizationTarget": {
13605          "description": "The target value of the metric that autoscaler maintains. This must be a positive value. A utilization metric scales number of virtual machines handling requests to increase or decrease proportionally to the metric. For example, a good metric to use as a utilization_target is https://www.googleapis.com/compute/v1/instance/network/received_bytes_count. The autoscaler works to keep this value constant for each of the instances.",
13606          "type": "number",
13607          "format": "double"
13608        },
13609        "singleInstanceAssignment": {
13610          "description": "If scaling is based on a per-group metric value that represents the total amount of work to be done or resource usage, set this value to an amount assigned for a single instance of the scaled group. Autoscaler keeps the number of instances proportional to the value of this metric. The metric itself does not change value due to group resizing. A good metric to use with the target is for example pubsub.googleapis.com/subscription/num_undelivered_messages or a custom metric exporting the total number of requests coming to your instances. A bad example would be a metric exporting an average or median latency, since this value can't include a chunk assignable to a single instance, it could be better used with utilization_target instead.",
13611          "type": "number",
13612          "format": "double"
13613        },
13614        "utilizationTargetType": {
13615          "description": "Defines how target utilization value is expressed for a Stackdriver Monitoring metric. Either GAUGE, DELTA_PER_SECOND, or DELTA_PER_MINUTE.",
13616          "type": "string",
13617          "enumDescriptions": [
13618            "Sets the utilization target value for a cumulative or delta metric, expressed as the rate of growth per minute.",
13619            "Sets the utilization target value for a cumulative or delta metric, expressed as the rate of growth per second.",
13620            "Sets the utilization target value for a gauge metric. The autoscaler will collect the average utilization of the virtual machines from the last couple of minutes, and compare the value to the utilization target value to perform autoscaling."
13621          ],
13622          "enum": [
13623            "DELTA_PER_MINUTE",
13624            "DELTA_PER_SECOND",
13625            "GAUGE"
13626          ]
13627        }
13628      }
13629    },
13630    "AutoscalingPolicyLoadBalancingUtilization": {
13631      "id": "AutoscalingPolicyLoadBalancingUtilization",
13632      "description": "Configuration parameters of autoscaling based on load balancing.",
13633      "type": "object",
13634      "properties": {
13635        "utilizationTarget": {
13636          "description": "Fraction of backend capacity utilization (set in HTTP(S) load balancing configuration) that the autoscaler maintains. Must be a positive float value. If not defined, the default is 0.8.",
13637          "type": "number",
13638          "format": "double"
13639        }
13640      }
13641    },
13642    "AutoscalingPolicyScalingSchedule": {
13643      "id": "AutoscalingPolicyScalingSchedule",
13644      "description": "Scaling based on user-defined schedule. The message describes a single scaling schedule. A scaling schedule changes the minimum number of VM instances an autoscaler can recommend, which can trigger scaling out.",
13645      "type": "object",
13646      "properties": {
13647        "minRequiredReplicas": {
13648          "description": "The minimum number of VM instances that the autoscaler will recommend in time intervals starting according to schedule. This field is required.",
13649          "type": "integer",
13650          "format": "int32"
13651        },
13652        "schedule": {
13653          "description": "The start timestamps of time intervals when this scaling schedule is to provide a scaling signal. This field uses the extended cron format (with an optional year field). The expression can describe a single timestamp if the optional year is set, in which case the scaling schedule runs once. The schedule is interpreted with respect to time_zone. This field is required. Note: These timestamps only describe when autoscaler starts providing the scaling signal. The VMs need additional time to become serving.",
13654          "type": "string"
13655        },
13656        "timeZone": {
13657          "description": "The time zone to use when interpreting the schedule. The value of this field must be a time zone name from the tz database: https://en.wikipedia.org/wiki/Tz_database. This field is assigned a default value of \"UTC\" if left empty.",
13658          "type": "string"
13659        },
13660        "durationSec": {
13661          "description": "The duration of time intervals, in seconds, for which this scaling schedule is to run. The minimum allowed value is 300. This field is required.",
13662          "type": "integer",
13663          "format": "int32"
13664        },
13665        "disabled": {
13666          "description": "A boolean value that specifies whether a scaling schedule can influence autoscaler recommendations. If set to true, then a scaling schedule has no effect. This field is optional, and its value is false by default.",
13667          "type": "boolean"
13668        },
13669        "description": {
13670          "description": "A description of a scaling schedule.",
13671          "type": "string"
13672        }
13673      }
13674    },
13675    "AutoscalerStatusDetails": {
13676      "id": "AutoscalerStatusDetails",
13677      "type": "object",
13678      "properties": {
13679        "message": {
13680          "description": "The status message.",
13681          "type": "string"
13682        },
13683        "type": {
13684          "description": "The type of error, warning, or notice returned. Current set of possible values: - ALL_INSTANCES_UNHEALTHY (WARNING): All instances in the instance group are unhealthy (not in RUNNING state). - BACKEND_SERVICE_DOES_NOT_EXIST (ERROR): There is no backend service attached to the instance group. - CAPPED_AT_MAX_NUM_REPLICAS (WARNING): Autoscaler recommends a size greater than maxNumReplicas. - CUSTOM_METRIC_DATA_POINTS_TOO_SPARSE (WARNING): The custom metric samples are not exported often enough to be a credible base for autoscaling. - CUSTOM_METRIC_INVALID (ERROR): The custom metric that was specified does not exist or does not have the necessary labels. - MIN_EQUALS_MAX (WARNING): The minNumReplicas is equal to maxNumReplicas. This means the autoscaler cannot add or remove instances from the instance group. - MISSING_CUSTOM_METRIC_DATA_POINTS (WARNING): The autoscaler did not receive any data from the custom metric configured for autoscaling. - MISSING_LOAD_BALANCING_DATA_POINTS (WARNING): The autoscaler is configured to scale based on a load balancing signal but the instance group has not received any requests from the load balancer. - MODE_OFF (WARNING): Autoscaling is turned off. The number of instances in the group won't change automatically. The autoscaling configuration is preserved. - MODE_ONLY_UP (WARNING): Autoscaling is in the \"Autoscale only out\" mode. The autoscaler can add instances but not remove any. - MORE_THAN_ONE_BACKEND_SERVICE (ERROR): The instance group cannot be autoscaled because it has more than one backend service attached to it. - NOT_ENOUGH_QUOTA_AVAILABLE (ERROR): There is insufficient quota for the necessary resources, such as CPU or number of instances. - REGION_RESOURCE_STOCKOUT (ERROR): Shown only for regional autoscalers: there is a resource stockout in the chosen region. - SCALING_TARGET_DOES_NOT_EXIST (ERROR): The target to be scaled does not exist. - UNSUPPORTED_MAX_RATE_LOAD_BALANCING_CONFIGURATION (ERROR): Autoscaling does not work with an HTTP/S load balancer that has been configured for maxRate. - ZONE_RESOURCE_STOCKOUT (ERROR): For zonal autoscalers: there is a resource stockout in the chosen zone. For regional autoscalers: in at least one of the zones you're using there is a resource stockout. New values might be added in the future. Some of the values might not be available in all API versions.",
13685          "type": "string",
13686          "enumDescriptions": [
13687            "All instances in the instance group are unhealthy (not in RUNNING state).",
13688            "There is no backend service attached to the instance group.",
13689            "Autoscaler recommends a size greater than maxNumReplicas.",
13690            "The custom metric samples are not exported often enough to be a credible base for autoscaling.",
13691            "The custom metric that was specified does not exist or does not have the necessary labels.",
13692            "The minNumReplicas is equal to maxNumReplicas. This means the autoscaler cannot add or remove instances from the instance group.",
13693            "The autoscaler did not receive any data from the custom metric configured for autoscaling.",
13694            "The autoscaler is configured to scale based on a load balancing signal but the instance group has not received any requests from the load balancer.",
13695            "Autoscaling is turned off. The number of instances in the group won't change automatically. The autoscaling configuration is preserved.",
13696            "Autoscaling is in the \"Autoscale only scale out\" mode. Instances in the group will be only added.",
13697            "Autoscaling is in the \"Autoscale only out\" mode. Instances in the group will be only added.",
13698            "The instance group cannot be autoscaled because it has more than one backend service attached to it.",
13699            "There is insufficient quota for the necessary resources, such as CPU or number of instances.",
13700            "Showed only for regional autoscalers: there is a resource stockout in the chosen region.",
13701            "The target to be scaled does not exist.",
13702            "For some scaling schedules minRequiredReplicas is greater than maxNumReplicas. Autoscaler always recommends at most maxNumReplicas instances.",
13703            "For some scaling schedules minRequiredReplicas is less than minNumReplicas. Autoscaler always recommends at least minNumReplicas instances.",
13704            "",
13705            "Autoscaling does not work with an HTTP/S load balancer that has been configured for maxRate.",
13706            "For zonal autoscalers: there is a resource stockout in the chosen zone. For regional autoscalers: in at least one of the zones you're using there is a resource stockout."
13707          ],
13708          "enum": [
13709            "ALL_INSTANCES_UNHEALTHY",
13710            "BACKEND_SERVICE_DOES_NOT_EXIST",
13711            "CAPPED_AT_MAX_NUM_REPLICAS",
13712            "CUSTOM_METRIC_DATA_POINTS_TOO_SPARSE",
13713            "CUSTOM_METRIC_INVALID",
13714            "MIN_EQUALS_MAX",
13715            "MISSING_CUSTOM_METRIC_DATA_POINTS",
13716            "MISSING_LOAD_BALANCING_DATA_POINTS",
13717            "MODE_OFF",
13718            "MODE_ONLY_SCALE_OUT",
13719            "MODE_ONLY_UP",
13720            "MORE_THAN_ONE_BACKEND_SERVICE",
13721            "NOT_ENOUGH_QUOTA_AVAILABLE",
13722            "REGION_RESOURCE_STOCKOUT",
13723            "SCALING_TARGET_DOES_NOT_EXIST",
13724            "SCHEDULED_INSTANCES_GREATER_THAN_AUTOSCALER_MAX",
13725            "SCHEDULED_INSTANCES_LESS_THAN_AUTOSCALER_MIN",
13726            "UNKNOWN",
13727            "UNSUPPORTED_MAX_RATE_LOAD_BALANCING_CONFIGURATION",
13728            "ZONE_RESOURCE_STOCKOUT"
13729          ]
13730        }
13731      }
13732    },
13733    "ScalingScheduleStatus": {
13734      "id": "ScalingScheduleStatus",
13735      "type": "object",
13736      "properties": {
13737        "nextStartTime": {
13738          "description": "[Output Only] The next time the scaling schedule is to become active. Note: this is a timestamp when a schedule is planned to run, but the actual time might be slightly different. The timestamp is in RFC3339 text format.",
13739          "type": "string"
13740        },
13741        "lastStartTime": {
13742          "description": "[Output Only] The last time the scaling schedule became active. Note: this is a timestamp when a schedule actually became active, not when it was planned to do so. The timestamp is in RFC3339 text format.",
13743          "type": "string"
13744        },
13745        "state": {
13746          "description": "[Output Only] The current state of a scaling schedule.",
13747          "type": "string",
13748          "enumDescriptions": [
13749            "The current autoscaling recommendation is influenced by this scaling schedule.",
13750            "This scaling schedule has been disabled by the user.",
13751            "This scaling schedule will never become active again.",
13752            "The current autoscaling recommendation is not influenced by this scaling schedule."
13753          ],
13754          "enum": [
13755            "ACTIVE",
13756            "DISABLED",
13757            "OBSOLETE",
13758            "READY"
13759          ]
13760        }
13761      }
13762    },
13763    "AutoscalerAggregatedList": {
13764      "id": "AutoscalerAggregatedList",
13765      "type": "object",
13766      "properties": {
13767        "kind": {
13768          "description": "[Output Only] Type of resource. Always compute#autoscalerAggregatedList for aggregated lists of autoscalers.",
13769          "default": "compute#autoscalerAggregatedList",
13770          "type": "string"
13771        },
13772        "id": {
13773          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
13774          "type": "string"
13775        },
13776        "items": {
13777          "description": "A list of AutoscalersScopedList resources.",
13778          "type": "object",
13779          "additionalProperties": {
13780            "description": "[Output Only] Name of the scope containing this set of autoscalers.",
13781            "$ref": "AutoscalersScopedList"
13782          }
13783        },
13784        "nextPageToken": {
13785          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
13786          "type": "string"
13787        },
13788        "selfLink": {
13789          "description": "[Output Only] Server-defined URL for this resource.",
13790          "type": "string"
13791        },
13792        "warning": {
13793          "description": "[Output Only] Informational warning message.",
13794          "type": "object",
13795          "properties": {
13796            "code": {
13797              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
13798              "type": "string",
13799              "enumDescriptions": [
13800                "Warning about failed cleanup of transient changes made by a failed operation.",
13801                "A link to a deprecated resource was created.",
13802                "When deploying and at least one of the resources has a type marked as deprecated",
13803                "The user created a boot disk that is larger than image size.",
13804                "When deploying and at least one of the resources has a type marked as experimental",
13805                "Warning that is present in an external api call",
13806                "Warning that value of a field has been overridden. Deprecated unused field.",
13807                "The operation involved use of an injected kernel, which is deprecated.",
13808                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
13809                "When deploying a deployment with a exceedingly large number of resources",
13810                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
13811                "A resource depends on a missing type",
13812                "The route's nextHopIp address is not assigned to an instance on the network.",
13813                "The route's next hop instance cannot ip forward.",
13814                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
13815                "The route's nextHopInstance URL refers to an instance that does not exist.",
13816                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
13817                "The route's next hop instance does not have a status of RUNNING.",
13818                "Error which is not critical. We decided to continue the process despite the mentioned error.",
13819                "No results are present on a particular list page.",
13820                "Success is reported, but some results may be missing due to errors",
13821                "The user attempted to use a resource that requires a TOS they have not accepted.",
13822                "Warning that a resource is in use.",
13823                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
13824                "When a resource schema validation is ignored.",
13825                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
13826                "When undeclared properties in the schema are present",
13827                "A given scope cannot be reached."
13828              ],
13829              "enumDeprecated": [
13830                false,
13831                false,
13832                false,
13833                false,
13834                false,
13835                false,
13836                true,
13837                false,
13838                false,
13839                false,
13840                false,
13841                false,
13842                false,
13843                false,
13844                false,
13845                false,
13846                false,
13847                false,
13848                false,
13849                false,
13850                false,
13851                false,
13852                false,
13853                false,
13854                false,
13855                false,
13856                false,
13857                false
13858              ],
13859              "enum": [
13860                "CLEANUP_FAILED",
13861                "DEPRECATED_RESOURCE_USED",
13862                "DEPRECATED_TYPE_USED",
13863                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
13864                "EXPERIMENTAL_TYPE_USED",
13865                "EXTERNAL_API_WARNING",
13866                "FIELD_VALUE_OVERRIDEN",
13867                "INJECTED_KERNELS_DEPRECATED",
13868                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
13869                "LARGE_DEPLOYMENT_WARNING",
13870                "LIST_OVERHEAD_QUOTA_EXCEED",
13871                "MISSING_TYPE_DEPENDENCY",
13872                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
13873                "NEXT_HOP_CANNOT_IP_FORWARD",
13874                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
13875                "NEXT_HOP_INSTANCE_NOT_FOUND",
13876                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
13877                "NEXT_HOP_NOT_RUNNING",
13878                "NOT_CRITICAL_ERROR",
13879                "NO_RESULTS_ON_PAGE",
13880                "PARTIAL_SUCCESS",
13881                "REQUIRED_TOS_AGREEMENT",
13882                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
13883                "RESOURCE_NOT_DELETED",
13884                "SCHEMA_VALIDATION_IGNORED",
13885                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
13886                "UNDECLARED_PROPERTIES",
13887                "UNREACHABLE"
13888              ]
13889            },
13890            "message": {
13891              "description": "[Output Only] A human-readable description of the warning code.",
13892              "type": "string"
13893            },
13894            "data": {
13895              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
13896              "type": "array",
13897              "items": {
13898                "type": "object",
13899                "properties": {
13900                  "key": {
13901                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
13902                    "type": "string"
13903                  },
13904                  "value": {
13905                    "description": "[Output Only] A warning data value corresponding to the key.",
13906                    "type": "string"
13907                  }
13908                }
13909              }
13910            }
13911          }
13912        },
13913        "unreachables": {
13914          "description": "[Output Only] Unreachable resources. end_interface: MixerListResponseWithEtagBuilder",
13915          "type": "array",
13916          "items": {
13917            "type": "string"
13918          }
13919        }
13920      }
13921    },
13922    "AutoscalersScopedList": {
13923      "id": "AutoscalersScopedList",
13924      "type": "object",
13925      "properties": {
13926        "autoscalers": {
13927          "description": "[Output Only] A list of autoscalers contained in this scope.",
13928          "type": "array",
13929          "items": {
13930            "$ref": "Autoscaler"
13931          }
13932        },
13933        "warning": {
13934          "description": "[Output Only] Informational warning which replaces the list of autoscalers when the list is empty.",
13935          "type": "object",
13936          "properties": {
13937            "code": {
13938              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
13939              "type": "string",
13940              "enumDescriptions": [
13941                "Warning about failed cleanup of transient changes made by a failed operation.",
13942                "A link to a deprecated resource was created.",
13943                "When deploying and at least one of the resources has a type marked as deprecated",
13944                "The user created a boot disk that is larger than image size.",
13945                "When deploying and at least one of the resources has a type marked as experimental",
13946                "Warning that is present in an external api call",
13947                "Warning that value of a field has been overridden. Deprecated unused field.",
13948                "The operation involved use of an injected kernel, which is deprecated.",
13949                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
13950                "When deploying a deployment with a exceedingly large number of resources",
13951                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
13952                "A resource depends on a missing type",
13953                "The route's nextHopIp address is not assigned to an instance on the network.",
13954                "The route's next hop instance cannot ip forward.",
13955                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
13956                "The route's nextHopInstance URL refers to an instance that does not exist.",
13957                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
13958                "The route's next hop instance does not have a status of RUNNING.",
13959                "Error which is not critical. We decided to continue the process despite the mentioned error.",
13960                "No results are present on a particular list page.",
13961                "Success is reported, but some results may be missing due to errors",
13962                "The user attempted to use a resource that requires a TOS they have not accepted.",
13963                "Warning that a resource is in use.",
13964                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
13965                "When a resource schema validation is ignored.",
13966                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
13967                "When undeclared properties in the schema are present",
13968                "A given scope cannot be reached."
13969              ],
13970              "enumDeprecated": [
13971                false,
13972                false,
13973                false,
13974                false,
13975                false,
13976                false,
13977                true,
13978                false,
13979                false,
13980                false,
13981                false,
13982                false,
13983                false,
13984                false,
13985                false,
13986                false,
13987                false,
13988                false,
13989                false,
13990                false,
13991                false,
13992                false,
13993                false,
13994                false,
13995                false,
13996                false,
13997                false,
13998                false
13999              ],
14000              "enum": [
14001                "CLEANUP_FAILED",
14002                "DEPRECATED_RESOURCE_USED",
14003                "DEPRECATED_TYPE_USED",
14004                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
14005                "EXPERIMENTAL_TYPE_USED",
14006                "EXTERNAL_API_WARNING",
14007                "FIELD_VALUE_OVERRIDEN",
14008                "INJECTED_KERNELS_DEPRECATED",
14009                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
14010                "LARGE_DEPLOYMENT_WARNING",
14011                "LIST_OVERHEAD_QUOTA_EXCEED",
14012                "MISSING_TYPE_DEPENDENCY",
14013                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
14014                "NEXT_HOP_CANNOT_IP_FORWARD",
14015                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
14016                "NEXT_HOP_INSTANCE_NOT_FOUND",
14017                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
14018                "NEXT_HOP_NOT_RUNNING",
14019                "NOT_CRITICAL_ERROR",
14020                "NO_RESULTS_ON_PAGE",
14021                "PARTIAL_SUCCESS",
14022                "REQUIRED_TOS_AGREEMENT",
14023                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
14024                "RESOURCE_NOT_DELETED",
14025                "SCHEMA_VALIDATION_IGNORED",
14026                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
14027                "UNDECLARED_PROPERTIES",
14028                "UNREACHABLE"
14029              ]
14030            },
14031            "message": {
14032              "description": "[Output Only] A human-readable description of the warning code.",
14033              "type": "string"
14034            },
14035            "data": {
14036              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
14037              "type": "array",
14038              "items": {
14039                "type": "object",
14040                "properties": {
14041                  "key": {
14042                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
14043                    "type": "string"
14044                  },
14045                  "value": {
14046                    "description": "[Output Only] A warning data value corresponding to the key.",
14047                    "type": "string"
14048                  }
14049                }
14050              }
14051            }
14052          }
14053        }
14054      }
14055    },
14056    "RegionAutoscalerList": {
14057      "id": "RegionAutoscalerList",
14058      "description": "Contains a list of autoscalers.",
14059      "type": "object",
14060      "properties": {
14061        "kind": {
14062          "description": "Type of resource.",
14063          "default": "compute#regionAutoscalerList",
14064          "type": "string"
14065        },
14066        "id": {
14067          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
14068          "type": "string"
14069        },
14070        "items": {
14071          "description": "A list of Autoscaler resources.",
14072          "type": "array",
14073          "items": {
14074            "$ref": "Autoscaler"
14075          }
14076        },
14077        "nextPageToken": {
14078          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
14079          "type": "string"
14080        },
14081        "selfLink": {
14082          "description": "[Output Only] Server-defined URL for this resource.",
14083          "type": "string"
14084        },
14085        "warning": {
14086          "description": "[Output Only] Informational warning message.",
14087          "type": "object",
14088          "properties": {
14089            "code": {
14090              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
14091              "type": "string",
14092              "enumDescriptions": [
14093                "Warning about failed cleanup of transient changes made by a failed operation.",
14094                "A link to a deprecated resource was created.",
14095                "When deploying and at least one of the resources has a type marked as deprecated",
14096                "The user created a boot disk that is larger than image size.",
14097                "When deploying and at least one of the resources has a type marked as experimental",
14098                "Warning that is present in an external api call",
14099                "Warning that value of a field has been overridden. Deprecated unused field.",
14100                "The operation involved use of an injected kernel, which is deprecated.",
14101                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
14102                "When deploying a deployment with a exceedingly large number of resources",
14103                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
14104                "A resource depends on a missing type",
14105                "The route's nextHopIp address is not assigned to an instance on the network.",
14106                "The route's next hop instance cannot ip forward.",
14107                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
14108                "The route's nextHopInstance URL refers to an instance that does not exist.",
14109                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
14110                "The route's next hop instance does not have a status of RUNNING.",
14111                "Error which is not critical. We decided to continue the process despite the mentioned error.",
14112                "No results are present on a particular list page.",
14113                "Success is reported, but some results may be missing due to errors",
14114                "The user attempted to use a resource that requires a TOS they have not accepted.",
14115                "Warning that a resource is in use.",
14116                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
14117                "When a resource schema validation is ignored.",
14118                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
14119                "When undeclared properties in the schema are present",
14120                "A given scope cannot be reached."
14121              ],
14122              "enumDeprecated": [
14123                false,
14124                false,
14125                false,
14126                false,
14127                false,
14128                false,
14129                true,
14130                false,
14131                false,
14132                false,
14133                false,
14134                false,
14135                false,
14136                false,
14137                false,
14138                false,
14139                false,
14140                false,
14141                false,
14142                false,
14143                false,
14144                false,
14145                false,
14146                false,
14147                false,
14148                false,
14149                false,
14150                false
14151              ],
14152              "enum": [
14153                "CLEANUP_FAILED",
14154                "DEPRECATED_RESOURCE_USED",
14155                "DEPRECATED_TYPE_USED",
14156                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
14157                "EXPERIMENTAL_TYPE_USED",
14158                "EXTERNAL_API_WARNING",
14159                "FIELD_VALUE_OVERRIDEN",
14160                "INJECTED_KERNELS_DEPRECATED",
14161                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
14162                "LARGE_DEPLOYMENT_WARNING",
14163                "LIST_OVERHEAD_QUOTA_EXCEED",
14164                "MISSING_TYPE_DEPENDENCY",
14165                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
14166                "NEXT_HOP_CANNOT_IP_FORWARD",
14167                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
14168                "NEXT_HOP_INSTANCE_NOT_FOUND",
14169                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
14170                "NEXT_HOP_NOT_RUNNING",
14171                "NOT_CRITICAL_ERROR",
14172                "NO_RESULTS_ON_PAGE",
14173                "PARTIAL_SUCCESS",
14174                "REQUIRED_TOS_AGREEMENT",
14175                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
14176                "RESOURCE_NOT_DELETED",
14177                "SCHEMA_VALIDATION_IGNORED",
14178                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
14179                "UNDECLARED_PROPERTIES",
14180                "UNREACHABLE"
14181              ]
14182            },
14183            "message": {
14184              "description": "[Output Only] A human-readable description of the warning code.",
14185              "type": "string"
14186            },
14187            "data": {
14188              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
14189              "type": "array",
14190              "items": {
14191                "type": "object",
14192                "properties": {
14193                  "key": {
14194                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
14195                    "type": "string"
14196                  },
14197                  "value": {
14198                    "description": "[Output Only] A warning data value corresponding to the key.",
14199                    "type": "string"
14200                  }
14201                }
14202              }
14203            }
14204          }
14205        }
14206      }
14207    },
14208    "BackendBucketList": {
14209      "id": "BackendBucketList",
14210      "description": "Contains a list of BackendBucket resources.",
14211      "type": "object",
14212      "properties": {
14213        "kind": {
14214          "description": "Type of resource.",
14215          "default": "compute#backendBucketList",
14216          "type": "string"
14217        },
14218        "id": {
14219          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
14220          "type": "string"
14221        },
14222        "items": {
14223          "description": "A list of BackendBucket resources.",
14224          "type": "array",
14225          "items": {
14226            "$ref": "BackendBucket"
14227          }
14228        },
14229        "nextPageToken": {
14230          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
14231          "type": "string"
14232        },
14233        "selfLink": {
14234          "description": "[Output Only] Server-defined URL for this resource.",
14235          "type": "string"
14236        },
14237        "warning": {
14238          "description": "[Output Only] Informational warning message.",
14239          "type": "object",
14240          "properties": {
14241            "code": {
14242              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
14243              "type": "string",
14244              "enumDescriptions": [
14245                "Warning about failed cleanup of transient changes made by a failed operation.",
14246                "A link to a deprecated resource was created.",
14247                "When deploying and at least one of the resources has a type marked as deprecated",
14248                "The user created a boot disk that is larger than image size.",
14249                "When deploying and at least one of the resources has a type marked as experimental",
14250                "Warning that is present in an external api call",
14251                "Warning that value of a field has been overridden. Deprecated unused field.",
14252                "The operation involved use of an injected kernel, which is deprecated.",
14253                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
14254                "When deploying a deployment with a exceedingly large number of resources",
14255                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
14256                "A resource depends on a missing type",
14257                "The route's nextHopIp address is not assigned to an instance on the network.",
14258                "The route's next hop instance cannot ip forward.",
14259                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
14260                "The route's nextHopInstance URL refers to an instance that does not exist.",
14261                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
14262                "The route's next hop instance does not have a status of RUNNING.",
14263                "Error which is not critical. We decided to continue the process despite the mentioned error.",
14264                "No results are present on a particular list page.",
14265                "Success is reported, but some results may be missing due to errors",
14266                "The user attempted to use a resource that requires a TOS they have not accepted.",
14267                "Warning that a resource is in use.",
14268                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
14269                "When a resource schema validation is ignored.",
14270                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
14271                "When undeclared properties in the schema are present",
14272                "A given scope cannot be reached."
14273              ],
14274              "enumDeprecated": [
14275                false,
14276                false,
14277                false,
14278                false,
14279                false,
14280                false,
14281                true,
14282                false,
14283                false,
14284                false,
14285                false,
14286                false,
14287                false,
14288                false,
14289                false,
14290                false,
14291                false,
14292                false,
14293                false,
14294                false,
14295                false,
14296                false,
14297                false,
14298                false,
14299                false,
14300                false,
14301                false,
14302                false
14303              ],
14304              "enum": [
14305                "CLEANUP_FAILED",
14306                "DEPRECATED_RESOURCE_USED",
14307                "DEPRECATED_TYPE_USED",
14308                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
14309                "EXPERIMENTAL_TYPE_USED",
14310                "EXTERNAL_API_WARNING",
14311                "FIELD_VALUE_OVERRIDEN",
14312                "INJECTED_KERNELS_DEPRECATED",
14313                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
14314                "LARGE_DEPLOYMENT_WARNING",
14315                "LIST_OVERHEAD_QUOTA_EXCEED",
14316                "MISSING_TYPE_DEPENDENCY",
14317                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
14318                "NEXT_HOP_CANNOT_IP_FORWARD",
14319                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
14320                "NEXT_HOP_INSTANCE_NOT_FOUND",
14321                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
14322                "NEXT_HOP_NOT_RUNNING",
14323                "NOT_CRITICAL_ERROR",
14324                "NO_RESULTS_ON_PAGE",
14325                "PARTIAL_SUCCESS",
14326                "REQUIRED_TOS_AGREEMENT",
14327                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
14328                "RESOURCE_NOT_DELETED",
14329                "SCHEMA_VALIDATION_IGNORED",
14330                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
14331                "UNDECLARED_PROPERTIES",
14332                "UNREACHABLE"
14333              ]
14334            },
14335            "message": {
14336              "description": "[Output Only] A human-readable description of the warning code.",
14337              "type": "string"
14338            },
14339            "data": {
14340              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
14341              "type": "array",
14342              "items": {
14343                "type": "object",
14344                "properties": {
14345                  "key": {
14346                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
14347                    "type": "string"
14348                  },
14349                  "value": {
14350                    "description": "[Output Only] A warning data value corresponding to the key.",
14351                    "type": "string"
14352                  }
14353                }
14354              }
14355            }
14356          }
14357        }
14358      }
14359    },
14360    "BackendBucket": {
14361      "id": "BackendBucket",
14362      "description": "Represents a Cloud Storage Bucket resource. This Cloud Storage bucket resource is referenced by a URL map of a load balancer. For more information, read Backend Buckets.",
14363      "type": "object",
14364      "properties": {
14365        "kind": {
14366          "description": "Type of the resource.",
14367          "default": "compute#backendBucket",
14368          "type": "string"
14369        },
14370        "id": {
14371          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
14372          "type": "string",
14373          "format": "uint64"
14374        },
14375        "creationTimestamp": {
14376          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
14377          "type": "string"
14378        },
14379        "name": {
14380          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
14381          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
14382          "type": "string"
14383        },
14384        "description": {
14385          "description": "An optional textual description of the resource; provided by the client when the resource is created.",
14386          "type": "string"
14387        },
14388        "selfLink": {
14389          "description": "[Output Only] Server-defined URL for the resource.",
14390          "type": "string"
14391        },
14392        "bucketName": {
14393          "description": "Cloud Storage bucket name.",
14394          "type": "string"
14395        },
14396        "enableCdn": {
14397          "description": "If true, enable Cloud CDN for this BackendBucket.",
14398          "type": "boolean"
14399        },
14400        "cdnPolicy": {
14401          "description": "Cloud CDN configuration for this BackendBucket.",
14402          "$ref": "BackendBucketCdnPolicy"
14403        },
14404        "customResponseHeaders": {
14405          "description": "Headers that the Application Load Balancer should add to proxied responses.",
14406          "type": "array",
14407          "items": {
14408            "type": "string"
14409          }
14410        },
14411        "edgeSecurityPolicy": {
14412          "description": "[Output Only] The resource URL for the edge security policy associated with this backend bucket.",
14413          "type": "string"
14414        },
14415        "compressionMode": {
14416          "description": "Compress text responses using Brotli or gzip compression, based on the client's Accept-Encoding header.",
14417          "type": "string",
14418          "enumDescriptions": [
14419            "Automatically uses the best compression based on the Accept-Encoding header sent by the client.",
14420            "Disables compression. Existing compressed responses cached by Cloud CDN will not be served to clients."
14421          ],
14422          "enum": [
14423            "AUTOMATIC",
14424            "DISABLED"
14425          ]
14426        }
14427      }
14428    },
14429    "BackendBucketCdnPolicy": {
14430      "id": "BackendBucketCdnPolicy",
14431      "description": "Message containing Cloud CDN configuration for a backend bucket.",
14432      "type": "object",
14433      "properties": {
14434        "signedUrlKeyNames": {
14435          "description": "[Output Only] Names of the keys for signing request URLs.",
14436          "type": "array",
14437          "items": {
14438            "type": "string"
14439          }
14440        },
14441        "signedUrlCacheMaxAgeSec": {
14442          "description": "Maximum number of seconds the response to a signed URL request will be considered fresh. After this time period, the response will be revalidated before being served. Defaults to 1hr (3600s). When serving responses to signed URL requests, Cloud CDN will internally behave as though all responses from this backend had a \"Cache-Control: public, max-age=[TTL]\" header, regardless of any existing Cache-Control header. The actual headers served in responses will not be altered.",
14443          "type": "string",
14444          "format": "int64"
14445        },
14446        "requestCoalescing": {
14447          "description": "If true then Cloud CDN will combine multiple concurrent cache fill requests into a small number of requests to the origin.",
14448          "type": "boolean"
14449        },
14450        "cacheMode": {
14451          "description": "Specifies the cache setting for all responses from this backend. The possible values are: USE_ORIGIN_HEADERS Requires the origin to set valid caching headers to cache content. Responses without these headers will not be cached at Google's edge, and will require a full trip to the origin on every request, potentially impacting performance and increasing load on the origin server. FORCE_CACHE_ALL Cache all content, ignoring any \"private\", \"no-store\" or \"no-cache\" directives in Cache-Control response headers. Warning: this may result in Cloud CDN caching private, per-user (user identifiable) content. CACHE_ALL_STATIC Automatically cache static content, including common image formats, media (video and audio), and web assets (JavaScript and CSS). Requests and responses that are marked as uncacheable, as well as dynamic content (including HTML), will not be cached.",
14452          "type": "string",
14453          "enumDescriptions": [
14454            "Automatically cache static content, including common image formats, media (video and audio), and web assets (JavaScript and CSS). Requests and responses that are marked as uncacheable, as well as dynamic content (including HTML), will not be cached.",
14455            "Cache all content, ignoring any \"private\", \"no-store\" or \"no-cache\" directives in Cache-Control response headers. Warning: this may result in Cloud CDN caching private, per-user (user identifiable) content.",
14456            "",
14457            "Requires the origin to set valid caching headers to cache content. Responses without these headers will not be cached at Google's edge, and will require a full trip to the origin on every request, potentially impacting performance and increasing load on the origin server."
14458          ],
14459          "enum": [
14460            "CACHE_ALL_STATIC",
14461            "FORCE_CACHE_ALL",
14462            "INVALID_CACHE_MODE",
14463            "USE_ORIGIN_HEADERS"
14464          ]
14465        },
14466        "defaultTtl": {
14467          "description": "Specifies the default TTL for cached content served by this origin for responses that do not have an existing valid TTL (max-age or s-max-age). Setting a TTL of \"0\" means \"always revalidate\". The value of defaultTTL cannot be set to a value greater than that of maxTTL, but can be equal. When the cacheMode is set to FORCE_CACHE_ALL, the defaultTTL will overwrite the TTL set in all responses. The maximum allowed value is 31,622,400s (1 year), noting that infrequently accessed objects may be evicted from the cache before the defined TTL.",
14468          "type": "integer",
14469          "format": "int32"
14470        },
14471        "maxTtl": {
14472          "description": "Specifies the maximum allowed TTL for cached content served by this origin. Cache directives that attempt to set a max-age or s-maxage higher than this, or an Expires header more than maxTTL seconds in the future will be capped at the value of maxTTL, as if it were the value of an s-maxage Cache-Control directive. Headers sent to the client will not be modified. Setting a TTL of \"0\" means \"always revalidate\". The maximum allowed value is 31,622,400s (1 year), noting that infrequently accessed objects may be evicted from the cache before the defined TTL.",
14473          "type": "integer",
14474          "format": "int32"
14475        },
14476        "clientTtl": {
14477          "description": "Specifies a separate client (e.g. browser client) maximum TTL. This is used to clamp the max-age (or Expires) value sent to the client. With FORCE_CACHE_ALL, the lesser of client_ttl and default_ttl is used for the response max-age directive, along with a \"public\" directive. For cacheable content in CACHE_ALL_STATIC mode, client_ttl clamps the max-age from the origin (if specified), or else sets the response max-age directive to the lesser of the client_ttl and default_ttl, and also ensures a \"public\" cache-control directive is present. If a client TTL is not specified, a default value (1 hour) will be used. The maximum allowed value is 31,622,400s (1 year).",
14478          "type": "integer",
14479          "format": "int32"
14480        },
14481        "negativeCaching": {
14482          "description": "Negative caching allows per-status code TTLs to be set, in order to apply fine-grained caching for common errors or redirects. This can reduce the load on your origin and improve end-user experience by reducing response latency. When the cache mode is set to CACHE_ALL_STATIC or USE_ORIGIN_HEADERS, negative caching applies to responses with the specified response code that lack any Cache-Control, Expires, or Pragma: no-cache directives. When the cache mode is set to FORCE_CACHE_ALL, negative caching applies to all responses with the specified response code, and override any caching headers. By default, Cloud CDN will apply the following default TTLs to these status codes: HTTP 300 (Multiple Choice), 301, 308 (Permanent Redirects): 10m HTTP 404 (Not Found), 410 (Gone), 451 (Unavailable For Legal Reasons): 120s HTTP 405 (Method Not Found), 421 (Misdirected Request), 501 (Not Implemented): 60s. These defaults can be overridden in negative_caching_policy.",
14483          "type": "boolean"
14484        },
14485        "negativeCachingPolicy": {
14486          "description": "Sets a cache TTL for the specified HTTP status code. negative_caching must be enabled to configure negative_caching_policy. Omitting the policy and leaving negative_caching enabled will use Cloud CDN's default cache TTLs. Note that when specifying an explicit negative_caching_policy, you should take care to specify a cache TTL for all response codes that you wish to cache. Cloud CDN will not apply any default negative caching when a policy exists.",
14487          "type": "array",
14488          "items": {
14489            "$ref": "BackendBucketCdnPolicyNegativeCachingPolicy"
14490          }
14491        },
14492        "bypassCacheOnRequestHeaders": {
14493          "description": "Bypass the cache when the specified request headers are matched - e.g. Pragma or Authorization headers. Up to 5 headers can be specified. The cache is bypassed for all cdnPolicy.cacheMode settings.",
14494          "type": "array",
14495          "items": {
14496            "$ref": "BackendBucketCdnPolicyBypassCacheOnRequestHeader"
14497          }
14498        },
14499        "serveWhileStale": {
14500          "description": "Serve existing content from the cache (if available) when revalidating content with the origin, or when an error is encountered when refreshing the cache. This setting defines the default \"max-stale\" duration for any cached responses that do not specify a max-stale directive. Stale responses that exceed the TTL configured here will not be served. The default limit (max-stale) is 86400s (1 day), which will allow stale content to be served up to this limit beyond the max-age (or s-max-age) of a cached response. The maximum allowed value is 604800 (1 week). Set this to zero (0) to disable serve-while-stale.",
14501          "type": "integer",
14502          "format": "int32"
14503        },
14504        "cacheKeyPolicy": {
14505          "description": "The CacheKeyPolicy for this CdnPolicy.",
14506          "$ref": "BackendBucketCdnPolicyCacheKeyPolicy"
14507        }
14508      }
14509    },
14510    "BackendBucketCdnPolicyNegativeCachingPolicy": {
14511      "id": "BackendBucketCdnPolicyNegativeCachingPolicy",
14512      "description": "Specify CDN TTLs for response error codes.",
14513      "type": "object",
14514      "properties": {
14515        "code": {
14516          "description": "The HTTP status code to define a TTL against. Only HTTP status codes 300, 301, 302, 307, 308, 404, 405, 410, 421, 451 and 501 are can be specified as values, and you cannot specify a status code more than once.",
14517          "type": "integer",
14518          "format": "int32"
14519        },
14520        "ttl": {
14521          "description": "The TTL (in seconds) for which to cache responses with the corresponding status code. The maximum allowed value is 1800s (30 minutes), noting that infrequently accessed objects may be evicted from the cache before the defined TTL.",
14522          "type": "integer",
14523          "format": "int32"
14524        }
14525      }
14526    },
14527    "BackendBucketCdnPolicyBypassCacheOnRequestHeader": {
14528      "id": "BackendBucketCdnPolicyBypassCacheOnRequestHeader",
14529      "description": "Bypass the cache when the specified request headers are present, e.g. Pragma or Authorization headers. Values are case insensitive. The presence of such a header overrides the cache_mode setting.",
14530      "type": "object",
14531      "properties": {
14532        "headerName": {
14533          "description": "The header field name to match on when bypassing cache. Values are case-insensitive.",
14534          "type": "string"
14535        }
14536      }
14537    },
14538    "BackendBucketCdnPolicyCacheKeyPolicy": {
14539      "id": "BackendBucketCdnPolicyCacheKeyPolicy",
14540      "description": "Message containing what to include in the cache key for a request for Cloud CDN.",
14541      "type": "object",
14542      "properties": {
14543        "queryStringWhitelist": {
14544          "description": "Names of query string parameters to include in cache keys. Default parameters are always included. '&' and '=' will be percent encoded and not treated as delimiters.",
14545          "type": "array",
14546          "items": {
14547            "type": "string"
14548          }
14549        },
14550        "includeHttpHeaders": {
14551          "description": "Allows HTTP request headers (by name) to be used in the cache key.",
14552          "type": "array",
14553          "items": {
14554            "type": "string"
14555          }
14556        }
14557      }
14558    },
14559    "SignedUrlKey": {
14560      "id": "SignedUrlKey",
14561      "description": "Represents a customer-supplied Signing Key used by Cloud CDN Signed URLs",
14562      "type": "object",
14563      "properties": {
14564        "keyName": {
14565          "description": "Name of the key. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
14566          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
14567          "type": "string"
14568        },
14569        "keyValue": {
14570          "description": "128-bit key value used for signing the URL. The key value must be a valid RFC 4648 Section 5 base64url encoded string.",
14571          "type": "string"
14572        }
14573      }
14574    },
14575    "SecurityPolicyReference": {
14576      "id": "SecurityPolicyReference",
14577      "type": "object",
14578      "properties": {
14579        "securityPolicy": {
14580          "type": "string"
14581        }
14582      }
14583    },
14584    "BackendServiceList": {
14585      "id": "BackendServiceList",
14586      "description": "Contains a list of BackendService resources.",
14587      "type": "object",
14588      "properties": {
14589        "kind": {
14590          "description": "[Output Only] Type of resource. Always compute#backendServiceList for lists of backend services.",
14591          "default": "compute#backendServiceList",
14592          "type": "string"
14593        },
14594        "id": {
14595          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
14596          "type": "string"
14597        },
14598        "items": {
14599          "description": "A list of BackendService resources.",
14600          "type": "array",
14601          "items": {
14602            "$ref": "BackendService"
14603          }
14604        },
14605        "nextPageToken": {
14606          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
14607          "type": "string"
14608        },
14609        "selfLink": {
14610          "description": "[Output Only] Server-defined URL for this resource.",
14611          "type": "string"
14612        },
14613        "warning": {
14614          "description": "[Output Only] Informational warning message.",
14615          "type": "object",
14616          "properties": {
14617            "code": {
14618              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
14619              "type": "string",
14620              "enumDescriptions": [
14621                "Warning about failed cleanup of transient changes made by a failed operation.",
14622                "A link to a deprecated resource was created.",
14623                "When deploying and at least one of the resources has a type marked as deprecated",
14624                "The user created a boot disk that is larger than image size.",
14625                "When deploying and at least one of the resources has a type marked as experimental",
14626                "Warning that is present in an external api call",
14627                "Warning that value of a field has been overridden. Deprecated unused field.",
14628                "The operation involved use of an injected kernel, which is deprecated.",
14629                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
14630                "When deploying a deployment with a exceedingly large number of resources",
14631                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
14632                "A resource depends on a missing type",
14633                "The route's nextHopIp address is not assigned to an instance on the network.",
14634                "The route's next hop instance cannot ip forward.",
14635                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
14636                "The route's nextHopInstance URL refers to an instance that does not exist.",
14637                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
14638                "The route's next hop instance does not have a status of RUNNING.",
14639                "Error which is not critical. We decided to continue the process despite the mentioned error.",
14640                "No results are present on a particular list page.",
14641                "Success is reported, but some results may be missing due to errors",
14642                "The user attempted to use a resource that requires a TOS they have not accepted.",
14643                "Warning that a resource is in use.",
14644                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
14645                "When a resource schema validation is ignored.",
14646                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
14647                "When undeclared properties in the schema are present",
14648                "A given scope cannot be reached."
14649              ],
14650              "enumDeprecated": [
14651                false,
14652                false,
14653                false,
14654                false,
14655                false,
14656                false,
14657                true,
14658                false,
14659                false,
14660                false,
14661                false,
14662                false,
14663                false,
14664                false,
14665                false,
14666                false,
14667                false,
14668                false,
14669                false,
14670                false,
14671                false,
14672                false,
14673                false,
14674                false,
14675                false,
14676                false,
14677                false,
14678                false
14679              ],
14680              "enum": [
14681                "CLEANUP_FAILED",
14682                "DEPRECATED_RESOURCE_USED",
14683                "DEPRECATED_TYPE_USED",
14684                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
14685                "EXPERIMENTAL_TYPE_USED",
14686                "EXTERNAL_API_WARNING",
14687                "FIELD_VALUE_OVERRIDEN",
14688                "INJECTED_KERNELS_DEPRECATED",
14689                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
14690                "LARGE_DEPLOYMENT_WARNING",
14691                "LIST_OVERHEAD_QUOTA_EXCEED",
14692                "MISSING_TYPE_DEPENDENCY",
14693                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
14694                "NEXT_HOP_CANNOT_IP_FORWARD",
14695                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
14696                "NEXT_HOP_INSTANCE_NOT_FOUND",
14697                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
14698                "NEXT_HOP_NOT_RUNNING",
14699                "NOT_CRITICAL_ERROR",
14700                "NO_RESULTS_ON_PAGE",
14701                "PARTIAL_SUCCESS",
14702                "REQUIRED_TOS_AGREEMENT",
14703                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
14704                "RESOURCE_NOT_DELETED",
14705                "SCHEMA_VALIDATION_IGNORED",
14706                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
14707                "UNDECLARED_PROPERTIES",
14708                "UNREACHABLE"
14709              ]
14710            },
14711            "message": {
14712              "description": "[Output Only] A human-readable description of the warning code.",
14713              "type": "string"
14714            },
14715            "data": {
14716              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
14717              "type": "array",
14718              "items": {
14719                "type": "object",
14720                "properties": {
14721                  "key": {
14722                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
14723                    "type": "string"
14724                  },
14725                  "value": {
14726                    "description": "[Output Only] A warning data value corresponding to the key.",
14727                    "type": "string"
14728                  }
14729                }
14730              }
14731            }
14732          }
14733        }
14734      }
14735    },
14736    "BackendService": {
14737      "id": "BackendService",
14738      "description": "Represents a Backend Service resource. A backend service defines how Google Cloud load balancers distribute traffic. The backend service configuration contains a set of values, such as the protocol used to connect to backends, various distribution and session settings, health checks, and timeouts. These settings provide fine-grained control over how your load balancer behaves. Most of the settings have default values that allow for easy configuration if you need to get started quickly. Backend services in Google Compute Engine can be either regionally or globally scoped. * [Global](https://cloud.google.com/compute/docs/reference/rest/v1/backendServices) * [Regional](https://cloud.google.com/compute/docs/reference/rest/v1/regionBackendServices) For more information, see Backend Services.",
14739      "type": "object",
14740      "properties": {
14741        "kind": {
14742          "description": "[Output Only] Type of resource. Always compute#backendService for backend services.",
14743          "default": "compute#backendService",
14744          "type": "string"
14745        },
14746        "id": {
14747          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
14748          "type": "string",
14749          "format": "uint64"
14750        },
14751        "creationTimestamp": {
14752          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
14753          "type": "string"
14754        },
14755        "name": {
14756          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
14757          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
14758          "type": "string"
14759        },
14760        "description": {
14761          "description": "An optional description of this resource. Provide this property when you create the resource.",
14762          "type": "string"
14763        },
14764        "selfLink": {
14765          "description": "[Output Only] Server-defined URL for the resource.",
14766          "type": "string"
14767        },
14768        "backends": {
14769          "description": "The list of backends that serve this BackendService.",
14770          "type": "array",
14771          "items": {
14772            "$ref": "Backend"
14773          }
14774        },
14775        "healthChecks": {
14776          "description": "The list of URLs to the healthChecks, httpHealthChecks (legacy), or httpsHealthChecks (legacy) resource for health checking this backend service. Not all backend services support legacy health checks. See Load balancer guide. Currently, at most one health check can be specified for each backend service. Backend services with instance group or zonal NEG backends must have a health check. Backend services with internet or serverless NEG backends must not have a health check.",
14777          "type": "array",
14778          "items": {
14779            "type": "string"
14780          }
14781        },
14782        "timeoutSec": {
14783          "description": "The backend service timeout has a different meaning depending on the type of load balancer. For more information see, Backend service settings. The default is 30 seconds. The full range of timeout values allowed goes from 1 through 2,147,483,647 seconds. This value can be overridden in the PathMatcher configuration of the UrlMap that references this backend service. Not supported when the backend service is referenced by a URL map that is bound to target gRPC proxy that has validateForProxyless field set to true. Instead, use maxStreamDuration.",
14784          "type": "integer",
14785          "format": "int32"
14786        },
14787        "port": {
14788          "description": "Deprecated in favor of portName. The TCP port to connect on the backend. The default value is 80. For internal passthrough Network Load Balancers and external passthrough Network Load Balancers, omit port.",
14789          "deprecated": true,
14790          "type": "integer",
14791          "format": "int32"
14792        },
14793        "protocol": {
14794          "description": "The protocol this BackendService uses to communicate with backends. Possible values are HTTP, HTTPS, HTTP2, TCP, SSL, UDP or GRPC. depending on the chosen load balancer or Traffic Director configuration. Refer to the documentation for the load balancers or for Traffic Director for more information. Must be set to GRPC when the backend service is referenced by a URL map that is bound to target gRPC proxy.",
14795          "type": "string",
14796          "enumDescriptions": [
14797            "gRPC (available for Traffic Director).",
14798            "",
14799            "HTTP/2 with SSL.",
14800            "",
14801            "TCP proxying with SSL.",
14802            "TCP proxying or TCP pass-through.",
14803            "UDP.",
14804            "If a Backend Service has UNSPECIFIED as its protocol, it can be used with any L3/L4 Forwarding Rules."
14805          ],
14806          "enum": [
14807            "GRPC",
14808            "HTTP",
14809            "HTTP2",
14810            "HTTPS",
14811            "SSL",
14812            "TCP",
14813            "UDP",
14814            "UNSPECIFIED"
14815          ]
14816        },
14817        "fingerprint": {
14818          "description": "Fingerprint of this resource. A hash of the contents stored in this object. This field is used in optimistic locking. This field will be ignored when inserting a BackendService. An up-to-date fingerprint must be provided in order to update the BackendService, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve a BackendService.",
14819          "type": "string",
14820          "format": "byte"
14821        },
14822        "portName": {
14823          "description": "A named port on a backend instance group representing the port for communication to the backend VMs in that group. The named port must be [defined on each backend instance group](https://cloud.google.com/load-balancing/docs/backend-service#named_ports). This parameter has no meaning if the backends are NEGs. For internal passthrough Network Load Balancers and external passthrough Network Load Balancers, omit port_name.",
14824          "type": "string"
14825        },
14826        "enableCDN": {
14827          "description": "If true, enables Cloud CDN for the backend service of a global external Application Load Balancer.",
14828          "type": "boolean"
14829        },
14830        "sessionAffinity": {
14831          "description": "Type of session affinity to use. The default is NONE. Only NONE and HEADER_FIELD are supported when the backend service is referenced by a URL map that is bound to target gRPC proxy that has validateForProxyless field set to true. For more details, see: [Session Affinity](https://cloud.google.com/load-balancing/docs/backend-service#session_affinity).",
14832          "type": "string",
14833          "enumDescriptions": [
14834            "2-tuple hash on packet's source and destination IP addresses. Connections from the same source IP address to the same destination IP address will be served by the same backend VM while that VM remains healthy.",
14835            "1-tuple hash only on packet's source IP address. Connections from the same source IP address will be served by the same backend VM while that VM remains healthy. This option can only be used for Internal TCP/UDP Load Balancing.",
14836            "5-tuple hash on packet's source and destination IP addresses, IP protocol, and source and destination ports. Connections for the same IP protocol from the same source IP address and port to the same destination IP address and port will be served by the same backend VM while that VM remains healthy. This option cannot be used for HTTP(S) load balancing.",
14837            "3-tuple hash on packet's source and destination IP addresses, and IP protocol. Connections for the same IP protocol from the same source IP address to the same destination IP address will be served by the same backend VM while that VM remains healthy. This option cannot be used for HTTP(S) load balancing.",
14838            "Hash based on a cookie generated by the L7 loadbalancer. Only valid for HTTP(S) load balancing.",
14839            "The hash is based on a user specified header field.",
14840            "The hash is based on a user provided cookie.",
14841            "No session affinity. Connections from the same client IP may go to any instance in the pool."
14842          ],
14843          "enum": [
14844            "CLIENT_IP",
14845            "CLIENT_IP_NO_DESTINATION",
14846            "CLIENT_IP_PORT_PROTO",
14847            "CLIENT_IP_PROTO",
14848            "GENERATED_COOKIE",
14849            "HEADER_FIELD",
14850            "HTTP_COOKIE",
14851            "NONE"
14852          ]
14853        },
14854        "affinityCookieTtlSec": {
14855          "description": "Lifetime of cookies in seconds. This setting is applicable to Application Load Balancers and Traffic Director and requires GENERATED_COOKIE or HTTP_COOKIE session affinity. If set to 0, the cookie is non-persistent and lasts only until the end of the browser session (or equivalent). The maximum allowed value is two weeks (1,209,600). Not supported when the backend service is referenced by a URL map that is bound to target gRPC proxy that has validateForProxyless field set to true.",
14856          "type": "integer",
14857          "format": "int32"
14858        },
14859        "region": {
14860          "description": "[Output Only] URL of the region where the regional backend service resides. This field is not applicable to global backend services. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
14861          "type": "string"
14862        },
14863        "failoverPolicy": {
14864          "description": "Requires at least one backend instance group to be defined as a backup (failover) backend. For load balancers that have configurable failover: [Internal passthrough Network Load Balancers](https://cloud.google.com/load-balancing/docs/internal/failover-overview) and [external passthrough Network Load Balancers](https://cloud.google.com/load-balancing/docs/network/networklb-failover-overview).",
14865          "$ref": "BackendServiceFailoverPolicy"
14866        },
14867        "loadBalancingScheme": {
14868          "description": "Specifies the load balancer type. A backend service created for one type of load balancer cannot be used with another. For more information, refer to Choosing a load balancer.",
14869          "type": "string",
14870          "enumDescriptions": [
14871            "Signifies that this will be used for classic Application Load Balancers, global external proxy Network Load Balancers, or external passthrough Network Load Balancers.",
14872            "Signifies that this will be used for global external Application Load Balancers, regional external Application Load Balancers, or regional external proxy Network Load Balancers.",
14873            "Signifies that this will be used for internal passthrough Network Load Balancers.",
14874            "Signifies that this will be used for internal Application Load Balancers.",
14875            "Signifies that this will be used by Traffic Director.",
14876            ""
14877          ],
14878          "enum": [
14879            "EXTERNAL",
14880            "EXTERNAL_MANAGED",
14881            "INTERNAL",
14882            "INTERNAL_MANAGED",
14883            "INTERNAL_SELF_MANAGED",
14884            "INVALID_LOAD_BALANCING_SCHEME"
14885          ]
14886        },
14887        "connectionDraining": {
14888          "$ref": "ConnectionDraining"
14889        },
14890        "iap": {
14891          "description": "The configurations for Identity-Aware Proxy on this resource. Not available for internal passthrough Network Load Balancers and external passthrough Network Load Balancers.",
14892          "$ref": "BackendServiceIAP"
14893        },
14894        "cdnPolicy": {
14895          "description": "Cloud CDN configuration for this BackendService. Only available for specified load balancer types.",
14896          "$ref": "BackendServiceCdnPolicy"
14897        },
14898        "customRequestHeaders": {
14899          "description": "Headers that the load balancer adds to proxied requests. See [Creating custom headers](https://cloud.google.com/load-balancing/docs/custom-headers).",
14900          "type": "array",
14901          "items": {
14902            "type": "string"
14903          }
14904        },
14905        "customResponseHeaders": {
14906          "description": "Headers that the load balancer adds to proxied responses. See [Creating custom headers](https://cloud.google.com/load-balancing/docs/custom-headers).",
14907          "type": "array",
14908          "items": {
14909            "type": "string"
14910          }
14911        },
14912        "securityPolicy": {
14913          "description": "[Output Only] The resource URL for the security policy associated with this backend service.",
14914          "type": "string"
14915        },
14916        "edgeSecurityPolicy": {
14917          "description": "[Output Only] The resource URL for the edge security policy associated with this backend service.",
14918          "type": "string"
14919        },
14920        "logConfig": {
14921          "description": "This field denotes the logging options for the load balancer traffic served by this backend service. If logging is enabled, logs will be exported to Stackdriver.",
14922          "$ref": "BackendServiceLogConfig"
14923        },
14924        "securitySettings": {
14925          "description": "This field specifies the security settings that apply to this backend service. This field is applicable to a global backend service with the load_balancing_scheme set to INTERNAL_SELF_MANAGED.",
14926          "$ref": "SecuritySettings"
14927        },
14928        "localityLbPolicy": {
14929          "description": "The load balancing algorithm used within the scope of the locality. The possible values are: - ROUND_ROBIN: This is a simple policy in which each healthy backend is selected in round robin order. This is the default. - LEAST_REQUEST: An O(1) algorithm which selects two random healthy hosts and picks the host which has fewer active requests. - RING_HASH: The ring/modulo hash load balancer implements consistent hashing to backends. The algorithm has the property that the addition/removal of a host from a set of N hosts only affects 1/N of the requests. - RANDOM: The load balancer selects a random healthy host. - ORIGINAL_DESTINATION: Backend host is selected based on the client connection metadata, i.e., connections are opened to the same address as the destination address of the incoming connection before the connection was redirected to the load balancer. - MAGLEV: used as a drop in replacement for the ring hash load balancer. Maglev is not as stable as ring hash but has faster table lookup build times and host selection times. For more information about Maglev, see https://ai.google/research/pubs/pub44824 This field is applicable to either: - A regional backend service with the service_protocol set to HTTP, HTTPS, or HTTP2, and load_balancing_scheme set to INTERNAL_MANAGED. - A global backend service with the load_balancing_scheme set to INTERNAL_SELF_MANAGED, INTERNAL_MANAGED, or EXTERNAL_MANAGED. If sessionAffinity is not NONE, and this field is not set to MAGLEV or RING_HASH, session affinity settings will not take effect. Only ROUND_ROBIN and RING_HASH are supported when the backend service is referenced by a URL map that is bound to target gRPC proxy that has validateForProxyless field set to true.",
14930          "type": "string",
14931          "enumDescriptions": [
14932            "",
14933            "An O(1) algorithm which selects two random healthy hosts and picks the host which has fewer active requests.",
14934            "This algorithm implements consistent hashing to backends. Maglev can be used as a drop in replacement for the ring hash load balancer. Maglev is not as stable as ring hash but has faster table lookup build times and host selection times. For more information about Maglev, see https://ai.google/research/pubs/pub44824",
14935            "Backend host is selected based on the client connection metadata, i.e., connections are opened to the same address as the destination address of the incoming connection before the connection was redirected to the load balancer.",
14936            "The load balancer selects a random healthy host.",
14937            "The ring/modulo hash load balancer implements consistent hashing to backends. The algorithm has the property that the addition/removal of a host from a set of N hosts only affects 1/N of the requests.",
14938            "This is a simple policy in which each healthy backend is selected in round robin order. This is the default.",
14939            "Per-instance weighted Load Balancing via health check reported weights. If set, the Backend Service must configure a non legacy HTTP-based Health Check, and health check replies are expected to contain non-standard HTTP response header field X-Load-Balancing-Endpoint-Weight to specify the per-instance weights. If set, Load Balancing is weighted based on the per-instance weights reported in the last processed health check replies, as long as every instance either reported a valid weight or had UNAVAILABLE_WEIGHT. Otherwise, Load Balancing remains equal-weight. This option is only supported in Network Load Balancing."
14940          ],
14941          "enum": [
14942            "INVALID_LB_POLICY",
14943            "LEAST_REQUEST",
14944            "MAGLEV",
14945            "ORIGINAL_DESTINATION",
14946            "RANDOM",
14947            "RING_HASH",
14948            "ROUND_ROBIN",
14949            "WEIGHTED_MAGLEV"
14950          ]
14951        },
14952        "consistentHash": {
14953          "description": "Consistent Hash-based load balancing can be used to provide soft session affinity based on HTTP headers, cookies or other properties. This load balancing policy is applicable only for HTTP connections. The affinity to a particular destination host will be lost when one or more hosts are added/removed from the destination service. This field specifies parameters that control consistent hashing. This field is only applicable when localityLbPolicy is set to MAGLEV or RING_HASH. This field is applicable to either: - A regional backend service with the service_protocol set to HTTP, HTTPS, or HTTP2, and load_balancing_scheme set to INTERNAL_MANAGED. - A global backend service with the load_balancing_scheme set to INTERNAL_SELF_MANAGED. ",
14954          "$ref": "ConsistentHashLoadBalancerSettings"
14955        },
14956        "circuitBreakers": {
14957          "$ref": "CircuitBreakers"
14958        },
14959        "outlierDetection": {
14960          "description": "Settings controlling the ejection of unhealthy backend endpoints from the load balancing pool of each individual proxy instance that processes the traffic for the given backend service. If not set, this feature is considered disabled. Results of the outlier detection algorithm (ejection of endpoints from the load balancing pool and returning them back to the pool) are executed independently by each proxy instance of the load balancer. In most cases, more than one proxy instance handles the traffic received by a backend service. Thus, it is possible that an unhealthy endpoint is detected and ejected by only some of the proxies, and while this happens, other proxies may continue to send requests to the same unhealthy endpoint until they detect and eject the unhealthy endpoint. Applicable backend endpoints can be: - VM instances in an Instance Group - Endpoints in a Zonal NEG (GCE_VM_IP, GCE_VM_IP_PORT) - Endpoints in a Hybrid Connectivity NEG (NON_GCP_PRIVATE_IP_PORT) - Serverless NEGs, that resolve to Cloud Run, App Engine, or Cloud Functions Services - Private Service Connect NEGs, that resolve to Google-managed regional API endpoints or managed services published using Private Service Connect Applicable backend service types can be: - A global backend service with the loadBalancingScheme set to INTERNAL_SELF_MANAGED or EXTERNAL_MANAGED. - A regional backend service with the serviceProtocol set to HTTP, HTTPS, or HTTP2, and loadBalancingScheme set to INTERNAL_MANAGED or EXTERNAL_MANAGED. Not supported for Serverless NEGs. Not supported when the backend service is referenced by a URL map that is bound to target gRPC proxy that has validateForProxyless field set to true.",
14961          "$ref": "OutlierDetection"
14962        },
14963        "network": {
14964          "description": "The URL of the network to which this backend service belongs. This field can only be specified when the load balancing scheme is set to INTERNAL.",
14965          "type": "string"
14966        },
14967        "subsetting": {
14968          "$ref": "Subsetting"
14969        },
14970        "connectionTrackingPolicy": {
14971          "description": "Connection Tracking configuration for this BackendService. Connection tracking policy settings are only available for external passthrough Network Load Balancers and internal passthrough Network Load Balancers.",
14972          "$ref": "BackendServiceConnectionTrackingPolicy"
14973        },
14974        "maxStreamDuration": {
14975          "description": "Specifies the default maximum duration (timeout) for streams to this service. Duration is computed from the beginning of the stream until the response has been completely processed, including all retries. A stream that does not complete in this duration is closed. If not specified, there will be no timeout limit, i.e. the maximum duration is infinite. This value can be overridden in the PathMatcher configuration of the UrlMap that references this backend service. This field is only allowed when the loadBalancingScheme of the backend service is INTERNAL_SELF_MANAGED.",
14976          "$ref": "Duration"
14977        },
14978        "compressionMode": {
14979          "description": "Compress text responses using Brotli or gzip compression, based on the client's Accept-Encoding header.",
14980          "type": "string",
14981          "enumDescriptions": [
14982            "Automatically uses the best compression based on the Accept-Encoding header sent by the client.",
14983            "Disables compression. Existing compressed responses cached by Cloud CDN will not be served to clients."
14984          ],
14985          "enum": [
14986            "AUTOMATIC",
14987            "DISABLED"
14988          ]
14989        },
14990        "serviceLbPolicy": {
14991          "description": "URL to networkservices.ServiceLbPolicy resource. Can only be set if load balancing scheme is EXTERNAL, EXTERNAL_MANAGED, INTERNAL_MANAGED or INTERNAL_SELF_MANAGED and the scope is global.",
14992          "type": "string"
14993        },
14994        "serviceBindings": {
14995          "description": "URLs of networkservices.ServiceBinding resources. Can only be set if load balancing scheme is INTERNAL_SELF_MANAGED. If set, lists of backends and health checks must be both empty.",
14996          "type": "array",
14997          "items": {
14998            "type": "string"
14999          }
15000        },
15001        "localityLbPolicies": {
15002          "description": "A list of locality load-balancing policies to be used in order of preference. When you use localityLbPolicies, you must set at least one value for either the localityLbPolicies[].policy or the localityLbPolicies[].customPolicy field. localityLbPolicies overrides any value set in the localityLbPolicy field. For an example of how to use this field, see Define a list of preferred policies. Caution: This field and its children are intended for use in a service mesh that includes gRPC clients only. Envoy proxies can't use backend services that have this configuration.",
15003          "type": "array",
15004          "items": {
15005            "$ref": "BackendServiceLocalityLoadBalancingPolicyConfig"
15006          }
15007        },
15008        "metadatas": {
15009          "description": "Deployment metadata associated with the resource to be set by a GKE hub controller and read by the backend RCTH",
15010          "type": "object",
15011          "additionalProperties": {
15012            "type": "string"
15013          }
15014        },
15015        "usedBy": {
15016          "type": "array",
15017          "items": {
15018            "$ref": "BackendServiceUsedBy"
15019          }
15020        }
15021      }
15022    },
15023    "Backend": {
15024      "id": "Backend",
15025      "description": "Message containing information of one individual backend.",
15026      "type": "object",
15027      "properties": {
15028        "description": {
15029          "description": "An optional description of this resource. Provide this property when you create the resource.",
15030          "type": "string"
15031        },
15032        "group": {
15033          "description": "The fully-qualified URL of an instance group or network endpoint group (NEG) resource. To determine what types of backends a load balancer supports, see the [Backend services overview](https://cloud.google.com/load-balancing/docs/backend-service#backends). You must use the *fully-qualified* URL (starting with https://www.googleapis.com/) to specify the instance group or NEG. Partial URLs are not supported.",
15034          "type": "string"
15035        },
15036        "balancingMode": {
15037          "description": "Specifies how to determine whether the backend of a load balancer can handle additional traffic or is fully loaded. For usage guidelines, see Connection balancing mode. Backends must use compatible balancing modes. For more information, see Supported balancing modes and target capacity settings and Restrictions and guidance for instance groups. Note: Currently, if you use the API to configure incompatible balancing modes, the configuration might be accepted even though it has no impact and is ignored. Specifically, Backend.maxUtilization is ignored when Backend.balancingMode is RATE. In the future, this incompatible combination will be rejected.",
15038          "type": "string",
15039          "enumDescriptions": [
15040            "Balance based on the number of simultaneous connections.",
15041            "Balance based on requests per second (RPS).",
15042            "Balance based on the backend utilization."
15043          ],
15044          "enum": [
15045            "CONNECTION",
15046            "RATE",
15047            "UTILIZATION"
15048          ]
15049        },
15050        "maxUtilization": {
15051          "description": "Optional parameter to define a target capacity for the UTILIZATION balancing mode. The valid range is [0.0, 1.0]. For usage guidelines, see Utilization balancing mode.",
15052          "type": "number",
15053          "format": "float"
15054        },
15055        "maxRate": {
15056          "description": "Defines a maximum number of HTTP requests per second (RPS). For usage guidelines, see Rate balancing mode and Utilization balancing mode. Not available if the backend's balancingMode is CONNECTION.",
15057          "type": "integer",
15058          "format": "int32"
15059        },
15060        "maxRatePerInstance": {
15061          "description": "Defines a maximum target for requests per second (RPS). For usage guidelines, see Rate balancing mode and Utilization balancing mode. Not available if the backend's balancingMode is CONNECTION.",
15062          "type": "number",
15063          "format": "float"
15064        },
15065        "maxRatePerEndpoint": {
15066          "description": "Defines a maximum target for requests per second (RPS). For usage guidelines, see Rate balancing mode and Utilization balancing mode. Not available if the backend's balancingMode is CONNECTION.",
15067          "type": "number",
15068          "format": "float"
15069        },
15070        "maxConnections": {
15071          "description": "Defines a target maximum number of simultaneous connections. For usage guidelines, see Connection balancing mode and Utilization balancing mode. Not available if the backend's balancingMode is RATE.",
15072          "type": "integer",
15073          "format": "int32"
15074        },
15075        "maxConnectionsPerInstance": {
15076          "description": "Defines a target maximum number of simultaneous connections. For usage guidelines, see Connection balancing mode and Utilization balancing mode. Not available if the backend's balancingMode is RATE.",
15077          "type": "integer",
15078          "format": "int32"
15079        },
15080        "maxConnectionsPerEndpoint": {
15081          "description": "Defines a target maximum number of simultaneous connections. For usage guidelines, see Connection balancing mode and Utilization balancing mode. Not available if the backend's balancingMode is RATE.",
15082          "type": "integer",
15083          "format": "int32"
15084        },
15085        "capacityScaler": {
15086          "description": "A multiplier applied to the backend's target capacity of its balancing mode. The default value is 1, which means the group serves up to 100% of its configured capacity (depending on balancingMode). A setting of 0 means the group is completely drained, offering 0% of its available capacity. The valid ranges are 0.0 and [0.1,1.0]. You cannot configure a setting larger than 0 and smaller than 0.1. You cannot configure a setting of 0 when there is only one backend attached to the backend service. Not available with backends that don't support using a balancingMode. This includes backends such as global internet NEGs, regional serverless NEGs, and PSC NEGs.",
15087          "type": "number",
15088          "format": "float"
15089        },
15090        "failover": {
15091          "description": "This field designates whether this is a failover backend. More than one failover backend can be configured for a given BackendService.",
15092          "type": "boolean"
15093        },
15094        "preference": {
15095          "description": "This field indicates whether this backend should be fully utilized before sending traffic to backends with default preference. The possible values are: - PREFERRED: Backends with this preference level will be filled up to their capacity limits first, based on RTT. - DEFAULT: If preferred backends don't have enough capacity, backends in this layer would be used and traffic would be assigned based on the load balancing algorithm you use. This is the default ",
15096          "type": "string",
15097          "enumDescriptions": [
15098            "No preference.",
15099            "If preference is unspecified, we set it to the DEFAULT value",
15100            "Traffic will be sent to this backend first."
15101          ],
15102          "enum": [
15103            "DEFAULT",
15104            "PREFERENCE_UNSPECIFIED",
15105            "PREFERRED"
15106          ]
15107        }
15108      }
15109    },
15110    "BackendServiceFailoverPolicy": {
15111      "id": "BackendServiceFailoverPolicy",
15112      "description": "For load balancers that have configurable failover: [Internal passthrough Network Load Balancers](https://cloud.google.com/load-balancing/docs/internal/failover-overview) and [external passthrough Network Load Balancers](https://cloud.google.com/load-balancing/docs/network/networklb-failover-overview). On failover or failback, this field indicates whether connection draining will be honored. Google Cloud has a fixed connection draining timeout of 10 minutes. A setting of true terminates existing TCP connections to the active pool during failover and failback, immediately draining traffic. A setting of false allows existing TCP connections to persist, even on VMs no longer in the active pool, for up to the duration of the connection draining timeout (10 minutes).",
15113      "type": "object",
15114      "properties": {
15115        "disableConnectionDrainOnFailover": {
15116          "description": "This can be set to true only if the protocol is TCP. The default is false.",
15117          "type": "boolean"
15118        },
15119        "dropTrafficIfUnhealthy": {
15120          "description": "If set to true, connections to the load balancer are dropped when all primary and all backup backend VMs are unhealthy.If set to false, connections are distributed among all primary VMs when all primary and all backup backend VMs are unhealthy. For load balancers that have configurable failover: [Internal passthrough Network Load Balancers](https://cloud.google.com/load-balancing/docs/internal/failover-overview) and [external passthrough Network Load Balancers](https://cloud.google.com/load-balancing/docs/network/networklb-failover-overview). The default is false.",
15121          "type": "boolean"
15122        },
15123        "failoverRatio": {
15124          "description": "The value of the field must be in the range [0, 1]. If the value is 0, the load balancer performs a failover when the number of healthy primary VMs equals zero. For all other values, the load balancer performs a failover when the total number of healthy primary VMs is less than this ratio. For load balancers that have configurable failover: [Internal TCP/UDP Load Balancing](https://cloud.google.com/load-balancing/docs/internal/failover-overview) and [external TCP/UDP Load Balancing](https://cloud.google.com/load-balancing/docs/network/networklb-failover-overview).",
15125          "type": "number",
15126          "format": "float"
15127        }
15128      }
15129    },
15130    "ConnectionDraining": {
15131      "id": "ConnectionDraining",
15132      "description": "Message containing connection draining configuration.",
15133      "type": "object",
15134      "properties": {
15135        "drainingTimeoutSec": {
15136          "description": "Configures a duration timeout for existing requests on a removed backend instance. For supported load balancers and protocols, as described in Enabling connection draining.",
15137          "type": "integer",
15138          "format": "int32"
15139        }
15140      }
15141    },
15142    "BackendServiceIAP": {
15143      "id": "BackendServiceIAP",
15144      "description": "Identity-Aware Proxy",
15145      "type": "object",
15146      "properties": {
15147        "enabled": {
15148          "description": "Whether the serving infrastructure will authenticate and authorize all incoming requests.",
15149          "type": "boolean"
15150        },
15151        "oauth2ClientId": {
15152          "description": "OAuth2 client ID to use for the authentication flow.",
15153          "type": "string"
15154        },
15155        "oauth2ClientSecret": {
15156          "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 oauth2ClientSecretSha256 field. @InputOnly",
15157          "type": "string"
15158        },
15159        "oauth2ClientSecretSha256": {
15160          "description": "[Output Only] SHA256 hash value for the field oauth2_client_secret above.",
15161          "type": "string"
15162        }
15163      }
15164    },
15165    "BackendServiceCdnPolicy": {
15166      "id": "BackendServiceCdnPolicy",
15167      "description": "Message containing Cloud CDN configuration for a backend service.",
15168      "type": "object",
15169      "properties": {
15170        "cacheKeyPolicy": {
15171          "description": "The CacheKeyPolicy for this CdnPolicy.",
15172          "$ref": "CacheKeyPolicy"
15173        },
15174        "signedUrlKeyNames": {
15175          "description": "[Output Only] Names of the keys for signing request URLs.",
15176          "type": "array",
15177          "items": {
15178            "type": "string"
15179          }
15180        },
15181        "signedUrlCacheMaxAgeSec": {
15182          "description": "Maximum number of seconds the response to a signed URL request will be considered fresh. After this time period, the response will be revalidated before being served. Defaults to 1hr (3600s). When serving responses to signed URL requests, Cloud CDN will internally behave as though all responses from this backend had a \"Cache-Control: public, max-age=[TTL]\" header, regardless of any existing Cache-Control header. The actual headers served in responses will not be altered.",
15183          "type": "string",
15184          "format": "int64"
15185        },
15186        "requestCoalescing": {
15187          "description": "If true then Cloud CDN will combine multiple concurrent cache fill requests into a small number of requests to the origin.",
15188          "type": "boolean"
15189        },
15190        "cacheMode": {
15191          "description": "Specifies the cache setting for all responses from this backend. The possible values are: USE_ORIGIN_HEADERS Requires the origin to set valid caching headers to cache content. Responses without these headers will not be cached at Google's edge, and will require a full trip to the origin on every request, potentially impacting performance and increasing load on the origin server. FORCE_CACHE_ALL Cache all content, ignoring any \"private\", \"no-store\" or \"no-cache\" directives in Cache-Control response headers. Warning: this may result in Cloud CDN caching private, per-user (user identifiable) content. CACHE_ALL_STATIC Automatically cache static content, including common image formats, media (video and audio), and web assets (JavaScript and CSS). Requests and responses that are marked as uncacheable, as well as dynamic content (including HTML), will not be cached.",
15192          "type": "string",
15193          "enumDescriptions": [
15194            "Automatically cache static content, including common image formats, media (video and audio), and web assets (JavaScript and CSS). Requests and responses that are marked as uncacheable, as well as dynamic content (including HTML), will not be cached.",
15195            "Cache all content, ignoring any \"private\", \"no-store\" or \"no-cache\" directives in Cache-Control response headers. Warning: this may result in Cloud CDN caching private, per-user (user identifiable) content.",
15196            "",
15197            "Requires the origin to set valid caching headers to cache content. Responses without these headers will not be cached at Google's edge, and will require a full trip to the origin on every request, potentially impacting performance and increasing load on the origin server."
15198          ],
15199          "enum": [
15200            "CACHE_ALL_STATIC",
15201            "FORCE_CACHE_ALL",
15202            "INVALID_CACHE_MODE",
15203            "USE_ORIGIN_HEADERS"
15204          ]
15205        },
15206        "defaultTtl": {
15207          "description": "Specifies the default TTL for cached content served by this origin for responses that do not have an existing valid TTL (max-age or s-max-age). Setting a TTL of \"0\" means \"always revalidate\". The value of defaultTTL cannot be set to a value greater than that of maxTTL, but can be equal. When the cacheMode is set to FORCE_CACHE_ALL, the defaultTTL will overwrite the TTL set in all responses. The maximum allowed value is 31,622,400s (1 year), noting that infrequently accessed objects may be evicted from the cache before the defined TTL.",
15208          "type": "integer",
15209          "format": "int32"
15210        },
15211        "maxTtl": {
15212          "description": "Specifies the maximum allowed TTL for cached content served by this origin. Cache directives that attempt to set a max-age or s-maxage higher than this, or an Expires header more than maxTTL seconds in the future will be capped at the value of maxTTL, as if it were the value of an s-maxage Cache-Control directive. Headers sent to the client will not be modified. Setting a TTL of \"0\" means \"always revalidate\". The maximum allowed value is 31,622,400s (1 year), noting that infrequently accessed objects may be evicted from the cache before the defined TTL.",
15213          "type": "integer",
15214          "format": "int32"
15215        },
15216        "clientTtl": {
15217          "description": "Specifies a separate client (e.g. browser client) maximum TTL. This is used to clamp the max-age (or Expires) value sent to the client. With FORCE_CACHE_ALL, the lesser of client_ttl and default_ttl is used for the response max-age directive, along with a \"public\" directive. For cacheable content in CACHE_ALL_STATIC mode, client_ttl clamps the max-age from the origin (if specified), or else sets the response max-age directive to the lesser of the client_ttl and default_ttl, and also ensures a \"public\" cache-control directive is present. If a client TTL is not specified, a default value (1 hour) will be used. The maximum allowed value is 31,622,400s (1 year).",
15218          "type": "integer",
15219          "format": "int32"
15220        },
15221        "negativeCaching": {
15222          "description": "Negative caching allows per-status code TTLs to be set, in order to apply fine-grained caching for common errors or redirects. This can reduce the load on your origin and improve end-user experience by reducing response latency. When the cache mode is set to CACHE_ALL_STATIC or USE_ORIGIN_HEADERS, negative caching applies to responses with the specified response code that lack any Cache-Control, Expires, or Pragma: no-cache directives. When the cache mode is set to FORCE_CACHE_ALL, negative caching applies to all responses with the specified response code, and override any caching headers. By default, Cloud CDN will apply the following default TTLs to these status codes: HTTP 300 (Multiple Choice), 301, 308 (Permanent Redirects): 10m HTTP 404 (Not Found), 410 (Gone), 451 (Unavailable For Legal Reasons): 120s HTTP 405 (Method Not Found), 421 (Misdirected Request), 501 (Not Implemented): 60s. These defaults can be overridden in negative_caching_policy.",
15223          "type": "boolean"
15224        },
15225        "negativeCachingPolicy": {
15226          "description": "Sets a cache TTL for the specified HTTP status code. negative_caching must be enabled to configure negative_caching_policy. Omitting the policy and leaving negative_caching enabled will use Cloud CDN's default cache TTLs. Note that when specifying an explicit negative_caching_policy, you should take care to specify a cache TTL for all response codes that you wish to cache. Cloud CDN will not apply any default negative caching when a policy exists.",
15227          "type": "array",
15228          "items": {
15229            "$ref": "BackendServiceCdnPolicyNegativeCachingPolicy"
15230          }
15231        },
15232        "bypassCacheOnRequestHeaders": {
15233          "description": "Bypass the cache when the specified request headers are matched - e.g. Pragma or Authorization headers. Up to 5 headers can be specified. The cache is bypassed for all cdnPolicy.cacheMode settings.",
15234          "type": "array",
15235          "items": {
15236            "$ref": "BackendServiceCdnPolicyBypassCacheOnRequestHeader"
15237          }
15238        },
15239        "serveWhileStale": {
15240          "description": "Serve existing content from the cache (if available) when revalidating content with the origin, or when an error is encountered when refreshing the cache. This setting defines the default \"max-stale\" duration for any cached responses that do not specify a max-stale directive. Stale responses that exceed the TTL configured here will not be served. The default limit (max-stale) is 86400s (1 day), which will allow stale content to be served up to this limit beyond the max-age (or s-max-age) of a cached response. The maximum allowed value is 604800 (1 week). Set this to zero (0) to disable serve-while-stale.",
15241          "type": "integer",
15242          "format": "int32"
15243        }
15244      }
15245    },
15246    "CacheKeyPolicy": {
15247      "id": "CacheKeyPolicy",
15248      "description": "Message containing what to include in the cache key for a request for Cloud CDN.",
15249      "type": "object",
15250      "properties": {
15251        "includeProtocol": {
15252          "description": "If true, http and https requests will be cached separately.",
15253          "type": "boolean"
15254        },
15255        "includeHost": {
15256          "description": "If true, requests to different hosts will be cached separately.",
15257          "type": "boolean"
15258        },
15259        "includeQueryString": {
15260          "description": "If true, include query string parameters in the cache key according to query_string_whitelist and query_string_blacklist. If neither is set, the entire query string will be included. If false, the query string will be excluded from the cache key entirely.",
15261          "type": "boolean"
15262        },
15263        "queryStringWhitelist": {
15264          "description": "Names of query string parameters to include in cache keys. All other parameters will be excluded. Either specify query_string_whitelist or query_string_blacklist, not both. '&' and '=' will be percent encoded and not treated as delimiters.",
15265          "type": "array",
15266          "items": {
15267            "type": "string"
15268          }
15269        },
15270        "queryStringBlacklist": {
15271          "description": "Names of query string parameters to exclude in cache keys. All other parameters will be included. Either specify query_string_whitelist or query_string_blacklist, not both. '&' and '=' will be percent encoded and not treated as delimiters.",
15272          "type": "array",
15273          "items": {
15274            "type": "string"
15275          }
15276        },
15277        "includeHttpHeaders": {
15278          "description": "Allows HTTP request headers (by name) to be used in the cache key.",
15279          "type": "array",
15280          "items": {
15281            "type": "string"
15282          }
15283        },
15284        "includeNamedCookies": {
15285          "description": "Allows HTTP cookies (by name) to be used in the cache key. The name=value pair will be used in the cache key Cloud CDN generates.",
15286          "type": "array",
15287          "items": {
15288            "type": "string"
15289          }
15290        }
15291      }
15292    },
15293    "BackendServiceCdnPolicyNegativeCachingPolicy": {
15294      "id": "BackendServiceCdnPolicyNegativeCachingPolicy",
15295      "description": "Specify CDN TTLs for response error codes.",
15296      "type": "object",
15297      "properties": {
15298        "code": {
15299          "description": "The HTTP status code to define a TTL against. Only HTTP status codes 300, 301, 302, 307, 308, 404, 405, 410, 421, 451 and 501 are can be specified as values, and you cannot specify a status code more than once.",
15300          "type": "integer",
15301          "format": "int32"
15302        },
15303        "ttl": {
15304          "description": "The TTL (in seconds) for which to cache responses with the corresponding status code. The maximum allowed value is 1800s (30 minutes), noting that infrequently accessed objects may be evicted from the cache before the defined TTL.",
15305          "type": "integer",
15306          "format": "int32"
15307        }
15308      }
15309    },
15310    "BackendServiceCdnPolicyBypassCacheOnRequestHeader": {
15311      "id": "BackendServiceCdnPolicyBypassCacheOnRequestHeader",
15312      "description": "Bypass the cache when the specified request headers are present, e.g. Pragma or Authorization headers. Values are case insensitive. The presence of such a header overrides the cache_mode setting.",
15313      "type": "object",
15314      "properties": {
15315        "headerName": {
15316          "description": "The header field name to match on when bypassing cache. Values are case-insensitive.",
15317          "type": "string"
15318        }
15319      }
15320    },
15321    "BackendServiceLogConfig": {
15322      "id": "BackendServiceLogConfig",
15323      "description": "The available logging options for the load balancer traffic served by this backend service.",
15324      "type": "object",
15325      "properties": {
15326        "enable": {
15327          "description": "Denotes whether to enable logging for the load balancer traffic served by this backend service. The default value is false.",
15328          "type": "boolean"
15329        },
15330        "sampleRate": {
15331          "description": "This field can only be specified if logging is enabled for this backend service. The value of the field must be in [0, 1]. This configures the sampling rate of requests to the load balancer where 1.0 means all logged requests are reported and 0.0 means no logged requests are reported. The default value is 1.0.",
15332          "type": "number",
15333          "format": "float"
15334        },
15335        "optionalMode": {
15336          "description": "This field can only be specified if logging is enabled for this backend service. Configures whether all, none or a subset of optional fields should be added to the reported logs. One of [INCLUDE_ALL_OPTIONAL, EXCLUDE_ALL_OPTIONAL, CUSTOM]. Default is EXCLUDE_ALL_OPTIONAL.",
15337          "type": "string",
15338          "enumDescriptions": [
15339            "A subset of optional fields.",
15340            "None optional fields.",
15341            "All optional fields."
15342          ],
15343          "enum": [
15344            "CUSTOM",
15345            "EXCLUDE_ALL_OPTIONAL",
15346            "INCLUDE_ALL_OPTIONAL"
15347          ]
15348        },
15349        "optionalFields": {
15350          "description": "This field can only be specified if logging is enabled for this backend service and \"logConfig.optionalMode\" was set to CUSTOM. Contains a list of optional fields you want to include in the logs. For example: serverInstance, serverGkeDetails.cluster, serverGkeDetails.pod.podNamespace",
15351          "type": "array",
15352          "items": {
15353            "type": "string"
15354          }
15355        }
15356      }
15357    },
15358    "SecuritySettings": {
15359      "id": "SecuritySettings",
15360      "description": "The authentication and authorization settings for a BackendService.",
15361      "type": "object",
15362      "properties": {
15363        "clientTlsPolicy": {
15364          "description": "Optional. A URL referring to a networksecurity.ClientTlsPolicy resource that describes how clients should authenticate with this service's backends. clientTlsPolicy only applies to a global BackendService with the loadBalancingScheme set to INTERNAL_SELF_MANAGED. If left blank, communications are not encrypted.",
15365          "type": "string"
15366        },
15367        "subjectAltNames": {
15368          "description": "Optional. A list of Subject Alternative Names (SANs) that the client verifies during a mutual TLS handshake with an server/endpoint for this BackendService. When the server presents its X.509 certificate to the client, the client inspects the certificate's subjectAltName field. If the field contains one of the specified values, the communication continues. Otherwise, it fails. This additional check enables the client to verify that the server is authorized to run the requested service. Note that the contents of the server certificate's subjectAltName field are configured by the Public Key Infrastructure which provisions server identities. Only applies to a global BackendService with loadBalancingScheme set to INTERNAL_SELF_MANAGED. Only applies when BackendService has an attached clientTlsPolicy with clientCertificate (mTLS mode).",
15369          "type": "array",
15370          "items": {
15371            "type": "string"
15372          }
15373        },
15374        "awsV4Authentication": {
15375          "description": "The configuration needed to generate a signature for access to private storage buckets that support AWS's Signature Version 4 for authentication. Allowed only for INTERNET_IP_PORT and INTERNET_FQDN_PORT NEG backends.",
15376          "$ref": "AWSV4Signature"
15377        }
15378      }
15379    },
15380    "AWSV4Signature": {
15381      "id": "AWSV4Signature",
15382      "description": "Contains the configurations necessary to generate a signature for access to private storage buckets that support Signature Version 4 for authentication. The service name for generating the authentication header will always default to 's3'.",
15383      "type": "object",
15384      "properties": {
15385        "accessKeyId": {
15386          "description": "The identifier of an access key used for s3 bucket authentication.",
15387          "type": "string"
15388        },
15389        "accessKey": {
15390          "description": "The access key used for s3 bucket authentication. Required for updating or creating a backend that uses AWS v4 signature authentication, but will not be returned as part of the configuration when queried with a REST API GET request. @InputOnly",
15391          "type": "string"
15392        },
15393        "accessKeyVersion": {
15394          "description": "The optional version identifier for the access key. You can use this to keep track of different iterations of your access key.",
15395          "type": "string"
15396        },
15397        "originRegion": {
15398          "description": "The name of the cloud region of your origin. This is a free-form field with the name of the region your cloud uses to host your origin. For example, \"us-east-1\" for AWS or \"us-ashburn-1\" for OCI.",
15399          "type": "string"
15400        }
15401      }
15402    },
15403    "ConsistentHashLoadBalancerSettings": {
15404      "id": "ConsistentHashLoadBalancerSettings",
15405      "description": "This message defines settings for a consistent hash style load balancer.",
15406      "type": "object",
15407      "properties": {
15408        "httpCookie": {
15409          "description": "Hash is based on HTTP Cookie. This field describes a HTTP cookie that will be used as the hash key for the consistent hash load balancer. If the cookie is not present, it will be generated. This field is applicable if the sessionAffinity is set to HTTP_COOKIE. Not supported when the backend service is referenced by a URL map that is bound to target gRPC proxy that has validateForProxyless field set to true.",
15410          "$ref": "ConsistentHashLoadBalancerSettingsHttpCookie"
15411        },
15412        "httpHeaderName": {
15413          "description": "The hash based on the value of the specified header field. This field is applicable if the sessionAffinity is set to HEADER_FIELD.",
15414          "type": "string"
15415        },
15416        "minimumRingSize": {
15417          "description": "The minimum number of virtual nodes to use for the hash ring. Defaults to 1024. Larger ring sizes result in more granular load distributions. If the number of hosts in the load balancing pool is larger than the ring size, each host will be assigned a single virtual node.",
15418          "type": "string",
15419          "format": "int64"
15420        }
15421      }
15422    },
15423    "ConsistentHashLoadBalancerSettingsHttpCookie": {
15424      "id": "ConsistentHashLoadBalancerSettingsHttpCookie",
15425      "description": "The information about the HTTP Cookie on which the hash function is based for load balancing policies that use a consistent hash.",
15426      "type": "object",
15427      "properties": {
15428        "name": {
15429          "description": "Name of the cookie.",
15430          "type": "string"
15431        },
15432        "path": {
15433          "description": "Path to set for the cookie.",
15434          "type": "string"
15435        },
15436        "ttl": {
15437          "description": "Lifetime of the cookie.",
15438          "$ref": "Duration"
15439        }
15440      }
15441    },
15442    "CircuitBreakers": {
15443      "id": "CircuitBreakers",
15444      "description": "Settings controlling the volume of requests, connections and retries to this backend service.",
15445      "type": "object",
15446      "properties": {
15447        "maxRequestsPerConnection": {
15448          "description": "Maximum requests for a single connection to the backend service. This parameter is respected by both the HTTP/1.1 and HTTP/2 implementations. If not specified, there is no limit. Setting this parameter to 1 will effectively disable keep alive. Not supported when the backend service is referenced by a URL map that is bound to target gRPC proxy that has validateForProxyless field set to true.",
15449          "type": "integer",
15450          "format": "int32"
15451        },
15452        "maxConnections": {
15453          "description": "The maximum number of connections to the backend service. If not specified, there is no limit. Not supported when the backend service is referenced by a URL map that is bound to target gRPC proxy that has validateForProxyless field set to true.",
15454          "type": "integer",
15455          "format": "int32"
15456        },
15457        "maxPendingRequests": {
15458          "description": "The maximum number of pending requests allowed to the backend service. If not specified, there is no limit. Not supported when the backend service is referenced by a URL map that is bound to target gRPC proxy that has validateForProxyless field set to true.",
15459          "type": "integer",
15460          "format": "int32"
15461        },
15462        "maxRequests": {
15463          "description": "The maximum number of parallel requests that allowed to the backend service. If not specified, there is no limit.",
15464          "type": "integer",
15465          "format": "int32"
15466        },
15467        "maxRetries": {
15468          "description": "The maximum number of parallel retries allowed to the backend cluster. If not specified, the default is 1. Not supported when the backend service is referenced by a URL map that is bound to target gRPC proxy that has validateForProxyless field set to true.",
15469          "type": "integer",
15470          "format": "int32"
15471        }
15472      }
15473    },
15474    "OutlierDetection": {
15475      "id": "OutlierDetection",
15476      "description": "Settings controlling the eviction of unhealthy hosts from the load balancing pool for the backend service.",
15477      "type": "object",
15478      "properties": {
15479        "consecutiveErrors": {
15480          "description": "Number of consecutive errors before a backend endpoint is ejected from the load balancing pool. When the backend endpoint is accessed over HTTP, a 5xx return code qualifies as an error. Defaults to 5.",
15481          "type": "integer",
15482          "format": "int32"
15483        },
15484        "interval": {
15485          "description": "Time interval between ejection analysis sweeps. This can result in both new ejections and backend endpoints being returned to service. The interval is equal to the number of seconds as defined in outlierDetection.interval.seconds plus the number of nanoseconds as defined in outlierDetection.interval.nanos. Defaults to 1 second.",
15486          "$ref": "Duration"
15487        },
15488        "baseEjectionTime": {
15489          "description": "The base time that a backend endpoint is ejected for. Defaults to 30000ms or 30s. After a backend endpoint is returned back to the load balancing pool, it can be ejected again in another ejection analysis. Thus, the total ejection time is equal to the base ejection time multiplied by the number of times the backend endpoint has been ejected. Defaults to 30000ms or 30s.",
15490          "$ref": "Duration"
15491        },
15492        "maxEjectionPercent": {
15493          "description": "Maximum percentage of backend endpoints in the load balancing pool for the backend service that can be ejected if the ejection conditions are met. Defaults to 50%.",
15494          "type": "integer",
15495          "format": "int32"
15496        },
15497        "enforcingConsecutiveErrors": {
15498          "description": "The percentage chance that a backend endpoint will be ejected when an outlier status is detected through consecutive 5xx. This setting can be used to disable ejection or to ramp it up slowly. Defaults to 0.",
15499          "type": "integer",
15500          "format": "int32"
15501        },
15502        "enforcingSuccessRate": {
15503          "description": "The percentage chance that a backend endpoint will be ejected when an outlier status is detected through success rate statistics. This setting can be used to disable ejection or to ramp it up slowly. Defaults to 100. Not supported when the backend service uses Serverless NEG.",
15504          "type": "integer",
15505          "format": "int32"
15506        },
15507        "successRateMinimumHosts": {
15508          "description": "The number of backend endpoints in the load balancing pool that must have enough request volume to detect success rate outliers. If the number of backend endpoints is fewer than this setting, outlier detection via success rate statistics is not performed for any backend endpoint in the load balancing pool. Defaults to 5. Not supported when the backend service uses Serverless NEG.",
15509          "type": "integer",
15510          "format": "int32"
15511        },
15512        "successRateRequestVolume": {
15513          "description": "The minimum number of total requests that must be collected in one interval (as defined by the interval duration above) to include this backend endpoint in success rate based outlier detection. If the volume is lower than this setting, outlier detection via success rate statistics is not performed for that backend endpoint. Defaults to 100. Not supported when the backend service uses Serverless NEG.",
15514          "type": "integer",
15515          "format": "int32"
15516        },
15517        "successRateStdevFactor": {
15518          "description": "This factor is used to determine the ejection threshold for success rate outlier ejection. The ejection threshold is the difference between the mean success rate, and the product of this factor and the standard deviation of the mean success rate: mean - (stdev * successRateStdevFactor). This factor is divided by a thousand to get a double. That is, if the desired factor is 1.9, the runtime value should be 1900. Defaults to 1900. Not supported when the backend service uses Serverless NEG.",
15519          "type": "integer",
15520          "format": "int32"
15521        },
15522        "consecutiveGatewayFailure": {
15523          "description": "The number of consecutive gateway failures (502, 503, 504 status or connection errors that are mapped to one of those status codes) before a consecutive gateway failure ejection occurs. Defaults to 3.",
15524          "type": "integer",
15525          "format": "int32"
15526        },
15527        "enforcingConsecutiveGatewayFailure": {
15528          "description": "The percentage chance that a backend endpoint will be ejected when an outlier status is detected through consecutive gateway failures. This setting can be used to disable ejection or to ramp it up slowly. Defaults to 100.",
15529          "type": "integer",
15530          "format": "int32"
15531        }
15532      }
15533    },
15534    "Subsetting": {
15535      "id": "Subsetting",
15536      "description": "Subsetting configuration for this BackendService. Currently this is applicable only for Internal TCP/UDP load balancing, Internal HTTP(S) load balancing and Traffic Director.",
15537      "type": "object",
15538      "properties": {
15539        "policy": {
15540          "type": "string",
15541          "enumDescriptions": [
15542            "Subsetting based on consistent hashing. For Traffic Director, the number of backends per backend group (the subset size) is based on the `subset_size` parameter. For Internal HTTP(S) load balancing, the number of backends per backend group (the subset size) is dynamically adjusted in two cases: - As the number of proxy instances participating in Internal HTTP(S) load balancing increases, the subset size decreases. - When the total number of backends in a network exceeds the capacity of a single proxy instance, subset sizes are reduced automatically for each service that has backend subsetting enabled.",
15543            "No Subsetting. Clients may open connections and send traffic to all backends of this backend service. This can lead to performance issues if there is substantial imbalance in the count of clients and backends."
15544          ],
15545          "enum": [
15546            "CONSISTENT_HASH_SUBSETTING",
15547            "NONE"
15548          ]
15549        }
15550      }
15551    },
15552    "BackendServiceConnectionTrackingPolicy": {
15553      "id": "BackendServiceConnectionTrackingPolicy",
15554      "description": "Connection Tracking configuration for this BackendService.",
15555      "type": "object",
15556      "properties": {
15557        "trackingMode": {
15558          "description": "Specifies the key used for connection tracking. There are two options: - PER_CONNECTION: This is the default mode. The Connection Tracking is performed as per the Connection Key (default Hash Method) for the specific protocol. - PER_SESSION: The Connection Tracking is performed as per the configured Session Affinity. It matches the configured Session Affinity. For more details, see [Tracking Mode for Network Load Balancing](https://cloud.google.com/load-balancing/docs/network/networklb-backend-service#tracking-mode) and [Tracking Mode for Internal TCP/UDP Load Balancing](https://cloud.google.com/load-balancing/docs/internal#tracking-mode).",
15559          "type": "string",
15560          "enumDescriptions": [
15561            "",
15562            "",
15563            ""
15564          ],
15565          "enum": [
15566            "INVALID_TRACKING_MODE",
15567            "PER_CONNECTION",
15568            "PER_SESSION"
15569          ]
15570        },
15571        "connectionPersistenceOnUnhealthyBackends": {
15572          "description": "Specifies connection persistence when backends are unhealthy. The default value is DEFAULT_FOR_PROTOCOL. If set to DEFAULT_FOR_PROTOCOL, the existing connections persist on unhealthy backends only for connection-oriented protocols (TCP and SCTP) and only if the Tracking Mode is PER_CONNECTION (default tracking mode) or the Session Affinity is configured for 5-tuple. They do not persist for UDP. If set to NEVER_PERSIST, after a backend becomes unhealthy, the existing connections on the unhealthy backend are never persisted on the unhealthy backend. They are always diverted to newly selected healthy backends (unless all backends are unhealthy). If set to ALWAYS_PERSIST, existing connections always persist on unhealthy backends regardless of protocol and session affinity. It is generally not recommended to use this mode overriding the default. For more details, see [Connection Persistence for Network Load Balancing](https://cloud.google.com/load-balancing/docs/network/networklb-backend-service#connection-persistence) and [Connection Persistence for Internal TCP/UDP Load Balancing](https://cloud.google.com/load-balancing/docs/internal#connection-persistence).",
15573          "type": "string",
15574          "enumDescriptions": [
15575            "",
15576            "",
15577            ""
15578          ],
15579          "enum": [
15580            "ALWAYS_PERSIST",
15581            "DEFAULT_FOR_PROTOCOL",
15582            "NEVER_PERSIST"
15583          ]
15584        },
15585        "idleTimeoutSec": {
15586          "description": "Specifies how long to keep a Connection Tracking entry while there is no matching traffic (in seconds). For internal passthrough Network Load Balancers: - The minimum (default) is 10 minutes and the maximum is 16 hours. - It can be set only if Connection Tracking is less than 5-tuple (i.e. Session Affinity is CLIENT_IP_NO_DESTINATION, CLIENT_IP or CLIENT_IP_PROTO, and Tracking Mode is PER_SESSION). For external passthrough Network Load Balancers the default is 60 seconds. This option is not available publicly.",
15587          "type": "integer",
15588          "format": "int32"
15589        },
15590        "enableStrongAffinity": {
15591          "description": "Enable Strong Session Affinity for external passthrough Network Load Balancers. This option is not available publicly.",
15592          "type": "boolean"
15593        }
15594      }
15595    },
15596    "BackendServiceLocalityLoadBalancingPolicyConfig": {
15597      "id": "BackendServiceLocalityLoadBalancingPolicyConfig",
15598      "description": "Container for either a built-in LB policy supported by gRPC or Envoy or a custom one implemented by the end user.",
15599      "type": "object",
15600      "properties": {
15601        "policy": {
15602          "$ref": "BackendServiceLocalityLoadBalancingPolicyConfigPolicy"
15603        },
15604        "customPolicy": {
15605          "$ref": "BackendServiceLocalityLoadBalancingPolicyConfigCustomPolicy"
15606        }
15607      }
15608    },
15609    "BackendServiceLocalityLoadBalancingPolicyConfigPolicy": {
15610      "id": "BackendServiceLocalityLoadBalancingPolicyConfigPolicy",
15611      "description": "The configuration for a built-in load balancing policy.",
15612      "type": "object",
15613      "properties": {
15614        "name": {
15615          "description": "The name of a locality load-balancing policy. Valid values include ROUND_ROBIN and, for Java clients, LEAST_REQUEST. For information about these values, see the description of localityLbPolicy. Do not specify the same policy more than once for a backend. If you do, the configuration is rejected.",
15616          "type": "string",
15617          "enumDescriptions": [
15618            "",
15619            "An O(1) algorithm which selects two random healthy hosts and picks the host which has fewer active requests.",
15620            "This algorithm implements consistent hashing to backends. Maglev can be used as a drop in replacement for the ring hash load balancer. Maglev is not as stable as ring hash but has faster table lookup build times and host selection times. For more information about Maglev, see https://ai.google/research/pubs/pub44824",
15621            "Backend host is selected based on the client connection metadata, i.e., connections are opened to the same address as the destination address of the incoming connection before the connection was redirected to the load balancer.",
15622            "The load balancer selects a random healthy host.",
15623            "The ring/modulo hash load balancer implements consistent hashing to backends. The algorithm has the property that the addition/removal of a host from a set of N hosts only affects 1/N of the requests.",
15624            "This is a simple policy in which each healthy backend is selected in round robin order. This is the default.",
15625            "Per-instance weighted Load Balancing via health check reported weights. If set, the Backend Service must configure a non legacy HTTP-based Health Check, and health check replies are expected to contain non-standard HTTP response header field X-Load-Balancing-Endpoint-Weight to specify the per-instance weights. If set, Load Balancing is weighted based on the per-instance weights reported in the last processed health check replies, as long as every instance either reported a valid weight or had UNAVAILABLE_WEIGHT. Otherwise, Load Balancing remains equal-weight. This option is only supported in Network Load Balancing."
15626          ],
15627          "enum": [
15628            "INVALID_LB_POLICY",
15629            "LEAST_REQUEST",
15630            "MAGLEV",
15631            "ORIGINAL_DESTINATION",
15632            "RANDOM",
15633            "RING_HASH",
15634            "ROUND_ROBIN",
15635            "WEIGHTED_MAGLEV"
15636          ]
15637        }
15638      }
15639    },
15640    "BackendServiceLocalityLoadBalancingPolicyConfigCustomPolicy": {
15641      "id": "BackendServiceLocalityLoadBalancingPolicyConfigCustomPolicy",
15642      "description": "The configuration for a custom policy implemented by the user and deployed with the client.",
15643      "type": "object",
15644      "properties": {
15645        "name": {
15646          "description": "Identifies the custom policy. The value should match the name of a custom implementation registered on the gRPC clients. It should follow protocol buffer message naming conventions and include the full path (for example, myorg.CustomLbPolicy). The maximum length is 256 characters. Do not specify the same custom policy more than once for a backend. If you do, the configuration is rejected. For an example of how to use this field, see Use a custom policy.",
15647          "type": "string"
15648        },
15649        "data": {
15650          "description": "An optional, arbitrary JSON object with configuration data, understood by a locally installed custom policy implementation.",
15651          "type": "string"
15652        }
15653      }
15654    },
15655    "BackendServiceUsedBy": {
15656      "id": "BackendServiceUsedBy",
15657      "type": "object",
15658      "properties": {
15659        "reference": {
15660          "type": "string"
15661        }
15662      }
15663    },
15664    "BackendServiceAggregatedList": {
15665      "id": "BackendServiceAggregatedList",
15666      "description": "Contains a list of BackendServicesScopedList.",
15667      "type": "object",
15668      "properties": {
15669        "kind": {
15670          "description": "Type of resource.",
15671          "default": "compute#backendServiceAggregatedList",
15672          "type": "string"
15673        },
15674        "id": {
15675          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
15676          "type": "string"
15677        },
15678        "items": {
15679          "description": "A list of BackendServicesScopedList resources.",
15680          "type": "object",
15681          "additionalProperties": {
15682            "description": "Name of the scope containing this set of BackendServices.",
15683            "$ref": "BackendServicesScopedList"
15684          }
15685        },
15686        "nextPageToken": {
15687          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
15688          "type": "string"
15689        },
15690        "selfLink": {
15691          "description": "[Output Only] Server-defined URL for this resource.",
15692          "type": "string"
15693        },
15694        "warning": {
15695          "description": "[Output Only] Informational warning message.",
15696          "type": "object",
15697          "properties": {
15698            "code": {
15699              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
15700              "type": "string",
15701              "enumDescriptions": [
15702                "Warning about failed cleanup of transient changes made by a failed operation.",
15703                "A link to a deprecated resource was created.",
15704                "When deploying and at least one of the resources has a type marked as deprecated",
15705                "The user created a boot disk that is larger than image size.",
15706                "When deploying and at least one of the resources has a type marked as experimental",
15707                "Warning that is present in an external api call",
15708                "Warning that value of a field has been overridden. Deprecated unused field.",
15709                "The operation involved use of an injected kernel, which is deprecated.",
15710                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
15711                "When deploying a deployment with a exceedingly large number of resources",
15712                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
15713                "A resource depends on a missing type",
15714                "The route's nextHopIp address is not assigned to an instance on the network.",
15715                "The route's next hop instance cannot ip forward.",
15716                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
15717                "The route's nextHopInstance URL refers to an instance that does not exist.",
15718                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
15719                "The route's next hop instance does not have a status of RUNNING.",
15720                "Error which is not critical. We decided to continue the process despite the mentioned error.",
15721                "No results are present on a particular list page.",
15722                "Success is reported, but some results may be missing due to errors",
15723                "The user attempted to use a resource that requires a TOS they have not accepted.",
15724                "Warning that a resource is in use.",
15725                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
15726                "When a resource schema validation is ignored.",
15727                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
15728                "When undeclared properties in the schema are present",
15729                "A given scope cannot be reached."
15730              ],
15731              "enumDeprecated": [
15732                false,
15733                false,
15734                false,
15735                false,
15736                false,
15737                false,
15738                true,
15739                false,
15740                false,
15741                false,
15742                false,
15743                false,
15744                false,
15745                false,
15746                false,
15747                false,
15748                false,
15749                false,
15750                false,
15751                false,
15752                false,
15753                false,
15754                false,
15755                false,
15756                false,
15757                false,
15758                false,
15759                false
15760              ],
15761              "enum": [
15762                "CLEANUP_FAILED",
15763                "DEPRECATED_RESOURCE_USED",
15764                "DEPRECATED_TYPE_USED",
15765                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
15766                "EXPERIMENTAL_TYPE_USED",
15767                "EXTERNAL_API_WARNING",
15768                "FIELD_VALUE_OVERRIDEN",
15769                "INJECTED_KERNELS_DEPRECATED",
15770                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
15771                "LARGE_DEPLOYMENT_WARNING",
15772                "LIST_OVERHEAD_QUOTA_EXCEED",
15773                "MISSING_TYPE_DEPENDENCY",
15774                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
15775                "NEXT_HOP_CANNOT_IP_FORWARD",
15776                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
15777                "NEXT_HOP_INSTANCE_NOT_FOUND",
15778                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
15779                "NEXT_HOP_NOT_RUNNING",
15780                "NOT_CRITICAL_ERROR",
15781                "NO_RESULTS_ON_PAGE",
15782                "PARTIAL_SUCCESS",
15783                "REQUIRED_TOS_AGREEMENT",
15784                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
15785                "RESOURCE_NOT_DELETED",
15786                "SCHEMA_VALIDATION_IGNORED",
15787                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
15788                "UNDECLARED_PROPERTIES",
15789                "UNREACHABLE"
15790              ]
15791            },
15792            "message": {
15793              "description": "[Output Only] A human-readable description of the warning code.",
15794              "type": "string"
15795            },
15796            "data": {
15797              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
15798              "type": "array",
15799              "items": {
15800                "type": "object",
15801                "properties": {
15802                  "key": {
15803                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
15804                    "type": "string"
15805                  },
15806                  "value": {
15807                    "description": "[Output Only] A warning data value corresponding to the key.",
15808                    "type": "string"
15809                  }
15810                }
15811              }
15812            }
15813          }
15814        },
15815        "unreachables": {
15816          "description": "[Output Only] Unreachable resources.",
15817          "type": "array",
15818          "items": {
15819            "type": "string"
15820          }
15821        }
15822      }
15823    },
15824    "BackendServicesScopedList": {
15825      "id": "BackendServicesScopedList",
15826      "type": "object",
15827      "properties": {
15828        "backendServices": {
15829          "description": "A list of BackendServices contained in this scope.",
15830          "type": "array",
15831          "items": {
15832            "$ref": "BackendService"
15833          }
15834        },
15835        "warning": {
15836          "description": "Informational warning which replaces the list of backend services when the list is empty.",
15837          "type": "object",
15838          "properties": {
15839            "code": {
15840              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
15841              "type": "string",
15842              "enumDescriptions": [
15843                "Warning about failed cleanup of transient changes made by a failed operation.",
15844                "A link to a deprecated resource was created.",
15845                "When deploying and at least one of the resources has a type marked as deprecated",
15846                "The user created a boot disk that is larger than image size.",
15847                "When deploying and at least one of the resources has a type marked as experimental",
15848                "Warning that is present in an external api call",
15849                "Warning that value of a field has been overridden. Deprecated unused field.",
15850                "The operation involved use of an injected kernel, which is deprecated.",
15851                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
15852                "When deploying a deployment with a exceedingly large number of resources",
15853                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
15854                "A resource depends on a missing type",
15855                "The route's nextHopIp address is not assigned to an instance on the network.",
15856                "The route's next hop instance cannot ip forward.",
15857                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
15858                "The route's nextHopInstance URL refers to an instance that does not exist.",
15859                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
15860                "The route's next hop instance does not have a status of RUNNING.",
15861                "Error which is not critical. We decided to continue the process despite the mentioned error.",
15862                "No results are present on a particular list page.",
15863                "Success is reported, but some results may be missing due to errors",
15864                "The user attempted to use a resource that requires a TOS they have not accepted.",
15865                "Warning that a resource is in use.",
15866                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
15867                "When a resource schema validation is ignored.",
15868                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
15869                "When undeclared properties in the schema are present",
15870                "A given scope cannot be reached."
15871              ],
15872              "enumDeprecated": [
15873                false,
15874                false,
15875                false,
15876                false,
15877                false,
15878                false,
15879                true,
15880                false,
15881                false,
15882                false,
15883                false,
15884                false,
15885                false,
15886                false,
15887                false,
15888                false,
15889                false,
15890                false,
15891                false,
15892                false,
15893                false,
15894                false,
15895                false,
15896                false,
15897                false,
15898                false,
15899                false,
15900                false
15901              ],
15902              "enum": [
15903                "CLEANUP_FAILED",
15904                "DEPRECATED_RESOURCE_USED",
15905                "DEPRECATED_TYPE_USED",
15906                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
15907                "EXPERIMENTAL_TYPE_USED",
15908                "EXTERNAL_API_WARNING",
15909                "FIELD_VALUE_OVERRIDEN",
15910                "INJECTED_KERNELS_DEPRECATED",
15911                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
15912                "LARGE_DEPLOYMENT_WARNING",
15913                "LIST_OVERHEAD_QUOTA_EXCEED",
15914                "MISSING_TYPE_DEPENDENCY",
15915                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
15916                "NEXT_HOP_CANNOT_IP_FORWARD",
15917                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
15918                "NEXT_HOP_INSTANCE_NOT_FOUND",
15919                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
15920                "NEXT_HOP_NOT_RUNNING",
15921                "NOT_CRITICAL_ERROR",
15922                "NO_RESULTS_ON_PAGE",
15923                "PARTIAL_SUCCESS",
15924                "REQUIRED_TOS_AGREEMENT",
15925                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
15926                "RESOURCE_NOT_DELETED",
15927                "SCHEMA_VALIDATION_IGNORED",
15928                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
15929                "UNDECLARED_PROPERTIES",
15930                "UNREACHABLE"
15931              ]
15932            },
15933            "message": {
15934              "description": "[Output Only] A human-readable description of the warning code.",
15935              "type": "string"
15936            },
15937            "data": {
15938              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
15939              "type": "array",
15940              "items": {
15941                "type": "object",
15942                "properties": {
15943                  "key": {
15944                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
15945                    "type": "string"
15946                  },
15947                  "value": {
15948                    "description": "[Output Only] A warning data value corresponding to the key.",
15949                    "type": "string"
15950                  }
15951                }
15952              }
15953            }
15954          }
15955        }
15956      }
15957    },
15958    "BackendServiceListUsable": {
15959      "id": "BackendServiceListUsable",
15960      "description": "Contains a list of usable BackendService resources.",
15961      "type": "object",
15962      "properties": {
15963        "kind": {
15964          "description": "[Output Only] Type of resource. Always compute#usableBackendServiceList for lists of usable backend services.",
15965          "default": "compute#usableBackendServiceList",
15966          "type": "string"
15967        },
15968        "id": {
15969          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
15970          "type": "string"
15971        },
15972        "items": {
15973          "description": "A list of BackendService resources.",
15974          "type": "array",
15975          "items": {
15976            "$ref": "BackendService"
15977          }
15978        },
15979        "nextPageToken": {
15980          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
15981          "type": "string"
15982        },
15983        "selfLink": {
15984          "description": "[Output Only] Server-defined URL for this resource.",
15985          "type": "string"
15986        },
15987        "warning": {
15988          "description": "[Output Only] Informational warning message.",
15989          "type": "object",
15990          "properties": {
15991            "code": {
15992              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
15993              "type": "string",
15994              "enumDescriptions": [
15995                "Warning about failed cleanup of transient changes made by a failed operation.",
15996                "A link to a deprecated resource was created.",
15997                "When deploying and at least one of the resources has a type marked as deprecated",
15998                "The user created a boot disk that is larger than image size.",
15999                "When deploying and at least one of the resources has a type marked as experimental",
16000                "Warning that is present in an external api call",
16001                "Warning that value of a field has been overridden. Deprecated unused field.",
16002                "The operation involved use of an injected kernel, which is deprecated.",
16003                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
16004                "When deploying a deployment with a exceedingly large number of resources",
16005                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
16006                "A resource depends on a missing type",
16007                "The route's nextHopIp address is not assigned to an instance on the network.",
16008                "The route's next hop instance cannot ip forward.",
16009                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
16010                "The route's nextHopInstance URL refers to an instance that does not exist.",
16011                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
16012                "The route's next hop instance does not have a status of RUNNING.",
16013                "Error which is not critical. We decided to continue the process despite the mentioned error.",
16014                "No results are present on a particular list page.",
16015                "Success is reported, but some results may be missing due to errors",
16016                "The user attempted to use a resource that requires a TOS they have not accepted.",
16017                "Warning that a resource is in use.",
16018                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
16019                "When a resource schema validation is ignored.",
16020                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
16021                "When undeclared properties in the schema are present",
16022                "A given scope cannot be reached."
16023              ],
16024              "enumDeprecated": [
16025                false,
16026                false,
16027                false,
16028                false,
16029                false,
16030                false,
16031                true,
16032                false,
16033                false,
16034                false,
16035                false,
16036                false,
16037                false,
16038                false,
16039                false,
16040                false,
16041                false,
16042                false,
16043                false,
16044                false,
16045                false,
16046                false,
16047                false,
16048                false,
16049                false,
16050                false,
16051                false,
16052                false
16053              ],
16054              "enum": [
16055                "CLEANUP_FAILED",
16056                "DEPRECATED_RESOURCE_USED",
16057                "DEPRECATED_TYPE_USED",
16058                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
16059                "EXPERIMENTAL_TYPE_USED",
16060                "EXTERNAL_API_WARNING",
16061                "FIELD_VALUE_OVERRIDEN",
16062                "INJECTED_KERNELS_DEPRECATED",
16063                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
16064                "LARGE_DEPLOYMENT_WARNING",
16065                "LIST_OVERHEAD_QUOTA_EXCEED",
16066                "MISSING_TYPE_DEPENDENCY",
16067                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
16068                "NEXT_HOP_CANNOT_IP_FORWARD",
16069                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
16070                "NEXT_HOP_INSTANCE_NOT_FOUND",
16071                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
16072                "NEXT_HOP_NOT_RUNNING",
16073                "NOT_CRITICAL_ERROR",
16074                "NO_RESULTS_ON_PAGE",
16075                "PARTIAL_SUCCESS",
16076                "REQUIRED_TOS_AGREEMENT",
16077                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
16078                "RESOURCE_NOT_DELETED",
16079                "SCHEMA_VALIDATION_IGNORED",
16080                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
16081                "UNDECLARED_PROPERTIES",
16082                "UNREACHABLE"
16083              ]
16084            },
16085            "message": {
16086              "description": "[Output Only] A human-readable description of the warning code.",
16087              "type": "string"
16088            },
16089            "data": {
16090              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
16091              "type": "array",
16092              "items": {
16093                "type": "object",
16094                "properties": {
16095                  "key": {
16096                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
16097                    "type": "string"
16098                  },
16099                  "value": {
16100                    "description": "[Output Only] A warning data value corresponding to the key.",
16101                    "type": "string"
16102                  }
16103                }
16104              }
16105            }
16106          }
16107        }
16108      }
16109    },
16110    "ResourceGroupReference": {
16111      "id": "ResourceGroupReference",
16112      "type": "object",
16113      "properties": {
16114        "group": {
16115          "description": "A URI referencing one of the instance groups or network endpoint groups listed in the backend service.",
16116          "type": "string"
16117        }
16118      }
16119    },
16120    "BackendServiceGroupHealth": {
16121      "id": "BackendServiceGroupHealth",
16122      "type": "object",
16123      "properties": {
16124        "kind": {
16125          "description": "[Output Only] Type of resource. Always compute#backendServiceGroupHealth for the health of backend services.",
16126          "default": "compute#backendServiceGroupHealth",
16127          "type": "string"
16128        },
16129        "healthStatus": {
16130          "description": "Health state of the backend instances or endpoints in requested instance or network endpoint group, determined based on configured health checks.",
16131          "type": "array",
16132          "items": {
16133            "$ref": "HealthStatus"
16134          }
16135        },
16136        "annotations": {
16137          "description": "Metadata defined as annotations on the network endpoint group.",
16138          "type": "object",
16139          "additionalProperties": {
16140            "type": "string"
16141          }
16142        }
16143      }
16144    },
16145    "HealthStatus": {
16146      "id": "HealthStatus",
16147      "type": "object",
16148      "properties": {
16149        "ipAddress": {
16150          "description": "For target pool based Network Load Balancing, it indicates the forwarding rule's IP address assigned to this instance. For other types of load balancing, the field indicates VM internal ip.",
16151          "type": "string"
16152        },
16153        "port": {
16154          "description": "The named port of the instance group, not necessarily the port that is health-checked.",
16155          "type": "integer",
16156          "format": "int32"
16157        },
16158        "instance": {
16159          "description": "URL of the instance resource.",
16160          "type": "string"
16161        },
16162        "healthState": {
16163          "description": "Health state of the IPv4 address of the instance.",
16164          "type": "string",
16165          "enumDescriptions": [
16166            "",
16167            ""
16168          ],
16169          "enum": [
16170            "HEALTHY",
16171            "UNHEALTHY"
16172          ]
16173        },
16174        "annotations": {
16175          "description": "Metadata defined as annotations for network endpoint.",
16176          "type": "object",
16177          "additionalProperties": {
16178            "type": "string"
16179          }
16180        },
16181        "weight": {
16182          "type": "string"
16183        },
16184        "weightError": {
16185          "type": "string",
16186          "enumDescriptions": [
16187            "The response to a Health Check probe had the HTTP response header field X-Load-Balancing-Endpoint-Weight, but its content was invalid (i.e., not a non-negative single-precision floating-point number in decimal string representation).",
16188            "The response to a Health Check probe did not have the HTTP response header field X-Load-Balancing-Endpoint-Weight.",
16189            "This is the value when the accompanied health status is either TIMEOUT (i.e.,the Health Check probe was not able to get a response in time) or UNKNOWN. For the latter, it should be typically because there has not been sufficient time to parse and report the weight for a new backend (which is with 0.0.0.0 ip address). However, it can be also due to an outage case for which the health status is explicitly reset to UNKNOWN.",
16190            "This is the default value when WeightReportMode is DISABLE, and is also the initial value when WeightReportMode has just updated to ENABLE or DRY_RUN and there has not been sufficient time to parse and report the backend weight."
16191          ],
16192          "enum": [
16193            "INVALID_WEIGHT",
16194            "MISSING_WEIGHT",
16195            "UNAVAILABLE_WEIGHT",
16196            "WEIGHT_NONE"
16197          ]
16198        },
16199        "forwardingRuleIp": {
16200          "description": "A forwarding rule IP address assigned to this instance.",
16201          "type": "string"
16202        },
16203        "forwardingRule": {
16204          "description": "URL of the forwarding rule associated with the health status of the instance.",
16205          "type": "string"
16206        }
16207      }
16208    },
16209    "CommitmentList": {
16210      "id": "CommitmentList",
16211      "description": "Contains a list of Commitment resources.",
16212      "type": "object",
16213      "properties": {
16214        "kind": {
16215          "description": "[Output Only] Type of resource. Always compute#commitmentList for lists of commitments.",
16216          "default": "compute#commitmentList",
16217          "type": "string"
16218        },
16219        "id": {
16220          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
16221          "type": "string"
16222        },
16223        "items": {
16224          "description": "A list of Commitment resources.",
16225          "type": "array",
16226          "items": {
16227            "$ref": "Commitment"
16228          }
16229        },
16230        "nextPageToken": {
16231          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
16232          "type": "string"
16233        },
16234        "selfLink": {
16235          "description": "[Output Only] Server-defined URL for this resource.",
16236          "type": "string"
16237        },
16238        "warning": {
16239          "description": "[Output Only] Informational warning message.",
16240          "type": "object",
16241          "properties": {
16242            "code": {
16243              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
16244              "type": "string",
16245              "enumDescriptions": [
16246                "Warning about failed cleanup of transient changes made by a failed operation.",
16247                "A link to a deprecated resource was created.",
16248                "When deploying and at least one of the resources has a type marked as deprecated",
16249                "The user created a boot disk that is larger than image size.",
16250                "When deploying and at least one of the resources has a type marked as experimental",
16251                "Warning that is present in an external api call",
16252                "Warning that value of a field has been overridden. Deprecated unused field.",
16253                "The operation involved use of an injected kernel, which is deprecated.",
16254                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
16255                "When deploying a deployment with a exceedingly large number of resources",
16256                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
16257                "A resource depends on a missing type",
16258                "The route's nextHopIp address is not assigned to an instance on the network.",
16259                "The route's next hop instance cannot ip forward.",
16260                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
16261                "The route's nextHopInstance URL refers to an instance that does not exist.",
16262                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
16263                "The route's next hop instance does not have a status of RUNNING.",
16264                "Error which is not critical. We decided to continue the process despite the mentioned error.",
16265                "No results are present on a particular list page.",
16266                "Success is reported, but some results may be missing due to errors",
16267                "The user attempted to use a resource that requires a TOS they have not accepted.",
16268                "Warning that a resource is in use.",
16269                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
16270                "When a resource schema validation is ignored.",
16271                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
16272                "When undeclared properties in the schema are present",
16273                "A given scope cannot be reached."
16274              ],
16275              "enumDeprecated": [
16276                false,
16277                false,
16278                false,
16279                false,
16280                false,
16281                false,
16282                true,
16283                false,
16284                false,
16285                false,
16286                false,
16287                false,
16288                false,
16289                false,
16290                false,
16291                false,
16292                false,
16293                false,
16294                false,
16295                false,
16296                false,
16297                false,
16298                false,
16299                false,
16300                false,
16301                false,
16302                false,
16303                false
16304              ],
16305              "enum": [
16306                "CLEANUP_FAILED",
16307                "DEPRECATED_RESOURCE_USED",
16308                "DEPRECATED_TYPE_USED",
16309                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
16310                "EXPERIMENTAL_TYPE_USED",
16311                "EXTERNAL_API_WARNING",
16312                "FIELD_VALUE_OVERRIDEN",
16313                "INJECTED_KERNELS_DEPRECATED",
16314                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
16315                "LARGE_DEPLOYMENT_WARNING",
16316                "LIST_OVERHEAD_QUOTA_EXCEED",
16317                "MISSING_TYPE_DEPENDENCY",
16318                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
16319                "NEXT_HOP_CANNOT_IP_FORWARD",
16320                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
16321                "NEXT_HOP_INSTANCE_NOT_FOUND",
16322                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
16323                "NEXT_HOP_NOT_RUNNING",
16324                "NOT_CRITICAL_ERROR",
16325                "NO_RESULTS_ON_PAGE",
16326                "PARTIAL_SUCCESS",
16327                "REQUIRED_TOS_AGREEMENT",
16328                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
16329                "RESOURCE_NOT_DELETED",
16330                "SCHEMA_VALIDATION_IGNORED",
16331                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
16332                "UNDECLARED_PROPERTIES",
16333                "UNREACHABLE"
16334              ]
16335            },
16336            "message": {
16337              "description": "[Output Only] A human-readable description of the warning code.",
16338              "type": "string"
16339            },
16340            "data": {
16341              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
16342              "type": "array",
16343              "items": {
16344                "type": "object",
16345                "properties": {
16346                  "key": {
16347                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
16348                    "type": "string"
16349                  },
16350                  "value": {
16351                    "description": "[Output Only] A warning data value corresponding to the key.",
16352                    "type": "string"
16353                  }
16354                }
16355              }
16356            }
16357          }
16358        }
16359      }
16360    },
16361    "Commitment": {
16362      "id": "Commitment",
16363      "description": "Represents a regional Commitment resource. Creating a commitment resource means that you are purchasing a committed use contract with an explicit start and end time. You can create commitments based on vCPUs and memory usage and receive discounted rates. For full details, read Signing Up for Committed Use Discounts.",
16364      "type": "object",
16365      "properties": {
16366        "kind": {
16367          "description": "[Output Only] Type of the resource. Always compute#commitment for commitments.",
16368          "default": "compute#commitment",
16369          "type": "string"
16370        },
16371        "id": {
16372          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
16373          "type": "string",
16374          "format": "uint64"
16375        },
16376        "creationTimestamp": {
16377          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
16378          "type": "string"
16379        },
16380        "name": {
16381          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
16382          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
16383          "type": "string"
16384        },
16385        "description": {
16386          "description": "An optional description of this resource. Provide this property when you create the resource.",
16387          "type": "string"
16388        },
16389        "region": {
16390          "description": "[Output Only] URL of the region where this commitment may be used.",
16391          "type": "string"
16392        },
16393        "selfLink": {
16394          "description": "[Output Only] Server-defined URL for the resource.",
16395          "type": "string"
16396        },
16397        "status": {
16398          "description": "[Output Only] Status of the commitment with regards to eventual expiration (each commitment has an end date defined). One of the following values: NOT_YET_ACTIVE, ACTIVE, EXPIRED.",
16399          "type": "string",
16400          "enumDescriptions": [
16401            "",
16402            "Deprecate CANCELED status. Will use separate status to differentiate cancel by mergeCud or manual cancellation.",
16403            "",
16404            "",
16405            ""
16406          ],
16407          "enum": [
16408            "ACTIVE",
16409            "CANCELLED",
16410            "CREATING",
16411            "EXPIRED",
16412            "NOT_YET_ACTIVE"
16413          ]
16414        },
16415        "statusMessage": {
16416          "description": "[Output Only] An optional, human-readable explanation of the status.",
16417          "type": "string"
16418        },
16419        "plan": {
16420          "description": "The plan for this commitment, which determines duration and discount rate. The currently supported plans are TWELVE_MONTH (1 year), and THIRTY_SIX_MONTH (3 years).",
16421          "type": "string",
16422          "enumDescriptions": [
16423            "",
16424            "",
16425            ""
16426          ],
16427          "enum": [
16428            "INVALID",
16429            "THIRTY_SIX_MONTH",
16430            "TWELVE_MONTH"
16431          ]
16432        },
16433        "startTimestamp": {
16434          "description": "[Output Only] Commitment start time in RFC3339 text format.",
16435          "type": "string"
16436        },
16437        "endTimestamp": {
16438          "description": "[Output Only] Commitment end time in RFC3339 text format.",
16439          "type": "string"
16440        },
16441        "resources": {
16442          "description": "A list of commitment amounts for particular resources. Note that VCPU and MEMORY resource commitments must occur together.",
16443          "type": "array",
16444          "items": {
16445            "$ref": "ResourceCommitment"
16446          }
16447        },
16448        "type": {
16449          "description": "The type of commitment, which affects the discount rate and the eligible resources. Type MEMORY_OPTIMIZED specifies a commitment that will only apply to memory optimized machines. Type ACCELERATOR_OPTIMIZED specifies a commitment that will only apply to accelerator optimized machines.",
16450          "type": "string",
16451          "enumDescriptions": [
16452            "",
16453            "",
16454            "",
16455            "",
16456            "",
16457            "",
16458            "",
16459            "",
16460            "",
16461            "",
16462            "",
16463            "",
16464            "",
16465            "",
16466            "",
16467            "",
16468            ""
16469          ],
16470          "enum": [
16471            "ACCELERATOR_OPTIMIZED",
16472            "ACCELERATOR_OPTIMIZED_A3",
16473            "COMPUTE_OPTIMIZED",
16474            "COMPUTE_OPTIMIZED_C2D",
16475            "COMPUTE_OPTIMIZED_C3",
16476            "COMPUTE_OPTIMIZED_C3D",
16477            "COMPUTE_OPTIMIZED_H3",
16478            "GENERAL_PURPOSE",
16479            "GENERAL_PURPOSE_E2",
16480            "GENERAL_PURPOSE_N2",
16481            "GENERAL_PURPOSE_N2D",
16482            "GENERAL_PURPOSE_T2D",
16483            "GRAPHICS_OPTIMIZED",
16484            "MEMORY_OPTIMIZED",
16485            "MEMORY_OPTIMIZED_M3",
16486            "STORAGE_OPTIMIZED_Z3",
16487            "TYPE_UNSPECIFIED"
16488          ]
16489        },
16490        "reservations": {
16491          "description": "List of create-on-create reservations for this commitment.",
16492          "type": "array",
16493          "items": {
16494            "$ref": "Reservation"
16495          }
16496        },
16497        "category": {
16498          "description": "The category of the commitment. Category MACHINE specifies commitments composed of machine resources such as VCPU or MEMORY, listed in resources. Category LICENSE specifies commitments composed of software licenses, listed in licenseResources. Note that only MACHINE commitments should have a Type specified.",
16499          "type": "string",
16500          "enumDescriptions": [
16501            "",
16502            "",
16503            ""
16504          ],
16505          "enum": [
16506            "CATEGORY_UNSPECIFIED",
16507            "LICENSE",
16508            "MACHINE"
16509          ]
16510        },
16511        "licenseResource": {
16512          "description": "The license specification required as part of a license commitment.",
16513          "$ref": "LicenseResourceCommitment"
16514        },
16515        "autoRenew": {
16516          "description": "Specifies whether to enable automatic renewal for the commitment. The default value is false if not specified. The field can be updated until the day of the commitment expiration at 12:00am PST. If the field is set to true, the commitment will be automatically renewed for either one or three years according to the terms of the existing commitment.",
16517          "type": "boolean"
16518        },
16519        "mergeSourceCommitments": {
16520          "description": "List of source commitments to be merged into a new commitment.",
16521          "type": "array",
16522          "items": {
16523            "type": "string"
16524          }
16525        },
16526        "splitSourceCommitment": {
16527          "description": "Source commitment to be split into a new commitment.",
16528          "type": "string"
16529        },
16530        "existingReservations": {
16531          "description": "Specifies the already existing reservations to attach to the Commitment. This field is optional, and it can be a full or partial URL. For example, the following are valid URLs to an reservation: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /reservations/reservation - projects/project/zones/zone/reservations/reservation ",
16532          "type": "array",
16533          "items": {
16534            "type": "string"
16535          }
16536        }
16537      }
16538    },
16539    "ResourceCommitment": {
16540      "id": "ResourceCommitment",
16541      "description": "Commitment for a particular resource (a Commitment is composed of one or more of these).",
16542      "type": "object",
16543      "properties": {
16544        "type": {
16545          "description": "Type of resource for which this commitment applies. Possible values are VCPU, MEMORY, LOCAL_SSD, and ACCELERATOR.",
16546          "type": "string",
16547          "enumDescriptions": [
16548            "",
16549            "",
16550            "",
16551            "",
16552            ""
16553          ],
16554          "enum": [
16555            "ACCELERATOR",
16556            "LOCAL_SSD",
16557            "MEMORY",
16558            "UNSPECIFIED",
16559            "VCPU"
16560          ]
16561        },
16562        "amount": {
16563          "description": "The amount of the resource purchased (in a type-dependent unit, such as bytes). For vCPUs, this can just be an integer. For memory, this must be provided in MB. Memory must be a multiple of 256 MB, with up to 6.5GB of memory per every vCPU.",
16564          "type": "string",
16565          "format": "int64"
16566        },
16567        "acceleratorType": {
16568          "description": "Name of the accelerator type resource. Applicable only when the type is ACCELERATOR.",
16569          "type": "string"
16570        }
16571      }
16572    },
16573    "LicenseResourceCommitment": {
16574      "id": "LicenseResourceCommitment",
16575      "description": "Commitment for a particular license resource.",
16576      "type": "object",
16577      "properties": {
16578        "license": {
16579          "description": "Any applicable license URI.",
16580          "type": "string"
16581        },
16582        "amount": {
16583          "description": "The number of licenses purchased.",
16584          "type": "string",
16585          "format": "int64"
16586        },
16587        "coresPerLicense": {
16588          "description": "Specifies the core range of the instance for which this license applies.",
16589          "type": "string"
16590        }
16591      }
16592    },
16593    "CommitmentAggregatedList": {
16594      "id": "CommitmentAggregatedList",
16595      "type": "object",
16596      "properties": {
16597        "kind": {
16598          "description": "[Output Only] Type of resource. Always compute#commitmentAggregatedList for aggregated lists of commitments.",
16599          "default": "compute#commitmentAggregatedList",
16600          "type": "string"
16601        },
16602        "id": {
16603          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
16604          "type": "string"
16605        },
16606        "items": {
16607          "description": "A list of CommitmentsScopedList resources.",
16608          "type": "object",
16609          "additionalProperties": {
16610            "description": "[Output Only] Name of the scope containing this set of commitments.",
16611            "$ref": "CommitmentsScopedList"
16612          }
16613        },
16614        "nextPageToken": {
16615          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
16616          "type": "string"
16617        },
16618        "selfLink": {
16619          "description": "[Output Only] Server-defined URL for this resource.",
16620          "type": "string"
16621        },
16622        "warning": {
16623          "description": "[Output Only] Informational warning message.",
16624          "type": "object",
16625          "properties": {
16626            "code": {
16627              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
16628              "type": "string",
16629              "enumDescriptions": [
16630                "Warning about failed cleanup of transient changes made by a failed operation.",
16631                "A link to a deprecated resource was created.",
16632                "When deploying and at least one of the resources has a type marked as deprecated",
16633                "The user created a boot disk that is larger than image size.",
16634                "When deploying and at least one of the resources has a type marked as experimental",
16635                "Warning that is present in an external api call",
16636                "Warning that value of a field has been overridden. Deprecated unused field.",
16637                "The operation involved use of an injected kernel, which is deprecated.",
16638                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
16639                "When deploying a deployment with a exceedingly large number of resources",
16640                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
16641                "A resource depends on a missing type",
16642                "The route's nextHopIp address is not assigned to an instance on the network.",
16643                "The route's next hop instance cannot ip forward.",
16644                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
16645                "The route's nextHopInstance URL refers to an instance that does not exist.",
16646                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
16647                "The route's next hop instance does not have a status of RUNNING.",
16648                "Error which is not critical. We decided to continue the process despite the mentioned error.",
16649                "No results are present on a particular list page.",
16650                "Success is reported, but some results may be missing due to errors",
16651                "The user attempted to use a resource that requires a TOS they have not accepted.",
16652                "Warning that a resource is in use.",
16653                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
16654                "When a resource schema validation is ignored.",
16655                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
16656                "When undeclared properties in the schema are present",
16657                "A given scope cannot be reached."
16658              ],
16659              "enumDeprecated": [
16660                false,
16661                false,
16662                false,
16663                false,
16664                false,
16665                false,
16666                true,
16667                false,
16668                false,
16669                false,
16670                false,
16671                false,
16672                false,
16673                false,
16674                false,
16675                false,
16676                false,
16677                false,
16678                false,
16679                false,
16680                false,
16681                false,
16682                false,
16683                false,
16684                false,
16685                false,
16686                false,
16687                false
16688              ],
16689              "enum": [
16690                "CLEANUP_FAILED",
16691                "DEPRECATED_RESOURCE_USED",
16692                "DEPRECATED_TYPE_USED",
16693                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
16694                "EXPERIMENTAL_TYPE_USED",
16695                "EXTERNAL_API_WARNING",
16696                "FIELD_VALUE_OVERRIDEN",
16697                "INJECTED_KERNELS_DEPRECATED",
16698                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
16699                "LARGE_DEPLOYMENT_WARNING",
16700                "LIST_OVERHEAD_QUOTA_EXCEED",
16701                "MISSING_TYPE_DEPENDENCY",
16702                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
16703                "NEXT_HOP_CANNOT_IP_FORWARD",
16704                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
16705                "NEXT_HOP_INSTANCE_NOT_FOUND",
16706                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
16707                "NEXT_HOP_NOT_RUNNING",
16708                "NOT_CRITICAL_ERROR",
16709                "NO_RESULTS_ON_PAGE",
16710                "PARTIAL_SUCCESS",
16711                "REQUIRED_TOS_AGREEMENT",
16712                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
16713                "RESOURCE_NOT_DELETED",
16714                "SCHEMA_VALIDATION_IGNORED",
16715                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
16716                "UNDECLARED_PROPERTIES",
16717                "UNREACHABLE"
16718              ]
16719            },
16720            "message": {
16721              "description": "[Output Only] A human-readable description of the warning code.",
16722              "type": "string"
16723            },
16724            "data": {
16725              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
16726              "type": "array",
16727              "items": {
16728                "type": "object",
16729                "properties": {
16730                  "key": {
16731                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
16732                    "type": "string"
16733                  },
16734                  "value": {
16735                    "description": "[Output Only] A warning data value corresponding to the key.",
16736                    "type": "string"
16737                  }
16738                }
16739              }
16740            }
16741          }
16742        },
16743        "unreachables": {
16744          "description": "[Output Only] Unreachable resources.",
16745          "type": "array",
16746          "items": {
16747            "type": "string"
16748          }
16749        }
16750      }
16751    },
16752    "CommitmentsScopedList": {
16753      "id": "CommitmentsScopedList",
16754      "type": "object",
16755      "properties": {
16756        "commitments": {
16757          "description": "[Output Only] A list of commitments contained in this scope.",
16758          "type": "array",
16759          "items": {
16760            "$ref": "Commitment"
16761          }
16762        },
16763        "warning": {
16764          "description": "[Output Only] Informational warning which replaces the list of commitments when the list is empty.",
16765          "type": "object",
16766          "properties": {
16767            "code": {
16768              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
16769              "type": "string",
16770              "enumDescriptions": [
16771                "Warning about failed cleanup of transient changes made by a failed operation.",
16772                "A link to a deprecated resource was created.",
16773                "When deploying and at least one of the resources has a type marked as deprecated",
16774                "The user created a boot disk that is larger than image size.",
16775                "When deploying and at least one of the resources has a type marked as experimental",
16776                "Warning that is present in an external api call",
16777                "Warning that value of a field has been overridden. Deprecated unused field.",
16778                "The operation involved use of an injected kernel, which is deprecated.",
16779                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
16780                "When deploying a deployment with a exceedingly large number of resources",
16781                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
16782                "A resource depends on a missing type",
16783                "The route's nextHopIp address is not assigned to an instance on the network.",
16784                "The route's next hop instance cannot ip forward.",
16785                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
16786                "The route's nextHopInstance URL refers to an instance that does not exist.",
16787                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
16788                "The route's next hop instance does not have a status of RUNNING.",
16789                "Error which is not critical. We decided to continue the process despite the mentioned error.",
16790                "No results are present on a particular list page.",
16791                "Success is reported, but some results may be missing due to errors",
16792                "The user attempted to use a resource that requires a TOS they have not accepted.",
16793                "Warning that a resource is in use.",
16794                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
16795                "When a resource schema validation is ignored.",
16796                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
16797                "When undeclared properties in the schema are present",
16798                "A given scope cannot be reached."
16799              ],
16800              "enumDeprecated": [
16801                false,
16802                false,
16803                false,
16804                false,
16805                false,
16806                false,
16807                true,
16808                false,
16809                false,
16810                false,
16811                false,
16812                false,
16813                false,
16814                false,
16815                false,
16816                false,
16817                false,
16818                false,
16819                false,
16820                false,
16821                false,
16822                false,
16823                false,
16824                false,
16825                false,
16826                false,
16827                false,
16828                false
16829              ],
16830              "enum": [
16831                "CLEANUP_FAILED",
16832                "DEPRECATED_RESOURCE_USED",
16833                "DEPRECATED_TYPE_USED",
16834                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
16835                "EXPERIMENTAL_TYPE_USED",
16836                "EXTERNAL_API_WARNING",
16837                "FIELD_VALUE_OVERRIDEN",
16838                "INJECTED_KERNELS_DEPRECATED",
16839                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
16840                "LARGE_DEPLOYMENT_WARNING",
16841                "LIST_OVERHEAD_QUOTA_EXCEED",
16842                "MISSING_TYPE_DEPENDENCY",
16843                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
16844                "NEXT_HOP_CANNOT_IP_FORWARD",
16845                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
16846                "NEXT_HOP_INSTANCE_NOT_FOUND",
16847                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
16848                "NEXT_HOP_NOT_RUNNING",
16849                "NOT_CRITICAL_ERROR",
16850                "NO_RESULTS_ON_PAGE",
16851                "PARTIAL_SUCCESS",
16852                "REQUIRED_TOS_AGREEMENT",
16853                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
16854                "RESOURCE_NOT_DELETED",
16855                "SCHEMA_VALIDATION_IGNORED",
16856                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
16857                "UNDECLARED_PROPERTIES",
16858                "UNREACHABLE"
16859              ]
16860            },
16861            "message": {
16862              "description": "[Output Only] A human-readable description of the warning code.",
16863              "type": "string"
16864            },
16865            "data": {
16866              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
16867              "type": "array",
16868              "items": {
16869                "type": "object",
16870                "properties": {
16871                  "key": {
16872                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
16873                    "type": "string"
16874                  },
16875                  "value": {
16876                    "description": "[Output Only] A warning data value corresponding to the key.",
16877                    "type": "string"
16878                  }
16879                }
16880              }
16881            }
16882          }
16883        }
16884      }
16885    },
16886    "DiskTypeList": {
16887      "id": "DiskTypeList",
16888      "description": "Contains a list of disk types.",
16889      "type": "object",
16890      "properties": {
16891        "kind": {
16892          "description": "[Output Only] Type of resource. Always compute#diskTypeList for disk types.",
16893          "default": "compute#diskTypeList",
16894          "type": "string"
16895        },
16896        "id": {
16897          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
16898          "type": "string"
16899        },
16900        "items": {
16901          "description": "A list of DiskType resources.",
16902          "type": "array",
16903          "items": {
16904            "$ref": "DiskType"
16905          }
16906        },
16907        "nextPageToken": {
16908          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
16909          "type": "string"
16910        },
16911        "selfLink": {
16912          "description": "[Output Only] Server-defined URL for this resource.",
16913          "type": "string"
16914        },
16915        "warning": {
16916          "description": "[Output Only] Informational warning message.",
16917          "type": "object",
16918          "properties": {
16919            "code": {
16920              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
16921              "type": "string",
16922              "enumDescriptions": [
16923                "Warning about failed cleanup of transient changes made by a failed operation.",
16924                "A link to a deprecated resource was created.",
16925                "When deploying and at least one of the resources has a type marked as deprecated",
16926                "The user created a boot disk that is larger than image size.",
16927                "When deploying and at least one of the resources has a type marked as experimental",
16928                "Warning that is present in an external api call",
16929                "Warning that value of a field has been overridden. Deprecated unused field.",
16930                "The operation involved use of an injected kernel, which is deprecated.",
16931                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
16932                "When deploying a deployment with a exceedingly large number of resources",
16933                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
16934                "A resource depends on a missing type",
16935                "The route's nextHopIp address is not assigned to an instance on the network.",
16936                "The route's next hop instance cannot ip forward.",
16937                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
16938                "The route's nextHopInstance URL refers to an instance that does not exist.",
16939                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
16940                "The route's next hop instance does not have a status of RUNNING.",
16941                "Error which is not critical. We decided to continue the process despite the mentioned error.",
16942                "No results are present on a particular list page.",
16943                "Success is reported, but some results may be missing due to errors",
16944                "The user attempted to use a resource that requires a TOS they have not accepted.",
16945                "Warning that a resource is in use.",
16946                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
16947                "When a resource schema validation is ignored.",
16948                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
16949                "When undeclared properties in the schema are present",
16950                "A given scope cannot be reached."
16951              ],
16952              "enumDeprecated": [
16953                false,
16954                false,
16955                false,
16956                false,
16957                false,
16958                false,
16959                true,
16960                false,
16961                false,
16962                false,
16963                false,
16964                false,
16965                false,
16966                false,
16967                false,
16968                false,
16969                false,
16970                false,
16971                false,
16972                false,
16973                false,
16974                false,
16975                false,
16976                false,
16977                false,
16978                false,
16979                false,
16980                false
16981              ],
16982              "enum": [
16983                "CLEANUP_FAILED",
16984                "DEPRECATED_RESOURCE_USED",
16985                "DEPRECATED_TYPE_USED",
16986                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
16987                "EXPERIMENTAL_TYPE_USED",
16988                "EXTERNAL_API_WARNING",
16989                "FIELD_VALUE_OVERRIDEN",
16990                "INJECTED_KERNELS_DEPRECATED",
16991                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
16992                "LARGE_DEPLOYMENT_WARNING",
16993                "LIST_OVERHEAD_QUOTA_EXCEED",
16994                "MISSING_TYPE_DEPENDENCY",
16995                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
16996                "NEXT_HOP_CANNOT_IP_FORWARD",
16997                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
16998                "NEXT_HOP_INSTANCE_NOT_FOUND",
16999                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
17000                "NEXT_HOP_NOT_RUNNING",
17001                "NOT_CRITICAL_ERROR",
17002                "NO_RESULTS_ON_PAGE",
17003                "PARTIAL_SUCCESS",
17004                "REQUIRED_TOS_AGREEMENT",
17005                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
17006                "RESOURCE_NOT_DELETED",
17007                "SCHEMA_VALIDATION_IGNORED",
17008                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
17009                "UNDECLARED_PROPERTIES",
17010                "UNREACHABLE"
17011              ]
17012            },
17013            "message": {
17014              "description": "[Output Only] A human-readable description of the warning code.",
17015              "type": "string"
17016            },
17017            "data": {
17018              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
17019              "type": "array",
17020              "items": {
17021                "type": "object",
17022                "properties": {
17023                  "key": {
17024                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
17025                    "type": "string"
17026                  },
17027                  "value": {
17028                    "description": "[Output Only] A warning data value corresponding to the key.",
17029                    "type": "string"
17030                  }
17031                }
17032              }
17033            }
17034          }
17035        }
17036      }
17037    },
17038    "DiskType": {
17039      "id": "DiskType",
17040      "description": "Represents a Disk Type resource. Google Compute Engine has two Disk Type resources: * [Regional](/compute/docs/reference/rest/v1/regionDiskTypes) * [Zonal](/compute/docs/reference/rest/v1/diskTypes) You can choose from a variety of disk types based on your needs. For more information, read Storage options. The diskTypes resource represents disk types for a zonal persistent disk. For more information, read Zonal persistent disks. The regionDiskTypes resource represents disk types for a regional persistent disk. For more information, read Regional persistent disks.",
17041      "type": "object",
17042      "properties": {
17043        "kind": {
17044          "description": "[Output Only] Type of the resource. Always compute#diskType for disk types.",
17045          "default": "compute#diskType",
17046          "type": "string"
17047        },
17048        "id": {
17049          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
17050          "type": "string",
17051          "format": "uint64"
17052        },
17053        "creationTimestamp": {
17054          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
17055          "type": "string"
17056        },
17057        "name": {
17058          "description": "[Output Only] Name of the resource.",
17059          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
17060          "type": "string"
17061        },
17062        "description": {
17063          "description": "[Output Only] An optional description of this resource.",
17064          "type": "string"
17065        },
17066        "validDiskSize": {
17067          "description": "[Output Only] An optional textual description of the valid disk size, such as \"10GB-10TB\".",
17068          "type": "string"
17069        },
17070        "deprecated": {
17071          "description": "[Output Only] The deprecation status associated with this disk type.",
17072          "$ref": "DeprecationStatus"
17073        },
17074        "zone": {
17075          "description": "[Output Only] URL of the zone where the disk type resides. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
17076          "type": "string"
17077        },
17078        "selfLink": {
17079          "description": "[Output Only] Server-defined URL for the resource.",
17080          "type": "string"
17081        },
17082        "defaultDiskSizeGb": {
17083          "description": "[Output Only] Server-defined default disk size in GB.",
17084          "type": "string",
17085          "format": "int64"
17086        },
17087        "region": {
17088          "description": "[Output Only] URL of the region where the disk type resides. Only applicable for regional resources. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
17089          "type": "string"
17090        }
17091      }
17092    },
17093    "DiskTypeAggregatedList": {
17094      "id": "DiskTypeAggregatedList",
17095      "type": "object",
17096      "properties": {
17097        "kind": {
17098          "description": "[Output Only] Type of resource. Always compute#diskTypeAggregatedList.",
17099          "default": "compute#diskTypeAggregatedList",
17100          "type": "string"
17101        },
17102        "id": {
17103          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
17104          "type": "string"
17105        },
17106        "items": {
17107          "description": "A list of DiskTypesScopedList resources.",
17108          "type": "object",
17109          "additionalProperties": {
17110            "description": "[Output Only] Name of the scope containing this set of disk types.",
17111            "$ref": "DiskTypesScopedList"
17112          }
17113        },
17114        "nextPageToken": {
17115          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
17116          "type": "string"
17117        },
17118        "selfLink": {
17119          "description": "[Output Only] Server-defined URL for this resource.",
17120          "type": "string"
17121        },
17122        "warning": {
17123          "description": "[Output Only] Informational warning message.",
17124          "type": "object",
17125          "properties": {
17126            "code": {
17127              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
17128              "type": "string",
17129              "enumDescriptions": [
17130                "Warning about failed cleanup of transient changes made by a failed operation.",
17131                "A link to a deprecated resource was created.",
17132                "When deploying and at least one of the resources has a type marked as deprecated",
17133                "The user created a boot disk that is larger than image size.",
17134                "When deploying and at least one of the resources has a type marked as experimental",
17135                "Warning that is present in an external api call",
17136                "Warning that value of a field has been overridden. Deprecated unused field.",
17137                "The operation involved use of an injected kernel, which is deprecated.",
17138                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
17139                "When deploying a deployment with a exceedingly large number of resources",
17140                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
17141                "A resource depends on a missing type",
17142                "The route's nextHopIp address is not assigned to an instance on the network.",
17143                "The route's next hop instance cannot ip forward.",
17144                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
17145                "The route's nextHopInstance URL refers to an instance that does not exist.",
17146                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
17147                "The route's next hop instance does not have a status of RUNNING.",
17148                "Error which is not critical. We decided to continue the process despite the mentioned error.",
17149                "No results are present on a particular list page.",
17150                "Success is reported, but some results may be missing due to errors",
17151                "The user attempted to use a resource that requires a TOS they have not accepted.",
17152                "Warning that a resource is in use.",
17153                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
17154                "When a resource schema validation is ignored.",
17155                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
17156                "When undeclared properties in the schema are present",
17157                "A given scope cannot be reached."
17158              ],
17159              "enumDeprecated": [
17160                false,
17161                false,
17162                false,
17163                false,
17164                false,
17165                false,
17166                true,
17167                false,
17168                false,
17169                false,
17170                false,
17171                false,
17172                false,
17173                false,
17174                false,
17175                false,
17176                false,
17177                false,
17178                false,
17179                false,
17180                false,
17181                false,
17182                false,
17183                false,
17184                false,
17185                false,
17186                false,
17187                false
17188              ],
17189              "enum": [
17190                "CLEANUP_FAILED",
17191                "DEPRECATED_RESOURCE_USED",
17192                "DEPRECATED_TYPE_USED",
17193                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
17194                "EXPERIMENTAL_TYPE_USED",
17195                "EXTERNAL_API_WARNING",
17196                "FIELD_VALUE_OVERRIDEN",
17197                "INJECTED_KERNELS_DEPRECATED",
17198                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
17199                "LARGE_DEPLOYMENT_WARNING",
17200                "LIST_OVERHEAD_QUOTA_EXCEED",
17201                "MISSING_TYPE_DEPENDENCY",
17202                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
17203                "NEXT_HOP_CANNOT_IP_FORWARD",
17204                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
17205                "NEXT_HOP_INSTANCE_NOT_FOUND",
17206                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
17207                "NEXT_HOP_NOT_RUNNING",
17208                "NOT_CRITICAL_ERROR",
17209                "NO_RESULTS_ON_PAGE",
17210                "PARTIAL_SUCCESS",
17211                "REQUIRED_TOS_AGREEMENT",
17212                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
17213                "RESOURCE_NOT_DELETED",
17214                "SCHEMA_VALIDATION_IGNORED",
17215                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
17216                "UNDECLARED_PROPERTIES",
17217                "UNREACHABLE"
17218              ]
17219            },
17220            "message": {
17221              "description": "[Output Only] A human-readable description of the warning code.",
17222              "type": "string"
17223            },
17224            "data": {
17225              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
17226              "type": "array",
17227              "items": {
17228                "type": "object",
17229                "properties": {
17230                  "key": {
17231                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
17232                    "type": "string"
17233                  },
17234                  "value": {
17235                    "description": "[Output Only] A warning data value corresponding to the key.",
17236                    "type": "string"
17237                  }
17238                }
17239              }
17240            }
17241          }
17242        },
17243        "unreachables": {
17244          "description": "[Output Only] Unreachable resources.",
17245          "type": "array",
17246          "items": {
17247            "type": "string"
17248          }
17249        }
17250      }
17251    },
17252    "DiskTypesScopedList": {
17253      "id": "DiskTypesScopedList",
17254      "type": "object",
17255      "properties": {
17256        "diskTypes": {
17257          "description": "[Output Only] A list of disk types contained in this scope.",
17258          "type": "array",
17259          "items": {
17260            "$ref": "DiskType"
17261          }
17262        },
17263        "warning": {
17264          "description": "[Output Only] Informational warning which replaces the list of disk types when the list is empty.",
17265          "type": "object",
17266          "properties": {
17267            "code": {
17268              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
17269              "type": "string",
17270              "enumDescriptions": [
17271                "Warning about failed cleanup of transient changes made by a failed operation.",
17272                "A link to a deprecated resource was created.",
17273                "When deploying and at least one of the resources has a type marked as deprecated",
17274                "The user created a boot disk that is larger than image size.",
17275                "When deploying and at least one of the resources has a type marked as experimental",
17276                "Warning that is present in an external api call",
17277                "Warning that value of a field has been overridden. Deprecated unused field.",
17278                "The operation involved use of an injected kernel, which is deprecated.",
17279                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
17280                "When deploying a deployment with a exceedingly large number of resources",
17281                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
17282                "A resource depends on a missing type",
17283                "The route's nextHopIp address is not assigned to an instance on the network.",
17284                "The route's next hop instance cannot ip forward.",
17285                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
17286                "The route's nextHopInstance URL refers to an instance that does not exist.",
17287                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
17288                "The route's next hop instance does not have a status of RUNNING.",
17289                "Error which is not critical. We decided to continue the process despite the mentioned error.",
17290                "No results are present on a particular list page.",
17291                "Success is reported, but some results may be missing due to errors",
17292                "The user attempted to use a resource that requires a TOS they have not accepted.",
17293                "Warning that a resource is in use.",
17294                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
17295                "When a resource schema validation is ignored.",
17296                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
17297                "When undeclared properties in the schema are present",
17298                "A given scope cannot be reached."
17299              ],
17300              "enumDeprecated": [
17301                false,
17302                false,
17303                false,
17304                false,
17305                false,
17306                false,
17307                true,
17308                false,
17309                false,
17310                false,
17311                false,
17312                false,
17313                false,
17314                false,
17315                false,
17316                false,
17317                false,
17318                false,
17319                false,
17320                false,
17321                false,
17322                false,
17323                false,
17324                false,
17325                false,
17326                false,
17327                false,
17328                false
17329              ],
17330              "enum": [
17331                "CLEANUP_FAILED",
17332                "DEPRECATED_RESOURCE_USED",
17333                "DEPRECATED_TYPE_USED",
17334                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
17335                "EXPERIMENTAL_TYPE_USED",
17336                "EXTERNAL_API_WARNING",
17337                "FIELD_VALUE_OVERRIDEN",
17338                "INJECTED_KERNELS_DEPRECATED",
17339                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
17340                "LARGE_DEPLOYMENT_WARNING",
17341                "LIST_OVERHEAD_QUOTA_EXCEED",
17342                "MISSING_TYPE_DEPENDENCY",
17343                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
17344                "NEXT_HOP_CANNOT_IP_FORWARD",
17345                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
17346                "NEXT_HOP_INSTANCE_NOT_FOUND",
17347                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
17348                "NEXT_HOP_NOT_RUNNING",
17349                "NOT_CRITICAL_ERROR",
17350                "NO_RESULTS_ON_PAGE",
17351                "PARTIAL_SUCCESS",
17352                "REQUIRED_TOS_AGREEMENT",
17353                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
17354                "RESOURCE_NOT_DELETED",
17355                "SCHEMA_VALIDATION_IGNORED",
17356                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
17357                "UNDECLARED_PROPERTIES",
17358                "UNREACHABLE"
17359              ]
17360            },
17361            "message": {
17362              "description": "[Output Only] A human-readable description of the warning code.",
17363              "type": "string"
17364            },
17365            "data": {
17366              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
17367              "type": "array",
17368              "items": {
17369                "type": "object",
17370                "properties": {
17371                  "key": {
17372                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
17373                    "type": "string"
17374                  },
17375                  "value": {
17376                    "description": "[Output Only] A warning data value corresponding to the key.",
17377                    "type": "string"
17378                  }
17379                }
17380              }
17381            }
17382          }
17383        }
17384      }
17385    },
17386    "RegionDiskTypeList": {
17387      "id": "RegionDiskTypeList",
17388      "type": "object",
17389      "properties": {
17390        "kind": {
17391          "description": "[Output Only] Type of resource. Always compute#regionDiskTypeList for region disk types.",
17392          "default": "compute#regionDiskTypeList",
17393          "type": "string"
17394        },
17395        "id": {
17396          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
17397          "type": "string"
17398        },
17399        "items": {
17400          "description": "A list of DiskType resources.",
17401          "type": "array",
17402          "items": {
17403            "$ref": "DiskType"
17404          }
17405        },
17406        "nextPageToken": {
17407          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
17408          "type": "string"
17409        },
17410        "selfLink": {
17411          "description": "[Output Only] Server-defined URL for this resource.",
17412          "type": "string"
17413        },
17414        "warning": {
17415          "description": "[Output Only] Informational warning message.",
17416          "type": "object",
17417          "properties": {
17418            "code": {
17419              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
17420              "type": "string",
17421              "enumDescriptions": [
17422                "Warning about failed cleanup of transient changes made by a failed operation.",
17423                "A link to a deprecated resource was created.",
17424                "When deploying and at least one of the resources has a type marked as deprecated",
17425                "The user created a boot disk that is larger than image size.",
17426                "When deploying and at least one of the resources has a type marked as experimental",
17427                "Warning that is present in an external api call",
17428                "Warning that value of a field has been overridden. Deprecated unused field.",
17429                "The operation involved use of an injected kernel, which is deprecated.",
17430                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
17431                "When deploying a deployment with a exceedingly large number of resources",
17432                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
17433                "A resource depends on a missing type",
17434                "The route's nextHopIp address is not assigned to an instance on the network.",
17435                "The route's next hop instance cannot ip forward.",
17436                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
17437                "The route's nextHopInstance URL refers to an instance that does not exist.",
17438                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
17439                "The route's next hop instance does not have a status of RUNNING.",
17440                "Error which is not critical. We decided to continue the process despite the mentioned error.",
17441                "No results are present on a particular list page.",
17442                "Success is reported, but some results may be missing due to errors",
17443                "The user attempted to use a resource that requires a TOS they have not accepted.",
17444                "Warning that a resource is in use.",
17445                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
17446                "When a resource schema validation is ignored.",
17447                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
17448                "When undeclared properties in the schema are present",
17449                "A given scope cannot be reached."
17450              ],
17451              "enumDeprecated": [
17452                false,
17453                false,
17454                false,
17455                false,
17456                false,
17457                false,
17458                true,
17459                false,
17460                false,
17461                false,
17462                false,
17463                false,
17464                false,
17465                false,
17466                false,
17467                false,
17468                false,
17469                false,
17470                false,
17471                false,
17472                false,
17473                false,
17474                false,
17475                false,
17476                false,
17477                false,
17478                false,
17479                false
17480              ],
17481              "enum": [
17482                "CLEANUP_FAILED",
17483                "DEPRECATED_RESOURCE_USED",
17484                "DEPRECATED_TYPE_USED",
17485                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
17486                "EXPERIMENTAL_TYPE_USED",
17487                "EXTERNAL_API_WARNING",
17488                "FIELD_VALUE_OVERRIDEN",
17489                "INJECTED_KERNELS_DEPRECATED",
17490                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
17491                "LARGE_DEPLOYMENT_WARNING",
17492                "LIST_OVERHEAD_QUOTA_EXCEED",
17493                "MISSING_TYPE_DEPENDENCY",
17494                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
17495                "NEXT_HOP_CANNOT_IP_FORWARD",
17496                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
17497                "NEXT_HOP_INSTANCE_NOT_FOUND",
17498                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
17499                "NEXT_HOP_NOT_RUNNING",
17500                "NOT_CRITICAL_ERROR",
17501                "NO_RESULTS_ON_PAGE",
17502                "PARTIAL_SUCCESS",
17503                "REQUIRED_TOS_AGREEMENT",
17504                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
17505                "RESOURCE_NOT_DELETED",
17506                "SCHEMA_VALIDATION_IGNORED",
17507                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
17508                "UNDECLARED_PROPERTIES",
17509                "UNREACHABLE"
17510              ]
17511            },
17512            "message": {
17513              "description": "[Output Only] A human-readable description of the warning code.",
17514              "type": "string"
17515            },
17516            "data": {
17517              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
17518              "type": "array",
17519              "items": {
17520                "type": "object",
17521                "properties": {
17522                  "key": {
17523                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
17524                    "type": "string"
17525                  },
17526                  "value": {
17527                    "description": "[Output Only] A warning data value corresponding to the key.",
17528                    "type": "string"
17529                  }
17530                }
17531              }
17532            }
17533          }
17534        }
17535      }
17536    },
17537    "ExternalVpnGateway": {
17538      "id": "ExternalVpnGateway",
17539      "description": "Represents an external VPN gateway. External VPN gateway is the on-premises VPN gateway(s) or another cloud provider's VPN gateway that connects to your Google Cloud VPN gateway. To create a highly available VPN from Google Cloud Platform to your VPN gateway or another cloud provider's VPN gateway, you must create a external VPN gateway resource with information about the other gateway. For more information about using external VPN gateways, see Creating an HA VPN gateway and tunnel pair to a peer VPN.",
17540      "type": "object",
17541      "properties": {
17542        "kind": {
17543          "description": "[Output Only] Type of the resource. Always compute#externalVpnGateway for externalVpnGateways.",
17544          "default": "compute#externalVpnGateway",
17545          "type": "string"
17546        },
17547        "description": {
17548          "description": "An optional description of this resource. Provide this property when you create the resource.",
17549          "type": "string"
17550        },
17551        "selfLink": {
17552          "description": "[Output Only] Server-defined URL for the resource.",
17553          "type": "string"
17554        },
17555        "id": {
17556          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
17557          "type": "string",
17558          "format": "uint64"
17559        },
17560        "creationTimestamp": {
17561          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
17562          "type": "string"
17563        },
17564        "name": {
17565          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
17566          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
17567          "annotations": {
17568            "required": [
17569              "compute.externalVpnGateways.insert"
17570            ]
17571          },
17572          "type": "string"
17573        },
17574        "redundancyType": {
17575          "description": "Indicates the user-supplied redundancy type of this external VPN gateway.",
17576          "type": "string",
17577          "enumDescriptions": [
17578            "The external VPN gateway has four public IP addresses; at the time of writing this API, the AWS virtual private gateway is an example which has four public IP addresses for high availability connections; there should be two VPN connections in the AWS virtual private gateway , each AWS VPN connection has two public IP addresses; please make sure to put two public IP addresses from one AWS VPN connection into interfaces 0 and 1 of this external VPN gateway, and put the other two public IP addresses from another AWS VPN connection into interfaces 2 and 3 of this external VPN gateway. When displaying highly available configuration status for the VPN tunnels connected to FOUR_IPS_REDUNDANCY external VPN gateway, Google will always detect whether interfaces 0 and 1 are connected on one interface of HA Cloud VPN gateway, and detect whether interfaces 2 and 3 are connected to another interface of the HA Cloud VPN gateway.",
17579            "The external VPN gateway has only one public IP address which internally provide redundancy or failover.",
17580            "The external VPN gateway has two public IP addresses which are redundant with each other, the following two types of setup on your on-premises side would have this type of redundancy: (1) Two separate on-premises gateways, each with one public IP address, the two on-premises gateways are redundant with each other. (2) A single on-premise gateway with two public IP addresses that are redundant with eatch other."
17581          ],
17582          "enum": [
17583            "FOUR_IPS_REDUNDANCY",
17584            "SINGLE_IP_INTERNALLY_REDUNDANT",
17585            "TWO_IPS_REDUNDANCY"
17586          ]
17587        },
17588        "interfaces": {
17589          "description": "A list of interfaces for this external VPN gateway. If your peer-side gateway is an on-premises gateway and non-AWS cloud providers' gateway, at most two interfaces can be provided for an external VPN gateway. If your peer side is an AWS virtual private gateway, four interfaces should be provided for an external VPN gateway.",
17590          "type": "array",
17591          "items": {
17592            "$ref": "ExternalVpnGatewayInterface"
17593          }
17594        },
17595        "labels": {
17596          "description": "Labels for this resource. These can only be added or modified by the setLabels method. Each label key/value pair must comply with RFC1035. Label values may be empty.",
17597          "type": "object",
17598          "additionalProperties": {
17599            "type": "string"
17600          }
17601        },
17602        "labelFingerprint": {
17603          "description": "A fingerprint for the labels being applied to this ExternalVpnGateway, which is essentially a hash of the labels set used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve an ExternalVpnGateway.",
17604          "type": "string",
17605          "format": "byte"
17606        }
17607      }
17608    },
17609    "ExternalVpnGatewayInterface": {
17610      "id": "ExternalVpnGatewayInterface",
17611      "description": "The interface for the external VPN gateway.",
17612      "type": "object",
17613      "properties": {
17614        "id": {
17615          "description": "The numeric ID of this interface. The allowed input values for this id for different redundancy types of external VPN gateway: - SINGLE_IP_INTERNALLY_REDUNDANT - 0 - TWO_IPS_REDUNDANCY - 0, 1 - FOUR_IPS_REDUNDANCY - 0, 1, 2, 3 ",
17616          "type": "integer",
17617          "format": "uint32"
17618        },
17619        "ipAddress": {
17620          "description": "IP address of the interface in the external VPN gateway. Only IPv4 is supported. This IP address can be either from your on-premise gateway or another Cloud provider's VPN gateway, it cannot be an IP address from Google Compute Engine.",
17621          "type": "string"
17622        },
17623        "ipv6Address": {
17624          "description": "IPv6 address of the interface in the external VPN gateway. This IPv6 address can be either from your on-premise gateway or another Cloud provider's VPN gateway, it cannot be an IP address from Google Compute Engine. Must specify an IPv6 address (not IPV4-mapped) using any format described in RFC 4291 (e.g. 2001:db8:0:0:2d9:51:0:0). The output format is RFC 5952 format (e.g. 2001:db8::2d9:51:0:0).",
17625          "type": "string"
17626        }
17627      }
17628    },
17629    "ExternalVpnGatewayList": {
17630      "id": "ExternalVpnGatewayList",
17631      "description": "Response to the list request, and contains a list of externalVpnGateways.",
17632      "type": "object",
17633      "properties": {
17634        "kind": {
17635          "description": "[Output Only] Type of resource. Always compute#externalVpnGatewayList for lists of externalVpnGateways.",
17636          "default": "compute#externalVpnGatewayList",
17637          "type": "string"
17638        },
17639        "id": {
17640          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
17641          "type": "string"
17642        },
17643        "items": {
17644          "description": "A list of ExternalVpnGateway resources.",
17645          "type": "array",
17646          "items": {
17647            "$ref": "ExternalVpnGateway"
17648          }
17649        },
17650        "nextPageToken": {
17651          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
17652          "type": "string"
17653        },
17654        "selfLink": {
17655          "description": "[Output Only] Server-defined URL for this resource.",
17656          "type": "string"
17657        },
17658        "warning": {
17659          "description": "[Output Only] Informational warning message.",
17660          "type": "object",
17661          "properties": {
17662            "code": {
17663              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
17664              "type": "string",
17665              "enumDescriptions": [
17666                "Warning about failed cleanup of transient changes made by a failed operation.",
17667                "A link to a deprecated resource was created.",
17668                "When deploying and at least one of the resources has a type marked as deprecated",
17669                "The user created a boot disk that is larger than image size.",
17670                "When deploying and at least one of the resources has a type marked as experimental",
17671                "Warning that is present in an external api call",
17672                "Warning that value of a field has been overridden. Deprecated unused field.",
17673                "The operation involved use of an injected kernel, which is deprecated.",
17674                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
17675                "When deploying a deployment with a exceedingly large number of resources",
17676                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
17677                "A resource depends on a missing type",
17678                "The route's nextHopIp address is not assigned to an instance on the network.",
17679                "The route's next hop instance cannot ip forward.",
17680                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
17681                "The route's nextHopInstance URL refers to an instance that does not exist.",
17682                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
17683                "The route's next hop instance does not have a status of RUNNING.",
17684                "Error which is not critical. We decided to continue the process despite the mentioned error.",
17685                "No results are present on a particular list page.",
17686                "Success is reported, but some results may be missing due to errors",
17687                "The user attempted to use a resource that requires a TOS they have not accepted.",
17688                "Warning that a resource is in use.",
17689                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
17690                "When a resource schema validation is ignored.",
17691                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
17692                "When undeclared properties in the schema are present",
17693                "A given scope cannot be reached."
17694              ],
17695              "enumDeprecated": [
17696                false,
17697                false,
17698                false,
17699                false,
17700                false,
17701                false,
17702                true,
17703                false,
17704                false,
17705                false,
17706                false,
17707                false,
17708                false,
17709                false,
17710                false,
17711                false,
17712                false,
17713                false,
17714                false,
17715                false,
17716                false,
17717                false,
17718                false,
17719                false,
17720                false,
17721                false,
17722                false,
17723                false
17724              ],
17725              "enum": [
17726                "CLEANUP_FAILED",
17727                "DEPRECATED_RESOURCE_USED",
17728                "DEPRECATED_TYPE_USED",
17729                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
17730                "EXPERIMENTAL_TYPE_USED",
17731                "EXTERNAL_API_WARNING",
17732                "FIELD_VALUE_OVERRIDEN",
17733                "INJECTED_KERNELS_DEPRECATED",
17734                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
17735                "LARGE_DEPLOYMENT_WARNING",
17736                "LIST_OVERHEAD_QUOTA_EXCEED",
17737                "MISSING_TYPE_DEPENDENCY",
17738                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
17739                "NEXT_HOP_CANNOT_IP_FORWARD",
17740                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
17741                "NEXT_HOP_INSTANCE_NOT_FOUND",
17742                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
17743                "NEXT_HOP_NOT_RUNNING",
17744                "NOT_CRITICAL_ERROR",
17745                "NO_RESULTS_ON_PAGE",
17746                "PARTIAL_SUCCESS",
17747                "REQUIRED_TOS_AGREEMENT",
17748                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
17749                "RESOURCE_NOT_DELETED",
17750                "SCHEMA_VALIDATION_IGNORED",
17751                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
17752                "UNDECLARED_PROPERTIES",
17753                "UNREACHABLE"
17754              ]
17755            },
17756            "message": {
17757              "description": "[Output Only] A human-readable description of the warning code.",
17758              "type": "string"
17759            },
17760            "data": {
17761              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
17762              "type": "array",
17763              "items": {
17764                "type": "object",
17765                "properties": {
17766                  "key": {
17767                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
17768                    "type": "string"
17769                  },
17770                  "value": {
17771                    "description": "[Output Only] A warning data value corresponding to the key.",
17772                    "type": "string"
17773                  }
17774                }
17775              }
17776            }
17777          }
17778        },
17779        "etag": {
17780          "type": "string"
17781        }
17782      }
17783    },
17784    "ForwardingRuleList": {
17785      "id": "ForwardingRuleList",
17786      "description": "Contains a list of ForwardingRule resources.",
17787      "type": "object",
17788      "properties": {
17789        "kind": {
17790          "description": "Type of resource.",
17791          "default": "compute#forwardingRuleList",
17792          "type": "string"
17793        },
17794        "id": {
17795          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
17796          "type": "string"
17797        },
17798        "items": {
17799          "description": "A list of ForwardingRule resources.",
17800          "type": "array",
17801          "items": {
17802            "$ref": "ForwardingRule"
17803          }
17804        },
17805        "nextPageToken": {
17806          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
17807          "type": "string"
17808        },
17809        "selfLink": {
17810          "description": "[Output Only] Server-defined URL for this resource.",
17811          "type": "string"
17812        },
17813        "warning": {
17814          "description": "[Output Only] Informational warning message.",
17815          "type": "object",
17816          "properties": {
17817            "code": {
17818              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
17819              "type": "string",
17820              "enumDescriptions": [
17821                "Warning about failed cleanup of transient changes made by a failed operation.",
17822                "A link to a deprecated resource was created.",
17823                "When deploying and at least one of the resources has a type marked as deprecated",
17824                "The user created a boot disk that is larger than image size.",
17825                "When deploying and at least one of the resources has a type marked as experimental",
17826                "Warning that is present in an external api call",
17827                "Warning that value of a field has been overridden. Deprecated unused field.",
17828                "The operation involved use of an injected kernel, which is deprecated.",
17829                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
17830                "When deploying a deployment with a exceedingly large number of resources",
17831                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
17832                "A resource depends on a missing type",
17833                "The route's nextHopIp address is not assigned to an instance on the network.",
17834                "The route's next hop instance cannot ip forward.",
17835                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
17836                "The route's nextHopInstance URL refers to an instance that does not exist.",
17837                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
17838                "The route's next hop instance does not have a status of RUNNING.",
17839                "Error which is not critical. We decided to continue the process despite the mentioned error.",
17840                "No results are present on a particular list page.",
17841                "Success is reported, but some results may be missing due to errors",
17842                "The user attempted to use a resource that requires a TOS they have not accepted.",
17843                "Warning that a resource is in use.",
17844                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
17845                "When a resource schema validation is ignored.",
17846                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
17847                "When undeclared properties in the schema are present",
17848                "A given scope cannot be reached."
17849              ],
17850              "enumDeprecated": [
17851                false,
17852                false,
17853                false,
17854                false,
17855                false,
17856                false,
17857                true,
17858                false,
17859                false,
17860                false,
17861                false,
17862                false,
17863                false,
17864                false,
17865                false,
17866                false,
17867                false,
17868                false,
17869                false,
17870                false,
17871                false,
17872                false,
17873                false,
17874                false,
17875                false,
17876                false,
17877                false,
17878                false
17879              ],
17880              "enum": [
17881                "CLEANUP_FAILED",
17882                "DEPRECATED_RESOURCE_USED",
17883                "DEPRECATED_TYPE_USED",
17884                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
17885                "EXPERIMENTAL_TYPE_USED",
17886                "EXTERNAL_API_WARNING",
17887                "FIELD_VALUE_OVERRIDEN",
17888                "INJECTED_KERNELS_DEPRECATED",
17889                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
17890                "LARGE_DEPLOYMENT_WARNING",
17891                "LIST_OVERHEAD_QUOTA_EXCEED",
17892                "MISSING_TYPE_DEPENDENCY",
17893                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
17894                "NEXT_HOP_CANNOT_IP_FORWARD",
17895                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
17896                "NEXT_HOP_INSTANCE_NOT_FOUND",
17897                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
17898                "NEXT_HOP_NOT_RUNNING",
17899                "NOT_CRITICAL_ERROR",
17900                "NO_RESULTS_ON_PAGE",
17901                "PARTIAL_SUCCESS",
17902                "REQUIRED_TOS_AGREEMENT",
17903                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
17904                "RESOURCE_NOT_DELETED",
17905                "SCHEMA_VALIDATION_IGNORED",
17906                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
17907                "UNDECLARED_PROPERTIES",
17908                "UNREACHABLE"
17909              ]
17910            },
17911            "message": {
17912              "description": "[Output Only] A human-readable description of the warning code.",
17913              "type": "string"
17914            },
17915            "data": {
17916              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
17917              "type": "array",
17918              "items": {
17919                "type": "object",
17920                "properties": {
17921                  "key": {
17922                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
17923                    "type": "string"
17924                  },
17925                  "value": {
17926                    "description": "[Output Only] A warning data value corresponding to the key.",
17927                    "type": "string"
17928                  }
17929                }
17930              }
17931            }
17932          }
17933        }
17934      }
17935    },
17936    "ForwardingRule": {
17937      "id": "ForwardingRule",
17938      "description": "Represents a Forwarding Rule resource. Forwarding rule resources in Google Cloud can be either regional or global in scope: * [Global](https://cloud.google.com/compute/docs/reference/rest/v1/globalForwardingRules) * [Regional](https://cloud.google.com/compute/docs/reference/rest/v1/forwardingRules) A forwarding rule and its corresponding IP address represent the frontend configuration of a Google Cloud load balancer. Forwarding rules can also reference target instances and Cloud VPN Classic gateways (targetVpnGateway). For more information, read Forwarding rule concepts and Using protocol forwarding.",
17939      "type": "object",
17940      "properties": {
17941        "kind": {
17942          "description": "[Output Only] Type of the resource. Always compute#forwardingRule for forwarding rule resources.",
17943          "default": "compute#forwardingRule",
17944          "type": "string"
17945        },
17946        "id": {
17947          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
17948          "type": "string",
17949          "format": "uint64"
17950        },
17951        "creationTimestamp": {
17952          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
17953          "type": "string"
17954        },
17955        "name": {
17956          "description": "Name of the resource; provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash. For Private Service Connect forwarding rules that forward traffic to Google APIs, the forwarding rule name must be a 1-20 characters string with lowercase letters and numbers and must start with a letter.",
17957          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
17958          "type": "string"
17959        },
17960        "description": {
17961          "description": "An optional description of this resource. Provide this property when you create the resource.",
17962          "type": "string"
17963        },
17964        "region": {
17965          "description": "[Output Only] URL of the region where the regional forwarding rule resides. This field is not applicable to global forwarding rules. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
17966          "type": "string"
17967        },
17968        "IPAddress": {
17969          "description": "IP address for which this forwarding rule accepts traffic. When a client sends traffic to this IP address, the forwarding rule directs the traffic to the referenced target or backendService. While creating a forwarding rule, specifying an IPAddress is required under the following circumstances: - When the target is set to targetGrpcProxy and validateForProxyless is set to true, the IPAddress should be set to 0.0.0.0. - When the target is a Private Service Connect Google APIs bundle, you must specify an IPAddress. Otherwise, you can optionally specify an IP address that references an existing static (reserved) IP address resource. When omitted, Google Cloud assigns an ephemeral IP address. Use one of the following formats to specify an IP address while creating a forwarding rule: * IP address number, as in `100.1.2.3` * IPv6 address range, as in `2600:1234::/96` * Full resource URL, as in https://www.googleapis.com/compute/v1/projects/ project_id/regions/region/addresses/address-name * Partial URL or by name, as in: - projects/project_id/regions/region/addresses/address-name - regions/region/addresses/address-name - global/addresses/address-name - address-name The forwarding rule's target or backendService, and in most cases, also the loadBalancingScheme, determine the type of IP address that you can use. For detailed information, see [IP address specifications](https://cloud.google.com/load-balancing/docs/forwarding-rule-concepts#ip_address_specifications). When reading an IPAddress, the API always returns the IP address number.",
17970          "type": "string"
17971        },
17972        "IPProtocol": {
17973          "description": "The IP protocol to which this rule applies. For protocol forwarding, valid options are TCP, UDP, ESP, AH, SCTP, ICMP and L3_DEFAULT. The valid IP protocols are different for different load balancing products as described in [Load balancing features](https://cloud.google.com/load-balancing/docs/features#protocols_from_the_load_balancer_to_the_backends).",
17974          "type": "string",
17975          "enumDescriptions": [
17976            "",
17977            "",
17978            "",
17979            "",
17980            "",
17981            "",
17982            ""
17983          ],
17984          "enum": [
17985            "AH",
17986            "ESP",
17987            "ICMP",
17988            "L3_DEFAULT",
17989            "SCTP",
17990            "TCP",
17991            "UDP"
17992          ]
17993        },
17994        "portRange": {
17995          "description": "The ports, portRange, and allPorts fields are mutually exclusive. Only packets addressed to ports in the specified range will be forwarded to the backends configured with this forwarding rule. The portRange field has the following limitations: - It requires that the forwarding rule IPProtocol be TCP, UDP, or SCTP, and - It's applicable only to the following products: external passthrough Network Load Balancers, internal and external proxy Network Load Balancers, internal and external Application Load Balancers, external protocol forwarding, and Classic VPN. - Some products have restrictions on what ports can be used. See port specifications for details. For external forwarding rules, two or more forwarding rules cannot use the same [IPAddress, IPProtocol] pair, and cannot have overlapping portRanges. For internal forwarding rules within the same VPC network, two or more forwarding rules cannot use the same [IPAddress, IPProtocol] pair, and cannot have overlapping portRanges. @pattern: \\\\d+(?:-\\\\d+)?",
17996          "type": "string"
17997        },
17998        "ports": {
17999          "description": "The ports, portRange, and allPorts fields are mutually exclusive. Only packets addressed to ports in the specified range will be forwarded to the backends configured with this forwarding rule. The ports field has the following limitations: - It requires that the forwarding rule IPProtocol be TCP, UDP, or SCTP, and - It's applicable only to the following products: internal passthrough Network Load Balancers, backend service-based external passthrough Network Load Balancers, and internal protocol forwarding. - You can specify a list of up to five ports by number, separated by commas. The ports can be contiguous or discontiguous. For external forwarding rules, two or more forwarding rules cannot use the same [IPAddress, IPProtocol] pair if they share at least one port number. For internal forwarding rules within the same VPC network, two or more forwarding rules cannot use the same [IPAddress, IPProtocol] pair if they share at least one port number. @pattern: \\\\d+(?:-\\\\d+)?",
18000          "type": "array",
18001          "items": {
18002            "type": "string"
18003          }
18004        },
18005        "target": {
18006          "description": "The URL of the target resource to receive the matched traffic. For regional forwarding rules, this target must be in the same region as the forwarding rule. For global forwarding rules, this target must be a global load balancing resource. The forwarded traffic must be of a type appropriate to the target object. - For load balancers, see the \"Target\" column in [Port specifications](https://cloud.google.com/load-balancing/docs/forwarding-rule-concepts#ip_address_specifications). - For Private Service Connect forwarding rules that forward traffic to Google APIs, provide the name of a supported Google API bundle: - vpc-sc - APIs that support VPC Service Controls. - all-apis - All supported Google APIs. - For Private Service Connect forwarding rules that forward traffic to managed services, the target must be a service attachment. The target is not mutable once set as a service attachment. ",
18007          "type": "string"
18008        },
18009        "selfLink": {
18010          "description": "[Output Only] Server-defined URL for the resource.",
18011          "type": "string"
18012        },
18013        "loadBalancingScheme": {
18014          "description": "Specifies the forwarding rule type. For more information about forwarding rules, refer to Forwarding rule concepts.",
18015          "type": "string",
18016          "enumDescriptions": [
18017            "",
18018            "",
18019            "",
18020            "",
18021            "",
18022            ""
18023          ],
18024          "enum": [
18025            "EXTERNAL",
18026            "EXTERNAL_MANAGED",
18027            "INTERNAL",
18028            "INTERNAL_MANAGED",
18029            "INTERNAL_SELF_MANAGED",
18030            "INVALID"
18031          ]
18032        },
18033        "subnetwork": {
18034          "description": "This field identifies the subnetwork that the load balanced IP should belong to for this forwarding rule, used with internal load balancers and external passthrough Network Load Balancers with IPv6. If the network specified is in auto subnet mode, this field is optional. However, a subnetwork must be specified if the network is in custom subnet mode or when creating external forwarding rule with IPv6.",
18035          "type": "string"
18036        },
18037        "network": {
18038          "description": "This field is not used for global external load balancing. For internal passthrough Network Load Balancers, this field identifies the network that the load balanced IP should belong to for this forwarding rule. If the subnetwork is specified, the network of the subnetwork will be used. If neither subnetwork nor this field is specified, the default network will be used. For Private Service Connect forwarding rules that forward traffic to Google APIs, a network must be provided.",
18039          "type": "string"
18040        },
18041        "backendService": {
18042          "description": "Identifies the backend service to which the forwarding rule sends traffic. Required for internal and external passthrough Network Load Balancers; must be omitted for all other load balancer types.",
18043          "type": "string"
18044        },
18045        "serviceDirectoryRegistrations": {
18046          "description": "Service Directory resources to register this forwarding rule with. Currently, only supports a single Service Directory resource.",
18047          "type": "array",
18048          "items": {
18049            "$ref": "ForwardingRuleServiceDirectoryRegistration"
18050          }
18051        },
18052        "serviceLabel": {
18053          "description": "An optional prefix to the service name for this forwarding rule. If specified, the prefix is the first label of the fully qualified service name. The label must be 1-63 characters long, and comply with RFC1035. Specifically, the label must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash. This field is only used for internal load balancing.",
18054          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
18055          "type": "string"
18056        },
18057        "serviceName": {
18058          "description": "[Output Only] The internal fully qualified service name for this forwarding rule. This field is only used for internal load balancing.",
18059          "type": "string"
18060        },
18061        "networkTier": {
18062          "description": "This signifies the networking tier used for configuring this load balancer and can only take the following values: PREMIUM, STANDARD. For regional ForwardingRule, the valid values are PREMIUM and STANDARD. For GlobalForwardingRule, the valid value is PREMIUM. If this field is not specified, it is assumed to be PREMIUM. If IPAddress is specified, this value must be equal to the networkTier of the Address.",
18063          "type": "string",
18064          "enumDescriptions": [
18065            "Public internet quality with fixed bandwidth.",
18066            "High quality, Google-grade network tier, support for all networking products.",
18067            "Public internet quality, only limited support for other networking products.",
18068            "(Output only) Temporary tier for FIXED_STANDARD when fixed standard tier is expired or not configured."
18069          ],
18070          "enum": [
18071            "FIXED_STANDARD",
18072            "PREMIUM",
18073            "STANDARD",
18074            "STANDARD_OVERRIDES_FIXED_STANDARD"
18075          ]
18076        },
18077        "labels": {
18078          "description": "Labels for this resource. These can only be added or modified by the setLabels method. Each label key/value pair must comply with RFC1035. Label values may be empty.",
18079          "type": "object",
18080          "additionalProperties": {
18081            "type": "string"
18082          }
18083        },
18084        "labelFingerprint": {
18085          "description": "A fingerprint for the labels being applied to this resource, which is essentially a hash of the labels set used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve a ForwardingRule.",
18086          "type": "string",
18087          "format": "byte"
18088        },
18089        "ipVersion": {
18090          "description": "The IP Version that will be used by this forwarding rule. Valid options are IPV4 or IPV6.",
18091          "type": "string",
18092          "enumDescriptions": [
18093            "",
18094            "",
18095            ""
18096          ],
18097          "enum": [
18098            "IPV4",
18099            "IPV6",
18100            "UNSPECIFIED_VERSION"
18101          ]
18102        },
18103        "fingerprint": {
18104          "description": "Fingerprint of this resource. A hash of the contents stored in this object. This field is used in optimistic locking. This field will be ignored when inserting a ForwardingRule. Include the fingerprint in patch request to ensure that you do not overwrite changes that were applied from another concurrent request. To see the latest fingerprint, make a get() request to retrieve a ForwardingRule.",
18105          "type": "string",
18106          "format": "byte"
18107        },
18108        "allPorts": {
18109          "description": "The ports, portRange, and allPorts fields are mutually exclusive. Only packets addressed to ports in the specified range will be forwarded to the backends configured with this forwarding rule. The allPorts field has the following limitations: - It requires that the forwarding rule IPProtocol be TCP, UDP, SCTP, or L3_DEFAULT. - It's applicable only to the following products: internal passthrough Network Load Balancers, backend service-based external passthrough Network Load Balancers, and internal and external protocol forwarding. - Set this field to true to allow packets addressed to any port or packets lacking destination port information (for example, UDP fragments after the first fragment) to be forwarded to the backends configured with this forwarding rule. The L3_DEFAULT protocol requires allPorts be set to true. ",
18110          "type": "boolean"
18111        },
18112        "allowGlobalAccess": {
18113          "description": "If set to true, clients can access the internal passthrough Network Load Balancers, the regional internal Application Load Balancer, and the regional internal proxy Network Load Balancer from all regions. If false, only allows access from the local region the load balancer is located at. Note that for INTERNAL_MANAGED forwarding rules, this field cannot be changed after the forwarding rule is created.",
18114          "type": "boolean"
18115        },
18116        "metadataFilters": {
18117          "description": "Opaque filter criteria used by load balancer to restrict routing configuration to a limited set of xDS compliant clients. In their xDS requests to load balancer, xDS clients present node metadata. When there is a match, the relevant configuration is made available to those proxies. Otherwise, all the resources (e.g. TargetHttpProxy, UrlMap) referenced by the ForwardingRule are not visible to those proxies. For each metadataFilter in this list, if its filterMatchCriteria is set to MATCH_ANY, at least one of the filterLabels must match the corresponding label provided in the metadata. If its filterMatchCriteria is set to MATCH_ALL, then all of its filterLabels must match with corresponding labels provided in the metadata. If multiple metadataFilters are specified, all of them need to be satisfied in order to be considered a match. metadataFilters specified here will be applifed before those specified in the UrlMap that this ForwardingRule references. metadataFilters only applies to Loadbalancers that have their loadBalancingScheme set to INTERNAL_SELF_MANAGED.",
18118          "type": "array",
18119          "items": {
18120            "$ref": "MetadataFilter"
18121          }
18122        },
18123        "isMirroringCollector": {
18124          "description": "Indicates whether or not this load balancer can be used as a collector for packet mirroring. To prevent mirroring loops, instances behind this load balancer will not have their traffic mirrored even if a PacketMirroring rule applies to them. This can only be set to true for load balancers that have their loadBalancingScheme set to INTERNAL.",
18125          "type": "boolean"
18126        },
18127        "sourceIpRanges": {
18128          "description": "If not empty, this forwarding rule will only forward the traffic when the source IP address matches one of the IP addresses or CIDR ranges set here. Note that a forwarding rule can only have up to 64 source IP ranges, and this field can only be used with a regional forwarding rule whose scheme is EXTERNAL. Each source_ip_range entry should be either an IP address (for example, 1.2.3.4) or a CIDR range (for example, 1.2.3.0/24).",
18129          "type": "array",
18130          "items": {
18131            "type": "string"
18132          }
18133        },
18134        "pscConnectionId": {
18135          "description": "[Output Only] The PSC connection id of the PSC forwarding rule.",
18136          "type": "string",
18137          "format": "uint64"
18138        },
18139        "pscConnectionStatus": {
18140          "type": "string",
18141          "enumDescriptions": [
18142            "The connection has been accepted by the producer.",
18143            "The connection has been closed by the producer and will not serve traffic going forward.",
18144            "The connection has been accepted by the producer, but the producer needs to take further action before the forwarding rule can serve traffic.",
18145            "The connection is pending acceptance by the producer.",
18146            "The connection has been rejected by the producer.",
18147            ""
18148          ],
18149          "enum": [
18150            "ACCEPTED",
18151            "CLOSED",
18152            "NEEDS_ATTENTION",
18153            "PENDING",
18154            "REJECTED",
18155            "STATUS_UNSPECIFIED"
18156          ]
18157        },
18158        "baseForwardingRule": {
18159          "description": "[Output Only] The URL for the corresponding base forwarding rule. By base forwarding rule, we mean the forwarding rule that has the same IP address, protocol, and port settings with the current forwarding rule, but without sourceIPRanges specified. Always empty if the current forwarding rule does not have sourceIPRanges specified.",
18160          "type": "string"
18161        },
18162        "allowPscGlobalAccess": {
18163          "description": "This is used in PSC consumer ForwardingRule to control whether the PSC endpoint can be accessed from another region.",
18164          "type": "boolean"
18165        },
18166        "noAutomateDnsZone": {
18167          "description": "This is used in PSC consumer ForwardingRule to control whether it should try to auto-generate a DNS zone or not. Non-PSC forwarding rules do not use this field. Once set, this field is not mutable.",
18168          "type": "boolean"
18169        }
18170      }
18171    },
18172    "ForwardingRuleServiceDirectoryRegistration": {
18173      "id": "ForwardingRuleServiceDirectoryRegistration",
18174      "description": "Describes the auto-registration of the forwarding rule to Service Directory. The region and project of the Service Directory resource generated from this registration will be the same as this forwarding rule.",
18175      "type": "object",
18176      "properties": {
18177        "namespace": {
18178          "description": "Service Directory namespace to register the forwarding rule under.",
18179          "type": "string"
18180        },
18181        "service": {
18182          "description": "Service Directory service to register the forwarding rule under.",
18183          "type": "string"
18184        },
18185        "serviceDirectoryRegion": {
18186          "description": "[Optional] Service Directory region to register this global forwarding rule under. Default to \"us-central1\". Only used for PSC for Google APIs. All PSC for Google APIs forwarding rules on the same network should use the same Service Directory region.",
18187          "type": "string"
18188        }
18189      }
18190    },
18191    "MetadataFilter": {
18192      "id": "MetadataFilter",
18193      "description": "Opaque filter criteria used by load balancers to restrict routing configuration to a limited set of load balancing proxies. Proxies and sidecars involved in load balancing would typically present metadata to the load balancers that need to match criteria specified here. If a match takes place, the relevant configuration is made available to those proxies. For each metadataFilter in this list, if its filterMatchCriteria is set to MATCH_ANY, at least one of the filterLabels must match the corresponding label provided in the metadata. If its filterMatchCriteria is set to MATCH_ALL, then all of its filterLabels must match with corresponding labels provided in the metadata. An example for using metadataFilters would be: if load balancing involves Envoys, they receive routing configuration when values in metadataFilters match values supplied in of their XDS requests to loadbalancers.",
18194      "type": "object",
18195      "properties": {
18196        "filterMatchCriteria": {
18197          "description": "Specifies how individual filter label matches within the list of filterLabels and contributes toward the overall metadataFilter match. Supported values are: - MATCH_ANY: at least one of the filterLabels must have a matching label in the provided metadata. - MATCH_ALL: all filterLabels must have matching labels in the provided metadata. ",
18198          "type": "string",
18199          "enumDescriptions": [
18200            "Specifies that all filterLabels must match for the metadataFilter to be considered a match.",
18201            "Specifies that any filterLabel must match for the metadataFilter to be considered a match.",
18202            "Indicates that the match criteria was not set. A metadataFilter must never be created with this value."
18203          ],
18204          "enum": [
18205            "MATCH_ALL",
18206            "MATCH_ANY",
18207            "NOT_SET"
18208          ]
18209        },
18210        "filterLabels": {
18211          "description": "The list of label value pairs that must match labels in the provided metadata based on filterMatchCriteria This list must not be empty and can have at the most 64 entries.",
18212          "type": "array",
18213          "items": {
18214            "$ref": "MetadataFilterLabelMatch"
18215          }
18216        }
18217      }
18218    },
18219    "MetadataFilterLabelMatch": {
18220      "id": "MetadataFilterLabelMatch",
18221      "description": "MetadataFilter label name value pairs that are expected to match corresponding labels presented as metadata to the load balancer.",
18222      "type": "object",
18223      "properties": {
18224        "name": {
18225          "description": "Name of metadata label. The name can have a maximum length of 1024 characters and must be at least 1 character long.",
18226          "type": "string"
18227        },
18228        "value": {
18229          "description": "The value of the label must match the specified value. value can have a maximum length of 1024 characters.",
18230          "type": "string"
18231        }
18232      }
18233    },
18234    "TargetReference": {
18235      "id": "TargetReference",
18236      "type": "object",
18237      "properties": {
18238        "target": {
18239          "type": "string"
18240        }
18241      }
18242    },
18243    "ForwardingRuleAggregatedList": {
18244      "id": "ForwardingRuleAggregatedList",
18245      "type": "object",
18246      "properties": {
18247        "kind": {
18248          "description": "[Output Only] Type of resource. Always compute#forwardingRuleAggregatedList for lists of forwarding rules.",
18249          "default": "compute#forwardingRuleAggregatedList",
18250          "type": "string"
18251        },
18252        "id": {
18253          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
18254          "type": "string"
18255        },
18256        "items": {
18257          "description": "A list of ForwardingRulesScopedList resources.",
18258          "type": "object",
18259          "additionalProperties": {
18260            "description": "Name of the scope containing this set of addresses.",
18261            "$ref": "ForwardingRulesScopedList"
18262          }
18263        },
18264        "nextPageToken": {
18265          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
18266          "type": "string"
18267        },
18268        "selfLink": {
18269          "description": "[Output Only] Server-defined URL for this resource.",
18270          "type": "string"
18271        },
18272        "warning": {
18273          "description": "[Output Only] Informational warning message.",
18274          "type": "object",
18275          "properties": {
18276            "code": {
18277              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
18278              "type": "string",
18279              "enumDescriptions": [
18280                "Warning about failed cleanup of transient changes made by a failed operation.",
18281                "A link to a deprecated resource was created.",
18282                "When deploying and at least one of the resources has a type marked as deprecated",
18283                "The user created a boot disk that is larger than image size.",
18284                "When deploying and at least one of the resources has a type marked as experimental",
18285                "Warning that is present in an external api call",
18286                "Warning that value of a field has been overridden. Deprecated unused field.",
18287                "The operation involved use of an injected kernel, which is deprecated.",
18288                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
18289                "When deploying a deployment with a exceedingly large number of resources",
18290                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
18291                "A resource depends on a missing type",
18292                "The route's nextHopIp address is not assigned to an instance on the network.",
18293                "The route's next hop instance cannot ip forward.",
18294                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
18295                "The route's nextHopInstance URL refers to an instance that does not exist.",
18296                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
18297                "The route's next hop instance does not have a status of RUNNING.",
18298                "Error which is not critical. We decided to continue the process despite the mentioned error.",
18299                "No results are present on a particular list page.",
18300                "Success is reported, but some results may be missing due to errors",
18301                "The user attempted to use a resource that requires a TOS they have not accepted.",
18302                "Warning that a resource is in use.",
18303                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
18304                "When a resource schema validation is ignored.",
18305                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
18306                "When undeclared properties in the schema are present",
18307                "A given scope cannot be reached."
18308              ],
18309              "enumDeprecated": [
18310                false,
18311                false,
18312                false,
18313                false,
18314                false,
18315                false,
18316                true,
18317                false,
18318                false,
18319                false,
18320                false,
18321                false,
18322                false,
18323                false,
18324                false,
18325                false,
18326                false,
18327                false,
18328                false,
18329                false,
18330                false,
18331                false,
18332                false,
18333                false,
18334                false,
18335                false,
18336                false,
18337                false
18338              ],
18339              "enum": [
18340                "CLEANUP_FAILED",
18341                "DEPRECATED_RESOURCE_USED",
18342                "DEPRECATED_TYPE_USED",
18343                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
18344                "EXPERIMENTAL_TYPE_USED",
18345                "EXTERNAL_API_WARNING",
18346                "FIELD_VALUE_OVERRIDEN",
18347                "INJECTED_KERNELS_DEPRECATED",
18348                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
18349                "LARGE_DEPLOYMENT_WARNING",
18350                "LIST_OVERHEAD_QUOTA_EXCEED",
18351                "MISSING_TYPE_DEPENDENCY",
18352                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
18353                "NEXT_HOP_CANNOT_IP_FORWARD",
18354                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
18355                "NEXT_HOP_INSTANCE_NOT_FOUND",
18356                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
18357                "NEXT_HOP_NOT_RUNNING",
18358                "NOT_CRITICAL_ERROR",
18359                "NO_RESULTS_ON_PAGE",
18360                "PARTIAL_SUCCESS",
18361                "REQUIRED_TOS_AGREEMENT",
18362                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
18363                "RESOURCE_NOT_DELETED",
18364                "SCHEMA_VALIDATION_IGNORED",
18365                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
18366                "UNDECLARED_PROPERTIES",
18367                "UNREACHABLE"
18368              ]
18369            },
18370            "message": {
18371              "description": "[Output Only] A human-readable description of the warning code.",
18372              "type": "string"
18373            },
18374            "data": {
18375              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
18376              "type": "array",
18377              "items": {
18378                "type": "object",
18379                "properties": {
18380                  "key": {
18381                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
18382                    "type": "string"
18383                  },
18384                  "value": {
18385                    "description": "[Output Only] A warning data value corresponding to the key.",
18386                    "type": "string"
18387                  }
18388                }
18389              }
18390            }
18391          }
18392        },
18393        "unreachables": {
18394          "description": "[Output Only] Unreachable resources.",
18395          "type": "array",
18396          "items": {
18397            "type": "string"
18398          }
18399        }
18400      }
18401    },
18402    "ForwardingRulesScopedList": {
18403      "id": "ForwardingRulesScopedList",
18404      "type": "object",
18405      "properties": {
18406        "forwardingRules": {
18407          "description": "A list of forwarding rules contained in this scope.",
18408          "type": "array",
18409          "items": {
18410            "$ref": "ForwardingRule"
18411          }
18412        },
18413        "warning": {
18414          "description": "Informational warning which replaces the list of forwarding rules when the list is empty.",
18415          "type": "object",
18416          "properties": {
18417            "code": {
18418              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
18419              "type": "string",
18420              "enumDescriptions": [
18421                "Warning about failed cleanup of transient changes made by a failed operation.",
18422                "A link to a deprecated resource was created.",
18423                "When deploying and at least one of the resources has a type marked as deprecated",
18424                "The user created a boot disk that is larger than image size.",
18425                "When deploying and at least one of the resources has a type marked as experimental",
18426                "Warning that is present in an external api call",
18427                "Warning that value of a field has been overridden. Deprecated unused field.",
18428                "The operation involved use of an injected kernel, which is deprecated.",
18429                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
18430                "When deploying a deployment with a exceedingly large number of resources",
18431                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
18432                "A resource depends on a missing type",
18433                "The route's nextHopIp address is not assigned to an instance on the network.",
18434                "The route's next hop instance cannot ip forward.",
18435                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
18436                "The route's nextHopInstance URL refers to an instance that does not exist.",
18437                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
18438                "The route's next hop instance does not have a status of RUNNING.",
18439                "Error which is not critical. We decided to continue the process despite the mentioned error.",
18440                "No results are present on a particular list page.",
18441                "Success is reported, but some results may be missing due to errors",
18442                "The user attempted to use a resource that requires a TOS they have not accepted.",
18443                "Warning that a resource is in use.",
18444                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
18445                "When a resource schema validation is ignored.",
18446                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
18447                "When undeclared properties in the schema are present",
18448                "A given scope cannot be reached."
18449              ],
18450              "enumDeprecated": [
18451                false,
18452                false,
18453                false,
18454                false,
18455                false,
18456                false,
18457                true,
18458                false,
18459                false,
18460                false,
18461                false,
18462                false,
18463                false,
18464                false,
18465                false,
18466                false,
18467                false,
18468                false,
18469                false,
18470                false,
18471                false,
18472                false,
18473                false,
18474                false,
18475                false,
18476                false,
18477                false,
18478                false
18479              ],
18480              "enum": [
18481                "CLEANUP_FAILED",
18482                "DEPRECATED_RESOURCE_USED",
18483                "DEPRECATED_TYPE_USED",
18484                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
18485                "EXPERIMENTAL_TYPE_USED",
18486                "EXTERNAL_API_WARNING",
18487                "FIELD_VALUE_OVERRIDEN",
18488                "INJECTED_KERNELS_DEPRECATED",
18489                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
18490                "LARGE_DEPLOYMENT_WARNING",
18491                "LIST_OVERHEAD_QUOTA_EXCEED",
18492                "MISSING_TYPE_DEPENDENCY",
18493                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
18494                "NEXT_HOP_CANNOT_IP_FORWARD",
18495                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
18496                "NEXT_HOP_INSTANCE_NOT_FOUND",
18497                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
18498                "NEXT_HOP_NOT_RUNNING",
18499                "NOT_CRITICAL_ERROR",
18500                "NO_RESULTS_ON_PAGE",
18501                "PARTIAL_SUCCESS",
18502                "REQUIRED_TOS_AGREEMENT",
18503                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
18504                "RESOURCE_NOT_DELETED",
18505                "SCHEMA_VALIDATION_IGNORED",
18506                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
18507                "UNDECLARED_PROPERTIES",
18508                "UNREACHABLE"
18509              ]
18510            },
18511            "message": {
18512              "description": "[Output Only] A human-readable description of the warning code.",
18513              "type": "string"
18514            },
18515            "data": {
18516              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
18517              "type": "array",
18518              "items": {
18519                "type": "object",
18520                "properties": {
18521                  "key": {
18522                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
18523                    "type": "string"
18524                  },
18525                  "value": {
18526                    "description": "[Output Only] A warning data value corresponding to the key.",
18527                    "type": "string"
18528                  }
18529                }
18530              }
18531            }
18532          }
18533        }
18534      }
18535    },
18536    "HealthCheckServicesList": {
18537      "id": "HealthCheckServicesList",
18538      "type": "object",
18539      "properties": {
18540        "kind": {
18541          "description": "[Output Only] Type of the resource. Always compute#healthCheckServicesList for lists of HealthCheckServices.",
18542          "default": "compute#healthCheckServicesList",
18543          "type": "string"
18544        },
18545        "id": {
18546          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
18547          "type": "string"
18548        },
18549        "items": {
18550          "description": "A list of HealthCheckService resources.",
18551          "type": "array",
18552          "items": {
18553            "$ref": "HealthCheckService"
18554          }
18555        },
18556        "nextPageToken": {
18557          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
18558          "type": "string"
18559        },
18560        "selfLink": {
18561          "description": "[Output Only] Server-defined URL for this resource.",
18562          "type": "string"
18563        },
18564        "warning": {
18565          "description": "[Output Only] Informational warning message.",
18566          "type": "object",
18567          "properties": {
18568            "code": {
18569              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
18570              "type": "string",
18571              "enumDescriptions": [
18572                "Warning about failed cleanup of transient changes made by a failed operation.",
18573                "A link to a deprecated resource was created.",
18574                "When deploying and at least one of the resources has a type marked as deprecated",
18575                "The user created a boot disk that is larger than image size.",
18576                "When deploying and at least one of the resources has a type marked as experimental",
18577                "Warning that is present in an external api call",
18578                "Warning that value of a field has been overridden. Deprecated unused field.",
18579                "The operation involved use of an injected kernel, which is deprecated.",
18580                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
18581                "When deploying a deployment with a exceedingly large number of resources",
18582                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
18583                "A resource depends on a missing type",
18584                "The route's nextHopIp address is not assigned to an instance on the network.",
18585                "The route's next hop instance cannot ip forward.",
18586                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
18587                "The route's nextHopInstance URL refers to an instance that does not exist.",
18588                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
18589                "The route's next hop instance does not have a status of RUNNING.",
18590                "Error which is not critical. We decided to continue the process despite the mentioned error.",
18591                "No results are present on a particular list page.",
18592                "Success is reported, but some results may be missing due to errors",
18593                "The user attempted to use a resource that requires a TOS they have not accepted.",
18594                "Warning that a resource is in use.",
18595                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
18596                "When a resource schema validation is ignored.",
18597                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
18598                "When undeclared properties in the schema are present",
18599                "A given scope cannot be reached."
18600              ],
18601              "enumDeprecated": [
18602                false,
18603                false,
18604                false,
18605                false,
18606                false,
18607                false,
18608                true,
18609                false,
18610                false,
18611                false,
18612                false,
18613                false,
18614                false,
18615                false,
18616                false,
18617                false,
18618                false,
18619                false,
18620                false,
18621                false,
18622                false,
18623                false,
18624                false,
18625                false,
18626                false,
18627                false,
18628                false,
18629                false
18630              ],
18631              "enum": [
18632                "CLEANUP_FAILED",
18633                "DEPRECATED_RESOURCE_USED",
18634                "DEPRECATED_TYPE_USED",
18635                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
18636                "EXPERIMENTAL_TYPE_USED",
18637                "EXTERNAL_API_WARNING",
18638                "FIELD_VALUE_OVERRIDEN",
18639                "INJECTED_KERNELS_DEPRECATED",
18640                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
18641                "LARGE_DEPLOYMENT_WARNING",
18642                "LIST_OVERHEAD_QUOTA_EXCEED",
18643                "MISSING_TYPE_DEPENDENCY",
18644                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
18645                "NEXT_HOP_CANNOT_IP_FORWARD",
18646                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
18647                "NEXT_HOP_INSTANCE_NOT_FOUND",
18648                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
18649                "NEXT_HOP_NOT_RUNNING",
18650                "NOT_CRITICAL_ERROR",
18651                "NO_RESULTS_ON_PAGE",
18652                "PARTIAL_SUCCESS",
18653                "REQUIRED_TOS_AGREEMENT",
18654                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
18655                "RESOURCE_NOT_DELETED",
18656                "SCHEMA_VALIDATION_IGNORED",
18657                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
18658                "UNDECLARED_PROPERTIES",
18659                "UNREACHABLE"
18660              ]
18661            },
18662            "message": {
18663              "description": "[Output Only] A human-readable description of the warning code.",
18664              "type": "string"
18665            },
18666            "data": {
18667              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
18668              "type": "array",
18669              "items": {
18670                "type": "object",
18671                "properties": {
18672                  "key": {
18673                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
18674                    "type": "string"
18675                  },
18676                  "value": {
18677                    "description": "[Output Only] A warning data value corresponding to the key.",
18678                    "type": "string"
18679                  }
18680                }
18681              }
18682            }
18683          }
18684        }
18685      }
18686    },
18687    "HealthCheckService": {
18688      "id": "HealthCheckService",
18689      "description": "Represents a Health-Check as a Service resource.",
18690      "type": "object",
18691      "properties": {
18692        "kind": {
18693          "description": "[Output only] Type of the resource. Always compute#healthCheckServicefor health check services.",
18694          "default": "compute#healthCheckService",
18695          "type": "string"
18696        },
18697        "id": {
18698          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
18699          "type": "string",
18700          "format": "uint64"
18701        },
18702        "creationTimestamp": {
18703          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
18704          "type": "string"
18705        },
18706        "selfLink": {
18707          "description": "[Output Only] Server-defined URL for the resource.",
18708          "type": "string"
18709        },
18710        "name": {
18711          "description": "Name of the resource. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
18712          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
18713          "type": "string"
18714        },
18715        "description": {
18716          "description": "An optional description of this resource. Provide this property when you create the resource.",
18717          "type": "string"
18718        },
18719        "region": {
18720          "description": "[Output Only] URL of the region where the health check service resides. This field is not applicable to global health check services. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
18721          "type": "string"
18722        },
18723        "healthStatusAggregationPolicy": {
18724          "description": "Optional. Policy for how the results from multiple health checks for the same endpoint are aggregated. Defaults to NO_AGGREGATION if unspecified. - NO_AGGREGATION. An EndpointHealth message is returned for each pair in the health check service. - AND. If any health check of an endpoint reports UNHEALTHY, then UNHEALTHY is the HealthState of the endpoint. If all health checks report HEALTHY, the HealthState of the endpoint is HEALTHY. . This is only allowed with regional HealthCheckService.",
18725          "type": "string",
18726          "enumDescriptions": [
18727            "If any backend's health check reports UNHEALTHY, then UNHEALTHY is the HealthState of the entire health check service. If all backend's are healthy, the HealthState of the health check service is HEALTHY.",
18728            "An EndpointHealth message is returned for each backend in the health check service."
18729          ],
18730          "enum": [
18731            "AND",
18732            "NO_AGGREGATION"
18733          ]
18734        },
18735        "healthChecks": {
18736          "description": "A list of URLs to the HealthCheck resources. Must have at least one HealthCheck, and not more than 10 for regional HealthCheckService, and not more than 1 for global HealthCheckService. HealthCheck resources must have portSpecification=USE_SERVING_PORT or portSpecification=USE_FIXED_PORT. For regional HealthCheckService, the HealthCheck must be regional and in the same region. For global HealthCheckService, HealthCheck must be global. Mix of regional and global HealthChecks is not supported. Multiple regional HealthChecks must belong to the same region. Regional HealthChecks must belong to the same region as zones of NetworkEndpointGroups. For global HealthCheckService using global INTERNET_IP_PORT NetworkEndpointGroups, the global HealthChecks must specify sourceRegions, and HealthChecks that specify sourceRegions can only be used with global INTERNET_IP_PORT NetworkEndpointGroups.",
18737          "type": "array",
18738          "items": {
18739            "type": "string"
18740          }
18741        },
18742        "networkEndpointGroups": {
18743          "description": "A list of URLs to the NetworkEndpointGroup resources. Must not have more than 100. For regional HealthCheckService, NEGs must be in zones in the region of the HealthCheckService. For global HealthCheckServices, the NetworkEndpointGroups must be global INTERNET_IP_PORT.",
18744          "type": "array",
18745          "items": {
18746            "type": "string"
18747          }
18748        },
18749        "notificationEndpoints": {
18750          "description": "A list of URLs to the NotificationEndpoint resources. Must not have more than 10. A list of endpoints for receiving notifications of change in health status. For regional HealthCheckService, NotificationEndpoint must be regional and in the same region. For global HealthCheckService, NotificationEndpoint must be global.",
18751          "type": "array",
18752          "items": {
18753            "type": "string"
18754          }
18755        },
18756        "fingerprint": {
18757          "description": "Fingerprint of this resource. A hash of the contents stored in this object. This field is used in optimistic locking. This field will be ignored when inserting a HealthCheckService. An up-to-date fingerprint must be provided in order to patch/update the HealthCheckService; Otherwise, the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve the HealthCheckService.",
18758          "type": "string",
18759          "format": "byte"
18760        }
18761      }
18762    },
18763    "HealthCheckList": {
18764      "id": "HealthCheckList",
18765      "description": "Contains a list of HealthCheck resources.",
18766      "type": "object",
18767      "properties": {
18768        "kind": {
18769          "description": "Type of resource.",
18770          "default": "compute#healthCheckList",
18771          "type": "string"
18772        },
18773        "id": {
18774          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
18775          "type": "string"
18776        },
18777        "items": {
18778          "description": "A list of HealthCheck resources.",
18779          "type": "array",
18780          "items": {
18781            "$ref": "HealthCheck"
18782          }
18783        },
18784        "nextPageToken": {
18785          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
18786          "type": "string"
18787        },
18788        "selfLink": {
18789          "description": "[Output Only] Server-defined URL for this resource.",
18790          "type": "string"
18791        },
18792        "warning": {
18793          "description": "[Output Only] Informational warning message.",
18794          "type": "object",
18795          "properties": {
18796            "code": {
18797              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
18798              "type": "string",
18799              "enumDescriptions": [
18800                "Warning about failed cleanup of transient changes made by a failed operation.",
18801                "A link to a deprecated resource was created.",
18802                "When deploying and at least one of the resources has a type marked as deprecated",
18803                "The user created a boot disk that is larger than image size.",
18804                "When deploying and at least one of the resources has a type marked as experimental",
18805                "Warning that is present in an external api call",
18806                "Warning that value of a field has been overridden. Deprecated unused field.",
18807                "The operation involved use of an injected kernel, which is deprecated.",
18808                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
18809                "When deploying a deployment with a exceedingly large number of resources",
18810                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
18811                "A resource depends on a missing type",
18812                "The route's nextHopIp address is not assigned to an instance on the network.",
18813                "The route's next hop instance cannot ip forward.",
18814                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
18815                "The route's nextHopInstance URL refers to an instance that does not exist.",
18816                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
18817                "The route's next hop instance does not have a status of RUNNING.",
18818                "Error which is not critical. We decided to continue the process despite the mentioned error.",
18819                "No results are present on a particular list page.",
18820                "Success is reported, but some results may be missing due to errors",
18821                "The user attempted to use a resource that requires a TOS they have not accepted.",
18822                "Warning that a resource is in use.",
18823                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
18824                "When a resource schema validation is ignored.",
18825                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
18826                "When undeclared properties in the schema are present",
18827                "A given scope cannot be reached."
18828              ],
18829              "enumDeprecated": [
18830                false,
18831                false,
18832                false,
18833                false,
18834                false,
18835                false,
18836                true,
18837                false,
18838                false,
18839                false,
18840                false,
18841                false,
18842                false,
18843                false,
18844                false,
18845                false,
18846                false,
18847                false,
18848                false,
18849                false,
18850                false,
18851                false,
18852                false,
18853                false,
18854                false,
18855                false,
18856                false,
18857                false
18858              ],
18859              "enum": [
18860                "CLEANUP_FAILED",
18861                "DEPRECATED_RESOURCE_USED",
18862                "DEPRECATED_TYPE_USED",
18863                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
18864                "EXPERIMENTAL_TYPE_USED",
18865                "EXTERNAL_API_WARNING",
18866                "FIELD_VALUE_OVERRIDEN",
18867                "INJECTED_KERNELS_DEPRECATED",
18868                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
18869                "LARGE_DEPLOYMENT_WARNING",
18870                "LIST_OVERHEAD_QUOTA_EXCEED",
18871                "MISSING_TYPE_DEPENDENCY",
18872                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
18873                "NEXT_HOP_CANNOT_IP_FORWARD",
18874                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
18875                "NEXT_HOP_INSTANCE_NOT_FOUND",
18876                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
18877                "NEXT_HOP_NOT_RUNNING",
18878                "NOT_CRITICAL_ERROR",
18879                "NO_RESULTS_ON_PAGE",
18880                "PARTIAL_SUCCESS",
18881                "REQUIRED_TOS_AGREEMENT",
18882                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
18883                "RESOURCE_NOT_DELETED",
18884                "SCHEMA_VALIDATION_IGNORED",
18885                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
18886                "UNDECLARED_PROPERTIES",
18887                "UNREACHABLE"
18888              ]
18889            },
18890            "message": {
18891              "description": "[Output Only] A human-readable description of the warning code.",
18892              "type": "string"
18893            },
18894            "data": {
18895              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
18896              "type": "array",
18897              "items": {
18898                "type": "object",
18899                "properties": {
18900                  "key": {
18901                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
18902                    "type": "string"
18903                  },
18904                  "value": {
18905                    "description": "[Output Only] A warning data value corresponding to the key.",
18906                    "type": "string"
18907                  }
18908                }
18909              }
18910            }
18911          }
18912        }
18913      }
18914    },
18915    "HealthCheck": {
18916      "id": "HealthCheck",
18917      "description": "Represents a health check resource. Google Compute Engine has two health check resources: * [Regional](/compute/docs/reference/rest/v1/regionHealthChecks) * [Global](/compute/docs/reference/rest/v1/healthChecks) These health check resources can be used for load balancing and for autohealing VMs in a managed instance group (MIG). **Load balancing** Health check requirements vary depending on the type of load balancer. For details about the type of health check supported for each load balancer and corresponding backend type, see Health checks overview: Load balancer guide. **Autohealing in MIGs** The health checks that you use for autohealing VMs in a MIG can be either regional or global. For more information, see Set up an application health check and autohealing. For more information, see Health checks overview.",
18918      "type": "object",
18919      "properties": {
18920        "kind": {
18921          "description": "Type of the resource.",
18922          "default": "compute#healthCheck",
18923          "type": "string"
18924        },
18925        "id": {
18926          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
18927          "type": "string",
18928          "format": "uint64"
18929        },
18930        "creationTimestamp": {
18931          "description": "[Output Only] Creation timestamp in 3339 text format.",
18932          "type": "string"
18933        },
18934        "name": {
18935          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. For example, a name that is 1-63 characters long, matches the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?`, and otherwise complies with RFC1035. This regular expression describes a name where the first character is a lowercase letter, and all following characters are a dash, lowercase letter, or digit, except the last character, which isn't a dash.",
18936          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
18937          "type": "string"
18938        },
18939        "description": {
18940          "description": "An optional description of this resource. Provide this property when you create the resource.",
18941          "type": "string"
18942        },
18943        "checkIntervalSec": {
18944          "description": "How often (in seconds) to send a health check. The default value is 5 seconds.",
18945          "type": "integer",
18946          "format": "int32"
18947        },
18948        "timeoutSec": {
18949          "description": "How long (in seconds) to wait before claiming failure. The default value is 5 seconds. It is invalid for timeoutSec to have greater value than checkIntervalSec.",
18950          "type": "integer",
18951          "format": "int32"
18952        },
18953        "unhealthyThreshold": {
18954          "description": "A so-far healthy instance will be marked unhealthy after this many consecutive failures. The default value is 2.",
18955          "type": "integer",
18956          "format": "int32"
18957        },
18958        "healthyThreshold": {
18959          "description": "A so-far unhealthy instance will be marked healthy after this many consecutive successes. The default value is 2.",
18960          "type": "integer",
18961          "format": "int32"
18962        },
18963        "type": {
18964          "description": "Specifies the type of the healthCheck, either TCP, SSL, HTTP, HTTPS, HTTP2 or GRPC. Exactly one of the protocol-specific health check fields must be specified, which must match type field.",
18965          "type": "string",
18966          "enumDescriptions": [
18967            "",
18968            "",
18969            "",
18970            "",
18971            "",
18972            "",
18973            ""
18974          ],
18975          "enum": [
18976            "GRPC",
18977            "HTTP",
18978            "HTTP2",
18979            "HTTPS",
18980            "INVALID",
18981            "SSL",
18982            "TCP"
18983          ]
18984        },
18985        "tcpHealthCheck": {
18986          "$ref": "TCPHealthCheck"
18987        },
18988        "sslHealthCheck": {
18989          "$ref": "SSLHealthCheck"
18990        },
18991        "httpHealthCheck": {
18992          "$ref": "HTTPHealthCheck"
18993        },
18994        "httpsHealthCheck": {
18995          "$ref": "HTTPSHealthCheck"
18996        },
18997        "http2HealthCheck": {
18998          "$ref": "HTTP2HealthCheck"
18999        },
19000        "grpcHealthCheck": {
19001          "$ref": "GRPCHealthCheck"
19002        },
19003        "selfLink": {
19004          "description": "[Output Only] Server-defined URL for the resource.",
19005          "type": "string"
19006        },
19007        "region": {
19008          "description": "[Output Only] Region where the health check resides. Not applicable to global health checks.",
19009          "type": "string"
19010        },
19011        "logConfig": {
19012          "description": "Configure logging on this health check.",
19013          "$ref": "HealthCheckLogConfig"
19014        }
19015      }
19016    },
19017    "TCPHealthCheck": {
19018      "id": "TCPHealthCheck",
19019      "type": "object",
19020      "properties": {
19021        "port": {
19022          "description": "The TCP port number to which the health check prober sends packets. The default value is 80. Valid values are 1 through 65535.",
19023          "type": "integer",
19024          "format": "int32"
19025        },
19026        "portName": {
19027          "description": "Not supported.",
19028          "type": "string"
19029        },
19030        "portSpecification": {
19031          "description": "Specifies how a port is selected for health checking. Can be one of the following values: USE_FIXED_PORT: Specifies a port number explicitly using the port field in the health check. Supported by backend services for passthrough load balancers and backend services for proxy load balancers. Not supported by target pools. The health check supports all backends supported by the backend service provided the backend can be health checked. For example, GCE_VM_IP network endpoint groups, GCE_VM_IP_PORT network endpoint groups, and instance group backends. USE_NAMED_PORT: Not supported. USE_SERVING_PORT: Provides an indirect method of specifying the health check port by referring to the backend service. Only supported by backend services for proxy load balancers. Not supported by target pools. Not supported by backend services for passthrough load balancers. Supports all backends that can be health checked; for example, GCE_VM_IP_PORT network endpoint groups and instance group backends. For GCE_VM_IP_PORT network endpoint group backends, the health check uses the port number specified for each endpoint in the network endpoint group. For instance group backends, the health check uses the port number determined by looking up the backend service's named port in the instance group's list of named ports.",
19032          "type": "string",
19033          "enumDescriptions": [
19034            "The port number in the health check's port is used for health checking. Applies to network endpoint group and instance group backends.",
19035            "Not supported.",
19036            "For network endpoint group backends, the health check uses the port number specified on each endpoint in the network endpoint group. For instance group backends, the health check uses the port number specified for the backend service's named port defined in the instance group's named ports."
19037          ],
19038          "enum": [
19039            "USE_FIXED_PORT",
19040            "USE_NAMED_PORT",
19041            "USE_SERVING_PORT"
19042          ]
19043        },
19044        "request": {
19045          "description": "Instructs the health check prober to send this exact ASCII string, up to 1024 bytes in length, after establishing the TCP connection.",
19046          "type": "string"
19047        },
19048        "response": {
19049          "description": "Creates a content-based TCP health check. In addition to establishing a TCP connection, you can configure the health check to pass only when the backend sends this exact response ASCII string, up to 1024 bytes in length. For details, see: https://cloud.google.com/load-balancing/docs/health-check-concepts#criteria-protocol-ssl-tcp",
19050          "type": "string"
19051        },
19052        "proxyHeader": {
19053          "description": "Specifies the type of proxy header to append before sending data to the backend, either NONE or PROXY_V1. The default is NONE.",
19054          "type": "string",
19055          "enumDescriptions": [
19056            "",
19057            ""
19058          ],
19059          "enum": [
19060            "NONE",
19061            "PROXY_V1"
19062          ]
19063        }
19064      }
19065    },
19066    "SSLHealthCheck": {
19067      "id": "SSLHealthCheck",
19068      "type": "object",
19069      "properties": {
19070        "port": {
19071          "description": "The TCP port number to which the health check prober sends packets. The default value is 443. Valid values are 1 through 65535.",
19072          "type": "integer",
19073          "format": "int32"
19074        },
19075        "portName": {
19076          "description": "Not supported.",
19077          "type": "string"
19078        },
19079        "portSpecification": {
19080          "description": "Specifies how a port is selected for health checking. Can be one of the following values: USE_FIXED_PORT: Specifies a port number explicitly using the port field in the health check. Supported by backend services for passthrough load balancers and backend services for proxy load balancers. Not supported by target pools. The health check supports all backends supported by the backend service provided the backend can be health checked. For example, GCE_VM_IP network endpoint groups, GCE_VM_IP_PORT network endpoint groups, and instance group backends. USE_NAMED_PORT: Not supported. USE_SERVING_PORT: Provides an indirect method of specifying the health check port by referring to the backend service. Only supported by backend services for proxy load balancers. Not supported by target pools. Not supported by backend services for passthrough load balancers. Supports all backends that can be health checked; for example, GCE_VM_IP_PORT network endpoint groups and instance group backends. For GCE_VM_IP_PORT network endpoint group backends, the health check uses the port number specified for each endpoint in the network endpoint group. For instance group backends, the health check uses the port number determined by looking up the backend service's named port in the instance group's list of named ports.",
19081          "type": "string",
19082          "enumDescriptions": [
19083            "The port number in the health check's port is used for health checking. Applies to network endpoint group and instance group backends.",
19084            "Not supported.",
19085            "For network endpoint group backends, the health check uses the port number specified on each endpoint in the network endpoint group. For instance group backends, the health check uses the port number specified for the backend service's named port defined in the instance group's named ports."
19086          ],
19087          "enum": [
19088            "USE_FIXED_PORT",
19089            "USE_NAMED_PORT",
19090            "USE_SERVING_PORT"
19091          ]
19092        },
19093        "request": {
19094          "description": "Instructs the health check prober to send this exact ASCII string, up to 1024 bytes in length, after establishing the TCP connection and SSL handshake.",
19095          "type": "string"
19096        },
19097        "response": {
19098          "description": "Creates a content-based SSL health check. In addition to establishing a TCP connection and the TLS handshake, you can configure the health check to pass only when the backend sends this exact response ASCII string, up to 1024 bytes in length. For details, see: https://cloud.google.com/load-balancing/docs/health-check-concepts#criteria-protocol-ssl-tcp",
19099          "type": "string"
19100        },
19101        "proxyHeader": {
19102          "description": "Specifies the type of proxy header to append before sending data to the backend, either NONE or PROXY_V1. The default is NONE.",
19103          "type": "string",
19104          "enumDescriptions": [
19105            "",
19106            ""
19107          ],
19108          "enum": [
19109            "NONE",
19110            "PROXY_V1"
19111          ]
19112        }
19113      }
19114    },
19115    "HTTPHealthCheck": {
19116      "id": "HTTPHealthCheck",
19117      "type": "object",
19118      "properties": {
19119        "port": {
19120          "description": "The TCP port number to which the health check prober sends packets. The default value is 80. Valid values are 1 through 65535.",
19121          "type": "integer",
19122          "format": "int32"
19123        },
19124        "portName": {
19125          "description": "Not supported.",
19126          "type": "string"
19127        },
19128        "portSpecification": {
19129          "description": "Specifies how a port is selected for health checking. Can be one of the following values: USE_FIXED_PORT: Specifies a port number explicitly using the port field in the health check. Supported by backend services for passthrough load balancers and backend services for proxy load balancers. Also supported in legacy HTTP health checks for target pools. The health check supports all backends supported by the backend service provided the backend can be health checked. For example, GCE_VM_IP network endpoint groups, GCE_VM_IP_PORT network endpoint groups, and instance group backends. USE_NAMED_PORT: Not supported. USE_SERVING_PORT: Provides an indirect method of specifying the health check port by referring to the backend service. Only supported by backend services for proxy load balancers. Not supported by target pools. Not supported by backend services for pass-through load balancers. Supports all backends that can be health checked; for example, GCE_VM_IP_PORT network endpoint groups and instance group backends. For GCE_VM_IP_PORT network endpoint group backends, the health check uses the port number specified for each endpoint in the network endpoint group. For instance group backends, the health check uses the port number determined by looking up the backend service's named port in the instance group's list of named ports.",
19130          "type": "string",
19131          "enumDescriptions": [
19132            "The port number in the health check's port is used for health checking. Applies to network endpoint group and instance group backends.",
19133            "Not supported.",
19134            "For network endpoint group backends, the health check uses the port number specified on each endpoint in the network endpoint group. For instance group backends, the health check uses the port number specified for the backend service's named port defined in the instance group's named ports."
19135          ],
19136          "enum": [
19137            "USE_FIXED_PORT",
19138            "USE_NAMED_PORT",
19139            "USE_SERVING_PORT"
19140          ]
19141        },
19142        "host": {
19143          "description": "The value of the host header in the HTTP health check request. If left empty (default value), the host header is set to the destination IP address to which health check packets are sent. The destination IP address depends on the type of load balancer. For details, see: https://cloud.google.com/load-balancing/docs/health-check-concepts#hc-packet-dest",
19144          "type": "string"
19145        },
19146        "requestPath": {
19147          "description": "The request path of the HTTP health check request. The default value is /.",
19148          "type": "string"
19149        },
19150        "proxyHeader": {
19151          "description": "Specifies the type of proxy header to append before sending data to the backend, either NONE or PROXY_V1. The default is NONE.",
19152          "type": "string",
19153          "enumDescriptions": [
19154            "",
19155            ""
19156          ],
19157          "enum": [
19158            "NONE",
19159            "PROXY_V1"
19160          ]
19161        },
19162        "response": {
19163          "description": "Creates a content-based HTTP health check. In addition to the required HTTP 200 (OK) status code, you can configure the health check to pass only when the backend sends this specific ASCII response string within the first 1024 bytes of the HTTP response body. For details, see: https://cloud.google.com/load-balancing/docs/health-check-concepts#criteria-protocol-http",
19164          "type": "string"
19165        }
19166      }
19167    },
19168    "HTTPSHealthCheck": {
19169      "id": "HTTPSHealthCheck",
19170      "type": "object",
19171      "properties": {
19172        "port": {
19173          "description": "The TCP port number to which the health check prober sends packets. The default value is 443. Valid values are 1 through 65535.",
19174          "type": "integer",
19175          "format": "int32"
19176        },
19177        "portName": {
19178          "description": "Not supported.",
19179          "type": "string"
19180        },
19181        "portSpecification": {
19182          "description": "Specifies how a port is selected for health checking. Can be one of the following values: USE_FIXED_PORT: Specifies a port number explicitly using the port field in the health check. Supported by backend services for passthrough load balancers and backend services for proxy load balancers. Not supported by target pools. The health check supports all backends supported by the backend service provided the backend can be health checked. For example, GCE_VM_IP network endpoint groups, GCE_VM_IP_PORT network endpoint groups, and instance group backends. USE_NAMED_PORT: Not supported. USE_SERVING_PORT: Provides an indirect method of specifying the health check port by referring to the backend service. Only supported by backend services for proxy load balancers. Not supported by target pools. Not supported by backend services for passthrough load balancers. Supports all backends that can be health checked; for example, GCE_VM_IP_PORT network endpoint groups and instance group backends. For GCE_VM_IP_PORT network endpoint group backends, the health check uses the port number specified for each endpoint in the network endpoint group. For instance group backends, the health check uses the port number determined by looking up the backend service's named port in the instance group's list of named ports.",
19183          "type": "string",
19184          "enumDescriptions": [
19185            "The port number in the health check's port is used for health checking. Applies to network endpoint group and instance group backends.",
19186            "Not supported.",
19187            "For network endpoint group backends, the health check uses the port number specified on each endpoint in the network endpoint group. For instance group backends, the health check uses the port number specified for the backend service's named port defined in the instance group's named ports."
19188          ],
19189          "enum": [
19190            "USE_FIXED_PORT",
19191            "USE_NAMED_PORT",
19192            "USE_SERVING_PORT"
19193          ]
19194        },
19195        "host": {
19196          "description": "The value of the host header in the HTTPS health check request. If left empty (default value), the host header is set to the destination IP address to which health check packets are sent. The destination IP address depends on the type of load balancer. For details, see: https://cloud.google.com/load-balancing/docs/health-check-concepts#hc-packet-dest",
19197          "type": "string"
19198        },
19199        "requestPath": {
19200          "description": "The request path of the HTTPS health check request. The default value is /.",
19201          "type": "string"
19202        },
19203        "proxyHeader": {
19204          "description": "Specifies the type of proxy header to append before sending data to the backend, either NONE or PROXY_V1. The default is NONE.",
19205          "type": "string",
19206          "enumDescriptions": [
19207            "",
19208            ""
19209          ],
19210          "enum": [
19211            "NONE",
19212            "PROXY_V1"
19213          ]
19214        },
19215        "response": {
19216          "description": "Creates a content-based HTTPS health check. In addition to the required HTTP 200 (OK) status code, you can configure the health check to pass only when the backend sends this specific ASCII response string within the first 1024 bytes of the HTTP response body. For details, see: https://cloud.google.com/load-balancing/docs/health-check-concepts#criteria-protocol-http",
19217          "type": "string"
19218        }
19219      }
19220    },
19221    "HTTP2HealthCheck": {
19222      "id": "HTTP2HealthCheck",
19223      "type": "object",
19224      "properties": {
19225        "port": {
19226          "description": "The TCP port number to which the health check prober sends packets. The default value is 443. Valid values are 1 through 65535.",
19227          "type": "integer",
19228          "format": "int32"
19229        },
19230        "portName": {
19231          "description": "Not supported.",
19232          "type": "string"
19233        },
19234        "portSpecification": {
19235          "description": "Specifies how a port is selected for health checking. Can be one of the following values: USE_FIXED_PORT: Specifies a port number explicitly using the port field in the health check. Supported by backend services for passthrough load balancers and backend services for proxy load balancers. Not supported by target pools. The health check supports all backends supported by the backend service provided the backend can be health checked. For example, GCE_VM_IP network endpoint groups, GCE_VM_IP_PORT network endpoint groups, and instance group backends. USE_NAMED_PORT: Not supported. USE_SERVING_PORT: Provides an indirect method of specifying the health check port by referring to the backend service. Only supported by backend services for proxy load balancers. Not supported by target pools. Not supported by backend services for passthrough load balancers. Supports all backends that can be health checked; for example, GCE_VM_IP_PORT network endpoint groups and instance group backends. For GCE_VM_IP_PORT network endpoint group backends, the health check uses the port number specified for each endpoint in the network endpoint group. For instance group backends, the health check uses the port number determined by looking up the backend service's named port in the instance group's list of named ports.",
19236          "type": "string",
19237          "enumDescriptions": [
19238            "The port number in the health check's port is used for health checking. Applies to network endpoint group and instance group backends.",
19239            "Not supported.",
19240            "For network endpoint group backends, the health check uses the port number specified on each endpoint in the network endpoint group. For instance group backends, the health check uses the port number specified for the backend service's named port defined in the instance group's named ports."
19241          ],
19242          "enum": [
19243            "USE_FIXED_PORT",
19244            "USE_NAMED_PORT",
19245            "USE_SERVING_PORT"
19246          ]
19247        },
19248        "host": {
19249          "description": "The value of the host header in the HTTP/2 health check request. If left empty (default value), the host header is set to the destination IP address to which health check packets are sent. The destination IP address depends on the type of load balancer. For details, see: https://cloud.google.com/load-balancing/docs/health-check-concepts#hc-packet-dest",
19250          "type": "string"
19251        },
19252        "requestPath": {
19253          "description": "The request path of the HTTP/2 health check request. The default value is /.",
19254          "type": "string"
19255        },
19256        "proxyHeader": {
19257          "description": "Specifies the type of proxy header to append before sending data to the backend, either NONE or PROXY_V1. The default is NONE.",
19258          "type": "string",
19259          "enumDescriptions": [
19260            "",
19261            ""
19262          ],
19263          "enum": [
19264            "NONE",
19265            "PROXY_V1"
19266          ]
19267        },
19268        "response": {
19269          "description": "Creates a content-based HTTP/2 health check. In addition to the required HTTP 200 (OK) status code, you can configure the health check to pass only when the backend sends this specific ASCII response string within the first 1024 bytes of the HTTP response body. For details, see: https://cloud.google.com/load-balancing/docs/health-check-concepts#criteria-protocol-http",
19270          "type": "string"
19271        }
19272      }
19273    },
19274    "GRPCHealthCheck": {
19275      "id": "GRPCHealthCheck",
19276      "type": "object",
19277      "properties": {
19278        "port": {
19279          "description": "The TCP port number to which the health check prober sends packets. Valid values are 1 through 65535.",
19280          "type": "integer",
19281          "format": "int32"
19282        },
19283        "portName": {
19284          "description": "Not supported.",
19285          "type": "string"
19286        },
19287        "portSpecification": {
19288          "description": "Specifies how a port is selected for health checking. Can be one of the following values: USE_FIXED_PORT: Specifies a port number explicitly using the port field in the health check. Supported by backend services for passthrough load balancers and backend services for proxy load balancers. Not supported by target pools. The health check supports all backends supported by the backend service provided the backend can be health checked. For example, GCE_VM_IP network endpoint groups, GCE_VM_IP_PORT network endpoint groups, and instance group backends. USE_NAMED_PORT: Not supported. USE_SERVING_PORT: Provides an indirect method of specifying the health check port by referring to the backend service. Only supported by backend services for proxy load balancers. Not supported by target pools. Not supported by backend services for passthrough load balancers. Supports all backends that can be health checked; for example, GCE_VM_IP_PORT network endpoint groups and instance group backends. For GCE_VM_IP_PORT network endpoint group backends, the health check uses the port number specified for each endpoint in the network endpoint group. For instance group backends, the health check uses the port number determined by looking up the backend service's named port in the instance group's list of named ports.",
19289          "type": "string",
19290          "enumDescriptions": [
19291            "The port number in the health check's port is used for health checking. Applies to network endpoint group and instance group backends.",
19292            "Not supported.",
19293            "For network endpoint group backends, the health check uses the port number specified on each endpoint in the network endpoint group. For instance group backends, the health check uses the port number specified for the backend service's named port defined in the instance group's named ports."
19294          ],
19295          "enum": [
19296            "USE_FIXED_PORT",
19297            "USE_NAMED_PORT",
19298            "USE_SERVING_PORT"
19299          ]
19300        },
19301        "grpcServiceName": {
19302          "description": "The gRPC service name for the health check. This field is optional. The value of grpc_service_name has the following meanings by convention: - Empty service_name means the overall status of all services at the backend. - Non-empty service_name means the health of that gRPC service, as defined by the owner of the service. The grpc_service_name can only be ASCII.",
19303          "type": "string"
19304        }
19305      }
19306    },
19307    "HealthCheckLogConfig": {
19308      "id": "HealthCheckLogConfig",
19309      "description": "Configuration of logging on a health check. If logging is enabled, logs will be exported to Stackdriver.",
19310      "type": "object",
19311      "properties": {
19312        "enable": {
19313          "description": "Indicates whether or not to export logs. This is false by default, which means no health check logging will be done.",
19314          "type": "boolean"
19315        }
19316      }
19317    },
19318    "HealthChecksAggregatedList": {
19319      "id": "HealthChecksAggregatedList",
19320      "type": "object",
19321      "properties": {
19322        "kind": {
19323          "description": "Type of resource.",
19324          "default": "compute#healthChecksAggregatedList",
19325          "type": "string"
19326        },
19327        "id": {
19328          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
19329          "type": "string"
19330        },
19331        "items": {
19332          "description": "A list of HealthChecksScopedList resources.",
19333          "type": "object",
19334          "additionalProperties": {
19335            "description": "Name of the scope containing this set of HealthChecks.",
19336            "$ref": "HealthChecksScopedList"
19337          }
19338        },
19339        "nextPageToken": {
19340          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
19341          "type": "string"
19342        },
19343        "selfLink": {
19344          "description": "[Output Only] Server-defined URL for this resource.",
19345          "type": "string"
19346        },
19347        "warning": {
19348          "description": "[Output Only] Informational warning message.",
19349          "type": "object",
19350          "properties": {
19351            "code": {
19352              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
19353              "type": "string",
19354              "enumDescriptions": [
19355                "Warning about failed cleanup of transient changes made by a failed operation.",
19356                "A link to a deprecated resource was created.",
19357                "When deploying and at least one of the resources has a type marked as deprecated",
19358                "The user created a boot disk that is larger than image size.",
19359                "When deploying and at least one of the resources has a type marked as experimental",
19360                "Warning that is present in an external api call",
19361                "Warning that value of a field has been overridden. Deprecated unused field.",
19362                "The operation involved use of an injected kernel, which is deprecated.",
19363                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
19364                "When deploying a deployment with a exceedingly large number of resources",
19365                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
19366                "A resource depends on a missing type",
19367                "The route's nextHopIp address is not assigned to an instance on the network.",
19368                "The route's next hop instance cannot ip forward.",
19369                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
19370                "The route's nextHopInstance URL refers to an instance that does not exist.",
19371                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
19372                "The route's next hop instance does not have a status of RUNNING.",
19373                "Error which is not critical. We decided to continue the process despite the mentioned error.",
19374                "No results are present on a particular list page.",
19375                "Success is reported, but some results may be missing due to errors",
19376                "The user attempted to use a resource that requires a TOS they have not accepted.",
19377                "Warning that a resource is in use.",
19378                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
19379                "When a resource schema validation is ignored.",
19380                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
19381                "When undeclared properties in the schema are present",
19382                "A given scope cannot be reached."
19383              ],
19384              "enumDeprecated": [
19385                false,
19386                false,
19387                false,
19388                false,
19389                false,
19390                false,
19391                true,
19392                false,
19393                false,
19394                false,
19395                false,
19396                false,
19397                false,
19398                false,
19399                false,
19400                false,
19401                false,
19402                false,
19403                false,
19404                false,
19405                false,
19406                false,
19407                false,
19408                false,
19409                false,
19410                false,
19411                false,
19412                false
19413              ],
19414              "enum": [
19415                "CLEANUP_FAILED",
19416                "DEPRECATED_RESOURCE_USED",
19417                "DEPRECATED_TYPE_USED",
19418                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
19419                "EXPERIMENTAL_TYPE_USED",
19420                "EXTERNAL_API_WARNING",
19421                "FIELD_VALUE_OVERRIDEN",
19422                "INJECTED_KERNELS_DEPRECATED",
19423                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
19424                "LARGE_DEPLOYMENT_WARNING",
19425                "LIST_OVERHEAD_QUOTA_EXCEED",
19426                "MISSING_TYPE_DEPENDENCY",
19427                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
19428                "NEXT_HOP_CANNOT_IP_FORWARD",
19429                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
19430                "NEXT_HOP_INSTANCE_NOT_FOUND",
19431                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
19432                "NEXT_HOP_NOT_RUNNING",
19433                "NOT_CRITICAL_ERROR",
19434                "NO_RESULTS_ON_PAGE",
19435                "PARTIAL_SUCCESS",
19436                "REQUIRED_TOS_AGREEMENT",
19437                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
19438                "RESOURCE_NOT_DELETED",
19439                "SCHEMA_VALIDATION_IGNORED",
19440                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
19441                "UNDECLARED_PROPERTIES",
19442                "UNREACHABLE"
19443              ]
19444            },
19445            "message": {
19446              "description": "[Output Only] A human-readable description of the warning code.",
19447              "type": "string"
19448            },
19449            "data": {
19450              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
19451              "type": "array",
19452              "items": {
19453                "type": "object",
19454                "properties": {
19455                  "key": {
19456                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
19457                    "type": "string"
19458                  },
19459                  "value": {
19460                    "description": "[Output Only] A warning data value corresponding to the key.",
19461                    "type": "string"
19462                  }
19463                }
19464              }
19465            }
19466          }
19467        },
19468        "unreachables": {
19469          "description": "[Output Only] Unreachable resources.",
19470          "type": "array",
19471          "items": {
19472            "type": "string"
19473          }
19474        }
19475      }
19476    },
19477    "HealthChecksScopedList": {
19478      "id": "HealthChecksScopedList",
19479      "type": "object",
19480      "properties": {
19481        "healthChecks": {
19482          "description": "A list of HealthChecks contained in this scope.",
19483          "type": "array",
19484          "items": {
19485            "$ref": "HealthCheck"
19486          }
19487        },
19488        "warning": {
19489          "description": "Informational warning which replaces the list of backend services when the list is empty.",
19490          "type": "object",
19491          "properties": {
19492            "code": {
19493              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
19494              "type": "string",
19495              "enumDescriptions": [
19496                "Warning about failed cleanup of transient changes made by a failed operation.",
19497                "A link to a deprecated resource was created.",
19498                "When deploying and at least one of the resources has a type marked as deprecated",
19499                "The user created a boot disk that is larger than image size.",
19500                "When deploying and at least one of the resources has a type marked as experimental",
19501                "Warning that is present in an external api call",
19502                "Warning that value of a field has been overridden. Deprecated unused field.",
19503                "The operation involved use of an injected kernel, which is deprecated.",
19504                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
19505                "When deploying a deployment with a exceedingly large number of resources",
19506                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
19507                "A resource depends on a missing type",
19508                "The route's nextHopIp address is not assigned to an instance on the network.",
19509                "The route's next hop instance cannot ip forward.",
19510                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
19511                "The route's nextHopInstance URL refers to an instance that does not exist.",
19512                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
19513                "The route's next hop instance does not have a status of RUNNING.",
19514                "Error which is not critical. We decided to continue the process despite the mentioned error.",
19515                "No results are present on a particular list page.",
19516                "Success is reported, but some results may be missing due to errors",
19517                "The user attempted to use a resource that requires a TOS they have not accepted.",
19518                "Warning that a resource is in use.",
19519                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
19520                "When a resource schema validation is ignored.",
19521                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
19522                "When undeclared properties in the schema are present",
19523                "A given scope cannot be reached."
19524              ],
19525              "enumDeprecated": [
19526                false,
19527                false,
19528                false,
19529                false,
19530                false,
19531                false,
19532                true,
19533                false,
19534                false,
19535                false,
19536                false,
19537                false,
19538                false,
19539                false,
19540                false,
19541                false,
19542                false,
19543                false,
19544                false,
19545                false,
19546                false,
19547                false,
19548                false,
19549                false,
19550                false,
19551                false,
19552                false,
19553                false
19554              ],
19555              "enum": [
19556                "CLEANUP_FAILED",
19557                "DEPRECATED_RESOURCE_USED",
19558                "DEPRECATED_TYPE_USED",
19559                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
19560                "EXPERIMENTAL_TYPE_USED",
19561                "EXTERNAL_API_WARNING",
19562                "FIELD_VALUE_OVERRIDEN",
19563                "INJECTED_KERNELS_DEPRECATED",
19564                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
19565                "LARGE_DEPLOYMENT_WARNING",
19566                "LIST_OVERHEAD_QUOTA_EXCEED",
19567                "MISSING_TYPE_DEPENDENCY",
19568                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
19569                "NEXT_HOP_CANNOT_IP_FORWARD",
19570                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
19571                "NEXT_HOP_INSTANCE_NOT_FOUND",
19572                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
19573                "NEXT_HOP_NOT_RUNNING",
19574                "NOT_CRITICAL_ERROR",
19575                "NO_RESULTS_ON_PAGE",
19576                "PARTIAL_SUCCESS",
19577                "REQUIRED_TOS_AGREEMENT",
19578                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
19579                "RESOURCE_NOT_DELETED",
19580                "SCHEMA_VALIDATION_IGNORED",
19581                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
19582                "UNDECLARED_PROPERTIES",
19583                "UNREACHABLE"
19584              ]
19585            },
19586            "message": {
19587              "description": "[Output Only] A human-readable description of the warning code.",
19588              "type": "string"
19589            },
19590            "data": {
19591              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
19592              "type": "array",
19593              "items": {
19594                "type": "object",
19595                "properties": {
19596                  "key": {
19597                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
19598                    "type": "string"
19599                  },
19600                  "value": {
19601                    "description": "[Output Only] A warning data value corresponding to the key.",
19602                    "type": "string"
19603                  }
19604                }
19605              }
19606            }
19607          }
19608        }
19609      }
19610    },
19611    "HttpHealthCheckList": {
19612      "id": "HttpHealthCheckList",
19613      "description": "Contains a list of HttpHealthCheck resources.",
19614      "type": "object",
19615      "properties": {
19616        "kind": {
19617          "description": "Type of resource.",
19618          "default": "compute#httpHealthCheckList",
19619          "type": "string"
19620        },
19621        "id": {
19622          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
19623          "type": "string"
19624        },
19625        "items": {
19626          "description": "A list of HttpHealthCheck resources.",
19627          "type": "array",
19628          "items": {
19629            "$ref": "HttpHealthCheck"
19630          }
19631        },
19632        "nextPageToken": {
19633          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
19634          "type": "string"
19635        },
19636        "selfLink": {
19637          "description": "[Output Only] Server-defined URL for this resource.",
19638          "type": "string"
19639        },
19640        "warning": {
19641          "description": "[Output Only] Informational warning message.",
19642          "type": "object",
19643          "properties": {
19644            "code": {
19645              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
19646              "type": "string",
19647              "enumDescriptions": [
19648                "Warning about failed cleanup of transient changes made by a failed operation.",
19649                "A link to a deprecated resource was created.",
19650                "When deploying and at least one of the resources has a type marked as deprecated",
19651                "The user created a boot disk that is larger than image size.",
19652                "When deploying and at least one of the resources has a type marked as experimental",
19653                "Warning that is present in an external api call",
19654                "Warning that value of a field has been overridden. Deprecated unused field.",
19655                "The operation involved use of an injected kernel, which is deprecated.",
19656                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
19657                "When deploying a deployment with a exceedingly large number of resources",
19658                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
19659                "A resource depends on a missing type",
19660                "The route's nextHopIp address is not assigned to an instance on the network.",
19661                "The route's next hop instance cannot ip forward.",
19662                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
19663                "The route's nextHopInstance URL refers to an instance that does not exist.",
19664                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
19665                "The route's next hop instance does not have a status of RUNNING.",
19666                "Error which is not critical. We decided to continue the process despite the mentioned error.",
19667                "No results are present on a particular list page.",
19668                "Success is reported, but some results may be missing due to errors",
19669                "The user attempted to use a resource that requires a TOS they have not accepted.",
19670                "Warning that a resource is in use.",
19671                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
19672                "When a resource schema validation is ignored.",
19673                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
19674                "When undeclared properties in the schema are present",
19675                "A given scope cannot be reached."
19676              ],
19677              "enumDeprecated": [
19678                false,
19679                false,
19680                false,
19681                false,
19682                false,
19683                false,
19684                true,
19685                false,
19686                false,
19687                false,
19688                false,
19689                false,
19690                false,
19691                false,
19692                false,
19693                false,
19694                false,
19695                false,
19696                false,
19697                false,
19698                false,
19699                false,
19700                false,
19701                false,
19702                false,
19703                false,
19704                false,
19705                false
19706              ],
19707              "enum": [
19708                "CLEANUP_FAILED",
19709                "DEPRECATED_RESOURCE_USED",
19710                "DEPRECATED_TYPE_USED",
19711                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
19712                "EXPERIMENTAL_TYPE_USED",
19713                "EXTERNAL_API_WARNING",
19714                "FIELD_VALUE_OVERRIDEN",
19715                "INJECTED_KERNELS_DEPRECATED",
19716                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
19717                "LARGE_DEPLOYMENT_WARNING",
19718                "LIST_OVERHEAD_QUOTA_EXCEED",
19719                "MISSING_TYPE_DEPENDENCY",
19720                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
19721                "NEXT_HOP_CANNOT_IP_FORWARD",
19722                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
19723                "NEXT_HOP_INSTANCE_NOT_FOUND",
19724                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
19725                "NEXT_HOP_NOT_RUNNING",
19726                "NOT_CRITICAL_ERROR",
19727                "NO_RESULTS_ON_PAGE",
19728                "PARTIAL_SUCCESS",
19729                "REQUIRED_TOS_AGREEMENT",
19730                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
19731                "RESOURCE_NOT_DELETED",
19732                "SCHEMA_VALIDATION_IGNORED",
19733                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
19734                "UNDECLARED_PROPERTIES",
19735                "UNREACHABLE"
19736              ]
19737            },
19738            "message": {
19739              "description": "[Output Only] A human-readable description of the warning code.",
19740              "type": "string"
19741            },
19742            "data": {
19743              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
19744              "type": "array",
19745              "items": {
19746                "type": "object",
19747                "properties": {
19748                  "key": {
19749                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
19750                    "type": "string"
19751                  },
19752                  "value": {
19753                    "description": "[Output Only] A warning data value corresponding to the key.",
19754                    "type": "string"
19755                  }
19756                }
19757              }
19758            }
19759          }
19760        }
19761      }
19762    },
19763    "HttpHealthCheck": {
19764      "id": "HttpHealthCheck",
19765      "description": "Represents a legacy HTTP Health Check resource. Legacy HTTP health checks are now only required by target pool-based network load balancers. For all other load balancers, including backend service-based network load balancers, and for managed instance group auto-healing, you must use modern (non-legacy) health checks. For more information, see Health checks overview .",
19766      "type": "object",
19767      "properties": {
19768        "kind": {
19769          "description": "[Output Only] Type of the resource. Always compute#httpHealthCheck for HTTP health checks.",
19770          "default": "compute#httpHealthCheck",
19771          "type": "string"
19772        },
19773        "id": {
19774          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
19775          "type": "string",
19776          "format": "uint64"
19777        },
19778        "creationTimestamp": {
19779          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
19780          "type": "string"
19781        },
19782        "name": {
19783          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
19784          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
19785          "type": "string"
19786        },
19787        "description": {
19788          "description": "An optional description of this resource. Provide this property when you create the resource.",
19789          "type": "string"
19790        },
19791        "host": {
19792          "description": "The value of the host header in the HTTP health check request. If left empty (default value), the public IP on behalf of which this health check is performed will be used.",
19793          "type": "string"
19794        },
19795        "requestPath": {
19796          "description": "The request path of the HTTP health check request. The default value is /. This field does not support query parameters. Must comply with RFC3986.",
19797          "type": "string"
19798        },
19799        "port": {
19800          "description": "The TCP port number for the HTTP health check request. The default value is 80.",
19801          "type": "integer",
19802          "format": "int32"
19803        },
19804        "checkIntervalSec": {
19805          "description": "How often (in seconds) to send a health check. The default value is 5 seconds.",
19806          "type": "integer",
19807          "format": "int32"
19808        },
19809        "timeoutSec": {
19810          "description": "How long (in seconds) to wait before claiming failure. The default value is 5 seconds. It is invalid for timeoutSec to have greater value than checkIntervalSec.",
19811          "type": "integer",
19812          "format": "int32"
19813        },
19814        "unhealthyThreshold": {
19815          "description": "A so-far healthy instance will be marked unhealthy after this many consecutive failures. The default value is 2.",
19816          "type": "integer",
19817          "format": "int32"
19818        },
19819        "healthyThreshold": {
19820          "description": "A so-far unhealthy instance will be marked healthy after this many consecutive successes. The default value is 2.",
19821          "type": "integer",
19822          "format": "int32"
19823        },
19824        "selfLink": {
19825          "description": "[Output Only] Server-defined URL for the resource.",
19826          "type": "string"
19827        }
19828      }
19829    },
19830    "HttpsHealthCheckList": {
19831      "id": "HttpsHealthCheckList",
19832      "description": "Contains a list of HttpsHealthCheck resources.",
19833      "type": "object",
19834      "properties": {
19835        "kind": {
19836          "description": "Type of resource.",
19837          "default": "compute#httpsHealthCheckList",
19838          "type": "string"
19839        },
19840        "id": {
19841          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
19842          "type": "string"
19843        },
19844        "items": {
19845          "description": "A list of HttpsHealthCheck resources.",
19846          "type": "array",
19847          "items": {
19848            "$ref": "HttpsHealthCheck"
19849          }
19850        },
19851        "nextPageToken": {
19852          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
19853          "type": "string"
19854        },
19855        "selfLink": {
19856          "description": "[Output Only] Server-defined URL for this resource.",
19857          "type": "string"
19858        },
19859        "warning": {
19860          "description": "[Output Only] Informational warning message.",
19861          "type": "object",
19862          "properties": {
19863            "code": {
19864              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
19865              "type": "string",
19866              "enumDescriptions": [
19867                "Warning about failed cleanup of transient changes made by a failed operation.",
19868                "A link to a deprecated resource was created.",
19869                "When deploying and at least one of the resources has a type marked as deprecated",
19870                "The user created a boot disk that is larger than image size.",
19871                "When deploying and at least one of the resources has a type marked as experimental",
19872                "Warning that is present in an external api call",
19873                "Warning that value of a field has been overridden. Deprecated unused field.",
19874                "The operation involved use of an injected kernel, which is deprecated.",
19875                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
19876                "When deploying a deployment with a exceedingly large number of resources",
19877                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
19878                "A resource depends on a missing type",
19879                "The route's nextHopIp address is not assigned to an instance on the network.",
19880                "The route's next hop instance cannot ip forward.",
19881                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
19882                "The route's nextHopInstance URL refers to an instance that does not exist.",
19883                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
19884                "The route's next hop instance does not have a status of RUNNING.",
19885                "Error which is not critical. We decided to continue the process despite the mentioned error.",
19886                "No results are present on a particular list page.",
19887                "Success is reported, but some results may be missing due to errors",
19888                "The user attempted to use a resource that requires a TOS they have not accepted.",
19889                "Warning that a resource is in use.",
19890                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
19891                "When a resource schema validation is ignored.",
19892                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
19893                "When undeclared properties in the schema are present",
19894                "A given scope cannot be reached."
19895              ],
19896              "enumDeprecated": [
19897                false,
19898                false,
19899                false,
19900                false,
19901                false,
19902                false,
19903                true,
19904                false,
19905                false,
19906                false,
19907                false,
19908                false,
19909                false,
19910                false,
19911                false,
19912                false,
19913                false,
19914                false,
19915                false,
19916                false,
19917                false,
19918                false,
19919                false,
19920                false,
19921                false,
19922                false,
19923                false,
19924                false
19925              ],
19926              "enum": [
19927                "CLEANUP_FAILED",
19928                "DEPRECATED_RESOURCE_USED",
19929                "DEPRECATED_TYPE_USED",
19930                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
19931                "EXPERIMENTAL_TYPE_USED",
19932                "EXTERNAL_API_WARNING",
19933                "FIELD_VALUE_OVERRIDEN",
19934                "INJECTED_KERNELS_DEPRECATED",
19935                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
19936                "LARGE_DEPLOYMENT_WARNING",
19937                "LIST_OVERHEAD_QUOTA_EXCEED",
19938                "MISSING_TYPE_DEPENDENCY",
19939                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
19940                "NEXT_HOP_CANNOT_IP_FORWARD",
19941                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
19942                "NEXT_HOP_INSTANCE_NOT_FOUND",
19943                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
19944                "NEXT_HOP_NOT_RUNNING",
19945                "NOT_CRITICAL_ERROR",
19946                "NO_RESULTS_ON_PAGE",
19947                "PARTIAL_SUCCESS",
19948                "REQUIRED_TOS_AGREEMENT",
19949                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
19950                "RESOURCE_NOT_DELETED",
19951                "SCHEMA_VALIDATION_IGNORED",
19952                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
19953                "UNDECLARED_PROPERTIES",
19954                "UNREACHABLE"
19955              ]
19956            },
19957            "message": {
19958              "description": "[Output Only] A human-readable description of the warning code.",
19959              "type": "string"
19960            },
19961            "data": {
19962              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
19963              "type": "array",
19964              "items": {
19965                "type": "object",
19966                "properties": {
19967                  "key": {
19968                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
19969                    "type": "string"
19970                  },
19971                  "value": {
19972                    "description": "[Output Only] A warning data value corresponding to the key.",
19973                    "type": "string"
19974                  }
19975                }
19976              }
19977            }
19978          }
19979        }
19980      }
19981    },
19982    "HttpsHealthCheck": {
19983      "id": "HttpsHealthCheck",
19984      "description": "Represents a legacy HTTPS Health Check resource. Legacy HTTPS health checks have been deprecated. If you are using a target pool-based network load balancer, you must use a legacy HTTP (not HTTPS) health check. For all other load balancers, including backend service-based network load balancers, and for managed instance group auto-healing, you must use modern (non-legacy) health checks. For more information, see Health checks overview .",
19985      "type": "object",
19986      "properties": {
19987        "kind": {
19988          "description": "Type of the resource.",
19989          "default": "compute#httpsHealthCheck",
19990          "type": "string"
19991        },
19992        "id": {
19993          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
19994          "type": "string",
19995          "format": "uint64"
19996        },
19997        "creationTimestamp": {
19998          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
19999          "type": "string"
20000        },
20001        "name": {
20002          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
20003          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
20004          "type": "string"
20005        },
20006        "description": {
20007          "description": "An optional description of this resource. Provide this property when you create the resource.",
20008          "type": "string"
20009        },
20010        "host": {
20011          "description": "The value of the host header in the HTTPS health check request. If left empty (default value), the public IP on behalf of which this health check is performed will be used.",
20012          "type": "string"
20013        },
20014        "requestPath": {
20015          "description": "The request path of the HTTPS health check request. The default value is \"/\". Must comply with RFC3986.",
20016          "type": "string"
20017        },
20018        "port": {
20019          "description": "The TCP port number for the HTTPS health check request. The default value is 443.",
20020          "type": "integer",
20021          "format": "int32"
20022        },
20023        "checkIntervalSec": {
20024          "description": "How often (in seconds) to send a health check. The default value is 5 seconds.",
20025          "type": "integer",
20026          "format": "int32"
20027        },
20028        "timeoutSec": {
20029          "description": "How long (in seconds) to wait before claiming failure. The default value is 5 seconds. It is invalid for timeoutSec to have a greater value than checkIntervalSec.",
20030          "type": "integer",
20031          "format": "int32"
20032        },
20033        "unhealthyThreshold": {
20034          "description": "A so-far healthy instance will be marked unhealthy after this many consecutive failures. The default value is 2.",
20035          "type": "integer",
20036          "format": "int32"
20037        },
20038        "healthyThreshold": {
20039          "description": "A so-far unhealthy instance will be marked healthy after this many consecutive successes. The default value is 2.",
20040          "type": "integer",
20041          "format": "int32"
20042        },
20043        "selfLink": {
20044          "description": "[Output Only] Server-defined URL for the resource.",
20045          "type": "string"
20046        }
20047      }
20048    },
20049    "InstanceTemplateList": {
20050      "id": "InstanceTemplateList",
20051      "description": "A list of instance templates.",
20052      "type": "object",
20053      "properties": {
20054        "kind": {
20055          "description": "[Output Only] The resource type, which is always compute#instanceTemplatesListResponse for instance template lists.",
20056          "default": "compute#instanceTemplateList",
20057          "type": "string"
20058        },
20059        "id": {
20060          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
20061          "type": "string"
20062        },
20063        "items": {
20064          "description": "A list of InstanceTemplate resources.",
20065          "type": "array",
20066          "items": {
20067            "$ref": "InstanceTemplate"
20068          }
20069        },
20070        "nextPageToken": {
20071          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
20072          "type": "string"
20073        },
20074        "selfLink": {
20075          "description": "[Output Only] Server-defined URL for this resource.",
20076          "type": "string"
20077        },
20078        "warning": {
20079          "description": "[Output Only] Informational warning message.",
20080          "type": "object",
20081          "properties": {
20082            "code": {
20083              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
20084              "type": "string",
20085              "enumDescriptions": [
20086                "Warning about failed cleanup of transient changes made by a failed operation.",
20087                "A link to a deprecated resource was created.",
20088                "When deploying and at least one of the resources has a type marked as deprecated",
20089                "The user created a boot disk that is larger than image size.",
20090                "When deploying and at least one of the resources has a type marked as experimental",
20091                "Warning that is present in an external api call",
20092                "Warning that value of a field has been overridden. Deprecated unused field.",
20093                "The operation involved use of an injected kernel, which is deprecated.",
20094                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
20095                "When deploying a deployment with a exceedingly large number of resources",
20096                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
20097                "A resource depends on a missing type",
20098                "The route's nextHopIp address is not assigned to an instance on the network.",
20099                "The route's next hop instance cannot ip forward.",
20100                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
20101                "The route's nextHopInstance URL refers to an instance that does not exist.",
20102                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
20103                "The route's next hop instance does not have a status of RUNNING.",
20104                "Error which is not critical. We decided to continue the process despite the mentioned error.",
20105                "No results are present on a particular list page.",
20106                "Success is reported, but some results may be missing due to errors",
20107                "The user attempted to use a resource that requires a TOS they have not accepted.",
20108                "Warning that a resource is in use.",
20109                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
20110                "When a resource schema validation is ignored.",
20111                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
20112                "When undeclared properties in the schema are present",
20113                "A given scope cannot be reached."
20114              ],
20115              "enumDeprecated": [
20116                false,
20117                false,
20118                false,
20119                false,
20120                false,
20121                false,
20122                true,
20123                false,
20124                false,
20125                false,
20126                false,
20127                false,
20128                false,
20129                false,
20130                false,
20131                false,
20132                false,
20133                false,
20134                false,
20135                false,
20136                false,
20137                false,
20138                false,
20139                false,
20140                false,
20141                false,
20142                false,
20143                false
20144              ],
20145              "enum": [
20146                "CLEANUP_FAILED",
20147                "DEPRECATED_RESOURCE_USED",
20148                "DEPRECATED_TYPE_USED",
20149                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
20150                "EXPERIMENTAL_TYPE_USED",
20151                "EXTERNAL_API_WARNING",
20152                "FIELD_VALUE_OVERRIDEN",
20153                "INJECTED_KERNELS_DEPRECATED",
20154                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
20155                "LARGE_DEPLOYMENT_WARNING",
20156                "LIST_OVERHEAD_QUOTA_EXCEED",
20157                "MISSING_TYPE_DEPENDENCY",
20158                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
20159                "NEXT_HOP_CANNOT_IP_FORWARD",
20160                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
20161                "NEXT_HOP_INSTANCE_NOT_FOUND",
20162                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
20163                "NEXT_HOP_NOT_RUNNING",
20164                "NOT_CRITICAL_ERROR",
20165                "NO_RESULTS_ON_PAGE",
20166                "PARTIAL_SUCCESS",
20167                "REQUIRED_TOS_AGREEMENT",
20168                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
20169                "RESOURCE_NOT_DELETED",
20170                "SCHEMA_VALIDATION_IGNORED",
20171                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
20172                "UNDECLARED_PROPERTIES",
20173                "UNREACHABLE"
20174              ]
20175            },
20176            "message": {
20177              "description": "[Output Only] A human-readable description of the warning code.",
20178              "type": "string"
20179            },
20180            "data": {
20181              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
20182              "type": "array",
20183              "items": {
20184                "type": "object",
20185                "properties": {
20186                  "key": {
20187                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
20188                    "type": "string"
20189                  },
20190                  "value": {
20191                    "description": "[Output Only] A warning data value corresponding to the key.",
20192                    "type": "string"
20193                  }
20194                }
20195              }
20196            }
20197          }
20198        }
20199      }
20200    },
20201    "InstanceTemplate": {
20202      "id": "InstanceTemplate",
20203      "description": "Represents an Instance Template resource. Google Compute Engine has two Instance Template resources: * [Global](/compute/docs/reference/rest/v1/instanceTemplates) * [Regional](/compute/docs/reference/rest/v1/regionInstanceTemplates) You can reuse a global instance template in different regions whereas you can use a regional instance template in a specified region only. If you want to reduce cross-region dependency or achieve data residency, use a regional instance template. To create VMs, managed instance groups, and reservations, you can use either global or regional instance templates. For more information, read Instance Templates.",
20204      "type": "object",
20205      "properties": {
20206        "kind": {
20207          "description": "[Output Only] The resource type, which is always compute#instanceTemplate for instance templates.",
20208          "default": "compute#instanceTemplate",
20209          "type": "string"
20210        },
20211        "id": {
20212          "description": "[Output Only] A unique identifier for this instance template. The server defines this identifier.",
20213          "type": "string",
20214          "format": "uint64"
20215        },
20216        "creationTimestamp": {
20217          "description": "[Output Only] The creation timestamp for this instance template in RFC3339 text format.",
20218          "type": "string"
20219        },
20220        "name": {
20221          "description": "Name of the resource; provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
20222          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
20223          "annotations": {
20224            "required": [
20225              "compute.instanceTemplates.insert"
20226            ]
20227          },
20228          "type": "string"
20229        },
20230        "description": {
20231          "description": "An optional description of this resource. Provide this property when you create the resource.",
20232          "type": "string"
20233        },
20234        "properties": {
20235          "description": "The instance properties for this instance template.",
20236          "$ref": "InstanceProperties"
20237        },
20238        "selfLink": {
20239          "description": "[Output Only] The URL for this instance template. The server defines this URL.",
20240          "type": "string"
20241        },
20242        "sourceInstance": {
20243          "description": "The source instance used to create the template. You can provide this as a partial or full URL to the resource. For example, the following are valid values: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /instances/instance - projects/project/zones/zone/instances/instance ",
20244          "type": "string"
20245        },
20246        "sourceInstanceParams": {
20247          "description": "The source instance params to use to create this instance template.",
20248          "$ref": "SourceInstanceParams"
20249        },
20250        "region": {
20251          "description": "[Output Only] URL of the region where the instance template resides. Only applicable for regional resources.",
20252          "type": "string"
20253        }
20254      }
20255    },
20256    "SourceInstanceParams": {
20257      "id": "SourceInstanceParams",
20258      "description": "A specification of the parameters to use when creating the instance template from a source instance.",
20259      "type": "object",
20260      "properties": {
20261        "diskConfigs": {
20262          "description": "Attached disks configuration. If not provided, defaults are applied: For boot disk and any other R/W disks, the source images for each disk will be used. For read-only disks, they will be attached in read-only mode. Local SSD disks will be created as blank volumes.",
20263          "type": "array",
20264          "items": {
20265            "$ref": "DiskInstantiationConfig"
20266          }
20267        }
20268      }
20269    },
20270    "DiskInstantiationConfig": {
20271      "id": "DiskInstantiationConfig",
20272      "description": "A specification of the desired way to instantiate a disk in the instance template when its created from a source instance.",
20273      "type": "object",
20274      "properties": {
20275        "deviceName": {
20276          "description": "Specifies the device name of the disk to which the configurations apply to.",
20277          "type": "string"
20278        },
20279        "instantiateFrom": {
20280          "description": "Specifies whether to include the disk and what image to use. Possible values are: - source-image: to use the same image that was used to create the source instance's corresponding disk. Applicable to the boot disk and additional read-write disks. - source-image-family: to use the same image family that was used to create the source instance's corresponding disk. Applicable to the boot disk and additional read-write disks. - custom-image: to use a user-provided image url for disk creation. Applicable to the boot disk and additional read-write disks. - attach-read-only: to attach a read-only disk. Applicable to read-only disks. - do-not-include: to exclude a disk from the template. Applicable to additional read-write disks, local SSDs, and read-only disks. ",
20281          "type": "string",
20282          "enumDescriptions": [
20283            "Attach the existing disk in read-only mode. The request will fail if the disk was attached in read-write mode on the source instance. Applicable to: read-only disks.",
20284            "Create a blank disk. The disk will be created unformatted. Applicable to: additional read-write disks, local SSDs.",
20285            "Use the custom image specified in the custom_image field. Applicable to: boot disk, additional read-write disks.",
20286            "Use the default instantiation option for the corresponding type of disk. For boot disk and any other R/W disks, new custom images will be created from each disk. For read-only disks, they will be attached in read-only mode. Local SSD disks will be created as blank volumes.",
20287            "Do not include the disk in the instance template. Applicable to: additional read-write disks, local SSDs, read-only disks.",
20288            "Use the same source image used for creation of the source instance's corresponding disk. The request will fail if the source VM's disk was created from a snapshot. Applicable to: boot disk, additional read-write disks.",
20289            "Use the same source image family used for creation of the source instance's corresponding disk. The request will fail if the source image of the source disk does not belong to any image family. Applicable to: boot disk, additional read-write disks."
20290          ],
20291          "enum": [
20292            "ATTACH_READ_ONLY",
20293            "BLANK",
20294            "CUSTOM_IMAGE",
20295            "DEFAULT",
20296            "DO_NOT_INCLUDE",
20297            "SOURCE_IMAGE",
20298            "SOURCE_IMAGE_FAMILY"
20299          ]
20300        },
20301        "autoDelete": {
20302          "description": "Specifies whether the disk will be auto-deleted when the instance is deleted (but not when the disk is detached from the instance).",
20303          "type": "boolean"
20304        },
20305        "customImage": {
20306          "description": "The custom source image to be used to restore this disk when instantiating this instance template.",
20307          "type": "string"
20308        }
20309      }
20310    },
20311    "InstanceTemplateAggregatedList": {
20312      "id": "InstanceTemplateAggregatedList",
20313      "description": "Contains a list of InstanceTemplatesScopedList.",
20314      "type": "object",
20315      "properties": {
20316        "kind": {
20317          "description": "Type of resource.",
20318          "default": "compute#instanceTemplateAggregatedList",
20319          "type": "string"
20320        },
20321        "id": {
20322          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
20323          "type": "string"
20324        },
20325        "items": {
20326          "description": "A list of InstanceTemplatesScopedList resources.",
20327          "type": "object",
20328          "additionalProperties": {
20329            "description": "The name of the scope that contains this set of instance templates.",
20330            "$ref": "InstanceTemplatesScopedList"
20331          }
20332        },
20333        "nextPageToken": {
20334          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
20335          "type": "string"
20336        },
20337        "selfLink": {
20338          "description": "[Output Only] Server-defined URL for this resource.",
20339          "type": "string"
20340        },
20341        "warning": {
20342          "description": "[Output Only] Informational warning message.",
20343          "type": "object",
20344          "properties": {
20345            "code": {
20346              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
20347              "type": "string",
20348              "enumDescriptions": [
20349                "Warning about failed cleanup of transient changes made by a failed operation.",
20350                "A link to a deprecated resource was created.",
20351                "When deploying and at least one of the resources has a type marked as deprecated",
20352                "The user created a boot disk that is larger than image size.",
20353                "When deploying and at least one of the resources has a type marked as experimental",
20354                "Warning that is present in an external api call",
20355                "Warning that value of a field has been overridden. Deprecated unused field.",
20356                "The operation involved use of an injected kernel, which is deprecated.",
20357                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
20358                "When deploying a deployment with a exceedingly large number of resources",
20359                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
20360                "A resource depends on a missing type",
20361                "The route's nextHopIp address is not assigned to an instance on the network.",
20362                "The route's next hop instance cannot ip forward.",
20363                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
20364                "The route's nextHopInstance URL refers to an instance that does not exist.",
20365                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
20366                "The route's next hop instance does not have a status of RUNNING.",
20367                "Error which is not critical. We decided to continue the process despite the mentioned error.",
20368                "No results are present on a particular list page.",
20369                "Success is reported, but some results may be missing due to errors",
20370                "The user attempted to use a resource that requires a TOS they have not accepted.",
20371                "Warning that a resource is in use.",
20372                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
20373                "When a resource schema validation is ignored.",
20374                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
20375                "When undeclared properties in the schema are present",
20376                "A given scope cannot be reached."
20377              ],
20378              "enumDeprecated": [
20379                false,
20380                false,
20381                false,
20382                false,
20383                false,
20384                false,
20385                true,
20386                false,
20387                false,
20388                false,
20389                false,
20390                false,
20391                false,
20392                false,
20393                false,
20394                false,
20395                false,
20396                false,
20397                false,
20398                false,
20399                false,
20400                false,
20401                false,
20402                false,
20403                false,
20404                false,
20405                false,
20406                false
20407              ],
20408              "enum": [
20409                "CLEANUP_FAILED",
20410                "DEPRECATED_RESOURCE_USED",
20411                "DEPRECATED_TYPE_USED",
20412                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
20413                "EXPERIMENTAL_TYPE_USED",
20414                "EXTERNAL_API_WARNING",
20415                "FIELD_VALUE_OVERRIDEN",
20416                "INJECTED_KERNELS_DEPRECATED",
20417                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
20418                "LARGE_DEPLOYMENT_WARNING",
20419                "LIST_OVERHEAD_QUOTA_EXCEED",
20420                "MISSING_TYPE_DEPENDENCY",
20421                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
20422                "NEXT_HOP_CANNOT_IP_FORWARD",
20423                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
20424                "NEXT_HOP_INSTANCE_NOT_FOUND",
20425                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
20426                "NEXT_HOP_NOT_RUNNING",
20427                "NOT_CRITICAL_ERROR",
20428                "NO_RESULTS_ON_PAGE",
20429                "PARTIAL_SUCCESS",
20430                "REQUIRED_TOS_AGREEMENT",
20431                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
20432                "RESOURCE_NOT_DELETED",
20433                "SCHEMA_VALIDATION_IGNORED",
20434                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
20435                "UNDECLARED_PROPERTIES",
20436                "UNREACHABLE"
20437              ]
20438            },
20439            "message": {
20440              "description": "[Output Only] A human-readable description of the warning code.",
20441              "type": "string"
20442            },
20443            "data": {
20444              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
20445              "type": "array",
20446              "items": {
20447                "type": "object",
20448                "properties": {
20449                  "key": {
20450                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
20451                    "type": "string"
20452                  },
20453                  "value": {
20454                    "description": "[Output Only] A warning data value corresponding to the key.",
20455                    "type": "string"
20456                  }
20457                }
20458              }
20459            }
20460          }
20461        }
20462      }
20463    },
20464    "InstanceTemplatesScopedList": {
20465      "id": "InstanceTemplatesScopedList",
20466      "type": "object",
20467      "properties": {
20468        "instanceTemplates": {
20469          "description": "[Output Only] A list of instance templates that are contained within the specified project and zone.",
20470          "type": "array",
20471          "items": {
20472            "$ref": "InstanceTemplate"
20473          }
20474        },
20475        "warning": {
20476          "description": "[Output Only] An informational warning that replaces the list of instance templates when the list is empty.",
20477          "type": "object",
20478          "properties": {
20479            "code": {
20480              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
20481              "type": "string",
20482              "enumDescriptions": [
20483                "Warning about failed cleanup of transient changes made by a failed operation.",
20484                "A link to a deprecated resource was created.",
20485                "When deploying and at least one of the resources has a type marked as deprecated",
20486                "The user created a boot disk that is larger than image size.",
20487                "When deploying and at least one of the resources has a type marked as experimental",
20488                "Warning that is present in an external api call",
20489                "Warning that value of a field has been overridden. Deprecated unused field.",
20490                "The operation involved use of an injected kernel, which is deprecated.",
20491                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
20492                "When deploying a deployment with a exceedingly large number of resources",
20493                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
20494                "A resource depends on a missing type",
20495                "The route's nextHopIp address is not assigned to an instance on the network.",
20496                "The route's next hop instance cannot ip forward.",
20497                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
20498                "The route's nextHopInstance URL refers to an instance that does not exist.",
20499                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
20500                "The route's next hop instance does not have a status of RUNNING.",
20501                "Error which is not critical. We decided to continue the process despite the mentioned error.",
20502                "No results are present on a particular list page.",
20503                "Success is reported, but some results may be missing due to errors",
20504                "The user attempted to use a resource that requires a TOS they have not accepted.",
20505                "Warning that a resource is in use.",
20506                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
20507                "When a resource schema validation is ignored.",
20508                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
20509                "When undeclared properties in the schema are present",
20510                "A given scope cannot be reached."
20511              ],
20512              "enumDeprecated": [
20513                false,
20514                false,
20515                false,
20516                false,
20517                false,
20518                false,
20519                true,
20520                false,
20521                false,
20522                false,
20523                false,
20524                false,
20525                false,
20526                false,
20527                false,
20528                false,
20529                false,
20530                false,
20531                false,
20532                false,
20533                false,
20534                false,
20535                false,
20536                false,
20537                false,
20538                false,
20539                false,
20540                false
20541              ],
20542              "enum": [
20543                "CLEANUP_FAILED",
20544                "DEPRECATED_RESOURCE_USED",
20545                "DEPRECATED_TYPE_USED",
20546                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
20547                "EXPERIMENTAL_TYPE_USED",
20548                "EXTERNAL_API_WARNING",
20549                "FIELD_VALUE_OVERRIDEN",
20550                "INJECTED_KERNELS_DEPRECATED",
20551                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
20552                "LARGE_DEPLOYMENT_WARNING",
20553                "LIST_OVERHEAD_QUOTA_EXCEED",
20554                "MISSING_TYPE_DEPENDENCY",
20555                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
20556                "NEXT_HOP_CANNOT_IP_FORWARD",
20557                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
20558                "NEXT_HOP_INSTANCE_NOT_FOUND",
20559                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
20560                "NEXT_HOP_NOT_RUNNING",
20561                "NOT_CRITICAL_ERROR",
20562                "NO_RESULTS_ON_PAGE",
20563                "PARTIAL_SUCCESS",
20564                "REQUIRED_TOS_AGREEMENT",
20565                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
20566                "RESOURCE_NOT_DELETED",
20567                "SCHEMA_VALIDATION_IGNORED",
20568                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
20569                "UNDECLARED_PROPERTIES",
20570                "UNREACHABLE"
20571              ]
20572            },
20573            "message": {
20574              "description": "[Output Only] A human-readable description of the warning code.",
20575              "type": "string"
20576            },
20577            "data": {
20578              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
20579              "type": "array",
20580              "items": {
20581                "type": "object",
20582                "properties": {
20583                  "key": {
20584                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
20585                    "type": "string"
20586                  },
20587                  "value": {
20588                    "description": "[Output Only] A warning data value corresponding to the key.",
20589                    "type": "string"
20590                  }
20591                }
20592              }
20593            }
20594          }
20595        }
20596      }
20597    },
20598    "InstantSnapshotList": {
20599      "id": "InstantSnapshotList",
20600      "description": "Contains a list of InstantSnapshot resources.",
20601      "type": "object",
20602      "properties": {
20603        "kind": {
20604          "description": "Type of resource.",
20605          "default": "compute#instantSnapshotList",
20606          "type": "string"
20607        },
20608        "id": {
20609          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
20610          "type": "string"
20611        },
20612        "items": {
20613          "description": "A list of InstantSnapshot resources.",
20614          "type": "array",
20615          "items": {
20616            "$ref": "InstantSnapshot"
20617          }
20618        },
20619        "nextPageToken": {
20620          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
20621          "type": "string"
20622        },
20623        "selfLink": {
20624          "description": "[Output Only] Server-defined URL for this resource.",
20625          "type": "string"
20626        },
20627        "warning": {
20628          "description": "[Output Only] Informational warning message.",
20629          "type": "object",
20630          "properties": {
20631            "code": {
20632              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
20633              "type": "string",
20634              "enumDescriptions": [
20635                "Warning about failed cleanup of transient changes made by a failed operation.",
20636                "A link to a deprecated resource was created.",
20637                "When deploying and at least one of the resources has a type marked as deprecated",
20638                "The user created a boot disk that is larger than image size.",
20639                "When deploying and at least one of the resources has a type marked as experimental",
20640                "Warning that is present in an external api call",
20641                "Warning that value of a field has been overridden. Deprecated unused field.",
20642                "The operation involved use of an injected kernel, which is deprecated.",
20643                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
20644                "When deploying a deployment with a exceedingly large number of resources",
20645                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
20646                "A resource depends on a missing type",
20647                "The route's nextHopIp address is not assigned to an instance on the network.",
20648                "The route's next hop instance cannot ip forward.",
20649                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
20650                "The route's nextHopInstance URL refers to an instance that does not exist.",
20651                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
20652                "The route's next hop instance does not have a status of RUNNING.",
20653                "Error which is not critical. We decided to continue the process despite the mentioned error.",
20654                "No results are present on a particular list page.",
20655                "Success is reported, but some results may be missing due to errors",
20656                "The user attempted to use a resource that requires a TOS they have not accepted.",
20657                "Warning that a resource is in use.",
20658                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
20659                "When a resource schema validation is ignored.",
20660                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
20661                "When undeclared properties in the schema are present",
20662                "A given scope cannot be reached."
20663              ],
20664              "enumDeprecated": [
20665                false,
20666                false,
20667                false,
20668                false,
20669                false,
20670                false,
20671                true,
20672                false,
20673                false,
20674                false,
20675                false,
20676                false,
20677                false,
20678                false,
20679                false,
20680                false,
20681                false,
20682                false,
20683                false,
20684                false,
20685                false,
20686                false,
20687                false,
20688                false,
20689                false,
20690                false,
20691                false,
20692                false
20693              ],
20694              "enum": [
20695                "CLEANUP_FAILED",
20696                "DEPRECATED_RESOURCE_USED",
20697                "DEPRECATED_TYPE_USED",
20698                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
20699                "EXPERIMENTAL_TYPE_USED",
20700                "EXTERNAL_API_WARNING",
20701                "FIELD_VALUE_OVERRIDEN",
20702                "INJECTED_KERNELS_DEPRECATED",
20703                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
20704                "LARGE_DEPLOYMENT_WARNING",
20705                "LIST_OVERHEAD_QUOTA_EXCEED",
20706                "MISSING_TYPE_DEPENDENCY",
20707                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
20708                "NEXT_HOP_CANNOT_IP_FORWARD",
20709                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
20710                "NEXT_HOP_INSTANCE_NOT_FOUND",
20711                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
20712                "NEXT_HOP_NOT_RUNNING",
20713                "NOT_CRITICAL_ERROR",
20714                "NO_RESULTS_ON_PAGE",
20715                "PARTIAL_SUCCESS",
20716                "REQUIRED_TOS_AGREEMENT",
20717                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
20718                "RESOURCE_NOT_DELETED",
20719                "SCHEMA_VALIDATION_IGNORED",
20720                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
20721                "UNDECLARED_PROPERTIES",
20722                "UNREACHABLE"
20723              ]
20724            },
20725            "message": {
20726              "description": "[Output Only] A human-readable description of the warning code.",
20727              "type": "string"
20728            },
20729            "data": {
20730              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
20731              "type": "array",
20732              "items": {
20733                "type": "object",
20734                "properties": {
20735                  "key": {
20736                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
20737                    "type": "string"
20738                  },
20739                  "value": {
20740                    "description": "[Output Only] A warning data value corresponding to the key.",
20741                    "type": "string"
20742                  }
20743                }
20744              }
20745            }
20746          }
20747        }
20748      }
20749    },
20750    "InstantSnapshot": {
20751      "id": "InstantSnapshot",
20752      "description": "Represents a InstantSnapshot resource. You can use instant snapshots to create disk rollback points quickly..",
20753      "type": "object",
20754      "properties": {
20755        "kind": {
20756          "description": "[Output Only] Type of the resource. Always compute#instantSnapshot for InstantSnapshot resources.",
20757          "default": "compute#instantSnapshot",
20758          "type": "string"
20759        },
20760        "id": {
20761          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
20762          "type": "string",
20763          "format": "uint64"
20764        },
20765        "creationTimestamp": {
20766          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
20767          "type": "string"
20768        },
20769        "name": {
20770          "description": "Name of the resource; provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
20771          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
20772          "type": "string"
20773        },
20774        "description": {
20775          "description": "An optional description of this resource. Provide this property when you create the resource.",
20776          "type": "string"
20777        },
20778        "status": {
20779          "description": "[Output Only] The status of the instantSnapshot. This can be CREATING, DELETING, FAILED, or READY.",
20780          "type": "string",
20781          "enumDescriptions": [
20782            "InstantSnapshot creation is in progress.",
20783            "InstantSnapshot is currently being deleted.",
20784            "InstantSnapshot creation failed.",
20785            "InstantSnapshot has been created successfully."
20786          ],
20787          "enum": [
20788            "CREATING",
20789            "DELETING",
20790            "FAILED",
20791            "READY"
20792          ]
20793        },
20794        "sourceDisk": {
20795          "description": "URL of the source disk used to create this instant snapshot. Note that the source disk must be in the same zone/region as the instant snapshot to be created. This can be a full or valid partial URL. For example, the following are valid values: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /disks/disk - https://www.googleapis.com/compute/v1/projects/project/regions/region /disks/disk - projects/project/zones/zone/disks/disk - projects/project/regions/region/disks/disk - zones/zone/disks/disk - regions/region/disks/disk ",
20796          "type": "string"
20797        },
20798        "sourceDiskId": {
20799          "description": "[Output Only] The ID value of the disk used to create this InstantSnapshot. This value may be used to determine whether the InstantSnapshot was taken from the current or a previous instance of a given disk name.",
20800          "type": "string"
20801        },
20802        "diskSizeGb": {
20803          "description": "[Output Only] Size of the source disk, specified in GB.",
20804          "type": "string",
20805          "format": "int64"
20806        },
20807        "selfLink": {
20808          "description": "[Output Only] Server-defined URL for the resource.",
20809          "type": "string"
20810        },
20811        "selfLinkWithId": {
20812          "description": "[Output Only] Server-defined URL for this resource's resource id.",
20813          "type": "string"
20814        },
20815        "labels": {
20816          "description": "Labels to apply to this InstantSnapshot. These can be later modified by the setLabels method. Label values may be empty.",
20817          "type": "object",
20818          "additionalProperties": {
20819            "type": "string"
20820          }
20821        },
20822        "labelFingerprint": {
20823          "description": "A fingerprint for the labels being applied to this InstantSnapshot, which is essentially a hash of the labels set used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve a InstantSnapshot.",
20824          "type": "string",
20825          "format": "byte"
20826        },
20827        "zone": {
20828          "description": "[Output Only] URL of the zone where the instant snapshot resides. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
20829          "type": "string"
20830        },
20831        "region": {
20832          "description": "[Output Only] URL of the region where the instant snapshot resides. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
20833          "type": "string"
20834        },
20835        "satisfiesPzs": {
20836          "description": "[Output Only] Reserved for future use.",
20837          "type": "boolean"
20838        },
20839        "architecture": {
20840          "description": "[Output Only] The architecture of the instant snapshot. Valid values are ARM64 or X86_64.",
20841          "type": "string",
20842          "enumDescriptions": [
20843            "Default value indicating Architecture is not set.",
20844            "Machines with architecture ARM64",
20845            "Machines with architecture X86_64"
20846          ],
20847          "enum": [
20848            "ARCHITECTURE_UNSPECIFIED",
20849            "ARM64",
20850            "X86_64"
20851          ]
20852        },
20853        "resourceStatus": {
20854          "description": "[Output Only] Status information for the instant snapshot resource.",
20855          "$ref": "InstantSnapshotResourceStatus"
20856        },
20857        "satisfiesPzi": {
20858          "description": "Output only. Reserved for future use.",
20859          "readOnly": true,
20860          "type": "boolean"
20861        }
20862      }
20863    },
20864    "InstantSnapshotResourceStatus": {
20865      "id": "InstantSnapshotResourceStatus",
20866      "type": "object",
20867      "properties": {
20868        "storageSizeBytes": {
20869          "description": "[Output Only] The storage size of this instant snapshot.",
20870          "type": "string",
20871          "format": "int64"
20872        }
20873      }
20874    },
20875    "InstantSnapshotAggregatedList": {
20876      "id": "InstantSnapshotAggregatedList",
20877      "type": "object",
20878      "properties": {
20879        "kind": {
20880          "description": "[Output Only] Type of resource. Always compute#instantSnapshotAggregatedList for aggregated lists of instantSnapshots.",
20881          "default": "compute#instantSnapshotAggregatedList",
20882          "type": "string"
20883        },
20884        "id": {
20885          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
20886          "type": "string"
20887        },
20888        "items": {
20889          "description": "A list of InstantSnapshotsScopedList resources.",
20890          "type": "object",
20891          "additionalProperties": {
20892            "description": "[Output Only] Name of the scope containing this set of instantSnapshots.",
20893            "$ref": "InstantSnapshotsScopedList"
20894          }
20895        },
20896        "nextPageToken": {
20897          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
20898          "type": "string"
20899        },
20900        "selfLink": {
20901          "description": "[Output Only] Server-defined URL for this resource.",
20902          "type": "string"
20903        },
20904        "warning": {
20905          "description": "[Output Only] Informational warning message.",
20906          "type": "object",
20907          "properties": {
20908            "code": {
20909              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
20910              "type": "string",
20911              "enumDescriptions": [
20912                "Warning about failed cleanup of transient changes made by a failed operation.",
20913                "A link to a deprecated resource was created.",
20914                "When deploying and at least one of the resources has a type marked as deprecated",
20915                "The user created a boot disk that is larger than image size.",
20916                "When deploying and at least one of the resources has a type marked as experimental",
20917                "Warning that is present in an external api call",
20918                "Warning that value of a field has been overridden. Deprecated unused field.",
20919                "The operation involved use of an injected kernel, which is deprecated.",
20920                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
20921                "When deploying a deployment with a exceedingly large number of resources",
20922                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
20923                "A resource depends on a missing type",
20924                "The route's nextHopIp address is not assigned to an instance on the network.",
20925                "The route's next hop instance cannot ip forward.",
20926                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
20927                "The route's nextHopInstance URL refers to an instance that does not exist.",
20928                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
20929                "The route's next hop instance does not have a status of RUNNING.",
20930                "Error which is not critical. We decided to continue the process despite the mentioned error.",
20931                "No results are present on a particular list page.",
20932                "Success is reported, but some results may be missing due to errors",
20933                "The user attempted to use a resource that requires a TOS they have not accepted.",
20934                "Warning that a resource is in use.",
20935                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
20936                "When a resource schema validation is ignored.",
20937                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
20938                "When undeclared properties in the schema are present",
20939                "A given scope cannot be reached."
20940              ],
20941              "enumDeprecated": [
20942                false,
20943                false,
20944                false,
20945                false,
20946                false,
20947                false,
20948                true,
20949                false,
20950                false,
20951                false,
20952                false,
20953                false,
20954                false,
20955                false,
20956                false,
20957                false,
20958                false,
20959                false,
20960                false,
20961                false,
20962                false,
20963                false,
20964                false,
20965                false,
20966                false,
20967                false,
20968                false,
20969                false
20970              ],
20971              "enum": [
20972                "CLEANUP_FAILED",
20973                "DEPRECATED_RESOURCE_USED",
20974                "DEPRECATED_TYPE_USED",
20975                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
20976                "EXPERIMENTAL_TYPE_USED",
20977                "EXTERNAL_API_WARNING",
20978                "FIELD_VALUE_OVERRIDEN",
20979                "INJECTED_KERNELS_DEPRECATED",
20980                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
20981                "LARGE_DEPLOYMENT_WARNING",
20982                "LIST_OVERHEAD_QUOTA_EXCEED",
20983                "MISSING_TYPE_DEPENDENCY",
20984                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
20985                "NEXT_HOP_CANNOT_IP_FORWARD",
20986                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
20987                "NEXT_HOP_INSTANCE_NOT_FOUND",
20988                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
20989                "NEXT_HOP_NOT_RUNNING",
20990                "NOT_CRITICAL_ERROR",
20991                "NO_RESULTS_ON_PAGE",
20992                "PARTIAL_SUCCESS",
20993                "REQUIRED_TOS_AGREEMENT",
20994                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
20995                "RESOURCE_NOT_DELETED",
20996                "SCHEMA_VALIDATION_IGNORED",
20997                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
20998                "UNDECLARED_PROPERTIES",
20999                "UNREACHABLE"
21000              ]
21001            },
21002            "message": {
21003              "description": "[Output Only] A human-readable description of the warning code.",
21004              "type": "string"
21005            },
21006            "data": {
21007              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
21008              "type": "array",
21009              "items": {
21010                "type": "object",
21011                "properties": {
21012                  "key": {
21013                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
21014                    "type": "string"
21015                  },
21016                  "value": {
21017                    "description": "[Output Only] A warning data value corresponding to the key.",
21018                    "type": "string"
21019                  }
21020                }
21021              }
21022            }
21023          }
21024        },
21025        "unreachables": {
21026          "description": "[Output Only] Unreachable resources.",
21027          "type": "array",
21028          "items": {
21029            "type": "string"
21030          }
21031        }
21032      }
21033    },
21034    "InstantSnapshotsScopedList": {
21035      "id": "InstantSnapshotsScopedList",
21036      "type": "object",
21037      "properties": {
21038        "instantSnapshots": {
21039          "description": "[Output Only] A list of instantSnapshots contained in this scope.",
21040          "type": "array",
21041          "items": {
21042            "$ref": "InstantSnapshot"
21043          }
21044        },
21045        "warning": {
21046          "description": "[Output Only] Informational warning which replaces the list of instantSnapshots when the list is empty.",
21047          "type": "object",
21048          "properties": {
21049            "code": {
21050              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
21051              "type": "string",
21052              "enumDescriptions": [
21053                "Warning about failed cleanup of transient changes made by a failed operation.",
21054                "A link to a deprecated resource was created.",
21055                "When deploying and at least one of the resources has a type marked as deprecated",
21056                "The user created a boot disk that is larger than image size.",
21057                "When deploying and at least one of the resources has a type marked as experimental",
21058                "Warning that is present in an external api call",
21059                "Warning that value of a field has been overridden. Deprecated unused field.",
21060                "The operation involved use of an injected kernel, which is deprecated.",
21061                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
21062                "When deploying a deployment with a exceedingly large number of resources",
21063                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
21064                "A resource depends on a missing type",
21065                "The route's nextHopIp address is not assigned to an instance on the network.",
21066                "The route's next hop instance cannot ip forward.",
21067                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
21068                "The route's nextHopInstance URL refers to an instance that does not exist.",
21069                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
21070                "The route's next hop instance does not have a status of RUNNING.",
21071                "Error which is not critical. We decided to continue the process despite the mentioned error.",
21072                "No results are present on a particular list page.",
21073                "Success is reported, but some results may be missing due to errors",
21074                "The user attempted to use a resource that requires a TOS they have not accepted.",
21075                "Warning that a resource is in use.",
21076                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
21077                "When a resource schema validation is ignored.",
21078                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
21079                "When undeclared properties in the schema are present",
21080                "A given scope cannot be reached."
21081              ],
21082              "enumDeprecated": [
21083                false,
21084                false,
21085                false,
21086                false,
21087                false,
21088                false,
21089                true,
21090                false,
21091                false,
21092                false,
21093                false,
21094                false,
21095                false,
21096                false,
21097                false,
21098                false,
21099                false,
21100                false,
21101                false,
21102                false,
21103                false,
21104                false,
21105                false,
21106                false,
21107                false,
21108                false,
21109                false,
21110                false
21111              ],
21112              "enum": [
21113                "CLEANUP_FAILED",
21114                "DEPRECATED_RESOURCE_USED",
21115                "DEPRECATED_TYPE_USED",
21116                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
21117                "EXPERIMENTAL_TYPE_USED",
21118                "EXTERNAL_API_WARNING",
21119                "FIELD_VALUE_OVERRIDEN",
21120                "INJECTED_KERNELS_DEPRECATED",
21121                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
21122                "LARGE_DEPLOYMENT_WARNING",
21123                "LIST_OVERHEAD_QUOTA_EXCEED",
21124                "MISSING_TYPE_DEPENDENCY",
21125                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
21126                "NEXT_HOP_CANNOT_IP_FORWARD",
21127                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
21128                "NEXT_HOP_INSTANCE_NOT_FOUND",
21129                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
21130                "NEXT_HOP_NOT_RUNNING",
21131                "NOT_CRITICAL_ERROR",
21132                "NO_RESULTS_ON_PAGE",
21133                "PARTIAL_SUCCESS",
21134                "REQUIRED_TOS_AGREEMENT",
21135                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
21136                "RESOURCE_NOT_DELETED",
21137                "SCHEMA_VALIDATION_IGNORED",
21138                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
21139                "UNDECLARED_PROPERTIES",
21140                "UNREACHABLE"
21141              ]
21142            },
21143            "message": {
21144              "description": "[Output Only] A human-readable description of the warning code.",
21145              "type": "string"
21146            },
21147            "data": {
21148              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
21149              "type": "array",
21150              "items": {
21151                "type": "object",
21152                "properties": {
21153                  "key": {
21154                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
21155                    "type": "string"
21156                  },
21157                  "value": {
21158                    "description": "[Output Only] A warning data value corresponding to the key.",
21159                    "type": "string"
21160                  }
21161                }
21162              }
21163            }
21164          }
21165        }
21166      }
21167    },
21168    "InterconnectAttachmentList": {
21169      "id": "InterconnectAttachmentList",
21170      "description": "Response to the list request, and contains a list of interconnect attachments.",
21171      "type": "object",
21172      "properties": {
21173        "kind": {
21174          "description": "[Output Only] Type of resource. Always compute#interconnectAttachmentList for lists of interconnect attachments.",
21175          "default": "compute#interconnectAttachmentList",
21176          "type": "string"
21177        },
21178        "id": {
21179          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
21180          "type": "string"
21181        },
21182        "items": {
21183          "description": "A list of InterconnectAttachment resources.",
21184          "type": "array",
21185          "items": {
21186            "$ref": "InterconnectAttachment"
21187          }
21188        },
21189        "nextPageToken": {
21190          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
21191          "type": "string"
21192        },
21193        "selfLink": {
21194          "description": "[Output Only] Server-defined URL for this resource.",
21195          "type": "string"
21196        },
21197        "warning": {
21198          "description": "[Output Only] Informational warning message.",
21199          "type": "object",
21200          "properties": {
21201            "code": {
21202              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
21203              "type": "string",
21204              "enumDescriptions": [
21205                "Warning about failed cleanup of transient changes made by a failed operation.",
21206                "A link to a deprecated resource was created.",
21207                "When deploying and at least one of the resources has a type marked as deprecated",
21208                "The user created a boot disk that is larger than image size.",
21209                "When deploying and at least one of the resources has a type marked as experimental",
21210                "Warning that is present in an external api call",
21211                "Warning that value of a field has been overridden. Deprecated unused field.",
21212                "The operation involved use of an injected kernel, which is deprecated.",
21213                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
21214                "When deploying a deployment with a exceedingly large number of resources",
21215                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
21216                "A resource depends on a missing type",
21217                "The route's nextHopIp address is not assigned to an instance on the network.",
21218                "The route's next hop instance cannot ip forward.",
21219                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
21220                "The route's nextHopInstance URL refers to an instance that does not exist.",
21221                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
21222                "The route's next hop instance does not have a status of RUNNING.",
21223                "Error which is not critical. We decided to continue the process despite the mentioned error.",
21224                "No results are present on a particular list page.",
21225                "Success is reported, but some results may be missing due to errors",
21226                "The user attempted to use a resource that requires a TOS they have not accepted.",
21227                "Warning that a resource is in use.",
21228                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
21229                "When a resource schema validation is ignored.",
21230                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
21231                "When undeclared properties in the schema are present",
21232                "A given scope cannot be reached."
21233              ],
21234              "enumDeprecated": [
21235                false,
21236                false,
21237                false,
21238                false,
21239                false,
21240                false,
21241                true,
21242                false,
21243                false,
21244                false,
21245                false,
21246                false,
21247                false,
21248                false,
21249                false,
21250                false,
21251                false,
21252                false,
21253                false,
21254                false,
21255                false,
21256                false,
21257                false,
21258                false,
21259                false,
21260                false,
21261                false,
21262                false
21263              ],
21264              "enum": [
21265                "CLEANUP_FAILED",
21266                "DEPRECATED_RESOURCE_USED",
21267                "DEPRECATED_TYPE_USED",
21268                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
21269                "EXPERIMENTAL_TYPE_USED",
21270                "EXTERNAL_API_WARNING",
21271                "FIELD_VALUE_OVERRIDEN",
21272                "INJECTED_KERNELS_DEPRECATED",
21273                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
21274                "LARGE_DEPLOYMENT_WARNING",
21275                "LIST_OVERHEAD_QUOTA_EXCEED",
21276                "MISSING_TYPE_DEPENDENCY",
21277                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
21278                "NEXT_HOP_CANNOT_IP_FORWARD",
21279                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
21280                "NEXT_HOP_INSTANCE_NOT_FOUND",
21281                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
21282                "NEXT_HOP_NOT_RUNNING",
21283                "NOT_CRITICAL_ERROR",
21284                "NO_RESULTS_ON_PAGE",
21285                "PARTIAL_SUCCESS",
21286                "REQUIRED_TOS_AGREEMENT",
21287                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
21288                "RESOURCE_NOT_DELETED",
21289                "SCHEMA_VALIDATION_IGNORED",
21290                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
21291                "UNDECLARED_PROPERTIES",
21292                "UNREACHABLE"
21293              ]
21294            },
21295            "message": {
21296              "description": "[Output Only] A human-readable description of the warning code.",
21297              "type": "string"
21298            },
21299            "data": {
21300              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
21301              "type": "array",
21302              "items": {
21303                "type": "object",
21304                "properties": {
21305                  "key": {
21306                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
21307                    "type": "string"
21308                  },
21309                  "value": {
21310                    "description": "[Output Only] A warning data value corresponding to the key.",
21311                    "type": "string"
21312                  }
21313                }
21314              }
21315            }
21316          }
21317        }
21318      }
21319    },
21320    "InterconnectAttachment": {
21321      "id": "InterconnectAttachment",
21322      "description": "Represents an Interconnect Attachment (VLAN) resource. You can use Interconnect attachments (VLANS) to connect your Virtual Private Cloud networks to your on-premises networks through an Interconnect. For more information, read Creating VLAN Attachments.",
21323      "type": "object",
21324      "properties": {
21325        "kind": {
21326          "description": "[Output Only] Type of the resource. Always compute#interconnectAttachment for interconnect attachments.",
21327          "default": "compute#interconnectAttachment",
21328          "type": "string"
21329        },
21330        "description": {
21331          "description": "An optional description of this resource.",
21332          "type": "string"
21333        },
21334        "selfLink": {
21335          "description": "[Output Only] Server-defined URL for the resource.",
21336          "type": "string"
21337        },
21338        "id": {
21339          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
21340          "type": "string",
21341          "format": "uint64"
21342        },
21343        "creationTimestamp": {
21344          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
21345          "type": "string"
21346        },
21347        "name": {
21348          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
21349          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
21350          "type": "string"
21351        },
21352        "interconnect": {
21353          "description": "URL of the underlying Interconnect object that this attachment's traffic will traverse through.",
21354          "type": "string"
21355        },
21356        "router": {
21357          "description": "URL of the Cloud Router to be used for dynamic routing. This router must be in the same region as this InterconnectAttachment. The InterconnectAttachment will automatically connect the Interconnect to the network & region within which the Cloud Router is configured.",
21358          "type": "string"
21359        },
21360        "region": {
21361          "description": "[Output Only] URL of the region where the regional interconnect attachment resides. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
21362          "type": "string"
21363        },
21364        "googleReferenceId": {
21365          "description": "[Output Only] Google reference ID, to be used when raising support tickets with Google or otherwise to debug backend connectivity issues. [Deprecated] This field is not used.",
21366          "deprecated": true,
21367          "type": "string"
21368        },
21369        "mtu": {
21370          "description": "Maximum Transmission Unit (MTU), in bytes, of packets passing through this interconnect attachment. Only 1440 and 1500 are allowed. If not specified, the value will default to 1440.",
21371          "type": "integer",
21372          "format": "int32"
21373        },
21374        "privateInterconnectInfo": {
21375          "description": "[Output Only] Information specific to an InterconnectAttachment. This property is populated if the interconnect that this is attached to is of type DEDICATED.",
21376          "$ref": "InterconnectAttachmentPrivateInfo"
21377        },
21378        "operationalStatus": {
21379          "description": "[Output Only] The current status of whether or not this interconnect attachment is functional, which can take one of the following values: - OS_ACTIVE: The attachment has been turned up and is ready to use. - OS_UNPROVISIONED: The attachment is not ready to use yet, because turnup is not complete. ",
21380          "type": "string",
21381          "enumDescriptions": [
21382            "Indicates that attachment has been turned up and is ready to use.",
21383            "Indicates that attachment is not ready to use yet, because turnup is not complete."
21384          ],
21385          "enum": [
21386            "OS_ACTIVE",
21387            "OS_UNPROVISIONED"
21388          ]
21389        },
21390        "cloudRouterIpAddress": {
21391          "description": "[Output Only] IPv4 address + prefix length to be configured on Cloud Router Interface for this interconnect attachment.",
21392          "type": "string"
21393        },
21394        "customerRouterIpAddress": {
21395          "description": "[Output Only] IPv4 address + prefix length to be configured on the customer router subinterface for this interconnect attachment.",
21396          "type": "string"
21397        },
21398        "type": {
21399          "description": "The type of interconnect attachment this is, which can take one of the following values: - DEDICATED: an attachment to a Dedicated Interconnect. - PARTNER: an attachment to a Partner Interconnect, created by the customer. - PARTNER_PROVIDER: an attachment to a Partner Interconnect, created by the partner. ",
21400          "type": "string",
21401          "enumDescriptions": [
21402            "Attachment to a dedicated interconnect.",
21403            "Attachment to a partner interconnect, created by the customer.",
21404            "Attachment to a partner interconnect, created by the partner."
21405          ],
21406          "enum": [
21407            "DEDICATED",
21408            "PARTNER",
21409            "PARTNER_PROVIDER"
21410          ]
21411        },
21412        "pairingKey": {
21413          "description": "[Output only for type PARTNER. Input only for PARTNER_PROVIDER. Not present for DEDICATED]. The opaque identifier of a PARTNER attachment used to initiate provisioning with a selected partner. Of the form \"XXXXX/region/domain\"",
21414          "type": "string"
21415        },
21416        "adminEnabled": {
21417          "description": "Determines whether this Attachment will carry packets. Not present for PARTNER_PROVIDER.",
21418          "type": "boolean"
21419        },
21420        "vlanTag8021q": {
21421          "description": "The IEEE 802.1Q VLAN tag for this attachment, in the range 2-4093. Only specified at creation time.",
21422          "type": "integer",
21423          "format": "int32"
21424        },
21425        "edgeAvailabilityDomain": {
21426          "description": "Desired availability domain for the attachment. Only available for type PARTNER, at creation time, and can take one of the following values: - AVAILABILITY_DOMAIN_ANY - AVAILABILITY_DOMAIN_1 - AVAILABILITY_DOMAIN_2 For improved reliability, customers should configure a pair of attachments, one per availability domain. The selected availability domain will be provided to the Partner via the pairing key, so that the provisioned circuit will lie in the specified domain. If not specified, the value will default to AVAILABILITY_DOMAIN_ANY.",
21427          "type": "string",
21428          "enumDescriptions": [
21429            "",
21430            "",
21431            ""
21432          ],
21433          "enum": [
21434            "AVAILABILITY_DOMAIN_1",
21435            "AVAILABILITY_DOMAIN_2",
21436            "AVAILABILITY_DOMAIN_ANY"
21437          ]
21438        },
21439        "candidateSubnets": {
21440          "description": "Up to 16 candidate prefixes that can be used to restrict the allocation of cloudRouterIpAddress and customerRouterIpAddress for this attachment. All prefixes must be within link-local address space (169.254.0.0/16) and must be /29 or shorter (/28, /27, etc). Google will attempt to select an unused /29 from the supplied candidate prefix(es). The request will fail if all possible /29s are in use on Google's edge. If not supplied, Google will randomly select an unused /29 from all of link-local space.",
21441          "type": "array",
21442          "items": {
21443            "type": "string"
21444          }
21445        },
21446        "bandwidth": {
21447          "description": "Provisioned bandwidth capacity for the interconnect attachment. For attachments of type DEDICATED, the user can set the bandwidth. For attachments of type PARTNER, the Google Partner that is operating the interconnect must set the bandwidth. Output only for PARTNER type, mutable for PARTNER_PROVIDER and DEDICATED, and can take one of the following values: - BPS_50M: 50 Mbit/s - BPS_100M: 100 Mbit/s - BPS_200M: 200 Mbit/s - BPS_300M: 300 Mbit/s - BPS_400M: 400 Mbit/s - BPS_500M: 500 Mbit/s - BPS_1G: 1 Gbit/s - BPS_2G: 2 Gbit/s - BPS_5G: 5 Gbit/s - BPS_10G: 10 Gbit/s - BPS_20G: 20 Gbit/s - BPS_50G: 50 Gbit/s ",
21448          "type": "string",
21449          "enumDescriptions": [
21450            "100 Mbit/s",
21451            "10 Gbit/s",
21452            "1 Gbit/s",
21453            "200 Mbit/s",
21454            "20 Gbit/s",
21455            "2 Gbit/s",
21456            "300 Mbit/s",
21457            "400 Mbit/s",
21458            "500 Mbit/s",
21459            "50 Gbit/s",
21460            "50 Mbit/s",
21461            "5 Gbit/s"
21462          ],
21463          "enum": [
21464            "BPS_100M",
21465            "BPS_10G",
21466            "BPS_1G",
21467            "BPS_200M",
21468            "BPS_20G",
21469            "BPS_2G",
21470            "BPS_300M",
21471            "BPS_400M",
21472            "BPS_500M",
21473            "BPS_50G",
21474            "BPS_50M",
21475            "BPS_5G"
21476          ]
21477        },
21478        "partnerMetadata": {
21479          "description": "Informational metadata about Partner attachments from Partners to display to customers. Output only for PARTNER type, mutable for PARTNER_PROVIDER, not available for DEDICATED.",
21480          "$ref": "InterconnectAttachmentPartnerMetadata"
21481        },
21482        "labels": {
21483          "description": "Labels for this resource. These can only be added or modified by the setLabels method. Each label key/value pair must comply with RFC1035. Label values may be empty.",
21484          "type": "object",
21485          "additionalProperties": {
21486            "type": "string"
21487          }
21488        },
21489        "labelFingerprint": {
21490          "description": "A fingerprint for the labels being applied to this InterconnectAttachment, which is essentially a hash of the labels set used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve an InterconnectAttachment.",
21491          "type": "string",
21492          "format": "byte"
21493        },
21494        "state": {
21495          "description": "[Output Only] The current state of this attachment's functionality. Enum values ACTIVE and UNPROVISIONED are shared by DEDICATED/PRIVATE, PARTNER, and PARTNER_PROVIDER interconnect attachments, while enum values PENDING_PARTNER, PARTNER_REQUEST_RECEIVED, and PENDING_CUSTOMER are used for only PARTNER and PARTNER_PROVIDER interconnect attachments. This state can take one of the following values: - ACTIVE: The attachment has been turned up and is ready to use. - UNPROVISIONED: The attachment is not ready to use yet, because turnup is not complete. - PENDING_PARTNER: A newly-created PARTNER attachment that has not yet been configured on the Partner side. - PARTNER_REQUEST_RECEIVED: A PARTNER attachment is in the process of provisioning after a PARTNER_PROVIDER attachment was created that references it. - PENDING_CUSTOMER: A PARTNER or PARTNER_PROVIDER attachment that is waiting for a customer to activate it. - DEFUNCT: The attachment was deleted externally and is no longer functional. This could be because the associated Interconnect was removed, or because the other side of a Partner attachment was deleted. ",
21496          "type": "string",
21497          "enumDescriptions": [
21498            "Indicates that attachment has been turned up and is ready to use.",
21499            "The attachment was deleted externally and is no longer functional. This could be because the associated Interconnect was wiped out, or because the other side of a Partner attachment was deleted.",
21500            "A PARTNER attachment is in the process of provisioning after a PARTNER_PROVIDER attachment was created that references it.",
21501            "PARTNER or PARTNER_PROVIDER attachment that is waiting for the customer to activate.",
21502            "A newly created PARTNER attachment that has not yet been configured on the Partner side.",
21503            "",
21504            "Indicates that attachment is not ready to use yet, because turnup is not complete."
21505          ],
21506          "enum": [
21507            "ACTIVE",
21508            "DEFUNCT",
21509            "PARTNER_REQUEST_RECEIVED",
21510            "PENDING_CUSTOMER",
21511            "PENDING_PARTNER",
21512            "STATE_UNSPECIFIED",
21513            "UNPROVISIONED"
21514          ]
21515        },
21516        "partnerAsn": {
21517          "description": "Optional BGP ASN for the router supplied by a Layer 3 Partner if they configured BGP on behalf of the customer. Output only for PARTNER type, input only for PARTNER_PROVIDER, not available for DEDICATED.",
21518          "type": "string",
21519          "format": "int64"
21520        },
21521        "encryption": {
21522          "description": "Indicates the user-supplied encryption option of this VLAN attachment (interconnectAttachment). Can only be specified at attachment creation for PARTNER or DEDICATED attachments. Possible values are: - NONE - This is the default value, which means that the VLAN attachment carries unencrypted traffic. VMs are able to send traffic to, or receive traffic from, such a VLAN attachment. - IPSEC - The VLAN attachment carries only encrypted traffic that is encrypted by an IPsec device, such as an HA VPN gateway or third-party IPsec VPN. VMs cannot directly send traffic to, or receive traffic from, such a VLAN attachment. To use *HA VPN over Cloud Interconnect*, the VLAN attachment must be created with this option. ",
21523          "type": "string",
21524          "enumDescriptions": [
21525            "The interconnect attachment will carry only encrypted traffic that is encrypted by an IPsec device such as HA VPN gateway; VMs cannot directly send traffic to or receive traffic from such an interconnect attachment. To use HA VPN over Cloud Interconnect, the interconnect attachment must be created with this option.",
21526            "This is the default value, which means the Interconnect Attachment will carry unencrypted traffic. VMs will be able to send traffic to or receive traffic from such interconnect attachment."
21527          ],
21528          "enum": [
21529            "IPSEC",
21530            "NONE"
21531          ]
21532        },
21533        "ipsecInternalAddresses": {
21534          "description": "A list of URLs of addresses that have been reserved for the VLAN attachment. Used only for the VLAN attachment that has the encryption option as IPSEC. The addresses must be regional internal IP address ranges. When creating an HA VPN gateway over the VLAN attachment, if the attachment is configured to use a regional internal IP address, then the VPN gateway's IP address is allocated from the IP address range specified here. For example, if the HA VPN gateway's interface 0 is paired to this VLAN attachment, then a regional internal IP address for the VPN gateway interface 0 will be allocated from the IP address specified for this VLAN attachment. If this field is not specified when creating the VLAN attachment, then later on when creating an HA VPN gateway on this VLAN attachment, the HA VPN gateway's IP address is allocated from the regional external IP address pool.",
21535          "type": "array",
21536          "items": {
21537            "type": "string"
21538          }
21539        },
21540        "dataplaneVersion": {
21541          "description": "[Output Only] Dataplane version for this InterconnectAttachment. This field is only present for Dataplane version 2 and higher. Absence of this field in the API output indicates that the Dataplane is version 1.",
21542          "type": "integer",
21543          "format": "int32"
21544        },
21545        "satisfiesPzs": {
21546          "description": "[Output Only] Reserved for future use.",
21547          "type": "boolean"
21548        },
21549        "stackType": {
21550          "description": "The stack type for this interconnect attachment to identify whether the IPv6 feature is enabled or not. If not specified, IPV4_ONLY will be used. This field can be both set at interconnect attachments creation and update interconnect attachment operations.",
21551          "type": "string",
21552          "enumDescriptions": [
21553            "The interconnect attachment can have both IPv4 and IPv6 addresses.",
21554            "The interconnect attachment will only be assigned IPv4 addresses."
21555          ],
21556          "enum": [
21557            "IPV4_IPV6",
21558            "IPV4_ONLY"
21559          ]
21560        },
21561        "cloudRouterIpv6Address": {
21562          "description": "[Output Only] IPv6 address + prefix length to be configured on Cloud Router Interface for this interconnect attachment.",
21563          "type": "string"
21564        },
21565        "customerRouterIpv6Address": {
21566          "description": "[Output Only] IPv6 address + prefix length to be configured on the customer router subinterface for this interconnect attachment.",
21567          "type": "string"
21568        },
21569        "candidateIpv6Subnets": {
21570          "description": "This field is not available.",
21571          "type": "array",
21572          "items": {
21573            "type": "string"
21574          }
21575        },
21576        "cloudRouterIpv6InterfaceId": {
21577          "description": "This field is not available.",
21578          "type": "string"
21579        },
21580        "customerRouterIpv6InterfaceId": {
21581          "description": "This field is not available.",
21582          "type": "string"
21583        },
21584        "subnetLength": {
21585          "description": "Length of the IPv4 subnet mask. Allowed values: - 29 (default) - 30 The default value is 29, except for Cross-Cloud Interconnect connections that use an InterconnectRemoteLocation with a constraints.subnetLengthRange.min equal to 30. For example, connections that use an Azure remote location fall into this category. In these cases, the default value is 30, and requesting 29 returns an error. Where both 29 and 30 are allowed, 29 is preferred, because it gives Google Cloud Support more debugging visibility. ",
21586          "type": "integer",
21587          "format": "int32"
21588        },
21589        "remoteService": {
21590          "description": "[Output Only] If the attachment is on a Cross-Cloud Interconnect connection, this field contains the interconnect's remote location service provider. Example values: \"Amazon Web Services\" \"Microsoft Azure\". The field is set only for attachments on Cross-Cloud Interconnect connections. Its value is copied from the InterconnectRemoteLocation remoteService field.",
21591          "type": "string"
21592        },
21593        "configurationConstraints": {
21594          "description": "[Output Only] Constraints for this attachment, if any. The attachment does not work if these constraints are not met.",
21595          "$ref": "InterconnectAttachmentConfigurationConstraints"
21596        }
21597      }
21598    },
21599    "InterconnectAttachmentPrivateInfo": {
21600      "id": "InterconnectAttachmentPrivateInfo",
21601      "description": "Information for an interconnect attachment when this belongs to an interconnect of type DEDICATED.",
21602      "type": "object",
21603      "properties": {
21604        "tag8021q": {
21605          "description": "[Output Only] 802.1q encapsulation tag to be used for traffic between Google and the customer, going to and from this network and region.",
21606          "type": "integer",
21607          "format": "uint32"
21608        }
21609      }
21610    },
21611    "InterconnectAttachmentPartnerMetadata": {
21612      "id": "InterconnectAttachmentPartnerMetadata",
21613      "description": "Informational metadata about Partner attachments from Partners to display to customers. These fields are propagated from PARTNER_PROVIDER attachments to their corresponding PARTNER attachments.",
21614      "type": "object",
21615      "properties": {
21616        "partnerName": {
21617          "description": "Plain text name of the Partner providing this attachment. This value may be validated to match approved Partner values.",
21618          "type": "string"
21619        },
21620        "interconnectName": {
21621          "description": "Plain text name of the Interconnect this attachment is connected to, as displayed in the Partner's portal. For instance \"Chicago 1\". This value may be validated to match approved Partner values.",
21622          "type": "string"
21623        },
21624        "portalUrl": {
21625          "description": "URL of the Partner's portal for this Attachment. Partners may customise this to be a deep link to the specific resource on the Partner portal. This value may be validated to match approved Partner values.",
21626          "type": "string"
21627        }
21628      }
21629    },
21630    "InterconnectAttachmentConfigurationConstraints": {
21631      "id": "InterconnectAttachmentConfigurationConstraints",
21632      "type": "object",
21633      "properties": {
21634        "bgpMd5": {
21635          "description": "[Output Only] Whether the attachment's BGP session requires/allows/disallows BGP MD5 authentication. This can take one of the following values: MD5_OPTIONAL, MD5_REQUIRED, MD5_UNSUPPORTED. For example, a Cross-Cloud Interconnect connection to a remote cloud provider that requires BGP MD5 authentication has the interconnectRemoteLocation attachment_configuration_constraints.bgp_md5 field set to MD5_REQUIRED, and that property is propagated to the attachment. Similarly, if BGP MD5 is MD5_UNSUPPORTED, an error is returned if MD5 is requested.",
21636          "type": "string",
21637          "enumDescriptions": [
21638            "MD5_OPTIONAL: BGP MD5 authentication is supported and can optionally be configured.",
21639            "MD5_REQUIRED: BGP MD5 authentication must be configured.",
21640            "MD5_UNSUPPORTED: BGP MD5 authentication must not be configured"
21641          ],
21642          "enum": [
21643            "MD5_OPTIONAL",
21644            "MD5_REQUIRED",
21645            "MD5_UNSUPPORTED"
21646          ]
21647        },
21648        "bgpPeerAsnRanges": {
21649          "description": "[Output Only] List of ASN ranges that the remote location is known to support. Formatted as an array of inclusive ranges {min: min-value, max: max-value}. For example, [{min: 123, max: 123}, {min: 64512, max: 65534}] allows the peer ASN to be 123 or anything in the range 64512-65534. This field is only advisory. Although the API accepts other ranges, these are the ranges that we recommend.",
21650          "type": "array",
21651          "items": {
21652            "$ref": "InterconnectAttachmentConfigurationConstraintsBgpPeerASNRange"
21653          }
21654        }
21655      }
21656    },
21657    "InterconnectAttachmentConfigurationConstraintsBgpPeerASNRange": {
21658      "id": "InterconnectAttachmentConfigurationConstraintsBgpPeerASNRange",
21659      "type": "object",
21660      "properties": {
21661        "min": {
21662          "type": "integer",
21663          "format": "uint32"
21664        },
21665        "max": {
21666          "type": "integer",
21667          "format": "uint32"
21668        }
21669      }
21670    },
21671    "InterconnectAttachmentAggregatedList": {
21672      "id": "InterconnectAttachmentAggregatedList",
21673      "type": "object",
21674      "properties": {
21675        "kind": {
21676          "description": "[Output Only] Type of resource. Always compute#interconnectAttachmentAggregatedList for aggregated lists of interconnect attachments.",
21677          "default": "compute#interconnectAttachmentAggregatedList",
21678          "type": "string"
21679        },
21680        "id": {
21681          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
21682          "type": "string"
21683        },
21684        "items": {
21685          "description": "A list of InterconnectAttachmentsScopedList resources.",
21686          "type": "object",
21687          "additionalProperties": {
21688            "description": "Name of the scope containing this set of interconnect attachments.",
21689            "$ref": "InterconnectAttachmentsScopedList"
21690          }
21691        },
21692        "nextPageToken": {
21693          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
21694          "type": "string"
21695        },
21696        "selfLink": {
21697          "description": "[Output Only] Server-defined URL for this resource.",
21698          "type": "string"
21699        },
21700        "warning": {
21701          "description": "[Output Only] Informational warning message.",
21702          "type": "object",
21703          "properties": {
21704            "code": {
21705              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
21706              "type": "string",
21707              "enumDescriptions": [
21708                "Warning about failed cleanup of transient changes made by a failed operation.",
21709                "A link to a deprecated resource was created.",
21710                "When deploying and at least one of the resources has a type marked as deprecated",
21711                "The user created a boot disk that is larger than image size.",
21712                "When deploying and at least one of the resources has a type marked as experimental",
21713                "Warning that is present in an external api call",
21714                "Warning that value of a field has been overridden. Deprecated unused field.",
21715                "The operation involved use of an injected kernel, which is deprecated.",
21716                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
21717                "When deploying a deployment with a exceedingly large number of resources",
21718                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
21719                "A resource depends on a missing type",
21720                "The route's nextHopIp address is not assigned to an instance on the network.",
21721                "The route's next hop instance cannot ip forward.",
21722                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
21723                "The route's nextHopInstance URL refers to an instance that does not exist.",
21724                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
21725                "The route's next hop instance does not have a status of RUNNING.",
21726                "Error which is not critical. We decided to continue the process despite the mentioned error.",
21727                "No results are present on a particular list page.",
21728                "Success is reported, but some results may be missing due to errors",
21729                "The user attempted to use a resource that requires a TOS they have not accepted.",
21730                "Warning that a resource is in use.",
21731                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
21732                "When a resource schema validation is ignored.",
21733                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
21734                "When undeclared properties in the schema are present",
21735                "A given scope cannot be reached."
21736              ],
21737              "enumDeprecated": [
21738                false,
21739                false,
21740                false,
21741                false,
21742                false,
21743                false,
21744                true,
21745                false,
21746                false,
21747                false,
21748                false,
21749                false,
21750                false,
21751                false,
21752                false,
21753                false,
21754                false,
21755                false,
21756                false,
21757                false,
21758                false,
21759                false,
21760                false,
21761                false,
21762                false,
21763                false,
21764                false,
21765                false
21766              ],
21767              "enum": [
21768                "CLEANUP_FAILED",
21769                "DEPRECATED_RESOURCE_USED",
21770                "DEPRECATED_TYPE_USED",
21771                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
21772                "EXPERIMENTAL_TYPE_USED",
21773                "EXTERNAL_API_WARNING",
21774                "FIELD_VALUE_OVERRIDEN",
21775                "INJECTED_KERNELS_DEPRECATED",
21776                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
21777                "LARGE_DEPLOYMENT_WARNING",
21778                "LIST_OVERHEAD_QUOTA_EXCEED",
21779                "MISSING_TYPE_DEPENDENCY",
21780                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
21781                "NEXT_HOP_CANNOT_IP_FORWARD",
21782                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
21783                "NEXT_HOP_INSTANCE_NOT_FOUND",
21784                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
21785                "NEXT_HOP_NOT_RUNNING",
21786                "NOT_CRITICAL_ERROR",
21787                "NO_RESULTS_ON_PAGE",
21788                "PARTIAL_SUCCESS",
21789                "REQUIRED_TOS_AGREEMENT",
21790                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
21791                "RESOURCE_NOT_DELETED",
21792                "SCHEMA_VALIDATION_IGNORED",
21793                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
21794                "UNDECLARED_PROPERTIES",
21795                "UNREACHABLE"
21796              ]
21797            },
21798            "message": {
21799              "description": "[Output Only] A human-readable description of the warning code.",
21800              "type": "string"
21801            },
21802            "data": {
21803              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
21804              "type": "array",
21805              "items": {
21806                "type": "object",
21807                "properties": {
21808                  "key": {
21809                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
21810                    "type": "string"
21811                  },
21812                  "value": {
21813                    "description": "[Output Only] A warning data value corresponding to the key.",
21814                    "type": "string"
21815                  }
21816                }
21817              }
21818            }
21819          }
21820        },
21821        "unreachables": {
21822          "description": "[Output Only] Unreachable resources.",
21823          "type": "array",
21824          "items": {
21825            "type": "string"
21826          }
21827        }
21828      }
21829    },
21830    "InterconnectAttachmentsScopedList": {
21831      "id": "InterconnectAttachmentsScopedList",
21832      "type": "object",
21833      "properties": {
21834        "interconnectAttachments": {
21835          "description": "A list of interconnect attachments contained in this scope.",
21836          "type": "array",
21837          "items": {
21838            "$ref": "InterconnectAttachment"
21839          }
21840        },
21841        "warning": {
21842          "description": "Informational warning which replaces the list of addresses when the list is empty.",
21843          "type": "object",
21844          "properties": {
21845            "code": {
21846              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
21847              "type": "string",
21848              "enumDescriptions": [
21849                "Warning about failed cleanup of transient changes made by a failed operation.",
21850                "A link to a deprecated resource was created.",
21851                "When deploying and at least one of the resources has a type marked as deprecated",
21852                "The user created a boot disk that is larger than image size.",
21853                "When deploying and at least one of the resources has a type marked as experimental",
21854                "Warning that is present in an external api call",
21855                "Warning that value of a field has been overridden. Deprecated unused field.",
21856                "The operation involved use of an injected kernel, which is deprecated.",
21857                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
21858                "When deploying a deployment with a exceedingly large number of resources",
21859                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
21860                "A resource depends on a missing type",
21861                "The route's nextHopIp address is not assigned to an instance on the network.",
21862                "The route's next hop instance cannot ip forward.",
21863                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
21864                "The route's nextHopInstance URL refers to an instance that does not exist.",
21865                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
21866                "The route's next hop instance does not have a status of RUNNING.",
21867                "Error which is not critical. We decided to continue the process despite the mentioned error.",
21868                "No results are present on a particular list page.",
21869                "Success is reported, but some results may be missing due to errors",
21870                "The user attempted to use a resource that requires a TOS they have not accepted.",
21871                "Warning that a resource is in use.",
21872                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
21873                "When a resource schema validation is ignored.",
21874                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
21875                "When undeclared properties in the schema are present",
21876                "A given scope cannot be reached."
21877              ],
21878              "enumDeprecated": [
21879                false,
21880                false,
21881                false,
21882                false,
21883                false,
21884                false,
21885                true,
21886                false,
21887                false,
21888                false,
21889                false,
21890                false,
21891                false,
21892                false,
21893                false,
21894                false,
21895                false,
21896                false,
21897                false,
21898                false,
21899                false,
21900                false,
21901                false,
21902                false,
21903                false,
21904                false,
21905                false,
21906                false
21907              ],
21908              "enum": [
21909                "CLEANUP_FAILED",
21910                "DEPRECATED_RESOURCE_USED",
21911                "DEPRECATED_TYPE_USED",
21912                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
21913                "EXPERIMENTAL_TYPE_USED",
21914                "EXTERNAL_API_WARNING",
21915                "FIELD_VALUE_OVERRIDEN",
21916                "INJECTED_KERNELS_DEPRECATED",
21917                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
21918                "LARGE_DEPLOYMENT_WARNING",
21919                "LIST_OVERHEAD_QUOTA_EXCEED",
21920                "MISSING_TYPE_DEPENDENCY",
21921                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
21922                "NEXT_HOP_CANNOT_IP_FORWARD",
21923                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
21924                "NEXT_HOP_INSTANCE_NOT_FOUND",
21925                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
21926                "NEXT_HOP_NOT_RUNNING",
21927                "NOT_CRITICAL_ERROR",
21928                "NO_RESULTS_ON_PAGE",
21929                "PARTIAL_SUCCESS",
21930                "REQUIRED_TOS_AGREEMENT",
21931                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
21932                "RESOURCE_NOT_DELETED",
21933                "SCHEMA_VALIDATION_IGNORED",
21934                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
21935                "UNDECLARED_PROPERTIES",
21936                "UNREACHABLE"
21937              ]
21938            },
21939            "message": {
21940              "description": "[Output Only] A human-readable description of the warning code.",
21941              "type": "string"
21942            },
21943            "data": {
21944              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
21945              "type": "array",
21946              "items": {
21947                "type": "object",
21948                "properties": {
21949                  "key": {
21950                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
21951                    "type": "string"
21952                  },
21953                  "value": {
21954                    "description": "[Output Only] A warning data value corresponding to the key.",
21955                    "type": "string"
21956                  }
21957                }
21958              }
21959            }
21960          }
21961        }
21962      }
21963    },
21964    "Interconnect": {
21965      "id": "Interconnect",
21966      "description": "Represents an Interconnect resource. An Interconnect resource is a dedicated connection between the Google Cloud network and your on-premises network. For more information, read the Dedicated Interconnect Overview.",
21967      "type": "object",
21968      "properties": {
21969        "kind": {
21970          "description": "[Output Only] Type of the resource. Always compute#interconnect for interconnects.",
21971          "default": "compute#interconnect",
21972          "type": "string"
21973        },
21974        "description": {
21975          "description": "An optional description of this resource. Provide this property when you create the resource.",
21976          "type": "string"
21977        },
21978        "selfLink": {
21979          "description": "[Output Only] Server-defined URL for the resource.",
21980          "type": "string"
21981        },
21982        "id": {
21983          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
21984          "type": "string",
21985          "format": "uint64"
21986        },
21987        "creationTimestamp": {
21988          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
21989          "type": "string"
21990        },
21991        "name": {
21992          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
21993          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
21994          "annotations": {
21995            "required": [
21996              "compute.interconnects.insert"
21997            ]
21998          },
21999          "type": "string"
22000        },
22001        "location": {
22002          "description": "URL of the InterconnectLocation object that represents where this connection is to be provisioned.",
22003          "type": "string"
22004        },
22005        "linkType": {
22006          "description": "Type of link requested, which can take one of the following values: - LINK_TYPE_ETHERNET_10G_LR: A 10G Ethernet with LR optics - LINK_TYPE_ETHERNET_100G_LR: A 100G Ethernet with LR optics. Note that this field indicates the speed of each of the links in the bundle, not the speed of the entire bundle.",
22007          "type": "string",
22008          "enumDescriptions": [
22009            "100G Ethernet, LR Optics.",
22010            "10G Ethernet, LR Optics. [(rate_bps) = 10000000000];"
22011          ],
22012          "enum": [
22013            "LINK_TYPE_ETHERNET_100G_LR",
22014            "LINK_TYPE_ETHERNET_10G_LR"
22015          ]
22016        },
22017        "requestedLinkCount": {
22018          "description": "Target number of physical links in the link bundle, as requested by the customer.",
22019          "type": "integer",
22020          "format": "int32"
22021        },
22022        "interconnectType": {
22023          "description": "Type of interconnect, which can take one of the following values: - PARTNER: A partner-managed interconnection shared between customers though a partner. - DEDICATED: A dedicated physical interconnection with the customer. Note that a value IT_PRIVATE has been deprecated in favor of DEDICATED.",
22024          "type": "string",
22025          "enumDescriptions": [
22026            "A dedicated physical interconnection with the customer.",
22027            "[Deprecated] A private, physical interconnection with the customer.",
22028            "A partner-managed interconnection shared between customers via partner."
22029          ],
22030          "enum": [
22031            "DEDICATED",
22032            "IT_PRIVATE",
22033            "PARTNER"
22034          ]
22035        },
22036        "adminEnabled": {
22037          "description": "Administrative status of the interconnect. When this is set to true, the Interconnect is functional and can carry traffic. When set to false, no packets can be carried over the interconnect and no BGP routes are exchanged over it. By default, the status is set to true.",
22038          "type": "boolean"
22039        },
22040        "nocContactEmail": {
22041          "description": "Email address to contact the customer NOC for operations and maintenance notifications regarding this Interconnect. If specified, this will be used for notifications in addition to all other forms described, such as Cloud Monitoring logs alerting and Cloud Notifications. This field is required for users who sign up for Cloud Interconnect using workforce identity federation.",
22042          "type": "string"
22043        },
22044        "customerName": {
22045          "description": "Customer name, to put in the Letter of Authorization as the party authorized to request a crossconnect.",
22046          "type": "string"
22047        },
22048        "operationalStatus": {
22049          "description": "[Output Only] The current status of this Interconnect's functionality, which can take one of the following values: - OS_ACTIVE: A valid Interconnect, which is turned up and is ready to use. Attachments may be provisioned on this Interconnect. - OS_UNPROVISIONED: An Interconnect that has not completed turnup. No attachments may be provisioned on this Interconnect. - OS_UNDER_MAINTENANCE: An Interconnect that is undergoing internal maintenance. No attachments may be provisioned or updated on this Interconnect. ",
22050          "type": "string",
22051          "enumDescriptions": [
22052            "The interconnect is valid, turned up, and ready to use. Attachments may be provisioned on this interconnect.",
22053            "The interconnect has not completed turnup. No attachments may be provisioned on this interconnect."
22054          ],
22055          "enum": [
22056            "OS_ACTIVE",
22057            "OS_UNPROVISIONED"
22058          ]
22059        },
22060        "provisionedLinkCount": {
22061          "description": "[Output Only] Number of links actually provisioned in this interconnect.",
22062          "type": "integer",
22063          "format": "int32"
22064        },
22065        "interconnectAttachments": {
22066          "description": "[Output Only] A list of the URLs of all InterconnectAttachments configured to use this Interconnect.",
22067          "type": "array",
22068          "items": {
22069            "type": "string"
22070          }
22071        },
22072        "peerIpAddress": {
22073          "description": "[Output Only] IP address configured on the customer side of the Interconnect link. The customer should configure this IP address during turnup when prompted by Google NOC. This can be used only for ping tests.",
22074          "type": "string"
22075        },
22076        "googleIpAddress": {
22077          "description": "[Output Only] IP address configured on the Google side of the Interconnect link. This can be used only for ping tests.",
22078          "type": "string"
22079        },
22080        "googleReferenceId": {
22081          "description": "[Output Only] Google reference ID to be used when raising support tickets with Google or otherwise to debug backend connectivity issues.",
22082          "type": "string"
22083        },
22084        "expectedOutages": {
22085          "description": "[Output Only] A list of outages expected for this Interconnect.",
22086          "type": "array",
22087          "items": {
22088            "$ref": "InterconnectOutageNotification"
22089          }
22090        },
22091        "circuitInfos": {
22092          "description": "[Output Only] A list of CircuitInfo objects, that describe the individual circuits in this LAG.",
22093          "type": "array",
22094          "items": {
22095            "$ref": "InterconnectCircuitInfo"
22096          }
22097        },
22098        "labels": {
22099          "description": "Labels for this resource. These can only be added or modified by the setLabels method. Each label key/value pair must comply with RFC1035. Label values may be empty.",
22100          "type": "object",
22101          "additionalProperties": {
22102            "type": "string"
22103          }
22104        },
22105        "labelFingerprint": {
22106          "description": "A fingerprint for the labels being applied to this Interconnect, which is essentially a hash of the labels set used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve an Interconnect.",
22107          "type": "string",
22108          "format": "byte"
22109        },
22110        "state": {
22111          "description": "[Output Only] The current state of Interconnect functionality, which can take one of the following values: - ACTIVE: The Interconnect is valid, turned up and ready to use. Attachments may be provisioned on this Interconnect. - UNPROVISIONED: The Interconnect has not completed turnup. No attachments may be provisioned on this Interconnect. - UNDER_MAINTENANCE: The Interconnect is undergoing internal maintenance. No attachments may be provisioned or updated on this Interconnect. ",
22112          "type": "string",
22113          "enumDescriptions": [
22114            "The interconnect is valid, turned up, and ready to use. Attachments may be provisioned on this interconnect.",
22115            "The interconnect has not completed turnup. No attachments may be provisioned on this interconnect."
22116          ],
22117          "enum": [
22118            "ACTIVE",
22119            "UNPROVISIONED"
22120          ]
22121        },
22122        "satisfiesPzs": {
22123          "description": "[Output Only] Reserved for future use.",
22124          "type": "boolean"
22125        },
22126        "macsec": {
22127          "description": "Configuration that enables Media Access Control security (MACsec) on the Cloud Interconnect connection between Google and your on-premises router.",
22128          "$ref": "InterconnectMacsec"
22129        },
22130        "macsecEnabled": {
22131          "description": "Enable or disable MACsec on this Interconnect connection. MACsec enablement fails if the MACsec object is not specified.",
22132          "type": "boolean"
22133        },
22134        "remoteLocation": {
22135          "description": "Indicates that this is a Cross-Cloud Interconnect. This field specifies the location outside of Google's network that the interconnect is connected to.",
22136          "type": "string"
22137        },
22138        "requestedFeatures": {
22139          "description": "Optional. List of features requested for this Interconnect connection, which can take one of the following values: - MACSEC If specified then the connection is created on MACsec capable hardware ports. If not specified, the default value is false, which allocates non-MACsec capable ports first if available. This parameter can be provided only with Interconnect INSERT. It isn't valid for Interconnect PATCH.",
22140          "type": "array",
22141          "items": {
22142            "type": "string",
22143            "enumDescriptions": [
22144              "Media Access Control security (MACsec)"
22145            ],
22146            "enum": [
22147              "IF_MACSEC"
22148            ]
22149          }
22150        },
22151        "availableFeatures": {
22152          "description": "[Output only] List of features available for this Interconnect connection, which can take one of the following values: - MACSEC If present then the Interconnect connection is provisioned on MACsec capable hardware ports. If not present then the Interconnect connection is provisioned on non-MACsec capable ports and MACsec isn't supported and enabling MACsec fails.",
22153          "type": "array",
22154          "items": {
22155            "type": "string",
22156            "enumDescriptions": [
22157              "Media Access Control security (MACsec)"
22158            ],
22159            "enum": [
22160              "IF_MACSEC"
22161            ]
22162          }
22163        }
22164      }
22165    },
22166    "InterconnectOutageNotification": {
22167      "id": "InterconnectOutageNotification",
22168      "description": "Description of a planned outage on this Interconnect.",
22169      "type": "object",
22170      "properties": {
22171        "name": {
22172          "description": "Unique identifier for this outage notification.",
22173          "type": "string"
22174        },
22175        "description": {
22176          "description": "A description about the purpose of the outage.",
22177          "type": "string"
22178        },
22179        "source": {
22180          "description": "The party that generated this notification, which can take the following value: - GOOGLE: this notification as generated by Google. Note that the value of NSRC_GOOGLE has been deprecated in favor of GOOGLE.",
22181          "type": "string",
22182          "enumDescriptions": [
22183            "This notification was generated by Google.",
22184            "[Deprecated] This notification was generated by Google."
22185          ],
22186          "enum": [
22187            "GOOGLE",
22188            "NSRC_GOOGLE"
22189          ]
22190        },
22191        "state": {
22192          "description": "State of this notification, which can take one of the following values: - ACTIVE: This outage notification is active. The event could be in the past, present, or future. See start_time and end_time for scheduling. - CANCELLED: The outage associated with this notification was cancelled before the outage was due to start. - COMPLETED: The outage associated with this notification is complete. Note that the versions of this enum prefixed with \"NS_\" have been deprecated in favor of the unprefixed values.",
22193          "type": "string",
22194          "enumDescriptions": [
22195            "This outage notification is active. The event could be in the future, present, or past. See start_time and end_time for scheduling.",
22196            "The outage associated with this notification was cancelled before the outage was due to start.",
22197            "The outage associated with this notification is complete.",
22198            "[Deprecated] This outage notification is active. The event could be in the future, present, or past. See start_time and end_time for scheduling.",
22199            "[Deprecated] The outage associated with this notification was canceled before the outage was due to start."
22200          ],
22201          "enum": [
22202            "ACTIVE",
22203            "CANCELLED",
22204            "COMPLETED",
22205            "NS_ACTIVE",
22206            "NS_CANCELED"
22207          ]
22208        },
22209        "issueType": {
22210          "description": "Form this outage is expected to take, which can take one of the following values: - OUTAGE: The Interconnect may be completely out of service for some or all of the specified window. - PARTIAL_OUTAGE: Some circuits comprising the Interconnect as a whole should remain up, but with reduced bandwidth. Note that the versions of this enum prefixed with \"IT_\" have been deprecated in favor of the unprefixed values.",
22211          "type": "string",
22212          "enumDescriptions": [
22213            "[Deprecated] The Interconnect may be completely out of service for some or all of the specified window.",
22214            "[Deprecated] Some circuits comprising the Interconnect will be out of service during the expected window. The interconnect as a whole should remain up, albeit with reduced bandwidth.",
22215            "The Interconnect may be completely out of service for some or all of the specified window.",
22216            "Some circuits comprising the Interconnect will be out of service during the expected window. The interconnect as a whole should remain up, albeit with reduced bandwidth."
22217          ],
22218          "enum": [
22219            "IT_OUTAGE",
22220            "IT_PARTIAL_OUTAGE",
22221            "OUTAGE",
22222            "PARTIAL_OUTAGE"
22223          ]
22224        },
22225        "affectedCircuits": {
22226          "description": "If issue_type is IT_PARTIAL_OUTAGE, a list of the Google-side circuit IDs that will be affected.",
22227          "type": "array",
22228          "items": {
22229            "type": "string"
22230          }
22231        },
22232        "startTime": {
22233          "description": "Scheduled start time for the outage (milliseconds since Unix epoch).",
22234          "type": "string",
22235          "format": "int64"
22236        },
22237        "endTime": {
22238          "description": "Scheduled end time for the outage (milliseconds since Unix epoch).",
22239          "type": "string",
22240          "format": "int64"
22241        }
22242      }
22243    },
22244    "InterconnectCircuitInfo": {
22245      "id": "InterconnectCircuitInfo",
22246      "description": "Describes a single physical circuit between the Customer and Google. CircuitInfo objects are created by Google, so all fields are output only.",
22247      "type": "object",
22248      "properties": {
22249        "googleCircuitId": {
22250          "description": "Google-assigned unique ID for this circuit. Assigned at circuit turn-up.",
22251          "type": "string"
22252        },
22253        "googleDemarcId": {
22254          "description": "Google-side demarc ID for this circuit. Assigned at circuit turn-up and provided by Google to the customer in the LOA.",
22255          "type": "string"
22256        },
22257        "customerDemarcId": {
22258          "description": "Customer-side demarc ID for this circuit.",
22259          "type": "string"
22260        }
22261      }
22262    },
22263    "InterconnectMacsec": {
22264      "id": "InterconnectMacsec",
22265      "description": "Configuration information for enabling Media Access Control security (MACsec) on this Cloud Interconnect connection between Google and your on-premises router.",
22266      "type": "object",
22267      "properties": {
22268        "preSharedKeys": {
22269          "description": "Required. A keychain placeholder describing a set of named key objects along with their start times. A MACsec CKN/CAK is generated for each key in the key chain. Google router automatically picks the key with the most recent startTime when establishing or re-establishing a MACsec secure link.",
22270          "type": "array",
22271          "items": {
22272            "$ref": "InterconnectMacsecPreSharedKey"
22273          }
22274        },
22275        "failOpen": {
22276          "description": "If set to true, the Interconnect connection is configured with a should-secure MACsec security policy, that allows the Google router to fallback to cleartext traffic if the MKA session cannot be established. By default, the Interconnect connection is configured with a must-secure security policy that drops all traffic if the MKA session cannot be established with your router.",
22277          "type": "boolean"
22278        }
22279      }
22280    },
22281    "InterconnectMacsecPreSharedKey": {
22282      "id": "InterconnectMacsecPreSharedKey",
22283      "description": "Describes a pre-shared key used to setup MACsec in static connectivity association key (CAK) mode.",
22284      "type": "object",
22285      "properties": {
22286        "name": {
22287          "description": "Required. A name for this pre-shared key. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
22288          "type": "string"
22289        },
22290        "startTime": {
22291          "description": "A RFC3339 timestamp on or after which the key is valid. startTime can be in the future. If the keychain has a single key, startTime can be omitted. If the keychain has multiple keys, startTime is mandatory for each key. The start times of keys must be in increasing order. The start times of two consecutive keys must be at least 6 hours apart.",
22292          "type": "string"
22293        }
22294      }
22295    },
22296    "InterconnectList": {
22297      "id": "InterconnectList",
22298      "description": "Response to the list request, and contains a list of interconnects.",
22299      "type": "object",
22300      "properties": {
22301        "kind": {
22302          "description": "[Output Only] Type of resource. Always compute#interconnectList for lists of interconnects.",
22303          "default": "compute#interconnectList",
22304          "type": "string"
22305        },
22306        "id": {
22307          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
22308          "type": "string"
22309        },
22310        "items": {
22311          "description": "A list of Interconnect resources.",
22312          "type": "array",
22313          "items": {
22314            "$ref": "Interconnect"
22315          }
22316        },
22317        "nextPageToken": {
22318          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
22319          "type": "string"
22320        },
22321        "selfLink": {
22322          "description": "[Output Only] Server-defined URL for this resource.",
22323          "type": "string"
22324        },
22325        "warning": {
22326          "description": "[Output Only] Informational warning message.",
22327          "type": "object",
22328          "properties": {
22329            "code": {
22330              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
22331              "type": "string",
22332              "enumDescriptions": [
22333                "Warning about failed cleanup of transient changes made by a failed operation.",
22334                "A link to a deprecated resource was created.",
22335                "When deploying and at least one of the resources has a type marked as deprecated",
22336                "The user created a boot disk that is larger than image size.",
22337                "When deploying and at least one of the resources has a type marked as experimental",
22338                "Warning that is present in an external api call",
22339                "Warning that value of a field has been overridden. Deprecated unused field.",
22340                "The operation involved use of an injected kernel, which is deprecated.",
22341                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
22342                "When deploying a deployment with a exceedingly large number of resources",
22343                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
22344                "A resource depends on a missing type",
22345                "The route's nextHopIp address is not assigned to an instance on the network.",
22346                "The route's next hop instance cannot ip forward.",
22347                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
22348                "The route's nextHopInstance URL refers to an instance that does not exist.",
22349                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
22350                "The route's next hop instance does not have a status of RUNNING.",
22351                "Error which is not critical. We decided to continue the process despite the mentioned error.",
22352                "No results are present on a particular list page.",
22353                "Success is reported, but some results may be missing due to errors",
22354                "The user attempted to use a resource that requires a TOS they have not accepted.",
22355                "Warning that a resource is in use.",
22356                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
22357                "When a resource schema validation is ignored.",
22358                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
22359                "When undeclared properties in the schema are present",
22360                "A given scope cannot be reached."
22361              ],
22362              "enumDeprecated": [
22363                false,
22364                false,
22365                false,
22366                false,
22367                false,
22368                false,
22369                true,
22370                false,
22371                false,
22372                false,
22373                false,
22374                false,
22375                false,
22376                false,
22377                false,
22378                false,
22379                false,
22380                false,
22381                false,
22382                false,
22383                false,
22384                false,
22385                false,
22386                false,
22387                false,
22388                false,
22389                false,
22390                false
22391              ],
22392              "enum": [
22393                "CLEANUP_FAILED",
22394                "DEPRECATED_RESOURCE_USED",
22395                "DEPRECATED_TYPE_USED",
22396                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
22397                "EXPERIMENTAL_TYPE_USED",
22398                "EXTERNAL_API_WARNING",
22399                "FIELD_VALUE_OVERRIDEN",
22400                "INJECTED_KERNELS_DEPRECATED",
22401                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
22402                "LARGE_DEPLOYMENT_WARNING",
22403                "LIST_OVERHEAD_QUOTA_EXCEED",
22404                "MISSING_TYPE_DEPENDENCY",
22405                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
22406                "NEXT_HOP_CANNOT_IP_FORWARD",
22407                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
22408                "NEXT_HOP_INSTANCE_NOT_FOUND",
22409                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
22410                "NEXT_HOP_NOT_RUNNING",
22411                "NOT_CRITICAL_ERROR",
22412                "NO_RESULTS_ON_PAGE",
22413                "PARTIAL_SUCCESS",
22414                "REQUIRED_TOS_AGREEMENT",
22415                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
22416                "RESOURCE_NOT_DELETED",
22417                "SCHEMA_VALIDATION_IGNORED",
22418                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
22419                "UNDECLARED_PROPERTIES",
22420                "UNREACHABLE"
22421              ]
22422            },
22423            "message": {
22424              "description": "[Output Only] A human-readable description of the warning code.",
22425              "type": "string"
22426            },
22427            "data": {
22428              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
22429              "type": "array",
22430              "items": {
22431                "type": "object",
22432                "properties": {
22433                  "key": {
22434                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
22435                    "type": "string"
22436                  },
22437                  "value": {
22438                    "description": "[Output Only] A warning data value corresponding to the key.",
22439                    "type": "string"
22440                  }
22441                }
22442              }
22443            }
22444          }
22445        }
22446      }
22447    },
22448    "InterconnectsGetDiagnosticsResponse": {
22449      "id": "InterconnectsGetDiagnosticsResponse",
22450      "description": "Response for the InterconnectsGetDiagnosticsRequest.",
22451      "type": "object",
22452      "properties": {
22453        "result": {
22454          "$ref": "InterconnectDiagnostics"
22455        }
22456      }
22457    },
22458    "InterconnectDiagnostics": {
22459      "id": "InterconnectDiagnostics",
22460      "description": "Diagnostics information about the Interconnect connection, which contains detailed and current technical information about Google's side of the connection.",
22461      "type": "object",
22462      "properties": {
22463        "macAddress": {
22464          "description": "The MAC address of the Interconnect's bundle interface.",
22465          "type": "string"
22466        },
22467        "arpCaches": {
22468          "description": "A list of InterconnectDiagnostics.ARPEntry objects, describing individual neighbors currently seen by the Google router in the ARP cache for the Interconnect. This will be empty when the Interconnect is not bundled.",
22469          "type": "array",
22470          "items": {
22471            "$ref": "InterconnectDiagnosticsARPEntry"
22472          }
22473        },
22474        "links": {
22475          "description": "A list of InterconnectDiagnostics.LinkStatus objects, describing the status for each link on the Interconnect.",
22476          "type": "array",
22477          "items": {
22478            "$ref": "InterconnectDiagnosticsLinkStatus"
22479          }
22480        },
22481        "bundleOperationalStatus": {
22482          "description": "The operational status of the bundle interface.",
22483          "type": "string",
22484          "enumDescriptions": [
22485            "If bundleAggregationType is LACP: LACP is not established and/or all links in the bundle have DOWN operational status. If bundleAggregationType is STATIC: one or more links in the bundle has DOWN operational status.",
22486            "If bundleAggregationType is LACP: LACP is established and at least one link in the bundle has UP operational status. If bundleAggregationType is STATIC: all links in the bundle (typically just one) have UP operational status."
22487          ],
22488          "enum": [
22489            "BUNDLE_OPERATIONAL_STATUS_DOWN",
22490            "BUNDLE_OPERATIONAL_STATUS_UP"
22491          ]
22492        },
22493        "bundleAggregationType": {
22494          "description": "The aggregation type of the bundle interface.",
22495          "type": "string",
22496          "enumDescriptions": [
22497            "LACP is enabled.",
22498            "LACP is disabled."
22499          ],
22500          "enum": [
22501            "BUNDLE_AGGREGATION_TYPE_LACP",
22502            "BUNDLE_AGGREGATION_TYPE_STATIC"
22503          ]
22504        }
22505      }
22506    },
22507    "InterconnectDiagnosticsARPEntry": {
22508      "id": "InterconnectDiagnosticsARPEntry",
22509      "description": "Describing the ARP neighbor entries seen on this link",
22510      "type": "object",
22511      "properties": {
22512        "macAddress": {
22513          "description": "The MAC address of this ARP neighbor.",
22514          "type": "string"
22515        },
22516        "ipAddress": {
22517          "description": "The IP address of this ARP neighbor.",
22518          "type": "string"
22519        }
22520      }
22521    },
22522    "InterconnectDiagnosticsLinkStatus": {
22523      "id": "InterconnectDiagnosticsLinkStatus",
22524      "type": "object",
22525      "properties": {
22526        "circuitId": {
22527          "description": "The unique ID for this link assigned during turn up by Google.",
22528          "type": "string"
22529        },
22530        "googleDemarc": {
22531          "description": "The Demarc address assigned by Google and provided in the LoA.",
22532          "type": "string"
22533        },
22534        "receivingOpticalPower": {
22535          "description": "An InterconnectDiagnostics.LinkOpticalPower object, describing the current value and status of the received light level.",
22536          "$ref": "InterconnectDiagnosticsLinkOpticalPower"
22537        },
22538        "transmittingOpticalPower": {
22539          "description": "An InterconnectDiagnostics.LinkOpticalPower object, describing the current value and status of the transmitted light level.",
22540          "$ref": "InterconnectDiagnosticsLinkOpticalPower"
22541        },
22542        "lacpStatus": {
22543          "$ref": "InterconnectDiagnosticsLinkLACPStatus"
22544        },
22545        "operationalStatus": {
22546          "description": "The operational status of the link.",
22547          "type": "string",
22548          "enumDescriptions": [
22549            "The interface is unable to communicate with the remote end.",
22550            "The interface has low level communication with the remote end."
22551          ],
22552          "enum": [
22553            "LINK_OPERATIONAL_STATUS_DOWN",
22554            "LINK_OPERATIONAL_STATUS_UP"
22555          ]
22556        },
22557        "arpCaches": {
22558          "description": "A list of InterconnectDiagnostics.ARPEntry objects, describing the ARP neighbor entries seen on this link. This will be empty if the link is bundled",
22559          "type": "array",
22560          "items": {
22561            "$ref": "InterconnectDiagnosticsARPEntry"
22562          }
22563        },
22564        "macsec": {
22565          "description": "Describes the status of MACsec encryption on this link.",
22566          "$ref": "InterconnectDiagnosticsMacsecStatus"
22567        }
22568      }
22569    },
22570    "InterconnectDiagnosticsLinkOpticalPower": {
22571      "id": "InterconnectDiagnosticsLinkOpticalPower",
22572      "type": "object",
22573      "properties": {
22574        "value": {
22575          "description": "Value of the current receiving or transmitting optical power, read in dBm. Take a known good optical value, give it a 10% margin and trigger warnings relative to that value. In general, a -7dBm warning and a -11dBm alarm are good optical value estimates for most links.",
22576          "type": "number",
22577          "format": "float"
22578        },
22579        "state": {
22580          "description": "The status of the current value when compared to the warning and alarm levels for the receiving or transmitting transceiver. Possible states include: - OK: The value has not crossed a warning threshold. - LOW_WARNING: The value has crossed below the low warning threshold. - HIGH_WARNING: The value has crossed above the high warning threshold. - LOW_ALARM: The value has crossed below the low alarm threshold. - HIGH_ALARM: The value has crossed above the high alarm threshold. ",
22581          "type": "string",
22582          "enumDescriptions": [
22583            "The value has crossed above the high alarm threshold.",
22584            "The value of the current optical power has crossed above the high warning threshold.",
22585            "The value of the current optical power has crossed below the low alarm threshold.",
22586            "The value of the current optical power has crossed below the low warning threshold.",
22587            "The value of the current optical power has not crossed a warning threshold."
22588          ],
22589          "enum": [
22590            "HIGH_ALARM",
22591            "HIGH_WARNING",
22592            "LOW_ALARM",
22593            "LOW_WARNING",
22594            "OK"
22595          ]
22596        }
22597      }
22598    },
22599    "InterconnectDiagnosticsLinkLACPStatus": {
22600      "id": "InterconnectDiagnosticsLinkLACPStatus",
22601      "type": "object",
22602      "properties": {
22603        "state": {
22604          "description": "The state of a LACP link, which can take one of the following values: - ACTIVE: The link is configured and active within the bundle. - DETACHED: The link is not configured within the bundle. This means that the rest of the object should be empty. ",
22605          "type": "string",
22606          "enumDescriptions": [
22607            "The link is configured and active within the bundle.",
22608            "The link is not configured within the bundle, this means the rest of the object should be empty."
22609          ],
22610          "enum": [
22611            "ACTIVE",
22612            "DETACHED"
22613          ]
22614        },
22615        "googleSystemId": {
22616          "description": "System ID of the port on Google's side of the LACP exchange.",
22617          "type": "string"
22618        },
22619        "neighborSystemId": {
22620          "description": "System ID of the port on the neighbor's side of the LACP exchange.",
22621          "type": "string"
22622        }
22623      }
22624    },
22625    "InterconnectDiagnosticsMacsecStatus": {
22626      "id": "InterconnectDiagnosticsMacsecStatus",
22627      "description": "Describes the status of MACsec encryption on the link.",
22628      "type": "object",
22629      "properties": {
22630        "operational": {
22631          "description": "Indicates whether or not MACsec is operational on this link.",
22632          "type": "boolean"
22633        },
22634        "ckn": {
22635          "description": "Indicates the Connectivity Association Key Name (CKN) currently being used if MACsec is operational.",
22636          "type": "string"
22637        }
22638      }
22639    },
22640    "InterconnectsGetMacsecConfigResponse": {
22641      "id": "InterconnectsGetMacsecConfigResponse",
22642      "description": "Response for the InterconnectsGetMacsecConfigRequest.",
22643      "type": "object",
22644      "properties": {
22645        "result": {
22646          "$ref": "InterconnectMacsecConfig"
22647        },
22648        "etag": {
22649          "description": "end_interface: MixerGetResponseWithEtagBuilder",
22650          "type": "string"
22651        }
22652      }
22653    },
22654    "InterconnectMacsecConfig": {
22655      "id": "InterconnectMacsecConfig",
22656      "description": "MACsec configuration information for the Interconnect connection. Contains the generated Connectivity Association Key Name (CKN) and the key (CAK) for this Interconnect connection.",
22657      "type": "object",
22658      "properties": {
22659        "preSharedKeys": {
22660          "description": "A keychain placeholder describing a set of named key objects along with their start times. A MACsec CKN/CAK is generated for each key in the key chain. Google router automatically picks the key with the most recent startTime when establishing or re-establishing a MACsec secure link.",
22661          "type": "array",
22662          "items": {
22663            "$ref": "InterconnectMacsecConfigPreSharedKey"
22664          }
22665        }
22666      }
22667    },
22668    "InterconnectMacsecConfigPreSharedKey": {
22669      "id": "InterconnectMacsecConfigPreSharedKey",
22670      "description": "Describes a pre-shared key used to setup MACsec in static connectivity association key (CAK) mode.",
22671      "type": "object",
22672      "properties": {
22673        "name": {
22674          "description": "User provided name for this pre-shared key.",
22675          "type": "string"
22676        },
22677        "ckn": {
22678          "description": "An auto-generated Connectivity Association Key Name (CKN) for this key.",
22679          "type": "string"
22680        },
22681        "cak": {
22682          "description": "An auto-generated Connectivity Association Key (CAK) for this key.",
22683          "type": "string"
22684        },
22685        "startTime": {
22686          "description": "User provided timestamp on or after which this key is valid.",
22687          "type": "string"
22688        }
22689      }
22690    },
22691    "InterconnectLocationList": {
22692      "id": "InterconnectLocationList",
22693      "description": "Response to the list request, and contains a list of interconnect locations.",
22694      "type": "object",
22695      "properties": {
22696        "kind": {
22697          "description": "[Output Only] Type of resource. Always compute#interconnectLocationList for lists of interconnect locations.",
22698          "default": "compute#interconnectLocationList",
22699          "type": "string"
22700        },
22701        "id": {
22702          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
22703          "type": "string"
22704        },
22705        "items": {
22706          "description": "A list of InterconnectLocation resources.",
22707          "type": "array",
22708          "items": {
22709            "$ref": "InterconnectLocation"
22710          }
22711        },
22712        "nextPageToken": {
22713          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
22714          "type": "string"
22715        },
22716        "selfLink": {
22717          "description": "[Output Only] Server-defined URL for this resource.",
22718          "type": "string"
22719        },
22720        "warning": {
22721          "description": "[Output Only] Informational warning message.",
22722          "type": "object",
22723          "properties": {
22724            "code": {
22725              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
22726              "type": "string",
22727              "enumDescriptions": [
22728                "Warning about failed cleanup of transient changes made by a failed operation.",
22729                "A link to a deprecated resource was created.",
22730                "When deploying and at least one of the resources has a type marked as deprecated",
22731                "The user created a boot disk that is larger than image size.",
22732                "When deploying and at least one of the resources has a type marked as experimental",
22733                "Warning that is present in an external api call",
22734                "Warning that value of a field has been overridden. Deprecated unused field.",
22735                "The operation involved use of an injected kernel, which is deprecated.",
22736                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
22737                "When deploying a deployment with a exceedingly large number of resources",
22738                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
22739                "A resource depends on a missing type",
22740                "The route's nextHopIp address is not assigned to an instance on the network.",
22741                "The route's next hop instance cannot ip forward.",
22742                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
22743                "The route's nextHopInstance URL refers to an instance that does not exist.",
22744                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
22745                "The route's next hop instance does not have a status of RUNNING.",
22746                "Error which is not critical. We decided to continue the process despite the mentioned error.",
22747                "No results are present on a particular list page.",
22748                "Success is reported, but some results may be missing due to errors",
22749                "The user attempted to use a resource that requires a TOS they have not accepted.",
22750                "Warning that a resource is in use.",
22751                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
22752                "When a resource schema validation is ignored.",
22753                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
22754                "When undeclared properties in the schema are present",
22755                "A given scope cannot be reached."
22756              ],
22757              "enumDeprecated": [
22758                false,
22759                false,
22760                false,
22761                false,
22762                false,
22763                false,
22764                true,
22765                false,
22766                false,
22767                false,
22768                false,
22769                false,
22770                false,
22771                false,
22772                false,
22773                false,
22774                false,
22775                false,
22776                false,
22777                false,
22778                false,
22779                false,
22780                false,
22781                false,
22782                false,
22783                false,
22784                false,
22785                false
22786              ],
22787              "enum": [
22788                "CLEANUP_FAILED",
22789                "DEPRECATED_RESOURCE_USED",
22790                "DEPRECATED_TYPE_USED",
22791                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
22792                "EXPERIMENTAL_TYPE_USED",
22793                "EXTERNAL_API_WARNING",
22794                "FIELD_VALUE_OVERRIDEN",
22795                "INJECTED_KERNELS_DEPRECATED",
22796                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
22797                "LARGE_DEPLOYMENT_WARNING",
22798                "LIST_OVERHEAD_QUOTA_EXCEED",
22799                "MISSING_TYPE_DEPENDENCY",
22800                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
22801                "NEXT_HOP_CANNOT_IP_FORWARD",
22802                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
22803                "NEXT_HOP_INSTANCE_NOT_FOUND",
22804                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
22805                "NEXT_HOP_NOT_RUNNING",
22806                "NOT_CRITICAL_ERROR",
22807                "NO_RESULTS_ON_PAGE",
22808                "PARTIAL_SUCCESS",
22809                "REQUIRED_TOS_AGREEMENT",
22810                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
22811                "RESOURCE_NOT_DELETED",
22812                "SCHEMA_VALIDATION_IGNORED",
22813                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
22814                "UNDECLARED_PROPERTIES",
22815                "UNREACHABLE"
22816              ]
22817            },
22818            "message": {
22819              "description": "[Output Only] A human-readable description of the warning code.",
22820              "type": "string"
22821            },
22822            "data": {
22823              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
22824              "type": "array",
22825              "items": {
22826                "type": "object",
22827                "properties": {
22828                  "key": {
22829                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
22830                    "type": "string"
22831                  },
22832                  "value": {
22833                    "description": "[Output Only] A warning data value corresponding to the key.",
22834                    "type": "string"
22835                  }
22836                }
22837              }
22838            }
22839          }
22840        }
22841      }
22842    },
22843    "InterconnectLocation": {
22844      "id": "InterconnectLocation",
22845      "description": "Represents an Interconnect Attachment (VLAN) Location resource. You can use this resource to find location details about an Interconnect attachment (VLAN). For more information about interconnect attachments, read Creating VLAN Attachments.",
22846      "type": "object",
22847      "properties": {
22848        "kind": {
22849          "description": "[Output Only] Type of the resource. Always compute#interconnectLocation for interconnect locations.",
22850          "default": "compute#interconnectLocation",
22851          "type": "string"
22852        },
22853        "description": {
22854          "description": "[Output Only] An optional description of the resource.",
22855          "type": "string"
22856        },
22857        "selfLink": {
22858          "description": "[Output Only] Server-defined URL for the resource.",
22859          "type": "string"
22860        },
22861        "id": {
22862          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
22863          "type": "string",
22864          "format": "uint64"
22865        },
22866        "creationTimestamp": {
22867          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
22868          "type": "string"
22869        },
22870        "name": {
22871          "description": "[Output Only] Name of the resource.",
22872          "type": "string"
22873        },
22874        "peeringdbFacilityId": {
22875          "description": "[Output Only] The peeringdb identifier for this facility (corresponding with a netfac type in peeringdb).",
22876          "type": "string"
22877        },
22878        "address": {
22879          "description": "[Output Only] The postal address of the Point of Presence, each line in the address is separated by a newline character.",
22880          "type": "string"
22881        },
22882        "facilityProvider": {
22883          "description": "[Output Only] The name of the provider for this facility (e.g., EQUINIX).",
22884          "type": "string"
22885        },
22886        "facilityProviderFacilityId": {
22887          "description": "[Output Only] A provider-assigned Identifier for this facility (e.g., Ashburn-DC1).",
22888          "type": "string"
22889        },
22890        "regionInfos": {
22891          "description": "[Output Only] A list of InterconnectLocation.RegionInfo objects, that describe parameters pertaining to the relation between this InterconnectLocation and various Google Cloud regions.",
22892          "type": "array",
22893          "items": {
22894            "$ref": "InterconnectLocationRegionInfo"
22895          }
22896        },
22897        "continent": {
22898          "description": "[Output Only] Continent for this location, which can take one of the following values: - AFRICA - ASIA_PAC - EUROPE - NORTH_AMERICA - SOUTH_AMERICA ",
22899          "type": "string",
22900          "enumDescriptions": [
22901            "",
22902            "",
22903            "",
22904            "",
22905            "",
22906            "",
22907            "",
22908            "",
22909            "",
22910            ""
22911          ],
22912          "enum": [
22913            "AFRICA",
22914            "ASIA_PAC",
22915            "C_AFRICA",
22916            "C_ASIA_PAC",
22917            "C_EUROPE",
22918            "C_NORTH_AMERICA",
22919            "C_SOUTH_AMERICA",
22920            "EUROPE",
22921            "NORTH_AMERICA",
22922            "SOUTH_AMERICA"
22923          ]
22924        },
22925        "city": {
22926          "description": "[Output Only] Metropolitan area designator that indicates which city an interconnect is located. For example: \"Chicago, IL\", \"Amsterdam, Netherlands\".",
22927          "type": "string"
22928        },
22929        "availabilityZone": {
22930          "description": "[Output Only] Availability zone for this InterconnectLocation. Within a metropolitan area (metro), maintenance will not be simultaneously scheduled in more than one availability zone. Example: \"zone1\" or \"zone2\".",
22931          "type": "string"
22932        },
22933        "status": {
22934          "description": "[Output Only] The status of this InterconnectLocation, which can take one of the following values: - CLOSED: The InterconnectLocation is closed and is unavailable for provisioning new Interconnects. - AVAILABLE: The InterconnectLocation is available for provisioning new Interconnects. ",
22935          "type": "string",
22936          "enumDescriptions": [
22937            "The InterconnectLocation is available for provisioning new Interconnects.",
22938            "The InterconnectLocation is closed for provisioning new Interconnects."
22939          ],
22940          "enum": [
22941            "AVAILABLE",
22942            "CLOSED"
22943          ]
22944        },
22945        "supportsPzs": {
22946          "description": "[Output Only] Reserved for future use.",
22947          "type": "boolean"
22948        },
22949        "availableFeatures": {
22950          "description": "[Output only] List of features available at this InterconnectLocation, which can take one of the following values: - MACSEC ",
22951          "type": "array",
22952          "items": {
22953            "type": "string",
22954            "enumDescriptions": [
22955              "Media Access Control security (MACsec)"
22956            ],
22957            "enum": [
22958              "IF_MACSEC"
22959            ]
22960          }
22961        },
22962        "availableLinkTypes": {
22963          "description": "[Output only] List of link types available at this InterconnectLocation, which can take one of the following values: - LINK_TYPE_ETHERNET_10G_LR - LINK_TYPE_ETHERNET_100G_LR ",
22964          "type": "array",
22965          "items": {
22966            "type": "string",
22967            "enumDescriptions": [
22968              "100G Ethernet, LR Optics.",
22969              "10G Ethernet, LR Optics. [(rate_bps) = 10000000000];"
22970            ],
22971            "enum": [
22972              "LINK_TYPE_ETHERNET_100G_LR",
22973              "LINK_TYPE_ETHERNET_10G_LR"
22974            ]
22975          }
22976        }
22977      }
22978    },
22979    "InterconnectLocationRegionInfo": {
22980      "id": "InterconnectLocationRegionInfo",
22981      "description": "Information about any potential InterconnectAttachments between an Interconnect at a specific InterconnectLocation, and a specific Cloud Region.",
22982      "type": "object",
22983      "properties": {
22984        "region": {
22985          "description": "URL for the region of this location.",
22986          "type": "string"
22987        },
22988        "expectedRttMs": {
22989          "description": "Expected round-trip time in milliseconds, from this InterconnectLocation to a VM in this region.",
22990          "type": "string",
22991          "format": "int64"
22992        },
22993        "locationPresence": {
22994          "description": "Identifies the network presence of this location.",
22995          "type": "string",
22996          "enumDescriptions": [
22997            "This region is not in any common network presence with this InterconnectLocation.",
22998            "This region shares the same regional network presence as this InterconnectLocation.",
22999            "[Deprecated] This region is not in any common network presence with this InterconnectLocation.",
23000            "[Deprecated] This region shares the same regional network presence as this InterconnectLocation."
23001          ],
23002          "enum": [
23003            "GLOBAL",
23004            "LOCAL_REGION",
23005            "LP_GLOBAL",
23006            "LP_LOCAL_REGION"
23007          ]
23008        }
23009      }
23010    },
23011    "InterconnectRemoteLocationList": {
23012      "id": "InterconnectRemoteLocationList",
23013      "description": "Response to the list request, and contains a list of interconnect remote locations.",
23014      "type": "object",
23015      "properties": {
23016        "kind": {
23017          "description": "[Output Only] Type of resource. Always compute#interconnectRemoteLocationList for lists of interconnect remote locations.",
23018          "default": "compute#interconnectRemoteLocationList",
23019          "type": "string"
23020        },
23021        "id": {
23022          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
23023          "type": "string"
23024        },
23025        "items": {
23026          "description": "A list of InterconnectRemoteLocation resources.",
23027          "type": "array",
23028          "items": {
23029            "$ref": "InterconnectRemoteLocation"
23030          }
23031        },
23032        "nextPageToken": {
23033          "description": "[Output Only] This token lets you get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
23034          "type": "string"
23035        },
23036        "selfLink": {
23037          "description": "[Output Only] Server-defined URL for this resource.",
23038          "type": "string"
23039        },
23040        "warning": {
23041          "description": "[Output Only] Informational warning message.",
23042          "type": "object",
23043          "properties": {
23044            "code": {
23045              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
23046              "type": "string",
23047              "enumDescriptions": [
23048                "Warning about failed cleanup of transient changes made by a failed operation.",
23049                "A link to a deprecated resource was created.",
23050                "When deploying and at least one of the resources has a type marked as deprecated",
23051                "The user created a boot disk that is larger than image size.",
23052                "When deploying and at least one of the resources has a type marked as experimental",
23053                "Warning that is present in an external api call",
23054                "Warning that value of a field has been overridden. Deprecated unused field.",
23055                "The operation involved use of an injected kernel, which is deprecated.",
23056                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
23057                "When deploying a deployment with a exceedingly large number of resources",
23058                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
23059                "A resource depends on a missing type",
23060                "The route's nextHopIp address is not assigned to an instance on the network.",
23061                "The route's next hop instance cannot ip forward.",
23062                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
23063                "The route's nextHopInstance URL refers to an instance that does not exist.",
23064                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
23065                "The route's next hop instance does not have a status of RUNNING.",
23066                "Error which is not critical. We decided to continue the process despite the mentioned error.",
23067                "No results are present on a particular list page.",
23068                "Success is reported, but some results may be missing due to errors",
23069                "The user attempted to use a resource that requires a TOS they have not accepted.",
23070                "Warning that a resource is in use.",
23071                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
23072                "When a resource schema validation is ignored.",
23073                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
23074                "When undeclared properties in the schema are present",
23075                "A given scope cannot be reached."
23076              ],
23077              "enumDeprecated": [
23078                false,
23079                false,
23080                false,
23081                false,
23082                false,
23083                false,
23084                true,
23085                false,
23086                false,
23087                false,
23088                false,
23089                false,
23090                false,
23091                false,
23092                false,
23093                false,
23094                false,
23095                false,
23096                false,
23097                false,
23098                false,
23099                false,
23100                false,
23101                false,
23102                false,
23103                false,
23104                false,
23105                false
23106              ],
23107              "enum": [
23108                "CLEANUP_FAILED",
23109                "DEPRECATED_RESOURCE_USED",
23110                "DEPRECATED_TYPE_USED",
23111                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
23112                "EXPERIMENTAL_TYPE_USED",
23113                "EXTERNAL_API_WARNING",
23114                "FIELD_VALUE_OVERRIDEN",
23115                "INJECTED_KERNELS_DEPRECATED",
23116                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
23117                "LARGE_DEPLOYMENT_WARNING",
23118                "LIST_OVERHEAD_QUOTA_EXCEED",
23119                "MISSING_TYPE_DEPENDENCY",
23120                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
23121                "NEXT_HOP_CANNOT_IP_FORWARD",
23122                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
23123                "NEXT_HOP_INSTANCE_NOT_FOUND",
23124                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
23125                "NEXT_HOP_NOT_RUNNING",
23126                "NOT_CRITICAL_ERROR",
23127                "NO_RESULTS_ON_PAGE",
23128                "PARTIAL_SUCCESS",
23129                "REQUIRED_TOS_AGREEMENT",
23130                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
23131                "RESOURCE_NOT_DELETED",
23132                "SCHEMA_VALIDATION_IGNORED",
23133                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
23134                "UNDECLARED_PROPERTIES",
23135                "UNREACHABLE"
23136              ]
23137            },
23138            "message": {
23139              "description": "[Output Only] A human-readable description of the warning code.",
23140              "type": "string"
23141            },
23142            "data": {
23143              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
23144              "type": "array",
23145              "items": {
23146                "type": "object",
23147                "properties": {
23148                  "key": {
23149                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
23150                    "type": "string"
23151                  },
23152                  "value": {
23153                    "description": "[Output Only] A warning data value corresponding to the key.",
23154                    "type": "string"
23155                  }
23156                }
23157              }
23158            }
23159          }
23160        }
23161      }
23162    },
23163    "InterconnectRemoteLocation": {
23164      "id": "InterconnectRemoteLocation",
23165      "description": "Represents a Cross-Cloud Interconnect Remote Location resource. You can use this resource to find remote location details about an Interconnect attachment (VLAN).",
23166      "type": "object",
23167      "properties": {
23168        "kind": {
23169          "description": "[Output Only] Type of the resource. Always compute#interconnectRemoteLocation for interconnect remote locations.",
23170          "default": "compute#interconnectRemoteLocation",
23171          "type": "string"
23172        },
23173        "description": {
23174          "description": "[Output Only] An optional description of the resource.",
23175          "type": "string"
23176        },
23177        "selfLink": {
23178          "description": "[Output Only] Server-defined URL for the resource.",
23179          "type": "string"
23180        },
23181        "id": {
23182          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
23183          "type": "string",
23184          "format": "uint64"
23185        },
23186        "creationTimestamp": {
23187          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
23188          "type": "string"
23189        },
23190        "name": {
23191          "description": "[Output Only] Name of the resource.",
23192          "type": "string"
23193        },
23194        "peeringdbFacilityId": {
23195          "description": "[Output Only] The peeringdb identifier for this facility (corresponding with a netfac type in peeringdb).",
23196          "type": "string"
23197        },
23198        "address": {
23199          "description": "[Output Only] The postal address of the Point of Presence, each line in the address is separated by a newline character.",
23200          "type": "string"
23201        },
23202        "facilityProvider": {
23203          "description": "[Output Only] The name of the provider for this facility (e.g., EQUINIX).",
23204          "type": "string"
23205        },
23206        "facilityProviderFacilityId": {
23207          "description": "[Output Only] A provider-assigned Identifier for this facility (e.g., Ashburn-DC1).",
23208          "type": "string"
23209        },
23210        "continent": {
23211          "description": "[Output Only] Continent for this location, which can take one of the following values: - AFRICA - ASIA_PAC - EUROPE - NORTH_AMERICA - SOUTH_AMERICA ",
23212          "type": "string",
23213          "enumDescriptions": [
23214            "",
23215            "",
23216            "",
23217            "",
23218            ""
23219          ],
23220          "enum": [
23221            "AFRICA",
23222            "ASIA_PAC",
23223            "EUROPE",
23224            "NORTH_AMERICA",
23225            "SOUTH_AMERICA"
23226          ]
23227        },
23228        "city": {
23229          "description": "[Output Only] Metropolitan area designator that indicates which city an interconnect is located. For example: \"Chicago, IL\", \"Amsterdam, Netherlands\".",
23230          "type": "string"
23231        },
23232        "status": {
23233          "description": "[Output Only] The status of this InterconnectRemoteLocation, which can take one of the following values: - CLOSED: The InterconnectRemoteLocation is closed and is unavailable for provisioning new Cross-Cloud Interconnects. - AVAILABLE: The InterconnectRemoteLocation is available for provisioning new Cross-Cloud Interconnects. ",
23234          "type": "string",
23235          "enumDescriptions": [
23236            "The InterconnectRemoteLocation is available for provisioning new Cross-Cloud Interconnects.",
23237            "The InterconnectRemoteLocation is closed for provisioning new Cross-Cloud Interconnects."
23238          ],
23239          "enum": [
23240            "AVAILABLE",
23241            "CLOSED"
23242          ]
23243        },
23244        "remoteService": {
23245          "description": "[Output Only] Indicates the service provider present at the remote location. Example values: \"Amazon Web Services\", \"Microsoft Azure\".",
23246          "type": "string"
23247        },
23248        "permittedConnections": {
23249          "description": "[Output Only] Permitted connections.",
23250          "type": "array",
23251          "items": {
23252            "$ref": "InterconnectRemoteLocationPermittedConnections"
23253          }
23254        },
23255        "constraints": {
23256          "description": "[Output Only] Constraints on the parameters for creating Cross-Cloud Interconnect and associated InterconnectAttachments.",
23257          "$ref": "InterconnectRemoteLocationConstraints"
23258        },
23259        "attachmentConfigurationConstraints": {
23260          "description": "[Output Only] Subset of fields from InterconnectAttachment's |configurationConstraints| field that apply to all attachments for this remote location.",
23261          "$ref": "InterconnectAttachmentConfigurationConstraints"
23262        },
23263        "lacp": {
23264          "description": "[Output Only] Link Aggregation Control Protocol (LACP) constraints, which can take one of the following values: LACP_SUPPORTED, LACP_UNSUPPORTED",
23265          "type": "string",
23266          "enumDescriptions": [
23267            "LACP_SUPPORTED: LACP is supported, and enabled by default on the Cross-Cloud Interconnect.",
23268            "LACP_UNSUPPORTED: LACP is not supported and is not be enabled on this port. GetDiagnostics shows bundleAggregationType as \"static\". GCP does not support LAGs without LACP, so requestedLinkCount must be 1."
23269          ],
23270          "enum": [
23271            "LACP_SUPPORTED",
23272            "LACP_UNSUPPORTED"
23273          ]
23274        },
23275        "maxLagSize100Gbps": {
23276          "description": "[Output Only] The maximum number of 100 Gbps ports supported in a link aggregation group (LAG). When linkType is 100 Gbps, requestedLinkCount cannot exceed max_lag_size_100_gbps.",
23277          "type": "integer",
23278          "format": "int32"
23279        },
23280        "maxLagSize10Gbps": {
23281          "description": "[Output Only] The maximum number of 10 Gbps ports supported in a link aggregation group (LAG). When linkType is 10 Gbps, requestedLinkCount cannot exceed max_lag_size_10_gbps.",
23282          "type": "integer",
23283          "format": "int32"
23284        }
23285      }
23286    },
23287    "InterconnectRemoteLocationPermittedConnections": {
23288      "id": "InterconnectRemoteLocationPermittedConnections",
23289      "type": "object",
23290      "properties": {
23291        "interconnectLocation": {
23292          "description": "[Output Only] URL of an Interconnect location that is permitted to connect to this Interconnect remote location.",
23293          "type": "string"
23294        }
23295      }
23296    },
23297    "InterconnectRemoteLocationConstraints": {
23298      "id": "InterconnectRemoteLocationConstraints",
23299      "type": "object",
23300      "properties": {
23301        "subnetLengthRange": {
23302          "description": "[Output Only] [min-length, max-length] The minimum and maximum value (inclusive) for the IPv4 subnet length. For example, an interconnectRemoteLocation for Azure has {min: 30, max: 30} because Azure requires /30 subnets. This range specifies the values supported by both cloud providers. Interconnect currently supports /29 and /30 IPv4 subnet lengths. If a remote cloud has no constraint on IPv4 subnet length, the range would thus be {min: 29, max: 30}. ",
23303          "$ref": "InterconnectRemoteLocationConstraintsSubnetLengthRange"
23304        },
23305        "portPairVlan": {
23306          "description": "[Output Only] Port pair VLAN constraints, which can take one of the following values: PORT_PAIR_UNCONSTRAINED_VLAN, PORT_PAIR_MATCHING_VLAN",
23307          "type": "string",
23308          "enumDescriptions": [
23309            "If PORT_PAIR_MATCHING_VLAN, the Interconnect for this attachment is part of a pair of ports that should have matching VLAN allocations. This occurs with Cross-Cloud Interconnect to Azure remote locations. While GCP's API does not explicitly group pairs of ports, the UI uses this field to ensure matching VLAN ids when configuring a redundant VLAN pair.",
23310            "PORT_PAIR_UNCONSTRAINED_VLAN means there is no constraint."
23311          ],
23312          "enum": [
23313            "PORT_PAIR_MATCHING_VLAN",
23314            "PORT_PAIR_UNCONSTRAINED_VLAN"
23315          ]
23316        },
23317        "portPairRemoteLocation": {
23318          "description": "[Output Only] Port pair remote location constraints, which can take one of the following values: PORT_PAIR_UNCONSTRAINED_REMOTE_LOCATION, PORT_PAIR_MATCHING_REMOTE_LOCATION. GCP's API refers only to individual ports, but the UI uses this field when ordering a pair of ports, to prevent users from accidentally ordering something that is incompatible with their cloud provider. Specifically, when ordering a redundant pair of Cross-Cloud Interconnect ports, and one of them uses a remote location with portPairMatchingRemoteLocation set to matching, the UI requires that both ports use the same remote location.",
23319          "type": "string",
23320          "enumDescriptions": [
23321            "If PORT_PAIR_MATCHING_REMOTE_LOCATION, the remote cloud provider allocates ports in pairs, and the user should choose the same remote location for both ports.",
23322            "If PORT_PAIR_UNCONSTRAINED_REMOTE_LOCATION, a user may opt to provision a redundant pair of Cross-Cloud Interconnects using two different remote locations in the same city."
23323          ],
23324          "enum": [
23325            "PORT_PAIR_MATCHING_REMOTE_LOCATION",
23326            "PORT_PAIR_UNCONSTRAINED_REMOTE_LOCATION"
23327          ]
23328        }
23329      }
23330    },
23331    "InterconnectRemoteLocationConstraintsSubnetLengthRange": {
23332      "id": "InterconnectRemoteLocationConstraintsSubnetLengthRange",
23333      "type": "object",
23334      "properties": {
23335        "min": {
23336          "type": "integer",
23337          "format": "int32"
23338        },
23339        "max": {
23340          "type": "integer",
23341          "format": "int32"
23342        }
23343      }
23344    },
23345    "LicenseCode": {
23346      "id": "LicenseCode",
23347      "description": "Represents a License Code resource. A License Code is a unique identifier used to represent a license resource. *Caution* This resource is intended for use only by third-party partners who are creating Cloud Marketplace images. ",
23348      "type": "object",
23349      "properties": {
23350        "kind": {
23351          "description": "[Output Only] Type of resource. Always compute#licenseCode for licenses.",
23352          "default": "compute#licenseCode",
23353          "type": "string"
23354        },
23355        "id": {
23356          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
23357          "type": "string",
23358          "format": "uint64"
23359        },
23360        "name": {
23361          "description": "[Output Only] Name of the resource. The name is 1-20 characters long and must be a valid 64 bit integer.",
23362          "pattern": "[0-9]{0,20}?",
23363          "annotations": {
23364            "required": [
23365              "compute.licenses.insert"
23366            ]
23367          },
23368          "type": "string"
23369        },
23370        "creationTimestamp": {
23371          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
23372          "type": "string"
23373        },
23374        "description": {
23375          "description": "[Output Only] Description of this License Code.",
23376          "type": "string"
23377        },
23378        "selfLink": {
23379          "description": "[Output Only] Server-defined URL for the resource.",
23380          "type": "string"
23381        },
23382        "transferable": {
23383          "description": "[Output Only] If true, the license will remain attached when creating images or snapshots from disks. Otherwise, the license is not transferred.",
23384          "type": "boolean"
23385        },
23386        "state": {
23387          "description": "[Output Only] Current state of this License Code.",
23388          "type": "string",
23389          "enumDescriptions": [
23390            "Machines are not allowed to attach boot disks with this License Code. Requests to create new resources with this license will be rejected.",
23391            "Use is allowed for anyone with USE_READ_ONLY access to this License Code.",
23392            "Use of this license is limited to a project whitelist.",
23393            "",
23394            "Reserved state."
23395          ],
23396          "enum": [
23397            "DISABLED",
23398            "ENABLED",
23399            "RESTRICTED",
23400            "STATE_UNSPECIFIED",
23401            "TERMINATED"
23402          ]
23403        },
23404        "licenseAlias": {
23405          "description": "[Output Only] URL and description aliases of Licenses with the same License Code.",
23406          "type": "array",
23407          "items": {
23408            "$ref": "LicenseCodeLicenseAlias"
23409          }
23410        }
23411      }
23412    },
23413    "LicenseCodeLicenseAlias": {
23414      "id": "LicenseCodeLicenseAlias",
23415      "type": "object",
23416      "properties": {
23417        "selfLink": {
23418          "description": "[Output Only] URL of license corresponding to this License Code.",
23419          "type": "string"
23420        },
23421        "description": {
23422          "description": "[Output Only] Description of this License Code.",
23423          "type": "string"
23424        }
23425      }
23426    },
23427    "License": {
23428      "id": "License",
23429      "description": "Represents a License resource. A License represents billing and aggregate usage data for public and marketplace images. *Caution* This resource is intended for use only by third-party partners who are creating Cloud Marketplace images. ",
23430      "type": "object",
23431      "properties": {
23432        "kind": {
23433          "description": "[Output Only] Type of resource. Always compute#license for licenses.",
23434          "default": "compute#license",
23435          "type": "string"
23436        },
23437        "name": {
23438          "description": "Name of the resource. The name must be 1-63 characters long and comply with RFC1035.",
23439          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
23440          "annotations": {
23441            "required": [
23442              "compute.images.insert"
23443            ]
23444          },
23445          "type": "string"
23446        },
23447        "chargesUseFee": {
23448          "description": "[Output Only] Deprecated. This field no longer reflects whether a license charges a usage fee.",
23449          "type": "boolean"
23450        },
23451        "id": {
23452          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
23453          "type": "string",
23454          "format": "uint64"
23455        },
23456        "licenseCode": {
23457          "description": "[Output Only] The unique code used to attach this license to images, snapshots, and disks.",
23458          "type": "string",
23459          "format": "uint64"
23460        },
23461        "creationTimestamp": {
23462          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
23463          "type": "string"
23464        },
23465        "description": {
23466          "description": "An optional textual description of the resource; provided by the client when the resource is created.",
23467          "type": "string"
23468        },
23469        "transferable": {
23470          "description": "If false, licenses will not be copied from the source resource when creating an image from a disk, disk from snapshot, or snapshot from disk.",
23471          "type": "boolean"
23472        },
23473        "selfLink": {
23474          "description": "[Output Only] Server-defined URL for the resource.",
23475          "type": "string"
23476        },
23477        "resourceRequirements": {
23478          "$ref": "LicenseResourceRequirements"
23479        }
23480      }
23481    },
23482    "LicenseResourceRequirements": {
23483      "id": "LicenseResourceRequirements",
23484      "type": "object",
23485      "properties": {
23486        "minGuestCpuCount": {
23487          "description": "Minimum number of guest cpus required to use the Instance. Enforced at Instance creation and Instance start.",
23488          "type": "integer",
23489          "format": "int32"
23490        },
23491        "minMemoryMb": {
23492          "description": "Minimum memory required to use the Instance. Enforced at Instance creation and Instance start.",
23493          "type": "integer",
23494          "format": "int32"
23495        }
23496      }
23497    },
23498    "LicensesListResponse": {
23499      "id": "LicensesListResponse",
23500      "type": "object",
23501      "properties": {
23502        "id": {
23503          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
23504          "type": "string"
23505        },
23506        "items": {
23507          "description": "A list of License resources.",
23508          "type": "array",
23509          "items": {
23510            "$ref": "License"
23511          }
23512        },
23513        "nextPageToken": {
23514          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
23515          "type": "string"
23516        },
23517        "selfLink": {
23518          "description": "[Output Only] Server-defined URL for this resource.",
23519          "type": "string"
23520        },
23521        "warning": {
23522          "description": "[Output Only] Informational warning message.",
23523          "type": "object",
23524          "properties": {
23525            "code": {
23526              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
23527              "type": "string",
23528              "enumDescriptions": [
23529                "Warning about failed cleanup of transient changes made by a failed operation.",
23530                "A link to a deprecated resource was created.",
23531                "When deploying and at least one of the resources has a type marked as deprecated",
23532                "The user created a boot disk that is larger than image size.",
23533                "When deploying and at least one of the resources has a type marked as experimental",
23534                "Warning that is present in an external api call",
23535                "Warning that value of a field has been overridden. Deprecated unused field.",
23536                "The operation involved use of an injected kernel, which is deprecated.",
23537                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
23538                "When deploying a deployment with a exceedingly large number of resources",
23539                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
23540                "A resource depends on a missing type",
23541                "The route's nextHopIp address is not assigned to an instance on the network.",
23542                "The route's next hop instance cannot ip forward.",
23543                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
23544                "The route's nextHopInstance URL refers to an instance that does not exist.",
23545                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
23546                "The route's next hop instance does not have a status of RUNNING.",
23547                "Error which is not critical. We decided to continue the process despite the mentioned error.",
23548                "No results are present on a particular list page.",
23549                "Success is reported, but some results may be missing due to errors",
23550                "The user attempted to use a resource that requires a TOS they have not accepted.",
23551                "Warning that a resource is in use.",
23552                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
23553                "When a resource schema validation is ignored.",
23554                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
23555                "When undeclared properties in the schema are present",
23556                "A given scope cannot be reached."
23557              ],
23558              "enumDeprecated": [
23559                false,
23560                false,
23561                false,
23562                false,
23563                false,
23564                false,
23565                true,
23566                false,
23567                false,
23568                false,
23569                false,
23570                false,
23571                false,
23572                false,
23573                false,
23574                false,
23575                false,
23576                false,
23577                false,
23578                false,
23579                false,
23580                false,
23581                false,
23582                false,
23583                false,
23584                false,
23585                false,
23586                false
23587              ],
23588              "enum": [
23589                "CLEANUP_FAILED",
23590                "DEPRECATED_RESOURCE_USED",
23591                "DEPRECATED_TYPE_USED",
23592                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
23593                "EXPERIMENTAL_TYPE_USED",
23594                "EXTERNAL_API_WARNING",
23595                "FIELD_VALUE_OVERRIDEN",
23596                "INJECTED_KERNELS_DEPRECATED",
23597                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
23598                "LARGE_DEPLOYMENT_WARNING",
23599                "LIST_OVERHEAD_QUOTA_EXCEED",
23600                "MISSING_TYPE_DEPENDENCY",
23601                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
23602                "NEXT_HOP_CANNOT_IP_FORWARD",
23603                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
23604                "NEXT_HOP_INSTANCE_NOT_FOUND",
23605                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
23606                "NEXT_HOP_NOT_RUNNING",
23607                "NOT_CRITICAL_ERROR",
23608                "NO_RESULTS_ON_PAGE",
23609                "PARTIAL_SUCCESS",
23610                "REQUIRED_TOS_AGREEMENT",
23611                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
23612                "RESOURCE_NOT_DELETED",
23613                "SCHEMA_VALIDATION_IGNORED",
23614                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
23615                "UNDECLARED_PROPERTIES",
23616                "UNREACHABLE"
23617              ]
23618            },
23619            "message": {
23620              "description": "[Output Only] A human-readable description of the warning code.",
23621              "type": "string"
23622            },
23623            "data": {
23624              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
23625              "type": "array",
23626              "items": {
23627                "type": "object",
23628                "properties": {
23629                  "key": {
23630                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
23631                    "type": "string"
23632                  },
23633                  "value": {
23634                    "description": "[Output Only] A warning data value corresponding to the key.",
23635                    "type": "string"
23636                  }
23637                }
23638              }
23639            }
23640          }
23641        }
23642      }
23643    },
23644    "MachineImageList": {
23645      "id": "MachineImageList",
23646      "description": "A list of machine images.",
23647      "type": "object",
23648      "properties": {
23649        "kind": {
23650          "description": "[Output Only] The resource type, which is always compute#machineImagesListResponse for machine image lists.",
23651          "default": "compute#machineImageList",
23652          "type": "string"
23653        },
23654        "id": {
23655          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
23656          "type": "string"
23657        },
23658        "items": {
23659          "description": "A list of MachineImage resources.",
23660          "type": "array",
23661          "items": {
23662            "$ref": "MachineImage"
23663          }
23664        },
23665        "nextPageToken": {
23666          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
23667          "type": "string"
23668        },
23669        "selfLink": {
23670          "description": "[Output Only] Server-defined URL for this resource.",
23671          "type": "string"
23672        },
23673        "warning": {
23674          "description": "[Output Only] Informational warning message.",
23675          "type": "object",
23676          "properties": {
23677            "code": {
23678              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
23679              "type": "string",
23680              "enumDescriptions": [
23681                "Warning about failed cleanup of transient changes made by a failed operation.",
23682                "A link to a deprecated resource was created.",
23683                "When deploying and at least one of the resources has a type marked as deprecated",
23684                "The user created a boot disk that is larger than image size.",
23685                "When deploying and at least one of the resources has a type marked as experimental",
23686                "Warning that is present in an external api call",
23687                "Warning that value of a field has been overridden. Deprecated unused field.",
23688                "The operation involved use of an injected kernel, which is deprecated.",
23689                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
23690                "When deploying a deployment with a exceedingly large number of resources",
23691                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
23692                "A resource depends on a missing type",
23693                "The route's nextHopIp address is not assigned to an instance on the network.",
23694                "The route's next hop instance cannot ip forward.",
23695                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
23696                "The route's nextHopInstance URL refers to an instance that does not exist.",
23697                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
23698                "The route's next hop instance does not have a status of RUNNING.",
23699                "Error which is not critical. We decided to continue the process despite the mentioned error.",
23700                "No results are present on a particular list page.",
23701                "Success is reported, but some results may be missing due to errors",
23702                "The user attempted to use a resource that requires a TOS they have not accepted.",
23703                "Warning that a resource is in use.",
23704                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
23705                "When a resource schema validation is ignored.",
23706                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
23707                "When undeclared properties in the schema are present",
23708                "A given scope cannot be reached."
23709              ],
23710              "enumDeprecated": [
23711                false,
23712                false,
23713                false,
23714                false,
23715                false,
23716                false,
23717                true,
23718                false,
23719                false,
23720                false,
23721                false,
23722                false,
23723                false,
23724                false,
23725                false,
23726                false,
23727                false,
23728                false,
23729                false,
23730                false,
23731                false,
23732                false,
23733                false,
23734                false,
23735                false,
23736                false,
23737                false,
23738                false
23739              ],
23740              "enum": [
23741                "CLEANUP_FAILED",
23742                "DEPRECATED_RESOURCE_USED",
23743                "DEPRECATED_TYPE_USED",
23744                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
23745                "EXPERIMENTAL_TYPE_USED",
23746                "EXTERNAL_API_WARNING",
23747                "FIELD_VALUE_OVERRIDEN",
23748                "INJECTED_KERNELS_DEPRECATED",
23749                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
23750                "LARGE_DEPLOYMENT_WARNING",
23751                "LIST_OVERHEAD_QUOTA_EXCEED",
23752                "MISSING_TYPE_DEPENDENCY",
23753                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
23754                "NEXT_HOP_CANNOT_IP_FORWARD",
23755                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
23756                "NEXT_HOP_INSTANCE_NOT_FOUND",
23757                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
23758                "NEXT_HOP_NOT_RUNNING",
23759                "NOT_CRITICAL_ERROR",
23760                "NO_RESULTS_ON_PAGE",
23761                "PARTIAL_SUCCESS",
23762                "REQUIRED_TOS_AGREEMENT",
23763                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
23764                "RESOURCE_NOT_DELETED",
23765                "SCHEMA_VALIDATION_IGNORED",
23766                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
23767                "UNDECLARED_PROPERTIES",
23768                "UNREACHABLE"
23769              ]
23770            },
23771            "message": {
23772              "description": "[Output Only] A human-readable description of the warning code.",
23773              "type": "string"
23774            },
23775            "data": {
23776              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
23777              "type": "array",
23778              "items": {
23779                "type": "object",
23780                "properties": {
23781                  "key": {
23782                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
23783                    "type": "string"
23784                  },
23785                  "value": {
23786                    "description": "[Output Only] A warning data value corresponding to the key.",
23787                    "type": "string"
23788                  }
23789                }
23790              }
23791            }
23792          }
23793        }
23794      }
23795    },
23796    "MachineImage": {
23797      "id": "MachineImage",
23798      "description": "Represents a machine image resource. A machine image is a Compute Engine resource that stores all the configuration, metadata, permissions, and data from one or more disks required to create a Virtual machine (VM) instance. For more information, see Machine images.",
23799      "type": "object",
23800      "properties": {
23801        "kind": {
23802          "description": "[Output Only] The resource type, which is always compute#machineImage for machine image.",
23803          "default": "compute#machineImage",
23804          "type": "string"
23805        },
23806        "id": {
23807          "description": "[Output Only] A unique identifier for this machine image. The server defines this identifier.",
23808          "type": "string",
23809          "format": "uint64"
23810        },
23811        "creationTimestamp": {
23812          "description": "[Output Only] The creation timestamp for this machine image in RFC3339 text format.",
23813          "type": "string"
23814        },
23815        "name": {
23816          "description": "Name of the resource; provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
23817          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
23818          "annotations": {
23819            "required": [
23820              "compute.machineImages.insert"
23821            ]
23822          },
23823          "type": "string"
23824        },
23825        "description": {
23826          "description": "An optional description of this resource. Provide this property when you create the resource.",
23827          "type": "string"
23828        },
23829        "selfLink": {
23830          "description": "[Output Only] The URL for this machine image. The server defines this URL.",
23831          "type": "string"
23832        },
23833        "sourceInstance": {
23834          "description": "The source instance used to create the machine image. You can provide this as a partial or full URL to the resource. For example, the following are valid values: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /instances/instance - projects/project/zones/zone/instances/instance ",
23835          "type": "string"
23836        },
23837        "status": {
23838          "description": "[Output Only] The status of the machine image. One of the following values: INVALID, CREATING, READY, DELETING, and UPLOADING.",
23839          "type": "string",
23840          "enumDescriptions": [
23841            "",
23842            "",
23843            "",
23844            "",
23845            ""
23846          ],
23847          "enum": [
23848            "CREATING",
23849            "DELETING",
23850            "INVALID",
23851            "READY",
23852            "UPLOADING"
23853          ]
23854        },
23855        "sourceInstanceProperties": {
23856          "description": "[Output Only] DEPRECATED: Please use instance_properties instead for source instance related properties. New properties will not be added to this field.",
23857          "$ref": "SourceInstanceProperties"
23858        },
23859        "instanceProperties": {
23860          "description": "[Output Only] Properties of source instance",
23861          "$ref": "InstanceProperties"
23862        },
23863        "savedDisks": {
23864          "description": "An array of Machine Image specific properties for disks attached to the source instance",
23865          "type": "array",
23866          "items": {
23867            "$ref": "SavedDisk"
23868          }
23869        },
23870        "storageLocations": {
23871          "description": "The regional or multi-regional Cloud Storage bucket location where the machine image is stored.",
23872          "type": "array",
23873          "items": {
23874            "type": "string"
23875          }
23876        },
23877        "machineImageEncryptionKey": {
23878          "description": "Encrypts the machine image using a customer-supplied encryption key. After you encrypt a machine image using a customer-supplied key, you must provide the same key if you use the machine image later. For example, you must provide the encryption key when you create an instance from the encrypted machine image in a future request. Customer-supplied encryption keys do not protect access to metadata of the machine image. If you do not provide an encryption key when creating the machine image, then the machine image will be encrypted using an automatically generated key and you do not need to provide a key to use the machine image later.",
23879          "$ref": "CustomerEncryptionKey"
23880        },
23881        "guestFlush": {
23882          "description": "[Input Only] Whether to attempt an application consistent machine image by informing the OS to prepare for the snapshot process.",
23883          "type": "boolean"
23884        },
23885        "sourceDiskEncryptionKeys": {
23886          "description": "[Input Only] The customer-supplied encryption key of the disks attached to the source instance. Required if the source disk is protected by a customer-supplied encryption key.",
23887          "type": "array",
23888          "items": {
23889            "$ref": "SourceDiskEncryptionKey"
23890          }
23891        },
23892        "totalStorageBytes": {
23893          "description": "[Output Only] Total size of the storage used by the machine image.",
23894          "type": "string",
23895          "format": "int64"
23896        },
23897        "satisfiesPzs": {
23898          "description": "[Output Only] Reserved for future use.",
23899          "type": "boolean"
23900        },
23901        "satisfiesPzi": {
23902          "description": "Output only. Reserved for future use.",
23903          "readOnly": true,
23904          "type": "boolean"
23905        }
23906      }
23907    },
23908    "SourceInstanceProperties": {
23909      "id": "SourceInstanceProperties",
23910      "description": "DEPRECATED: Please use compute#instanceProperties instead. New properties will not be added to this field.",
23911      "type": "object",
23912      "properties": {
23913        "description": {
23914          "description": "An optional text description for the instances that are created from this machine image.",
23915          "type": "string"
23916        },
23917        "tags": {
23918          "description": "A list of tags to apply to the instances that are created from this machine image. The tags identify valid sources or targets for network firewalls. The setTags method can modify this list of tags. Each tag within the list must comply with RFC1035.",
23919          "$ref": "Tags"
23920        },
23921        "machineType": {
23922          "description": "The machine type to use for instances that are created from this machine image.",
23923          "type": "string"
23924        },
23925        "canIpForward": {
23926          "description": "Enables instances created based on this machine image to send packets with source IP addresses other than their own and receive packets with destination IP addresses other than their own. If these instances will be used as an IP gateway or it will be set as the next-hop in a Route resource, specify true. If unsure, leave this set to false. See the Enable IP forwarding documentation for more information.",
23927          "type": "boolean"
23928        },
23929        "networkInterfaces": {
23930          "description": "An array of network access configurations for this interface.",
23931          "type": "array",
23932          "items": {
23933            "$ref": "NetworkInterface"
23934          }
23935        },
23936        "disks": {
23937          "description": "An array of disks that are associated with the instances that are created from this machine image.",
23938          "type": "array",
23939          "items": {
23940            "$ref": "SavedAttachedDisk"
23941          }
23942        },
23943        "metadata": {
23944          "description": "The metadata key/value pairs to assign to instances that are created from this machine image. These pairs can consist of custom metadata or predefined keys. See Project and instance metadata for more information.",
23945          "$ref": "Metadata"
23946        },
23947        "serviceAccounts": {
23948          "description": "A list of service accounts with specified scopes. Access tokens for these service accounts are available to the instances that are created from this machine image. Use metadata queries to obtain the access tokens for these instances.",
23949          "type": "array",
23950          "items": {
23951            "$ref": "ServiceAccount"
23952          }
23953        },
23954        "scheduling": {
23955          "description": "Specifies the scheduling options for the instances that are created from this machine image.",
23956          "$ref": "Scheduling"
23957        },
23958        "labels": {
23959          "description": "Labels to apply to instances that are created from this machine image.",
23960          "type": "object",
23961          "additionalProperties": {
23962            "type": "string"
23963          }
23964        },
23965        "guestAccelerators": {
23966          "description": "A list of guest accelerator cards' type and count to use for instances created from this machine image.",
23967          "type": "array",
23968          "items": {
23969            "$ref": "AcceleratorConfig"
23970          }
23971        },
23972        "minCpuPlatform": {
23973          "description": "Minimum cpu/platform to be used by instances created from this machine image. The instance may be scheduled on the specified or newer cpu/platform. Applicable values are the friendly names of CPU platforms, such as minCpuPlatform: \"Intel Haswell\" or minCpuPlatform: \"Intel Sandy Bridge\". For more information, read Specifying a Minimum CPU Platform.",
23974          "type": "string"
23975        },
23976        "deletionProtection": {
23977          "description": "Whether the instance created from this machine image should be protected against deletion.",
23978          "type": "boolean"
23979        },
23980        "keyRevocationActionType": {
23981          "description": "KeyRevocationActionType of the instance. Supported options are \"STOP\" and \"NONE\". The default value is \"NONE\" if it is not specified.",
23982          "type": "string",
23983          "enumDescriptions": [
23984            "Default value. This value is unused.",
23985            "Indicates user chose no operation.",
23986            "Indicates user chose to opt for VM shutdown on key revocation."
23987          ],
23988          "enum": [
23989            "KEY_REVOCATION_ACTION_TYPE_UNSPECIFIED",
23990            "NONE",
23991            "STOP"
23992          ]
23993        }
23994      }
23995    },
23996    "SavedAttachedDisk": {
23997      "id": "SavedAttachedDisk",
23998      "description": "DEPRECATED: Please use compute#savedDisk instead. An instance-attached disk resource.",
23999      "type": "object",
24000      "properties": {
24001        "kind": {
24002          "description": "[Output Only] Type of the resource. Always compute#attachedDisk for attached disks.",
24003          "default": "compute#savedAttachedDisk",
24004          "type": "string"
24005        },
24006        "type": {
24007          "description": "Specifies the type of the attached disk, either SCRATCH or PERSISTENT.",
24008          "type": "string",
24009          "enumDescriptions": [
24010            "",
24011            ""
24012          ],
24013          "enum": [
24014            "PERSISTENT",
24015            "SCRATCH"
24016          ]
24017        },
24018        "mode": {
24019          "description": "The mode in which this disk is attached to the source instance, either READ_WRITE or READ_ONLY.",
24020          "type": "string",
24021          "enumDescriptions": [
24022            "Attaches this disk in read-only mode. Multiple virtual machines can use a disk in read-only mode at a time.",
24023            "*[Default]* Attaches this disk in read-write mode. Only one virtual machine at a time can be attached to a disk in read-write mode."
24024          ],
24025          "enum": [
24026            "READ_ONLY",
24027            "READ_WRITE"
24028          ]
24029        },
24030        "source": {
24031          "description": "Specifies a URL of the disk attached to the source instance.",
24032          "type": "string"
24033        },
24034        "deviceName": {
24035          "description": "Specifies the name of the disk attached to the source instance.",
24036          "type": "string"
24037        },
24038        "index": {
24039          "description": "Specifies zero-based index of the disk that is attached to the source instance.",
24040          "type": "integer",
24041          "format": "int32"
24042        },
24043        "boot": {
24044          "description": "Indicates that this is a boot disk. The virtual machine will use the first partition of the disk for its root filesystem.",
24045          "type": "boolean"
24046        },
24047        "autoDelete": {
24048          "description": "Specifies whether the disk will be auto-deleted when the instance is deleted (but not when the disk is detached from the instance).",
24049          "type": "boolean"
24050        },
24051        "licenses": {
24052          "description": "[Output Only] Any valid publicly visible licenses.",
24053          "type": "array",
24054          "items": {
24055            "type": "string"
24056          }
24057        },
24058        "interface": {
24059          "description": "Specifies the disk interface to use for attaching this disk, which is either SCSI or NVME.",
24060          "type": "string",
24061          "enumDescriptions": [
24062            "",
24063            ""
24064          ],
24065          "enum": [
24066            "NVME",
24067            "SCSI"
24068          ]
24069        },
24070        "guestOsFeatures": {
24071          "description": "A list of features to enable on the guest operating system. Applicable only for bootable images. Read Enabling guest operating system features to see a list of available options.",
24072          "type": "array",
24073          "items": {
24074            "$ref": "GuestOsFeature"
24075          }
24076        },
24077        "diskEncryptionKey": {
24078          "description": "The encryption key for the disk.",
24079          "$ref": "CustomerEncryptionKey"
24080        },
24081        "diskSizeGb": {
24082          "description": "The size of the disk in base-2 GB.",
24083          "type": "string",
24084          "format": "int64"
24085        },
24086        "storageBytes": {
24087          "description": "[Output Only] A size of the storage used by the disk's snapshot by this machine image.",
24088          "type": "string",
24089          "format": "int64"
24090        },
24091        "storageBytesStatus": {
24092          "description": "[Output Only] An indicator whether storageBytes is in a stable state or it is being adjusted as a result of shared storage reallocation. This status can either be UPDATING, meaning the size of the snapshot is being updated, or UP_TO_DATE, meaning the size of the snapshot is up-to-date.",
24093          "type": "string",
24094          "enumDescriptions": [
24095            "",
24096            ""
24097          ],
24098          "enum": [
24099            "UPDATING",
24100            "UP_TO_DATE"
24101          ]
24102        },
24103        "diskType": {
24104          "description": "[Output Only] URL of the disk type resource. For example: projects/project /zones/zone/diskTypes/pd-standard or pd-ssd",
24105          "type": "string"
24106        }
24107      }
24108    },
24109    "SavedDisk": {
24110      "id": "SavedDisk",
24111      "description": "An instance-attached disk resource.",
24112      "type": "object",
24113      "properties": {
24114        "kind": {
24115          "description": "[Output Only] Type of the resource. Always compute#savedDisk for attached disks.",
24116          "default": "compute#savedDisk",
24117          "type": "string"
24118        },
24119        "sourceDisk": {
24120          "description": "Specifies a URL of the disk attached to the source instance.",
24121          "type": "string"
24122        },
24123        "storageBytes": {
24124          "description": "[Output Only] Size of the individual disk snapshot used by this machine image.",
24125          "type": "string",
24126          "format": "int64"
24127        },
24128        "storageBytesStatus": {
24129          "description": "[Output Only] An indicator whether storageBytes is in a stable state or it is being adjusted as a result of shared storage reallocation. This status can either be UPDATING, meaning the size of the snapshot is being updated, or UP_TO_DATE, meaning the size of the snapshot is up-to-date.",
24130          "type": "string",
24131          "enumDescriptions": [
24132            "",
24133            ""
24134          ],
24135          "enum": [
24136            "UPDATING",
24137            "UP_TO_DATE"
24138          ]
24139        },
24140        "architecture": {
24141          "description": "[Output Only] The architecture of the attached disk.",
24142          "type": "string",
24143          "enumDescriptions": [
24144            "Default value indicating Architecture is not set.",
24145            "Machines with architecture ARM64",
24146            "Machines with architecture X86_64"
24147          ],
24148          "enum": [
24149            "ARCHITECTURE_UNSPECIFIED",
24150            "ARM64",
24151            "X86_64"
24152          ]
24153        }
24154      }
24155    },
24156    "SourceDiskEncryptionKey": {
24157      "id": "SourceDiskEncryptionKey",
24158      "type": "object",
24159      "properties": {
24160        "sourceDisk": {
24161          "description": "URL of the disk attached to the source instance. This can be a full or valid partial URL. For example, the following are valid values: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /disks/disk - projects/project/zones/zone/disks/disk - zones/zone/disks/disk ",
24162          "type": "string"
24163        },
24164        "diskEncryptionKey": {
24165          "description": "The customer-supplied encryption key of the source disk. Required if the source disk is protected by a customer-supplied encryption key.",
24166          "$ref": "CustomerEncryptionKey"
24167        }
24168      }
24169    },
24170    "MachineTypeList": {
24171      "id": "MachineTypeList",
24172      "description": "Contains a list of machine types.",
24173      "type": "object",
24174      "properties": {
24175        "kind": {
24176          "description": "[Output Only] Type of resource. Always compute#machineTypeList for lists of machine types.",
24177          "default": "compute#machineTypeList",
24178          "type": "string"
24179        },
24180        "id": {
24181          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
24182          "type": "string"
24183        },
24184        "items": {
24185          "description": "A list of MachineType resources.",
24186          "type": "array",
24187          "items": {
24188            "$ref": "MachineType"
24189          }
24190        },
24191        "nextPageToken": {
24192          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
24193          "type": "string"
24194        },
24195        "selfLink": {
24196          "description": "[Output Only] Server-defined URL for this resource.",
24197          "type": "string"
24198        },
24199        "warning": {
24200          "description": "[Output Only] Informational warning message.",
24201          "type": "object",
24202          "properties": {
24203            "code": {
24204              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
24205              "type": "string",
24206              "enumDescriptions": [
24207                "Warning about failed cleanup of transient changes made by a failed operation.",
24208                "A link to a deprecated resource was created.",
24209                "When deploying and at least one of the resources has a type marked as deprecated",
24210                "The user created a boot disk that is larger than image size.",
24211                "When deploying and at least one of the resources has a type marked as experimental",
24212                "Warning that is present in an external api call",
24213                "Warning that value of a field has been overridden. Deprecated unused field.",
24214                "The operation involved use of an injected kernel, which is deprecated.",
24215                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
24216                "When deploying a deployment with a exceedingly large number of resources",
24217                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
24218                "A resource depends on a missing type",
24219                "The route's nextHopIp address is not assigned to an instance on the network.",
24220                "The route's next hop instance cannot ip forward.",
24221                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
24222                "The route's nextHopInstance URL refers to an instance that does not exist.",
24223                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
24224                "The route's next hop instance does not have a status of RUNNING.",
24225                "Error which is not critical. We decided to continue the process despite the mentioned error.",
24226                "No results are present on a particular list page.",
24227                "Success is reported, but some results may be missing due to errors",
24228                "The user attempted to use a resource that requires a TOS they have not accepted.",
24229                "Warning that a resource is in use.",
24230                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
24231                "When a resource schema validation is ignored.",
24232                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
24233                "When undeclared properties in the schema are present",
24234                "A given scope cannot be reached."
24235              ],
24236              "enumDeprecated": [
24237                false,
24238                false,
24239                false,
24240                false,
24241                false,
24242                false,
24243                true,
24244                false,
24245                false,
24246                false,
24247                false,
24248                false,
24249                false,
24250                false,
24251                false,
24252                false,
24253                false,
24254                false,
24255                false,
24256                false,
24257                false,
24258                false,
24259                false,
24260                false,
24261                false,
24262                false,
24263                false,
24264                false
24265              ],
24266              "enum": [
24267                "CLEANUP_FAILED",
24268                "DEPRECATED_RESOURCE_USED",
24269                "DEPRECATED_TYPE_USED",
24270                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
24271                "EXPERIMENTAL_TYPE_USED",
24272                "EXTERNAL_API_WARNING",
24273                "FIELD_VALUE_OVERRIDEN",
24274                "INJECTED_KERNELS_DEPRECATED",
24275                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
24276                "LARGE_DEPLOYMENT_WARNING",
24277                "LIST_OVERHEAD_QUOTA_EXCEED",
24278                "MISSING_TYPE_DEPENDENCY",
24279                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
24280                "NEXT_HOP_CANNOT_IP_FORWARD",
24281                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
24282                "NEXT_HOP_INSTANCE_NOT_FOUND",
24283                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
24284                "NEXT_HOP_NOT_RUNNING",
24285                "NOT_CRITICAL_ERROR",
24286                "NO_RESULTS_ON_PAGE",
24287                "PARTIAL_SUCCESS",
24288                "REQUIRED_TOS_AGREEMENT",
24289                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
24290                "RESOURCE_NOT_DELETED",
24291                "SCHEMA_VALIDATION_IGNORED",
24292                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
24293                "UNDECLARED_PROPERTIES",
24294                "UNREACHABLE"
24295              ]
24296            },
24297            "message": {
24298              "description": "[Output Only] A human-readable description of the warning code.",
24299              "type": "string"
24300            },
24301            "data": {
24302              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
24303              "type": "array",
24304              "items": {
24305                "type": "object",
24306                "properties": {
24307                  "key": {
24308                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
24309                    "type": "string"
24310                  },
24311                  "value": {
24312                    "description": "[Output Only] A warning data value corresponding to the key.",
24313                    "type": "string"
24314                  }
24315                }
24316              }
24317            }
24318          }
24319        }
24320      }
24321    },
24322    "MachineType": {
24323      "id": "MachineType",
24324      "description": "Represents a Machine Type resource. You can use specific machine types for your VM instances based on performance and pricing requirements. For more information, read Machine Types.",
24325      "type": "object",
24326      "properties": {
24327        "kind": {
24328          "description": "[Output Only] The type of the resource. Always compute#machineType for machine types.",
24329          "default": "compute#machineType",
24330          "type": "string"
24331        },
24332        "id": {
24333          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
24334          "type": "string",
24335          "format": "uint64"
24336        },
24337        "creationTimestamp": {
24338          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
24339          "type": "string"
24340        },
24341        "name": {
24342          "description": "[Output Only] Name of the resource.",
24343          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
24344          "type": "string"
24345        },
24346        "description": {
24347          "description": "[Output Only] An optional textual description of the resource.",
24348          "type": "string"
24349        },
24350        "guestCpus": {
24351          "description": "[Output Only] The number of virtual CPUs that are available to the instance.",
24352          "type": "integer",
24353          "format": "int32"
24354        },
24355        "memoryMb": {
24356          "description": "[Output Only] The amount of physical memory available to the instance, defined in MB.",
24357          "type": "integer",
24358          "format": "int32"
24359        },
24360        "imageSpaceGb": {
24361          "description": "[Deprecated] This property is deprecated and will never be populated with any relevant values.",
24362          "type": "integer",
24363          "format": "int32"
24364        },
24365        "scratchDisks": {
24366          "description": "[Output Only] A list of extended scratch disks assigned to the instance.",
24367          "type": "array",
24368          "items": {
24369            "type": "object",
24370            "properties": {
24371              "diskGb": {
24372                "description": "Size of the scratch disk, defined in GB.",
24373                "type": "integer",
24374                "format": "int32"
24375              }
24376            }
24377          }
24378        },
24379        "maximumPersistentDisks": {
24380          "description": "[Output Only] Maximum persistent disks allowed.",
24381          "type": "integer",
24382          "format": "int32"
24383        },
24384        "maximumPersistentDisksSizeGb": {
24385          "description": "[Output Only] Maximum total persistent disks size (GB) allowed.",
24386          "type": "string",
24387          "format": "int64"
24388        },
24389        "deprecated": {
24390          "description": "[Output Only] The deprecation status associated with this machine type. Only applicable if the machine type is unavailable.",
24391          "$ref": "DeprecationStatus"
24392        },
24393        "zone": {
24394          "description": "[Output Only] The name of the zone where the machine type resides, such as us-central1-a.",
24395          "type": "string"
24396        },
24397        "selfLink": {
24398          "description": "[Output Only] Server-defined URL for the resource.",
24399          "type": "string"
24400        },
24401        "isSharedCpu": {
24402          "description": "[Output Only] Whether this machine type has a shared CPU. See Shared-core machine types for more information.",
24403          "type": "boolean"
24404        },
24405        "accelerators": {
24406          "description": "[Output Only] A list of accelerator configurations assigned to this machine type.",
24407          "type": "array",
24408          "items": {
24409            "type": "object",
24410            "properties": {
24411              "guestAcceleratorType": {
24412                "description": "The accelerator type resource name, not a full URL, e.g. nvidia-tesla-t4.",
24413                "type": "string"
24414              },
24415              "guestAcceleratorCount": {
24416                "description": "Number of accelerator cards exposed to the guest.",
24417                "type": "integer",
24418                "format": "int32"
24419              }
24420            }
24421          }
24422        }
24423      }
24424    },
24425    "MachineTypeAggregatedList": {
24426      "id": "MachineTypeAggregatedList",
24427      "type": "object",
24428      "properties": {
24429        "kind": {
24430          "description": "[Output Only] Type of resource. Always compute#machineTypeAggregatedList for aggregated lists of machine types.",
24431          "default": "compute#machineTypeAggregatedList",
24432          "type": "string"
24433        },
24434        "id": {
24435          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
24436          "type": "string"
24437        },
24438        "items": {
24439          "description": "A list of MachineTypesScopedList resources.",
24440          "type": "object",
24441          "additionalProperties": {
24442            "description": "[Output Only] Name of the scope containing this set of machine types.",
24443            "$ref": "MachineTypesScopedList"
24444          }
24445        },
24446        "nextPageToken": {
24447          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
24448          "type": "string"
24449        },
24450        "selfLink": {
24451          "description": "[Output Only] Server-defined URL for this resource.",
24452          "type": "string"
24453        },
24454        "warning": {
24455          "description": "[Output Only] Informational warning message.",
24456          "type": "object",
24457          "properties": {
24458            "code": {
24459              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
24460              "type": "string",
24461              "enumDescriptions": [
24462                "Warning about failed cleanup of transient changes made by a failed operation.",
24463                "A link to a deprecated resource was created.",
24464                "When deploying and at least one of the resources has a type marked as deprecated",
24465                "The user created a boot disk that is larger than image size.",
24466                "When deploying and at least one of the resources has a type marked as experimental",
24467                "Warning that is present in an external api call",
24468                "Warning that value of a field has been overridden. Deprecated unused field.",
24469                "The operation involved use of an injected kernel, which is deprecated.",
24470                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
24471                "When deploying a deployment with a exceedingly large number of resources",
24472                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
24473                "A resource depends on a missing type",
24474                "The route's nextHopIp address is not assigned to an instance on the network.",
24475                "The route's next hop instance cannot ip forward.",
24476                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
24477                "The route's nextHopInstance URL refers to an instance that does not exist.",
24478                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
24479                "The route's next hop instance does not have a status of RUNNING.",
24480                "Error which is not critical. We decided to continue the process despite the mentioned error.",
24481                "No results are present on a particular list page.",
24482                "Success is reported, but some results may be missing due to errors",
24483                "The user attempted to use a resource that requires a TOS they have not accepted.",
24484                "Warning that a resource is in use.",
24485                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
24486                "When a resource schema validation is ignored.",
24487                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
24488                "When undeclared properties in the schema are present",
24489                "A given scope cannot be reached."
24490              ],
24491              "enumDeprecated": [
24492                false,
24493                false,
24494                false,
24495                false,
24496                false,
24497                false,
24498                true,
24499                false,
24500                false,
24501                false,
24502                false,
24503                false,
24504                false,
24505                false,
24506                false,
24507                false,
24508                false,
24509                false,
24510                false,
24511                false,
24512                false,
24513                false,
24514                false,
24515                false,
24516                false,
24517                false,
24518                false,
24519                false
24520              ],
24521              "enum": [
24522                "CLEANUP_FAILED",
24523                "DEPRECATED_RESOURCE_USED",
24524                "DEPRECATED_TYPE_USED",
24525                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
24526                "EXPERIMENTAL_TYPE_USED",
24527                "EXTERNAL_API_WARNING",
24528                "FIELD_VALUE_OVERRIDEN",
24529                "INJECTED_KERNELS_DEPRECATED",
24530                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
24531                "LARGE_DEPLOYMENT_WARNING",
24532                "LIST_OVERHEAD_QUOTA_EXCEED",
24533                "MISSING_TYPE_DEPENDENCY",
24534                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
24535                "NEXT_HOP_CANNOT_IP_FORWARD",
24536                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
24537                "NEXT_HOP_INSTANCE_NOT_FOUND",
24538                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
24539                "NEXT_HOP_NOT_RUNNING",
24540                "NOT_CRITICAL_ERROR",
24541                "NO_RESULTS_ON_PAGE",
24542                "PARTIAL_SUCCESS",
24543                "REQUIRED_TOS_AGREEMENT",
24544                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
24545                "RESOURCE_NOT_DELETED",
24546                "SCHEMA_VALIDATION_IGNORED",
24547                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
24548                "UNDECLARED_PROPERTIES",
24549                "UNREACHABLE"
24550              ]
24551            },
24552            "message": {
24553              "description": "[Output Only] A human-readable description of the warning code.",
24554              "type": "string"
24555            },
24556            "data": {
24557              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
24558              "type": "array",
24559              "items": {
24560                "type": "object",
24561                "properties": {
24562                  "key": {
24563                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
24564                    "type": "string"
24565                  },
24566                  "value": {
24567                    "description": "[Output Only] A warning data value corresponding to the key.",
24568                    "type": "string"
24569                  }
24570                }
24571              }
24572            }
24573          }
24574        },
24575        "unreachables": {
24576          "description": "[Output Only] Unreachable resources.",
24577          "type": "array",
24578          "items": {
24579            "type": "string"
24580          }
24581        }
24582      }
24583    },
24584    "MachineTypesScopedList": {
24585      "id": "MachineTypesScopedList",
24586      "type": "object",
24587      "properties": {
24588        "machineTypes": {
24589          "description": "[Output Only] A list of machine types contained in this scope.",
24590          "type": "array",
24591          "items": {
24592            "$ref": "MachineType"
24593          }
24594        },
24595        "warning": {
24596          "description": "[Output Only] An informational warning that appears when the machine types list is empty.",
24597          "type": "object",
24598          "properties": {
24599            "code": {
24600              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
24601              "type": "string",
24602              "enumDescriptions": [
24603                "Warning about failed cleanup of transient changes made by a failed operation.",
24604                "A link to a deprecated resource was created.",
24605                "When deploying and at least one of the resources has a type marked as deprecated",
24606                "The user created a boot disk that is larger than image size.",
24607                "When deploying and at least one of the resources has a type marked as experimental",
24608                "Warning that is present in an external api call",
24609                "Warning that value of a field has been overridden. Deprecated unused field.",
24610                "The operation involved use of an injected kernel, which is deprecated.",
24611                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
24612                "When deploying a deployment with a exceedingly large number of resources",
24613                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
24614                "A resource depends on a missing type",
24615                "The route's nextHopIp address is not assigned to an instance on the network.",
24616                "The route's next hop instance cannot ip forward.",
24617                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
24618                "The route's nextHopInstance URL refers to an instance that does not exist.",
24619                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
24620                "The route's next hop instance does not have a status of RUNNING.",
24621                "Error which is not critical. We decided to continue the process despite the mentioned error.",
24622                "No results are present on a particular list page.",
24623                "Success is reported, but some results may be missing due to errors",
24624                "The user attempted to use a resource that requires a TOS they have not accepted.",
24625                "Warning that a resource is in use.",
24626                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
24627                "When a resource schema validation is ignored.",
24628                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
24629                "When undeclared properties in the schema are present",
24630                "A given scope cannot be reached."
24631              ],
24632              "enumDeprecated": [
24633                false,
24634                false,
24635                false,
24636                false,
24637                false,
24638                false,
24639                true,
24640                false,
24641                false,
24642                false,
24643                false,
24644                false,
24645                false,
24646                false,
24647                false,
24648                false,
24649                false,
24650                false,
24651                false,
24652                false,
24653                false,
24654                false,
24655                false,
24656                false,
24657                false,
24658                false,
24659                false,
24660                false
24661              ],
24662              "enum": [
24663                "CLEANUP_FAILED",
24664                "DEPRECATED_RESOURCE_USED",
24665                "DEPRECATED_TYPE_USED",
24666                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
24667                "EXPERIMENTAL_TYPE_USED",
24668                "EXTERNAL_API_WARNING",
24669                "FIELD_VALUE_OVERRIDEN",
24670                "INJECTED_KERNELS_DEPRECATED",
24671                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
24672                "LARGE_DEPLOYMENT_WARNING",
24673                "LIST_OVERHEAD_QUOTA_EXCEED",
24674                "MISSING_TYPE_DEPENDENCY",
24675                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
24676                "NEXT_HOP_CANNOT_IP_FORWARD",
24677                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
24678                "NEXT_HOP_INSTANCE_NOT_FOUND",
24679                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
24680                "NEXT_HOP_NOT_RUNNING",
24681                "NOT_CRITICAL_ERROR",
24682                "NO_RESULTS_ON_PAGE",
24683                "PARTIAL_SUCCESS",
24684                "REQUIRED_TOS_AGREEMENT",
24685                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
24686                "RESOURCE_NOT_DELETED",
24687                "SCHEMA_VALIDATION_IGNORED",
24688                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
24689                "UNDECLARED_PROPERTIES",
24690                "UNREACHABLE"
24691              ]
24692            },
24693            "message": {
24694              "description": "[Output Only] A human-readable description of the warning code.",
24695              "type": "string"
24696            },
24697            "data": {
24698              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
24699              "type": "array",
24700              "items": {
24701                "type": "object",
24702                "properties": {
24703                  "key": {
24704                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
24705                    "type": "string"
24706                  },
24707                  "value": {
24708                    "description": "[Output Only] A warning data value corresponding to the key.",
24709                    "type": "string"
24710                  }
24711                }
24712              }
24713            }
24714          }
24715        }
24716      }
24717    },
24718    "NetworkAttachmentAggregatedList": {
24719      "id": "NetworkAttachmentAggregatedList",
24720      "description": "Contains a list of NetworkAttachmentsScopedList.",
24721      "type": "object",
24722      "properties": {
24723        "kind": {
24724          "default": "compute#networkAttachmentAggregatedList",
24725          "type": "string"
24726        },
24727        "id": {
24728          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
24729          "type": "string"
24730        },
24731        "items": {
24732          "description": "A list of NetworkAttachmentsScopedList resources.",
24733          "type": "object",
24734          "additionalProperties": {
24735            "description": "Name of the scope containing this set of NetworkAttachments.",
24736            "$ref": "NetworkAttachmentsScopedList"
24737          }
24738        },
24739        "nextPageToken": {
24740          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
24741          "type": "string"
24742        },
24743        "selfLink": {
24744          "description": "[Output Only] Server-defined URL for this resource.",
24745          "type": "string"
24746        },
24747        "warning": {
24748          "description": "[Output Only] Informational warning message.",
24749          "type": "object",
24750          "properties": {
24751            "code": {
24752              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
24753              "type": "string",
24754              "enumDescriptions": [
24755                "Warning about failed cleanup of transient changes made by a failed operation.",
24756                "A link to a deprecated resource was created.",
24757                "When deploying and at least one of the resources has a type marked as deprecated",
24758                "The user created a boot disk that is larger than image size.",
24759                "When deploying and at least one of the resources has a type marked as experimental",
24760                "Warning that is present in an external api call",
24761                "Warning that value of a field has been overridden. Deprecated unused field.",
24762                "The operation involved use of an injected kernel, which is deprecated.",
24763                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
24764                "When deploying a deployment with a exceedingly large number of resources",
24765                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
24766                "A resource depends on a missing type",
24767                "The route's nextHopIp address is not assigned to an instance on the network.",
24768                "The route's next hop instance cannot ip forward.",
24769                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
24770                "The route's nextHopInstance URL refers to an instance that does not exist.",
24771                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
24772                "The route's next hop instance does not have a status of RUNNING.",
24773                "Error which is not critical. We decided to continue the process despite the mentioned error.",
24774                "No results are present on a particular list page.",
24775                "Success is reported, but some results may be missing due to errors",
24776                "The user attempted to use a resource that requires a TOS they have not accepted.",
24777                "Warning that a resource is in use.",
24778                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
24779                "When a resource schema validation is ignored.",
24780                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
24781                "When undeclared properties in the schema are present",
24782                "A given scope cannot be reached."
24783              ],
24784              "enumDeprecated": [
24785                false,
24786                false,
24787                false,
24788                false,
24789                false,
24790                false,
24791                true,
24792                false,
24793                false,
24794                false,
24795                false,
24796                false,
24797                false,
24798                false,
24799                false,
24800                false,
24801                false,
24802                false,
24803                false,
24804                false,
24805                false,
24806                false,
24807                false,
24808                false,
24809                false,
24810                false,
24811                false,
24812                false
24813              ],
24814              "enum": [
24815                "CLEANUP_FAILED",
24816                "DEPRECATED_RESOURCE_USED",
24817                "DEPRECATED_TYPE_USED",
24818                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
24819                "EXPERIMENTAL_TYPE_USED",
24820                "EXTERNAL_API_WARNING",
24821                "FIELD_VALUE_OVERRIDEN",
24822                "INJECTED_KERNELS_DEPRECATED",
24823                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
24824                "LARGE_DEPLOYMENT_WARNING",
24825                "LIST_OVERHEAD_QUOTA_EXCEED",
24826                "MISSING_TYPE_DEPENDENCY",
24827                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
24828                "NEXT_HOP_CANNOT_IP_FORWARD",
24829                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
24830                "NEXT_HOP_INSTANCE_NOT_FOUND",
24831                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
24832                "NEXT_HOP_NOT_RUNNING",
24833                "NOT_CRITICAL_ERROR",
24834                "NO_RESULTS_ON_PAGE",
24835                "PARTIAL_SUCCESS",
24836                "REQUIRED_TOS_AGREEMENT",
24837                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
24838                "RESOURCE_NOT_DELETED",
24839                "SCHEMA_VALIDATION_IGNORED",
24840                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
24841                "UNDECLARED_PROPERTIES",
24842                "UNREACHABLE"
24843              ]
24844            },
24845            "message": {
24846              "description": "[Output Only] A human-readable description of the warning code.",
24847              "type": "string"
24848            },
24849            "data": {
24850              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
24851              "type": "array",
24852              "items": {
24853                "type": "object",
24854                "properties": {
24855                  "key": {
24856                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
24857                    "type": "string"
24858                  },
24859                  "value": {
24860                    "description": "[Output Only] A warning data value corresponding to the key.",
24861                    "type": "string"
24862                  }
24863                }
24864              }
24865            }
24866          }
24867        }
24868      }
24869    },
24870    "NetworkAttachmentsScopedList": {
24871      "id": "NetworkAttachmentsScopedList",
24872      "type": "object",
24873      "properties": {
24874        "networkAttachments": {
24875          "description": "A list of NetworkAttachments contained in this scope.",
24876          "type": "array",
24877          "items": {
24878            "$ref": "NetworkAttachment"
24879          }
24880        },
24881        "warning": {
24882          "description": "Informational warning which replaces the list of network attachments when the list is empty.",
24883          "type": "object",
24884          "properties": {
24885            "code": {
24886              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
24887              "type": "string",
24888              "enumDescriptions": [
24889                "Warning about failed cleanup of transient changes made by a failed operation.",
24890                "A link to a deprecated resource was created.",
24891                "When deploying and at least one of the resources has a type marked as deprecated",
24892                "The user created a boot disk that is larger than image size.",
24893                "When deploying and at least one of the resources has a type marked as experimental",
24894                "Warning that is present in an external api call",
24895                "Warning that value of a field has been overridden. Deprecated unused field.",
24896                "The operation involved use of an injected kernel, which is deprecated.",
24897                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
24898                "When deploying a deployment with a exceedingly large number of resources",
24899                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
24900                "A resource depends on a missing type",
24901                "The route's nextHopIp address is not assigned to an instance on the network.",
24902                "The route's next hop instance cannot ip forward.",
24903                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
24904                "The route's nextHopInstance URL refers to an instance that does not exist.",
24905                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
24906                "The route's next hop instance does not have a status of RUNNING.",
24907                "Error which is not critical. We decided to continue the process despite the mentioned error.",
24908                "No results are present on a particular list page.",
24909                "Success is reported, but some results may be missing due to errors",
24910                "The user attempted to use a resource that requires a TOS they have not accepted.",
24911                "Warning that a resource is in use.",
24912                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
24913                "When a resource schema validation is ignored.",
24914                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
24915                "When undeclared properties in the schema are present",
24916                "A given scope cannot be reached."
24917              ],
24918              "enumDeprecated": [
24919                false,
24920                false,
24921                false,
24922                false,
24923                false,
24924                false,
24925                true,
24926                false,
24927                false,
24928                false,
24929                false,
24930                false,
24931                false,
24932                false,
24933                false,
24934                false,
24935                false,
24936                false,
24937                false,
24938                false,
24939                false,
24940                false,
24941                false,
24942                false,
24943                false,
24944                false,
24945                false,
24946                false
24947              ],
24948              "enum": [
24949                "CLEANUP_FAILED",
24950                "DEPRECATED_RESOURCE_USED",
24951                "DEPRECATED_TYPE_USED",
24952                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
24953                "EXPERIMENTAL_TYPE_USED",
24954                "EXTERNAL_API_WARNING",
24955                "FIELD_VALUE_OVERRIDEN",
24956                "INJECTED_KERNELS_DEPRECATED",
24957                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
24958                "LARGE_DEPLOYMENT_WARNING",
24959                "LIST_OVERHEAD_QUOTA_EXCEED",
24960                "MISSING_TYPE_DEPENDENCY",
24961                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
24962                "NEXT_HOP_CANNOT_IP_FORWARD",
24963                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
24964                "NEXT_HOP_INSTANCE_NOT_FOUND",
24965                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
24966                "NEXT_HOP_NOT_RUNNING",
24967                "NOT_CRITICAL_ERROR",
24968                "NO_RESULTS_ON_PAGE",
24969                "PARTIAL_SUCCESS",
24970                "REQUIRED_TOS_AGREEMENT",
24971                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
24972                "RESOURCE_NOT_DELETED",
24973                "SCHEMA_VALIDATION_IGNORED",
24974                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
24975                "UNDECLARED_PROPERTIES",
24976                "UNREACHABLE"
24977              ]
24978            },
24979            "message": {
24980              "description": "[Output Only] A human-readable description of the warning code.",
24981              "type": "string"
24982            },
24983            "data": {
24984              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
24985              "type": "array",
24986              "items": {
24987                "type": "object",
24988                "properties": {
24989                  "key": {
24990                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
24991                    "type": "string"
24992                  },
24993                  "value": {
24994                    "description": "[Output Only] A warning data value corresponding to the key.",
24995                    "type": "string"
24996                  }
24997                }
24998              }
24999            }
25000          }
25001        }
25002      }
25003    },
25004    "NetworkAttachment": {
25005      "id": "NetworkAttachment",
25006      "description": "NetworkAttachments A network attachment resource ...",
25007      "type": "object",
25008      "properties": {
25009        "kind": {
25010          "description": "[Output Only] Type of the resource.",
25011          "default": "compute#networkAttachment",
25012          "type": "string"
25013        },
25014        "id": {
25015          "description": "[Output Only] The unique identifier for the resource type. The server generates this identifier.",
25016          "type": "string",
25017          "format": "uint64"
25018        },
25019        "creationTimestamp": {
25020          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
25021          "type": "string"
25022        },
25023        "name": {
25024          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
25025          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
25026          "annotations": {
25027            "required": [
25028              "compute.networkAttachments.insert"
25029            ]
25030          },
25031          "type": "string"
25032        },
25033        "description": {
25034          "description": "An optional description of this resource. Provide this property when you create the resource.",
25035          "type": "string"
25036        },
25037        "selfLink": {
25038          "description": "[Output Only] Server-defined URL for the resource.",
25039          "type": "string"
25040        },
25041        "selfLinkWithId": {
25042          "description": "[Output Only] Server-defined URL for this resource's resource id.",
25043          "type": "string"
25044        },
25045        "region": {
25046          "description": "[Output Only] URL of the region where the network attachment resides. This field applies only to the region resource. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
25047          "type": "string"
25048        },
25049        "connectionPreference": {
25050          "type": "string",
25051          "enumDescriptions": [
25052            "",
25053            "",
25054            ""
25055          ],
25056          "enum": [
25057            "ACCEPT_AUTOMATIC",
25058            "ACCEPT_MANUAL",
25059            "INVALID"
25060          ]
25061        },
25062        "connectionEndpoints": {
25063          "description": "[Output Only] An array of connections for all the producers connected to this network attachment.",
25064          "type": "array",
25065          "items": {
25066            "$ref": "NetworkAttachmentConnectedEndpoint"
25067          }
25068        },
25069        "subnetworks": {
25070          "description": "An array of URLs where each entry is the URL of a subnet provided by the service consumer to use for endpoints in the producers that connect to this network attachment.",
25071          "type": "array",
25072          "items": {
25073            "type": "string"
25074          }
25075        },
25076        "producerRejectLists": {
25077          "description": "Projects that are not allowed to connect to this network attachment. The project can be specified using its id or number.",
25078          "type": "array",
25079          "items": {
25080            "type": "string"
25081          }
25082        },
25083        "producerAcceptLists": {
25084          "description": "Projects that are allowed to connect to this network attachment. The project can be specified using its id or number.",
25085          "type": "array",
25086          "items": {
25087            "type": "string"
25088          }
25089        },
25090        "fingerprint": {
25091          "description": "Fingerprint of this resource. A hash of the contents stored in this object. This field is used in optimistic locking. An up-to-date fingerprint must be provided in order to patch.",
25092          "type": "string",
25093          "format": "byte"
25094        },
25095        "network": {
25096          "description": "[Output Only] The URL of the network which the Network Attachment belongs to. Practically it is inferred by fetching the network of the first subnetwork associated. Because it is required that all the subnetworks must be from the same network, it is assured that the Network Attachment belongs to the same network as all the subnetworks.",
25097          "type": "string"
25098        }
25099      }
25100    },
25101    "NetworkAttachmentConnectedEndpoint": {
25102      "id": "NetworkAttachmentConnectedEndpoint",
25103      "description": "[Output Only] A connection connected to this network attachment.",
25104      "type": "object",
25105      "properties": {
25106        "status": {
25107          "description": "The status of a connected endpoint to this network attachment.",
25108          "type": "string",
25109          "enumDescriptions": [
25110            "The consumer allows traffic from the producer to reach its VPC.",
25111            "The consumer network attachment no longer exists.",
25112            "The consumer needs to take further action before traffic can be served.",
25113            "The consumer neither allows nor prohibits traffic from the producer to reach its VPC.",
25114            "The consumer prohibits traffic from the producer to reach its VPC.",
25115            ""
25116          ],
25117          "enum": [
25118            "ACCEPTED",
25119            "CLOSED",
25120            "NEEDS_ATTENTION",
25121            "PENDING",
25122            "REJECTED",
25123            "STATUS_UNSPECIFIED"
25124          ]
25125        },
25126        "projectIdOrNum": {
25127          "description": "The project id or number of the interface to which the IP was assigned.",
25128          "type": "string"
25129        },
25130        "subnetwork": {
25131          "description": "The subnetwork used to assign the IP to the producer instance network interface.",
25132          "type": "string"
25133        },
25134        "ipAddress": {
25135          "description": "The IPv4 address assigned to the producer instance network interface. This value will be a range in case of Serverless.",
25136          "type": "string"
25137        },
25138        "ipv6Address": {
25139          "description": "The IPv6 address assigned to the producer instance network interface. This is only assigned when the stack types of both the instance network interface and the consumer subnet are IPv4_IPv6.",
25140          "type": "string"
25141        },
25142        "secondaryIpCidrRanges": {
25143          "description": "Alias IP ranges from the same subnetwork.",
25144          "type": "array",
25145          "items": {
25146            "type": "string"
25147          }
25148        },
25149        "subnetworkCidrRange": {
25150          "description": "[Output Only] The CIDR range of the subnet from which the IPv4 internal IP was allocated from.",
25151          "type": "string"
25152        }
25153      }
25154    },
25155    "NetworkAttachmentList": {
25156      "id": "NetworkAttachmentList",
25157      "type": "object",
25158      "properties": {
25159        "kind": {
25160          "default": "compute#networkAttachmentList",
25161          "type": "string"
25162        },
25163        "id": {
25164          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
25165          "type": "string"
25166        },
25167        "items": {
25168          "description": "A list of NetworkAttachment resources.",
25169          "type": "array",
25170          "items": {
25171            "$ref": "NetworkAttachment"
25172          }
25173        },
25174        "nextPageToken": {
25175          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
25176          "type": "string"
25177        },
25178        "selfLink": {
25179          "description": "[Output Only] Server-defined URL for this resource.",
25180          "type": "string"
25181        },
25182        "warning": {
25183          "description": "[Output Only] Informational warning message.",
25184          "type": "object",
25185          "properties": {
25186            "code": {
25187              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
25188              "type": "string",
25189              "enumDescriptions": [
25190                "Warning about failed cleanup of transient changes made by a failed operation.",
25191                "A link to a deprecated resource was created.",
25192                "When deploying and at least one of the resources has a type marked as deprecated",
25193                "The user created a boot disk that is larger than image size.",
25194                "When deploying and at least one of the resources has a type marked as experimental",
25195                "Warning that is present in an external api call",
25196                "Warning that value of a field has been overridden. Deprecated unused field.",
25197                "The operation involved use of an injected kernel, which is deprecated.",
25198                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
25199                "When deploying a deployment with a exceedingly large number of resources",
25200                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
25201                "A resource depends on a missing type",
25202                "The route's nextHopIp address is not assigned to an instance on the network.",
25203                "The route's next hop instance cannot ip forward.",
25204                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
25205                "The route's nextHopInstance URL refers to an instance that does not exist.",
25206                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
25207                "The route's next hop instance does not have a status of RUNNING.",
25208                "Error which is not critical. We decided to continue the process despite the mentioned error.",
25209                "No results are present on a particular list page.",
25210                "Success is reported, but some results may be missing due to errors",
25211                "The user attempted to use a resource that requires a TOS they have not accepted.",
25212                "Warning that a resource is in use.",
25213                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
25214                "When a resource schema validation is ignored.",
25215                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
25216                "When undeclared properties in the schema are present",
25217                "A given scope cannot be reached."
25218              ],
25219              "enumDeprecated": [
25220                false,
25221                false,
25222                false,
25223                false,
25224                false,
25225                false,
25226                true,
25227                false,
25228                false,
25229                false,
25230                false,
25231                false,
25232                false,
25233                false,
25234                false,
25235                false,
25236                false,
25237                false,
25238                false,
25239                false,
25240                false,
25241                false,
25242                false,
25243                false,
25244                false,
25245                false,
25246                false,
25247                false
25248              ],
25249              "enum": [
25250                "CLEANUP_FAILED",
25251                "DEPRECATED_RESOURCE_USED",
25252                "DEPRECATED_TYPE_USED",
25253                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
25254                "EXPERIMENTAL_TYPE_USED",
25255                "EXTERNAL_API_WARNING",
25256                "FIELD_VALUE_OVERRIDEN",
25257                "INJECTED_KERNELS_DEPRECATED",
25258                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
25259                "LARGE_DEPLOYMENT_WARNING",
25260                "LIST_OVERHEAD_QUOTA_EXCEED",
25261                "MISSING_TYPE_DEPENDENCY",
25262                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
25263                "NEXT_HOP_CANNOT_IP_FORWARD",
25264                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
25265                "NEXT_HOP_INSTANCE_NOT_FOUND",
25266                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
25267                "NEXT_HOP_NOT_RUNNING",
25268                "NOT_CRITICAL_ERROR",
25269                "NO_RESULTS_ON_PAGE",
25270                "PARTIAL_SUCCESS",
25271                "REQUIRED_TOS_AGREEMENT",
25272                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
25273                "RESOURCE_NOT_DELETED",
25274                "SCHEMA_VALIDATION_IGNORED",
25275                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
25276                "UNDECLARED_PROPERTIES",
25277                "UNREACHABLE"
25278              ]
25279            },
25280            "message": {
25281              "description": "[Output Only] A human-readable description of the warning code.",
25282              "type": "string"
25283            },
25284            "data": {
25285              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
25286              "type": "array",
25287              "items": {
25288                "type": "object",
25289                "properties": {
25290                  "key": {
25291                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
25292                    "type": "string"
25293                  },
25294                  "value": {
25295                    "description": "[Output Only] A warning data value corresponding to the key.",
25296                    "type": "string"
25297                  }
25298                }
25299              }
25300            }
25301          }
25302        }
25303      }
25304    },
25305    "NetworkEdgeSecurityService": {
25306      "id": "NetworkEdgeSecurityService",
25307      "description": "Represents a Google Cloud Armor network edge security service resource.",
25308      "type": "object",
25309      "properties": {
25310        "kind": {
25311          "description": "[Output only] Type of the resource. Always compute#networkEdgeSecurityService for NetworkEdgeSecurityServices",
25312          "default": "compute#networkEdgeSecurityService",
25313          "type": "string"
25314        },
25315        "id": {
25316          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
25317          "type": "string",
25318          "format": "uint64"
25319        },
25320        "creationTimestamp": {
25321          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
25322          "type": "string"
25323        },
25324        "name": {
25325          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
25326          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
25327          "type": "string"
25328        },
25329        "description": {
25330          "description": "An optional description of this resource. Provide this property when you create the resource.",
25331          "type": "string"
25332        },
25333        "selfLink": {
25334          "description": "[Output Only] Server-defined URL for the resource.",
25335          "type": "string"
25336        },
25337        "selfLinkWithId": {
25338          "description": "[Output Only] Server-defined URL for this resource with the resource id.",
25339          "type": "string"
25340        },
25341        "region": {
25342          "description": "[Output Only] URL of the region where the resource resides. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
25343          "type": "string"
25344        },
25345        "fingerprint": {
25346          "description": "Fingerprint of this resource. A hash of the contents stored in this object. This field is used in optimistic locking. This field will be ignored when inserting a NetworkEdgeSecurityService. An up-to-date fingerprint must be provided in order to update the NetworkEdgeSecurityService, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve a NetworkEdgeSecurityService.",
25347          "type": "string",
25348          "format": "byte"
25349        },
25350        "securityPolicy": {
25351          "description": "The resource URL for the network edge security service associated with this network edge security service.",
25352          "type": "string"
25353        }
25354      }
25355    },
25356    "NetworkEdgeSecurityServiceAggregatedList": {
25357      "id": "NetworkEdgeSecurityServiceAggregatedList",
25358      "type": "object",
25359      "properties": {
25360        "kind": {
25361          "description": "[Output Only] Type of resource. Always compute#networkEdgeSecurityServiceAggregatedList for lists of Network Edge Security Services.",
25362          "default": "compute#networkEdgeSecurityServiceAggregatedList",
25363          "type": "string"
25364        },
25365        "id": {
25366          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
25367          "type": "string"
25368        },
25369        "items": {
25370          "description": "A list of NetworkEdgeSecurityServicesScopedList resources.",
25371          "type": "object",
25372          "additionalProperties": {
25373            "description": "Name of the scope containing this set of security policies.",
25374            "$ref": "NetworkEdgeSecurityServicesScopedList"
25375          }
25376        },
25377        "nextPageToken": {
25378          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
25379          "type": "string"
25380        },
25381        "selfLink": {
25382          "description": "[Output Only] Server-defined URL for this resource.",
25383          "type": "string"
25384        },
25385        "warning": {
25386          "description": "[Output Only] Informational warning message.",
25387          "type": "object",
25388          "properties": {
25389            "code": {
25390              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
25391              "type": "string",
25392              "enumDescriptions": [
25393                "Warning about failed cleanup of transient changes made by a failed operation.",
25394                "A link to a deprecated resource was created.",
25395                "When deploying and at least one of the resources has a type marked as deprecated",
25396                "The user created a boot disk that is larger than image size.",
25397                "When deploying and at least one of the resources has a type marked as experimental",
25398                "Warning that is present in an external api call",
25399                "Warning that value of a field has been overridden. Deprecated unused field.",
25400                "The operation involved use of an injected kernel, which is deprecated.",
25401                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
25402                "When deploying a deployment with a exceedingly large number of resources",
25403                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
25404                "A resource depends on a missing type",
25405                "The route's nextHopIp address is not assigned to an instance on the network.",
25406                "The route's next hop instance cannot ip forward.",
25407                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
25408                "The route's nextHopInstance URL refers to an instance that does not exist.",
25409                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
25410                "The route's next hop instance does not have a status of RUNNING.",
25411                "Error which is not critical. We decided to continue the process despite the mentioned error.",
25412                "No results are present on a particular list page.",
25413                "Success is reported, but some results may be missing due to errors",
25414                "The user attempted to use a resource that requires a TOS they have not accepted.",
25415                "Warning that a resource is in use.",
25416                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
25417                "When a resource schema validation is ignored.",
25418                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
25419                "When undeclared properties in the schema are present",
25420                "A given scope cannot be reached."
25421              ],
25422              "enumDeprecated": [
25423                false,
25424                false,
25425                false,
25426                false,
25427                false,
25428                false,
25429                true,
25430                false,
25431                false,
25432                false,
25433                false,
25434                false,
25435                false,
25436                false,
25437                false,
25438                false,
25439                false,
25440                false,
25441                false,
25442                false,
25443                false,
25444                false,
25445                false,
25446                false,
25447                false,
25448                false,
25449                false,
25450                false
25451              ],
25452              "enum": [
25453                "CLEANUP_FAILED",
25454                "DEPRECATED_RESOURCE_USED",
25455                "DEPRECATED_TYPE_USED",
25456                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
25457                "EXPERIMENTAL_TYPE_USED",
25458                "EXTERNAL_API_WARNING",
25459                "FIELD_VALUE_OVERRIDEN",
25460                "INJECTED_KERNELS_DEPRECATED",
25461                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
25462                "LARGE_DEPLOYMENT_WARNING",
25463                "LIST_OVERHEAD_QUOTA_EXCEED",
25464                "MISSING_TYPE_DEPENDENCY",
25465                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
25466                "NEXT_HOP_CANNOT_IP_FORWARD",
25467                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
25468                "NEXT_HOP_INSTANCE_NOT_FOUND",
25469                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
25470                "NEXT_HOP_NOT_RUNNING",
25471                "NOT_CRITICAL_ERROR",
25472                "NO_RESULTS_ON_PAGE",
25473                "PARTIAL_SUCCESS",
25474                "REQUIRED_TOS_AGREEMENT",
25475                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
25476                "RESOURCE_NOT_DELETED",
25477                "SCHEMA_VALIDATION_IGNORED",
25478                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
25479                "UNDECLARED_PROPERTIES",
25480                "UNREACHABLE"
25481              ]
25482            },
25483            "message": {
25484              "description": "[Output Only] A human-readable description of the warning code.",
25485              "type": "string"
25486            },
25487            "data": {
25488              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
25489              "type": "array",
25490              "items": {
25491                "type": "object",
25492                "properties": {
25493                  "key": {
25494                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
25495                    "type": "string"
25496                  },
25497                  "value": {
25498                    "description": "[Output Only] A warning data value corresponding to the key.",
25499                    "type": "string"
25500                  }
25501                }
25502              }
25503            }
25504          }
25505        },
25506        "etag": {
25507          "type": "string"
25508        },
25509        "unreachables": {
25510          "description": "[Output Only] Unreachable resources.",
25511          "type": "array",
25512          "items": {
25513            "type": "string"
25514          }
25515        }
25516      }
25517    },
25518    "NetworkEdgeSecurityServicesScopedList": {
25519      "id": "NetworkEdgeSecurityServicesScopedList",
25520      "type": "object",
25521      "properties": {
25522        "networkEdgeSecurityServices": {
25523          "description": "A list of NetworkEdgeSecurityServices contained in this scope.",
25524          "type": "array",
25525          "items": {
25526            "$ref": "NetworkEdgeSecurityService"
25527          }
25528        },
25529        "warning": {
25530          "description": "Informational warning which replaces the list of security policies when the list is empty.",
25531          "type": "object",
25532          "properties": {
25533            "code": {
25534              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
25535              "type": "string",
25536              "enumDescriptions": [
25537                "Warning about failed cleanup of transient changes made by a failed operation.",
25538                "A link to a deprecated resource was created.",
25539                "When deploying and at least one of the resources has a type marked as deprecated",
25540                "The user created a boot disk that is larger than image size.",
25541                "When deploying and at least one of the resources has a type marked as experimental",
25542                "Warning that is present in an external api call",
25543                "Warning that value of a field has been overridden. Deprecated unused field.",
25544                "The operation involved use of an injected kernel, which is deprecated.",
25545                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
25546                "When deploying a deployment with a exceedingly large number of resources",
25547                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
25548                "A resource depends on a missing type",
25549                "The route's nextHopIp address is not assigned to an instance on the network.",
25550                "The route's next hop instance cannot ip forward.",
25551                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
25552                "The route's nextHopInstance URL refers to an instance that does not exist.",
25553                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
25554                "The route's next hop instance does not have a status of RUNNING.",
25555                "Error which is not critical. We decided to continue the process despite the mentioned error.",
25556                "No results are present on a particular list page.",
25557                "Success is reported, but some results may be missing due to errors",
25558                "The user attempted to use a resource that requires a TOS they have not accepted.",
25559                "Warning that a resource is in use.",
25560                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
25561                "When a resource schema validation is ignored.",
25562                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
25563                "When undeclared properties in the schema are present",
25564                "A given scope cannot be reached."
25565              ],
25566              "enumDeprecated": [
25567                false,
25568                false,
25569                false,
25570                false,
25571                false,
25572                false,
25573                true,
25574                false,
25575                false,
25576                false,
25577                false,
25578                false,
25579                false,
25580                false,
25581                false,
25582                false,
25583                false,
25584                false,
25585                false,
25586                false,
25587                false,
25588                false,
25589                false,
25590                false,
25591                false,
25592                false,
25593                false,
25594                false
25595              ],
25596              "enum": [
25597                "CLEANUP_FAILED",
25598                "DEPRECATED_RESOURCE_USED",
25599                "DEPRECATED_TYPE_USED",
25600                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
25601                "EXPERIMENTAL_TYPE_USED",
25602                "EXTERNAL_API_WARNING",
25603                "FIELD_VALUE_OVERRIDEN",
25604                "INJECTED_KERNELS_DEPRECATED",
25605                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
25606                "LARGE_DEPLOYMENT_WARNING",
25607                "LIST_OVERHEAD_QUOTA_EXCEED",
25608                "MISSING_TYPE_DEPENDENCY",
25609                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
25610                "NEXT_HOP_CANNOT_IP_FORWARD",
25611                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
25612                "NEXT_HOP_INSTANCE_NOT_FOUND",
25613                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
25614                "NEXT_HOP_NOT_RUNNING",
25615                "NOT_CRITICAL_ERROR",
25616                "NO_RESULTS_ON_PAGE",
25617                "PARTIAL_SUCCESS",
25618                "REQUIRED_TOS_AGREEMENT",
25619                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
25620                "RESOURCE_NOT_DELETED",
25621                "SCHEMA_VALIDATION_IGNORED",
25622                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
25623                "UNDECLARED_PROPERTIES",
25624                "UNREACHABLE"
25625              ]
25626            },
25627            "message": {
25628              "description": "[Output Only] A human-readable description of the warning code.",
25629              "type": "string"
25630            },
25631            "data": {
25632              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
25633              "type": "array",
25634              "items": {
25635                "type": "object",
25636                "properties": {
25637                  "key": {
25638                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
25639                    "type": "string"
25640                  },
25641                  "value": {
25642                    "description": "[Output Only] A warning data value corresponding to the key.",
25643                    "type": "string"
25644                  }
25645                }
25646              }
25647            }
25648          }
25649        }
25650      }
25651    },
25652    "NetworkEndpointGroupList": {
25653      "id": "NetworkEndpointGroupList",
25654      "type": "object",
25655      "properties": {
25656        "kind": {
25657          "description": "[Output Only] The resource type, which is always compute#networkEndpointGroupList for network endpoint group lists.",
25658          "default": "compute#networkEndpointGroupList",
25659          "type": "string"
25660        },
25661        "id": {
25662          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
25663          "type": "string"
25664        },
25665        "items": {
25666          "description": "A list of NetworkEndpointGroup resources.",
25667          "type": "array",
25668          "items": {
25669            "$ref": "NetworkEndpointGroup"
25670          }
25671        },
25672        "nextPageToken": {
25673          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
25674          "type": "string"
25675        },
25676        "selfLink": {
25677          "description": "[Output Only] Server-defined URL for this resource.",
25678          "type": "string"
25679        },
25680        "warning": {
25681          "description": "[Output Only] Informational warning message.",
25682          "type": "object",
25683          "properties": {
25684            "code": {
25685              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
25686              "type": "string",
25687              "enumDescriptions": [
25688                "Warning about failed cleanup of transient changes made by a failed operation.",
25689                "A link to a deprecated resource was created.",
25690                "When deploying and at least one of the resources has a type marked as deprecated",
25691                "The user created a boot disk that is larger than image size.",
25692                "When deploying and at least one of the resources has a type marked as experimental",
25693                "Warning that is present in an external api call",
25694                "Warning that value of a field has been overridden. Deprecated unused field.",
25695                "The operation involved use of an injected kernel, which is deprecated.",
25696                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
25697                "When deploying a deployment with a exceedingly large number of resources",
25698                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
25699                "A resource depends on a missing type",
25700                "The route's nextHopIp address is not assigned to an instance on the network.",
25701                "The route's next hop instance cannot ip forward.",
25702                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
25703                "The route's nextHopInstance URL refers to an instance that does not exist.",
25704                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
25705                "The route's next hop instance does not have a status of RUNNING.",
25706                "Error which is not critical. We decided to continue the process despite the mentioned error.",
25707                "No results are present on a particular list page.",
25708                "Success is reported, but some results may be missing due to errors",
25709                "The user attempted to use a resource that requires a TOS they have not accepted.",
25710                "Warning that a resource is in use.",
25711                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
25712                "When a resource schema validation is ignored.",
25713                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
25714                "When undeclared properties in the schema are present",
25715                "A given scope cannot be reached."
25716              ],
25717              "enumDeprecated": [
25718                false,
25719                false,
25720                false,
25721                false,
25722                false,
25723                false,
25724                true,
25725                false,
25726                false,
25727                false,
25728                false,
25729                false,
25730                false,
25731                false,
25732                false,
25733                false,
25734                false,
25735                false,
25736                false,
25737                false,
25738                false,
25739                false,
25740                false,
25741                false,
25742                false,
25743                false,
25744                false,
25745                false
25746              ],
25747              "enum": [
25748                "CLEANUP_FAILED",
25749                "DEPRECATED_RESOURCE_USED",
25750                "DEPRECATED_TYPE_USED",
25751                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
25752                "EXPERIMENTAL_TYPE_USED",
25753                "EXTERNAL_API_WARNING",
25754                "FIELD_VALUE_OVERRIDEN",
25755                "INJECTED_KERNELS_DEPRECATED",
25756                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
25757                "LARGE_DEPLOYMENT_WARNING",
25758                "LIST_OVERHEAD_QUOTA_EXCEED",
25759                "MISSING_TYPE_DEPENDENCY",
25760                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
25761                "NEXT_HOP_CANNOT_IP_FORWARD",
25762                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
25763                "NEXT_HOP_INSTANCE_NOT_FOUND",
25764                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
25765                "NEXT_HOP_NOT_RUNNING",
25766                "NOT_CRITICAL_ERROR",
25767                "NO_RESULTS_ON_PAGE",
25768                "PARTIAL_SUCCESS",
25769                "REQUIRED_TOS_AGREEMENT",
25770                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
25771                "RESOURCE_NOT_DELETED",
25772                "SCHEMA_VALIDATION_IGNORED",
25773                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
25774                "UNDECLARED_PROPERTIES",
25775                "UNREACHABLE"
25776              ]
25777            },
25778            "message": {
25779              "description": "[Output Only] A human-readable description of the warning code.",
25780              "type": "string"
25781            },
25782            "data": {
25783              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
25784              "type": "array",
25785              "items": {
25786                "type": "object",
25787                "properties": {
25788                  "key": {
25789                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
25790                    "type": "string"
25791                  },
25792                  "value": {
25793                    "description": "[Output Only] A warning data value corresponding to the key.",
25794                    "type": "string"
25795                  }
25796                }
25797              }
25798            }
25799          }
25800        }
25801      }
25802    },
25803    "NetworkEndpointGroup": {
25804      "id": "NetworkEndpointGroup",
25805      "description": "Represents a collection of network endpoints. A network endpoint group (NEG) defines how a set of endpoints should be reached, whether they are reachable, and where they are located. For more information about using NEGs for different use cases, see Network endpoint groups overview.",
25806      "type": "object",
25807      "properties": {
25808        "kind": {
25809          "description": "[Output Only] Type of the resource. Always compute#networkEndpointGroup for network endpoint group.",
25810          "default": "compute#networkEndpointGroup",
25811          "type": "string"
25812        },
25813        "id": {
25814          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
25815          "type": "string",
25816          "format": "uint64"
25817        },
25818        "creationTimestamp": {
25819          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
25820          "type": "string"
25821        },
25822        "selfLink": {
25823          "description": "[Output Only] Server-defined URL for the resource.",
25824          "type": "string"
25825        },
25826        "name": {
25827          "description": "Name of the resource; provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
25828          "type": "string"
25829        },
25830        "description": {
25831          "description": "An optional description of this resource. Provide this property when you create the resource.",
25832          "type": "string"
25833        },
25834        "networkEndpointType": {
25835          "description": "Type of network endpoints in this network endpoint group. Can be one of GCE_VM_IP, GCE_VM_IP_PORT, NON_GCP_PRIVATE_IP_PORT, INTERNET_FQDN_PORT, INTERNET_IP_PORT, SERVERLESS, PRIVATE_SERVICE_CONNECT.",
25836          "type": "string",
25837          "enumDescriptions": [
25838            "The network endpoint is represented by an IP address.",
25839            "The network endpoint is represented by IP address and port pair.",
25840            "The network endpoint is represented by fully qualified domain name and port.",
25841            "The network endpoint is represented by an internet IP address and port.",
25842            "The network endpoint is represented by an IP address and port. The endpoint belongs to a VM or pod running in a customer's on-premises.",
25843            "The network endpoint is either public Google APIs or services exposed by other GCP Project with a Service Attachment. The connection is set up by private service connect",
25844            "The network endpoint is handled by specified serverless infrastructure."
25845          ],
25846          "enum": [
25847            "GCE_VM_IP",
25848            "GCE_VM_IP_PORT",
25849            "INTERNET_FQDN_PORT",
25850            "INTERNET_IP_PORT",
25851            "NON_GCP_PRIVATE_IP_PORT",
25852            "PRIVATE_SERVICE_CONNECT",
25853            "SERVERLESS"
25854          ]
25855        },
25856        "size": {
25857          "description": "[Output only] Number of network endpoints in the network endpoint group.",
25858          "type": "integer",
25859          "format": "int32"
25860        },
25861        "region": {
25862          "description": "[Output Only] The URL of the region where the network endpoint group is located.",
25863          "type": "string"
25864        },
25865        "zone": {
25866          "description": "[Output Only] The URL of the zone where the network endpoint group is located.",
25867          "type": "string"
25868        },
25869        "network": {
25870          "description": "The URL of the network to which all network endpoints in the NEG belong. Uses default project network if unspecified.",
25871          "type": "string"
25872        },
25873        "subnetwork": {
25874          "description": "Optional URL of the subnetwork to which all network endpoints in the NEG belong.",
25875          "type": "string"
25876        },
25877        "defaultPort": {
25878          "description": "The default port used if the port number is not specified in the network endpoint. If the network endpoint type is either GCE_VM_IP, SERVERLESS or PRIVATE_SERVICE_CONNECT, this field must not be specified.",
25879          "type": "integer",
25880          "format": "int32"
25881        },
25882        "annotations": {
25883          "description": "Metadata defined as annotations on the network endpoint group.",
25884          "type": "object",
25885          "additionalProperties": {
25886            "type": "string"
25887          }
25888        },
25889        "cloudRun": {
25890          "description": "Only valid when networkEndpointType is SERVERLESS. Only one of cloudRun, appEngine or cloudFunction may be set.",
25891          "$ref": "NetworkEndpointGroupCloudRun"
25892        },
25893        "appEngine": {
25894          "description": "Only valid when networkEndpointType is SERVERLESS. Only one of cloudRun, appEngine or cloudFunction may be set.",
25895          "$ref": "NetworkEndpointGroupAppEngine"
25896        },
25897        "cloudFunction": {
25898          "description": "Only valid when networkEndpointType is SERVERLESS. Only one of cloudRun, appEngine or cloudFunction may be set.",
25899          "$ref": "NetworkEndpointGroupCloudFunction"
25900        },
25901        "pscTargetService": {
25902          "description": "The target service url used to set up private service connection to a Google API or a PSC Producer Service Attachment. An example value is: asia-northeast3-cloudkms.googleapis.com",
25903          "type": "string"
25904        },
25905        "pscData": {
25906          "$ref": "NetworkEndpointGroupPscData"
25907        }
25908      }
25909    },
25910    "NetworkEndpointGroupCloudRun": {
25911      "id": "NetworkEndpointGroupCloudRun",
25912      "description": "Configuration for a Cloud Run network endpoint group (NEG). The service must be provided explicitly or in the URL mask. The tag is optional, may be provided explicitly or in the URL mask. Note: Cloud Run service must be in the same project and located in the same region as the Serverless NEG.",
25913      "type": "object",
25914      "properties": {
25915        "service": {
25916          "description": "Cloud Run service is the main resource of Cloud Run. The service must be 1-63 characters long, and comply with RFC1035. Example value: \"run-service\".",
25917          "type": "string"
25918        },
25919        "tag": {
25920          "description": "Optional Cloud Run tag represents the \"named-revision\" to provide additional fine-grained traffic routing information. The tag must be 1-63 characters long, and comply with RFC1035. Example value: \"revision-0010\".",
25921          "type": "string"
25922        },
25923        "urlMask": {
25924          "description": "An URL mask is one of the main components of the Cloud Function. A template to parse \u003cservice\u003e and \u003ctag\u003e fields from a request URL. URL mask allows for routing to multiple Run services without having to create multiple network endpoint groups and backend services. For example, request URLs foo1.domain.com/bar1 and foo1.domain.com/bar2 can be backed by the same Serverless Network Endpoint Group (NEG) with URL mask \u003ctag\u003e.domain.com/\u003cservice\u003e. The URL mask will parse them to { service=\"bar1\", tag=\"foo1\" } and { service=\"bar2\", tag=\"foo2\" } respectively.",
25925          "type": "string"
25926        }
25927      }
25928    },
25929    "NetworkEndpointGroupAppEngine": {
25930      "id": "NetworkEndpointGroupAppEngine",
25931      "description": "Configuration for an App Engine network endpoint group (NEG). The service is optional, may be provided explicitly or in the URL mask. The version is optional and can only be provided explicitly or in the URL mask when service is present. Note: App Engine service must be in the same project and located in the same region as the Serverless NEG.",
25932      "type": "object",
25933      "properties": {
25934        "service": {
25935          "description": "Optional serving service. The service name is case-sensitive and must be 1-63 characters long. Example value: default, my-service.",
25936          "type": "string"
25937        },
25938        "version": {
25939          "description": "Optional serving version. The version name is case-sensitive and must be 1-100 characters long. Example value: v1, v2.",
25940          "type": "string"
25941        },
25942        "urlMask": {
25943          "description": "An URL mask is one of the main components of the Cloud Function. A template to parse service and version fields from a request URL. URL mask allows for routing to multiple App Engine services without having to create multiple Network Endpoint Groups and backend services. For example, the request URLs foo1-dot-appname.appspot.com/v1 and foo1-dot-appname.appspot.com/v2 can be backed by the same Serverless NEG with URL mask \u003cservice\u003e-dot-appname.appspot.com/\u003cversion\u003e. The URL mask will parse them to { service = \"foo1\", version = \"v1\" } and { service = \"foo1\", version = \"v2\" } respectively.",
25944          "type": "string"
25945        }
25946      }
25947    },
25948    "NetworkEndpointGroupCloudFunction": {
25949      "id": "NetworkEndpointGroupCloudFunction",
25950      "description": "Configuration for a Cloud Function network endpoint group (NEG). The function must be provided explicitly or in the URL mask. Note: Cloud Function must be in the same project and located in the same region as the Serverless NEG.",
25951      "type": "object",
25952      "properties": {
25953        "function": {
25954          "description": "A user-defined name of the Cloud Function. The function name is case-sensitive and must be 1-63 characters long. Example value: func1.",
25955          "type": "string"
25956        },
25957        "urlMask": {
25958          "description": "An URL mask is one of the main components of the Cloud Function. A template to parse function field from a request URL. URL mask allows for routing to multiple Cloud Functions without having to create multiple Network Endpoint Groups and backend services. For example, request URLs mydomain.com/function1 and mydomain.com/function2 can be backed by the same Serverless NEG with URL mask /\u003cfunction\u003e. The URL mask will parse them to { function = \"function1\" } and { function = \"function2\" } respectively.",
25959          "type": "string"
25960        }
25961      }
25962    },
25963    "NetworkEndpointGroupPscData": {
25964      "id": "NetworkEndpointGroupPscData",
25965      "description": "All data that is specifically relevant to only network endpoint groups of type PRIVATE_SERVICE_CONNECT.",
25966      "type": "object",
25967      "properties": {
25968        "consumerPscAddress": {
25969          "description": "[Output Only] Address allocated from given subnetwork for PSC. This IP address acts as a VIP for a PSC NEG, allowing it to act as an endpoint in L7 PSC-XLB.",
25970          "type": "string"
25971        },
25972        "pscConnectionId": {
25973          "description": "[Output Only] The PSC connection id of the PSC Network Endpoint Group Consumer.",
25974          "type": "string",
25975          "format": "uint64"
25976        },
25977        "pscConnectionStatus": {
25978          "description": "[Output Only] The connection status of the PSC Forwarding Rule.",
25979          "type": "string",
25980          "enumDescriptions": [
25981            "The connection has been accepted by the producer.",
25982            "The connection has been closed by the producer and will not serve traffic going forward.",
25983            "The connection has been accepted by the producer, but the producer needs to take further action before the forwarding rule can serve traffic.",
25984            "The connection is pending acceptance by the producer.",
25985            "The connection has been rejected by the producer.",
25986            ""
25987          ],
25988          "enum": [
25989            "ACCEPTED",
25990            "CLOSED",
25991            "NEEDS_ATTENTION",
25992            "PENDING",
25993            "REJECTED",
25994            "STATUS_UNSPECIFIED"
25995          ]
25996        }
25997      }
25998    },
25999    "NetworkEndpointGroupAggregatedList": {
26000      "id": "NetworkEndpointGroupAggregatedList",
26001      "type": "object",
26002      "properties": {
26003        "kind": {
26004          "description": "[Output Only] The resource type, which is always compute#networkEndpointGroupAggregatedList for aggregated lists of network endpoint groups.",
26005          "default": "compute#networkEndpointGroupAggregatedList",
26006          "type": "string"
26007        },
26008        "id": {
26009          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
26010          "type": "string"
26011        },
26012        "items": {
26013          "description": "A list of NetworkEndpointGroupsScopedList resources.",
26014          "type": "object",
26015          "additionalProperties": {
26016            "description": "The name of the scope that contains this set of network endpoint groups.",
26017            "$ref": "NetworkEndpointGroupsScopedList"
26018          }
26019        },
26020        "nextPageToken": {
26021          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
26022          "type": "string"
26023        },
26024        "selfLink": {
26025          "description": "[Output Only] Server-defined URL for this resource.",
26026          "type": "string"
26027        },
26028        "warning": {
26029          "description": "[Output Only] Informational warning message.",
26030          "type": "object",
26031          "properties": {
26032            "code": {
26033              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
26034              "type": "string",
26035              "enumDescriptions": [
26036                "Warning about failed cleanup of transient changes made by a failed operation.",
26037                "A link to a deprecated resource was created.",
26038                "When deploying and at least one of the resources has a type marked as deprecated",
26039                "The user created a boot disk that is larger than image size.",
26040                "When deploying and at least one of the resources has a type marked as experimental",
26041                "Warning that is present in an external api call",
26042                "Warning that value of a field has been overridden. Deprecated unused field.",
26043                "The operation involved use of an injected kernel, which is deprecated.",
26044                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
26045                "When deploying a deployment with a exceedingly large number of resources",
26046                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
26047                "A resource depends on a missing type",
26048                "The route's nextHopIp address is not assigned to an instance on the network.",
26049                "The route's next hop instance cannot ip forward.",
26050                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
26051                "The route's nextHopInstance URL refers to an instance that does not exist.",
26052                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
26053                "The route's next hop instance does not have a status of RUNNING.",
26054                "Error which is not critical. We decided to continue the process despite the mentioned error.",
26055                "No results are present on a particular list page.",
26056                "Success is reported, but some results may be missing due to errors",
26057                "The user attempted to use a resource that requires a TOS they have not accepted.",
26058                "Warning that a resource is in use.",
26059                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
26060                "When a resource schema validation is ignored.",
26061                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
26062                "When undeclared properties in the schema are present",
26063                "A given scope cannot be reached."
26064              ],
26065              "enumDeprecated": [
26066                false,
26067                false,
26068                false,
26069                false,
26070                false,
26071                false,
26072                true,
26073                false,
26074                false,
26075                false,
26076                false,
26077                false,
26078                false,
26079                false,
26080                false,
26081                false,
26082                false,
26083                false,
26084                false,
26085                false,
26086                false,
26087                false,
26088                false,
26089                false,
26090                false,
26091                false,
26092                false,
26093                false
26094              ],
26095              "enum": [
26096                "CLEANUP_FAILED",
26097                "DEPRECATED_RESOURCE_USED",
26098                "DEPRECATED_TYPE_USED",
26099                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
26100                "EXPERIMENTAL_TYPE_USED",
26101                "EXTERNAL_API_WARNING",
26102                "FIELD_VALUE_OVERRIDEN",
26103                "INJECTED_KERNELS_DEPRECATED",
26104                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
26105                "LARGE_DEPLOYMENT_WARNING",
26106                "LIST_OVERHEAD_QUOTA_EXCEED",
26107                "MISSING_TYPE_DEPENDENCY",
26108                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
26109                "NEXT_HOP_CANNOT_IP_FORWARD",
26110                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
26111                "NEXT_HOP_INSTANCE_NOT_FOUND",
26112                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
26113                "NEXT_HOP_NOT_RUNNING",
26114                "NOT_CRITICAL_ERROR",
26115                "NO_RESULTS_ON_PAGE",
26116                "PARTIAL_SUCCESS",
26117                "REQUIRED_TOS_AGREEMENT",
26118                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
26119                "RESOURCE_NOT_DELETED",
26120                "SCHEMA_VALIDATION_IGNORED",
26121                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
26122                "UNDECLARED_PROPERTIES",
26123                "UNREACHABLE"
26124              ]
26125            },
26126            "message": {
26127              "description": "[Output Only] A human-readable description of the warning code.",
26128              "type": "string"
26129            },
26130            "data": {
26131              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
26132              "type": "array",
26133              "items": {
26134                "type": "object",
26135                "properties": {
26136                  "key": {
26137                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
26138                    "type": "string"
26139                  },
26140                  "value": {
26141                    "description": "[Output Only] A warning data value corresponding to the key.",
26142                    "type": "string"
26143                  }
26144                }
26145              }
26146            }
26147          }
26148        },
26149        "unreachables": {
26150          "description": "[Output Only] Unreachable resources.",
26151          "type": "array",
26152          "items": {
26153            "type": "string"
26154          }
26155        }
26156      }
26157    },
26158    "NetworkEndpointGroupsScopedList": {
26159      "id": "NetworkEndpointGroupsScopedList",
26160      "type": "object",
26161      "properties": {
26162        "networkEndpointGroups": {
26163          "description": "[Output Only] The list of network endpoint groups that are contained in this scope.",
26164          "type": "array",
26165          "items": {
26166            "$ref": "NetworkEndpointGroup"
26167          }
26168        },
26169        "warning": {
26170          "description": "[Output Only] An informational warning that replaces the list of network endpoint groups when the list is empty.",
26171          "type": "object",
26172          "properties": {
26173            "code": {
26174              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
26175              "type": "string",
26176              "enumDescriptions": [
26177                "Warning about failed cleanup of transient changes made by a failed operation.",
26178                "A link to a deprecated resource was created.",
26179                "When deploying and at least one of the resources has a type marked as deprecated",
26180                "The user created a boot disk that is larger than image size.",
26181                "When deploying and at least one of the resources has a type marked as experimental",
26182                "Warning that is present in an external api call",
26183                "Warning that value of a field has been overridden. Deprecated unused field.",
26184                "The operation involved use of an injected kernel, which is deprecated.",
26185                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
26186                "When deploying a deployment with a exceedingly large number of resources",
26187                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
26188                "A resource depends on a missing type",
26189                "The route's nextHopIp address is not assigned to an instance on the network.",
26190                "The route's next hop instance cannot ip forward.",
26191                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
26192                "The route's nextHopInstance URL refers to an instance that does not exist.",
26193                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
26194                "The route's next hop instance does not have a status of RUNNING.",
26195                "Error which is not critical. We decided to continue the process despite the mentioned error.",
26196                "No results are present on a particular list page.",
26197                "Success is reported, but some results may be missing due to errors",
26198                "The user attempted to use a resource that requires a TOS they have not accepted.",
26199                "Warning that a resource is in use.",
26200                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
26201                "When a resource schema validation is ignored.",
26202                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
26203                "When undeclared properties in the schema are present",
26204                "A given scope cannot be reached."
26205              ],
26206              "enumDeprecated": [
26207                false,
26208                false,
26209                false,
26210                false,
26211                false,
26212                false,
26213                true,
26214                false,
26215                false,
26216                false,
26217                false,
26218                false,
26219                false,
26220                false,
26221                false,
26222                false,
26223                false,
26224                false,
26225                false,
26226                false,
26227                false,
26228                false,
26229                false,
26230                false,
26231                false,
26232                false,
26233                false,
26234                false
26235              ],
26236              "enum": [
26237                "CLEANUP_FAILED",
26238                "DEPRECATED_RESOURCE_USED",
26239                "DEPRECATED_TYPE_USED",
26240                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
26241                "EXPERIMENTAL_TYPE_USED",
26242                "EXTERNAL_API_WARNING",
26243                "FIELD_VALUE_OVERRIDEN",
26244                "INJECTED_KERNELS_DEPRECATED",
26245                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
26246                "LARGE_DEPLOYMENT_WARNING",
26247                "LIST_OVERHEAD_QUOTA_EXCEED",
26248                "MISSING_TYPE_DEPENDENCY",
26249                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
26250                "NEXT_HOP_CANNOT_IP_FORWARD",
26251                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
26252                "NEXT_HOP_INSTANCE_NOT_FOUND",
26253                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
26254                "NEXT_HOP_NOT_RUNNING",
26255                "NOT_CRITICAL_ERROR",
26256                "NO_RESULTS_ON_PAGE",
26257                "PARTIAL_SUCCESS",
26258                "REQUIRED_TOS_AGREEMENT",
26259                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
26260                "RESOURCE_NOT_DELETED",
26261                "SCHEMA_VALIDATION_IGNORED",
26262                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
26263                "UNDECLARED_PROPERTIES",
26264                "UNREACHABLE"
26265              ]
26266            },
26267            "message": {
26268              "description": "[Output Only] A human-readable description of the warning code.",
26269              "type": "string"
26270            },
26271            "data": {
26272              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
26273              "type": "array",
26274              "items": {
26275                "type": "object",
26276                "properties": {
26277                  "key": {
26278                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
26279                    "type": "string"
26280                  },
26281                  "value": {
26282                    "description": "[Output Only] A warning data value corresponding to the key.",
26283                    "type": "string"
26284                  }
26285                }
26286              }
26287            }
26288          }
26289        }
26290      }
26291    },
26292    "NetworkEndpointGroupsAttachEndpointsRequest": {
26293      "id": "NetworkEndpointGroupsAttachEndpointsRequest",
26294      "type": "object",
26295      "properties": {
26296        "networkEndpoints": {
26297          "description": "The list of network endpoints to be attached.",
26298          "type": "array",
26299          "items": {
26300            "$ref": "NetworkEndpoint"
26301          }
26302        }
26303      }
26304    },
26305    "NetworkEndpoint": {
26306      "id": "NetworkEndpoint",
26307      "description": "The network endpoint.",
26308      "type": "object",
26309      "properties": {
26310        "ipAddress": {
26311          "description": "Optional IPv4 address of network endpoint. The IP address must belong to a VM in Compute Engine (either the primary IP or as part of an aliased IP range). If the IP address is not specified, then the primary IP address for the VM instance in the network that the network endpoint group belongs to will be used. This field is redundant and need not be set for network endpoints of type GCE_VM_IP. If set, it must be set to the primary internal IP address of the attached VM instance that matches the subnetwork of the NEG. The primary internal IP address from any NIC of a multi-NIC VM instance can be added to a NEG as long as it matches the NEG subnetwork.",
26312          "type": "string"
26313        },
26314        "fqdn": {
26315          "description": "Optional fully qualified domain name of network endpoint. This can only be specified when NetworkEndpointGroup.network_endpoint_type is NON_GCP_FQDN_PORT.",
26316          "type": "string"
26317        },
26318        "port": {
26319          "description": "Optional port number of network endpoint. If not specified, the defaultPort for the network endpoint group will be used. This field can not be set for network endpoints of type GCE_VM_IP.",
26320          "type": "integer",
26321          "format": "int32"
26322        },
26323        "instance": {
26324          "description": "The name or a URL of VM instance of this network endpoint. This field is required for network endpoints of type GCE_VM_IP and GCE_VM_IP_PORT. The instance must be in the same zone of network endpoint group (for zonal NEGs) or in the zone within the region of the NEG (for regional NEGs). If the ipAddress is specified, it must belongs to the VM instance. The name must be 1-63 characters long, and comply with RFC1035 or be a valid URL pointing to an existing instance.",
26325          "type": "string"
26326        },
26327        "annotations": {
26328          "description": "Metadata defined as annotations on the network endpoint.",
26329          "type": "object",
26330          "additionalProperties": {
26331            "type": "string"
26332          }
26333        }
26334      }
26335    },
26336    "NetworkEndpointGroupsDetachEndpointsRequest": {
26337      "id": "NetworkEndpointGroupsDetachEndpointsRequest",
26338      "type": "object",
26339      "properties": {
26340        "networkEndpoints": {
26341          "description": "The list of network endpoints to be detached.",
26342          "type": "array",
26343          "items": {
26344            "$ref": "NetworkEndpoint"
26345          }
26346        }
26347      }
26348    },
26349    "NetworkEndpointGroupsListEndpointsRequest": {
26350      "id": "NetworkEndpointGroupsListEndpointsRequest",
26351      "type": "object",
26352      "properties": {
26353        "healthStatus": {
26354          "description": "Optional query parameter for showing the health status of each network endpoint. Valid options are SKIP or SHOW. If you don't specify this parameter, the health status of network endpoints will not be provided.",
26355          "type": "string",
26356          "enumDescriptions": [
26357            "Show the health status for each network endpoint. Impacts latency of the call.",
26358            "Health status for network endpoints will not be provided."
26359          ],
26360          "enum": [
26361            "SHOW",
26362            "SKIP"
26363          ]
26364        }
26365      }
26366    },
26367    "NetworkEndpointGroupsListNetworkEndpoints": {
26368      "id": "NetworkEndpointGroupsListNetworkEndpoints",
26369      "type": "object",
26370      "properties": {
26371        "kind": {
26372          "description": "[Output Only] The resource type, which is always compute#networkEndpointGroupsListNetworkEndpoints for the list of network endpoints in the specified network endpoint group.",
26373          "default": "compute#networkEndpointGroupsListNetworkEndpoints",
26374          "type": "string"
26375        },
26376        "id": {
26377          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
26378          "type": "string"
26379        },
26380        "items": {
26381          "description": "A list of NetworkEndpointWithHealthStatus resources.",
26382          "type": "array",
26383          "items": {
26384            "$ref": "NetworkEndpointWithHealthStatus"
26385          }
26386        },
26387        "nextPageToken": {
26388          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
26389          "type": "string"
26390        },
26391        "warning": {
26392          "description": "[Output Only] Informational warning message.",
26393          "type": "object",
26394          "properties": {
26395            "code": {
26396              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
26397              "type": "string",
26398              "enumDescriptions": [
26399                "Warning about failed cleanup of transient changes made by a failed operation.",
26400                "A link to a deprecated resource was created.",
26401                "When deploying and at least one of the resources has a type marked as deprecated",
26402                "The user created a boot disk that is larger than image size.",
26403                "When deploying and at least one of the resources has a type marked as experimental",
26404                "Warning that is present in an external api call",
26405                "Warning that value of a field has been overridden. Deprecated unused field.",
26406                "The operation involved use of an injected kernel, which is deprecated.",
26407                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
26408                "When deploying a deployment with a exceedingly large number of resources",
26409                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
26410                "A resource depends on a missing type",
26411                "The route's nextHopIp address is not assigned to an instance on the network.",
26412                "The route's next hop instance cannot ip forward.",
26413                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
26414                "The route's nextHopInstance URL refers to an instance that does not exist.",
26415                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
26416                "The route's next hop instance does not have a status of RUNNING.",
26417                "Error which is not critical. We decided to continue the process despite the mentioned error.",
26418                "No results are present on a particular list page.",
26419                "Success is reported, but some results may be missing due to errors",
26420                "The user attempted to use a resource that requires a TOS they have not accepted.",
26421                "Warning that a resource is in use.",
26422                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
26423                "When a resource schema validation is ignored.",
26424                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
26425                "When undeclared properties in the schema are present",
26426                "A given scope cannot be reached."
26427              ],
26428              "enumDeprecated": [
26429                false,
26430                false,
26431                false,
26432                false,
26433                false,
26434                false,
26435                true,
26436                false,
26437                false,
26438                false,
26439                false,
26440                false,
26441                false,
26442                false,
26443                false,
26444                false,
26445                false,
26446                false,
26447                false,
26448                false,
26449                false,
26450                false,
26451                false,
26452                false,
26453                false,
26454                false,
26455                false,
26456                false
26457              ],
26458              "enum": [
26459                "CLEANUP_FAILED",
26460                "DEPRECATED_RESOURCE_USED",
26461                "DEPRECATED_TYPE_USED",
26462                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
26463                "EXPERIMENTAL_TYPE_USED",
26464                "EXTERNAL_API_WARNING",
26465                "FIELD_VALUE_OVERRIDEN",
26466                "INJECTED_KERNELS_DEPRECATED",
26467                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
26468                "LARGE_DEPLOYMENT_WARNING",
26469                "LIST_OVERHEAD_QUOTA_EXCEED",
26470                "MISSING_TYPE_DEPENDENCY",
26471                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
26472                "NEXT_HOP_CANNOT_IP_FORWARD",
26473                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
26474                "NEXT_HOP_INSTANCE_NOT_FOUND",
26475                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
26476                "NEXT_HOP_NOT_RUNNING",
26477                "NOT_CRITICAL_ERROR",
26478                "NO_RESULTS_ON_PAGE",
26479                "PARTIAL_SUCCESS",
26480                "REQUIRED_TOS_AGREEMENT",
26481                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
26482                "RESOURCE_NOT_DELETED",
26483                "SCHEMA_VALIDATION_IGNORED",
26484                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
26485                "UNDECLARED_PROPERTIES",
26486                "UNREACHABLE"
26487              ]
26488            },
26489            "message": {
26490              "description": "[Output Only] A human-readable description of the warning code.",
26491              "type": "string"
26492            },
26493            "data": {
26494              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
26495              "type": "array",
26496              "items": {
26497                "type": "object",
26498                "properties": {
26499                  "key": {
26500                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
26501                    "type": "string"
26502                  },
26503                  "value": {
26504                    "description": "[Output Only] A warning data value corresponding to the key.",
26505                    "type": "string"
26506                  }
26507                }
26508              }
26509            }
26510          }
26511        }
26512      }
26513    },
26514    "NetworkEndpointWithHealthStatus": {
26515      "id": "NetworkEndpointWithHealthStatus",
26516      "type": "object",
26517      "properties": {
26518        "networkEndpoint": {
26519          "description": "[Output only] The network endpoint;",
26520          "$ref": "NetworkEndpoint"
26521        },
26522        "healths": {
26523          "description": "[Output only] The health status of network endpoint;",
26524          "type": "array",
26525          "items": {
26526            "$ref": "HealthStatusForNetworkEndpoint"
26527          }
26528        }
26529      }
26530    },
26531    "HealthStatusForNetworkEndpoint": {
26532      "id": "HealthStatusForNetworkEndpoint",
26533      "type": "object",
26534      "properties": {
26535        "forwardingRule": {
26536          "description": "URL of the forwarding rule associated with the health state of the network endpoint.",
26537          "$ref": "ForwardingRuleReference"
26538        },
26539        "backendService": {
26540          "description": "URL of the backend service associated with the health state of the network endpoint.",
26541          "$ref": "BackendServiceReference"
26542        },
26543        "healthCheck": {
26544          "description": "URL of the health check associated with the health state of the network endpoint.",
26545          "$ref": "HealthCheckReference"
26546        },
26547        "healthCheckService": {
26548          "description": "URL of the health check service associated with the health state of the network endpoint.",
26549          "$ref": "HealthCheckServiceReference"
26550        },
26551        "healthState": {
26552          "description": "Health state of the network endpoint determined based on the health checks configured.",
26553          "type": "string",
26554          "enumDescriptions": [
26555            "Endpoint is being drained.",
26556            "Endpoint is healthy.",
26557            "Endpoint is unhealthy.",
26558            "Health status of the endpoint is unknown."
26559          ],
26560          "enum": [
26561            "DRAINING",
26562            "HEALTHY",
26563            "UNHEALTHY",
26564            "UNKNOWN"
26565          ]
26566        }
26567      }
26568    },
26569    "ForwardingRuleReference": {
26570      "id": "ForwardingRuleReference",
26571      "type": "object",
26572      "properties": {
26573        "forwardingRule": {
26574          "type": "string"
26575        }
26576      }
26577    },
26578    "BackendServiceReference": {
26579      "id": "BackendServiceReference",
26580      "type": "object",
26581      "properties": {
26582        "backendService": {
26583          "type": "string"
26584        }
26585      }
26586    },
26587    "HealthCheckReference": {
26588      "id": "HealthCheckReference",
26589      "description": "A full or valid partial URL to a health check. For example, the following are valid URLs: - https://www.googleapis.com/compute/beta/projects/project-id/global/httpHealthChecks/health-check - projects/project-id/global/httpHealthChecks/health-check - global/httpHealthChecks/health-check ",
26590      "type": "object",
26591      "properties": {
26592        "healthCheck": {
26593          "type": "string"
26594        }
26595      }
26596    },
26597    "HealthCheckServiceReference": {
26598      "id": "HealthCheckServiceReference",
26599      "description": "A full or valid partial URL to a health check service. For example, the following are valid URLs: - https://www.googleapis.com/compute/beta/projects/project-id/regions/us-west1/healthCheckServices/health-check-service - projects/project-id/regions/us-west1/healthCheckServices/health-check-service - regions/us-west1/healthCheckServices/health-check-service ",
26600      "type": "object",
26601      "properties": {
26602        "healthCheckService": {
26603          "type": "string"
26604        }
26605      }
26606    },
26607    "GlobalNetworkEndpointGroupsAttachEndpointsRequest": {
26608      "id": "GlobalNetworkEndpointGroupsAttachEndpointsRequest",
26609      "type": "object",
26610      "properties": {
26611        "networkEndpoints": {
26612          "description": "The list of network endpoints to be attached.",
26613          "type": "array",
26614          "items": {
26615            "$ref": "NetworkEndpoint"
26616          }
26617        }
26618      }
26619    },
26620    "GlobalNetworkEndpointGroupsDetachEndpointsRequest": {
26621      "id": "GlobalNetworkEndpointGroupsDetachEndpointsRequest",
26622      "type": "object",
26623      "properties": {
26624        "networkEndpoints": {
26625          "description": "The list of network endpoints to be detached.",
26626          "type": "array",
26627          "items": {
26628            "$ref": "NetworkEndpoint"
26629          }
26630        }
26631      }
26632    },
26633    "RegionNetworkEndpointGroupsAttachEndpointsRequest": {
26634      "id": "RegionNetworkEndpointGroupsAttachEndpointsRequest",
26635      "type": "object",
26636      "properties": {
26637        "networkEndpoints": {
26638          "description": "The list of network endpoints to be attached.",
26639          "type": "array",
26640          "items": {
26641            "$ref": "NetworkEndpoint"
26642          }
26643        }
26644      }
26645    },
26646    "RegionNetworkEndpointGroupsDetachEndpointsRequest": {
26647      "id": "RegionNetworkEndpointGroupsDetachEndpointsRequest",
26648      "type": "object",
26649      "properties": {
26650        "networkEndpoints": {
26651          "description": "The list of network endpoints to be detached.",
26652          "type": "array",
26653          "items": {
26654            "$ref": "NetworkEndpoint"
26655          }
26656        }
26657      }
26658    },
26659    "NetworkList": {
26660      "id": "NetworkList",
26661      "description": "Contains a list of networks.",
26662      "type": "object",
26663      "properties": {
26664        "kind": {
26665          "description": "[Output Only] Type of resource. Always compute#networkList for lists of networks.",
26666          "default": "compute#networkList",
26667          "type": "string"
26668        },
26669        "id": {
26670          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
26671          "type": "string"
26672        },
26673        "items": {
26674          "description": "A list of Network resources.",
26675          "type": "array",
26676          "items": {
26677            "$ref": "Network"
26678          }
26679        },
26680        "nextPageToken": {
26681          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
26682          "type": "string"
26683        },
26684        "selfLink": {
26685          "description": "[Output Only] Server-defined URL for this resource.",
26686          "type": "string"
26687        },
26688        "warning": {
26689          "description": "[Output Only] Informational warning message.",
26690          "type": "object",
26691          "properties": {
26692            "code": {
26693              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
26694              "type": "string",
26695              "enumDescriptions": [
26696                "Warning about failed cleanup of transient changes made by a failed operation.",
26697                "A link to a deprecated resource was created.",
26698                "When deploying and at least one of the resources has a type marked as deprecated",
26699                "The user created a boot disk that is larger than image size.",
26700                "When deploying and at least one of the resources has a type marked as experimental",
26701                "Warning that is present in an external api call",
26702                "Warning that value of a field has been overridden. Deprecated unused field.",
26703                "The operation involved use of an injected kernel, which is deprecated.",
26704                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
26705                "When deploying a deployment with a exceedingly large number of resources",
26706                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
26707                "A resource depends on a missing type",
26708                "The route's nextHopIp address is not assigned to an instance on the network.",
26709                "The route's next hop instance cannot ip forward.",
26710                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
26711                "The route's nextHopInstance URL refers to an instance that does not exist.",
26712                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
26713                "The route's next hop instance does not have a status of RUNNING.",
26714                "Error which is not critical. We decided to continue the process despite the mentioned error.",
26715                "No results are present on a particular list page.",
26716                "Success is reported, but some results may be missing due to errors",
26717                "The user attempted to use a resource that requires a TOS they have not accepted.",
26718                "Warning that a resource is in use.",
26719                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
26720                "When a resource schema validation is ignored.",
26721                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
26722                "When undeclared properties in the schema are present",
26723                "A given scope cannot be reached."
26724              ],
26725              "enumDeprecated": [
26726                false,
26727                false,
26728                false,
26729                false,
26730                false,
26731                false,
26732                true,
26733                false,
26734                false,
26735                false,
26736                false,
26737                false,
26738                false,
26739                false,
26740                false,
26741                false,
26742                false,
26743                false,
26744                false,
26745                false,
26746                false,
26747                false,
26748                false,
26749                false,
26750                false,
26751                false,
26752                false,
26753                false
26754              ],
26755              "enum": [
26756                "CLEANUP_FAILED",
26757                "DEPRECATED_RESOURCE_USED",
26758                "DEPRECATED_TYPE_USED",
26759                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
26760                "EXPERIMENTAL_TYPE_USED",
26761                "EXTERNAL_API_WARNING",
26762                "FIELD_VALUE_OVERRIDEN",
26763                "INJECTED_KERNELS_DEPRECATED",
26764                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
26765                "LARGE_DEPLOYMENT_WARNING",
26766                "LIST_OVERHEAD_QUOTA_EXCEED",
26767                "MISSING_TYPE_DEPENDENCY",
26768                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
26769                "NEXT_HOP_CANNOT_IP_FORWARD",
26770                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
26771                "NEXT_HOP_INSTANCE_NOT_FOUND",
26772                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
26773                "NEXT_HOP_NOT_RUNNING",
26774                "NOT_CRITICAL_ERROR",
26775                "NO_RESULTS_ON_PAGE",
26776                "PARTIAL_SUCCESS",
26777                "REQUIRED_TOS_AGREEMENT",
26778                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
26779                "RESOURCE_NOT_DELETED",
26780                "SCHEMA_VALIDATION_IGNORED",
26781                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
26782                "UNDECLARED_PROPERTIES",
26783                "UNREACHABLE"
26784              ]
26785            },
26786            "message": {
26787              "description": "[Output Only] A human-readable description of the warning code.",
26788              "type": "string"
26789            },
26790            "data": {
26791              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
26792              "type": "array",
26793              "items": {
26794                "type": "object",
26795                "properties": {
26796                  "key": {
26797                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
26798                    "type": "string"
26799                  },
26800                  "value": {
26801                    "description": "[Output Only] A warning data value corresponding to the key.",
26802                    "type": "string"
26803                  }
26804                }
26805              }
26806            }
26807          }
26808        }
26809      }
26810    },
26811    "Network": {
26812      "id": "Network",
26813      "description": "Represents a VPC Network resource. Networks connect resources to each other and to the internet. For more information, read Virtual Private Cloud (VPC) Network.",
26814      "type": "object",
26815      "properties": {
26816        "kind": {
26817          "description": "[Output Only] Type of the resource. Always compute#network for networks.",
26818          "default": "compute#network",
26819          "type": "string"
26820        },
26821        "id": {
26822          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
26823          "type": "string",
26824          "format": "uint64"
26825        },
26826        "creationTimestamp": {
26827          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
26828          "type": "string"
26829        },
26830        "name": {
26831          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?`. The first character must be a lowercase letter, and all following characters (except for the last character) must be a dash, lowercase letter, or digit. The last character must be a lowercase letter or digit.",
26832          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
26833          "annotations": {
26834            "required": [
26835              "compute.networks.insert"
26836            ]
26837          },
26838          "type": "string"
26839        },
26840        "description": {
26841          "description": "An optional description of this resource. Provide this field when you create the resource.",
26842          "type": "string"
26843        },
26844        "IPv4Range": {
26845          "description": "Deprecated in favor of subnet mode networks. The range of internal addresses that are legal on this network. This range is a CIDR specification, for example: 192.168.0.0/16. Provided by the client when the network is created.",
26846          "pattern": "[0-9]{1,3}(?:\\.[0-9]{1,3}){3}/[0-9]{1,2}",
26847          "deprecated": true,
26848          "type": "string"
26849        },
26850        "gatewayIPv4": {
26851          "description": "[Output Only] The gateway address for default routing out of the network, selected by Google Cloud.",
26852          "pattern": "[0-9]{1,3}(?:\\.[0-9]{1,3}){3}",
26853          "type": "string"
26854        },
26855        "selfLink": {
26856          "description": "[Output Only] Server-defined URL for the resource.",
26857          "type": "string"
26858        },
26859        "selfLinkWithId": {
26860          "description": "[Output Only] Server-defined URL for this resource with the resource id.",
26861          "type": "string"
26862        },
26863        "autoCreateSubnetworks": {
26864          "description": "Must be set to create a VPC network. If not set, a legacy network is created. When set to true, the VPC network is created in auto mode. When set to false, the VPC network is created in custom mode. An auto mode VPC network starts with one subnet per region. Each subnet has a predetermined range as described in Auto mode VPC network IP ranges. For custom mode VPC networks, you can add subnets using the subnetworks insert method.",
26865          "type": "boolean"
26866        },
26867        "subnetworks": {
26868          "description": "[Output Only] Server-defined fully-qualified URLs for all subnetworks in this VPC network.",
26869          "type": "array",
26870          "items": {
26871            "type": "string"
26872          }
26873        },
26874        "peerings": {
26875          "description": "[Output Only] A list of network peerings for the resource.",
26876          "type": "array",
26877          "items": {
26878            "$ref": "NetworkPeering"
26879          }
26880        },
26881        "routingConfig": {
26882          "description": "The network-level routing configuration for this network. Used by Cloud Router to determine what type of network-wide routing behavior to enforce.",
26883          "$ref": "NetworkRoutingConfig"
26884        },
26885        "mtu": {
26886          "description": "Maximum Transmission Unit in bytes. The minimum value for this field is 1300 and the maximum value is 8896. The suggested value is 1500, which is the default MTU used on the Internet, or 8896 if you want to use Jumbo frames. If unspecified, the value defaults to 1460.",
26887          "type": "integer",
26888          "format": "int32"
26889        },
26890        "firewallPolicy": {
26891          "description": "[Output Only] URL of the firewall policy the network is associated with.",
26892          "type": "string"
26893        },
26894        "networkFirewallPolicyEnforcementOrder": {
26895          "description": "The network firewall policy enforcement order. Can be either AFTER_CLASSIC_FIREWALL or BEFORE_CLASSIC_FIREWALL. Defaults to AFTER_CLASSIC_FIREWALL if the field is not specified.",
26896          "type": "string",
26897          "enumDescriptions": [
26898            "",
26899            ""
26900          ],
26901          "enum": [
26902            "AFTER_CLASSIC_FIREWALL",
26903            "BEFORE_CLASSIC_FIREWALL"
26904          ]
26905        },
26906        "enableUlaInternalIpv6": {
26907          "description": "Enable ULA internal ipv6 on this network. Enabling this feature will assign a /48 from google defined ULA prefix fd20::/20. .",
26908          "type": "boolean"
26909        },
26910        "internalIpv6Range": {
26911          "description": "When enabling ula internal ipv6, caller optionally can specify the /48 range they want from the google defined ULA prefix fd20::/20. The input must be a valid /48 ULA IPv6 address and must be within the fd20::/20. Operation will fail if the speficied /48 is already in used by another resource. If the field is not speficied, then a /48 range will be randomly allocated from fd20::/20 and returned via this field. .",
26912          "type": "string"
26913        }
26914      }
26915    },
26916    "NetworkPeering": {
26917      "id": "NetworkPeering",
26918      "description": "A network peering attached to a network resource. The message includes the peering name, peer network, peering state, and a flag indicating whether Google Compute Engine should automatically create routes for the peering.",
26919      "type": "object",
26920      "properties": {
26921        "name": {
26922          "description": "Name of this peering. Provided by the client when the peering is created. The name must comply with RFC1035. Specifically, the name must be 1-63 characters long and match regular expression `[a-z]([-a-z0-9]*[a-z0-9])?`. The first character must be a lowercase letter, and all the following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
26923          "type": "string"
26924        },
26925        "network": {
26926          "description": "The URL of the peer network. It can be either full URL or partial URL. The peer network may belong to a different project. If the partial URL does not contain project, it is assumed that the peer network is in the same project as the current network.",
26927          "type": "string"
26928        },
26929        "state": {
26930          "description": "[Output Only] State for the peering, either `ACTIVE` or `INACTIVE`. The peering is `ACTIVE` when there's a matching configuration in the peer network.",
26931          "type": "string",
26932          "enumDescriptions": [
26933            "Matching configuration exists on the peer.",
26934            "There is no matching configuration on the peer, including the case when peer does not exist."
26935          ],
26936          "enum": [
26937            "ACTIVE",
26938            "INACTIVE"
26939          ]
26940        },
26941        "stateDetails": {
26942          "description": "[Output Only] Details about the current state of the peering.",
26943          "type": "string"
26944        },
26945        "autoCreateRoutes": {
26946          "description": "This field will be deprecated soon. Use the exchange_subnet_routes field instead. Indicates whether full mesh connectivity is created and managed automatically between peered networks. Currently this field should always be true since Google Compute Engine will automatically create and manage subnetwork routes between two networks when peering state is ACTIVE.",
26947          "type": "boolean"
26948        },
26949        "exportCustomRoutes": {
26950          "description": "Whether to export the custom routes to peer network. The default value is false.",
26951          "type": "boolean"
26952        },
26953        "importCustomRoutes": {
26954          "description": "Whether to import the custom routes from peer network. The default value is false.",
26955          "type": "boolean"
26956        },
26957        "exchangeSubnetRoutes": {
26958          "description": "Indicates whether full mesh connectivity is created and managed automatically between peered networks. Currently this field should always be true since Google Compute Engine will automatically create and manage subnetwork routes between two networks when peering state is ACTIVE.",
26959          "type": "boolean"
26960        },
26961        "exportSubnetRoutesWithPublicIp": {
26962          "description": "Whether subnet routes with public IP range are exported. The default value is true, all subnet routes are exported. IPv4 special-use ranges are always exported to peers and are not controlled by this field.",
26963          "type": "boolean"
26964        },
26965        "importSubnetRoutesWithPublicIp": {
26966          "description": "Whether subnet routes with public IP range are imported. The default value is false. IPv4 special-use ranges are always imported from peers and are not controlled by this field.",
26967          "type": "boolean"
26968        },
26969        "peerMtu": {
26970          "description": "Maximum Transmission Unit in bytes.",
26971          "type": "integer",
26972          "format": "int32"
26973        },
26974        "stackType": {
26975          "description": "Which IP version(s) of traffic and routes are allowed to be imported or exported between peer networks. The default value is IPV4_ONLY.",
26976          "type": "string",
26977          "enumDescriptions": [
26978            "This Peering will allow IPv4 traffic and routes to be exchanged. Additionally if the matching peering is IPV4_IPV6, IPv6 traffic and routes will be exchanged as well.",
26979            "This Peering will only allow IPv4 traffic and routes to be exchanged, even if the matching peering is IPV4_IPV6."
26980          ],
26981          "enum": [
26982            "IPV4_IPV6",
26983            "IPV4_ONLY"
26984          ]
26985        }
26986      }
26987    },
26988    "NetworkRoutingConfig": {
26989      "id": "NetworkRoutingConfig",
26990      "description": "A routing configuration attached to a network resource. The message includes the list of routers associated with the network, and a flag indicating the type of routing behavior to enforce network-wide.",
26991      "type": "object",
26992      "properties": {
26993        "routingMode": {
26994          "description": "The network-wide routing mode to use. If set to REGIONAL, this network's Cloud Routers will only advertise routes with subnets of this network in the same region as the router. If set to GLOBAL, this network's Cloud Routers will advertise routes with all subnets of this network, across regions.",
26995          "type": "string",
26996          "enumDescriptions": [
26997            "",
26998            ""
26999          ],
27000          "enum": [
27001            "GLOBAL",
27002            "REGIONAL"
27003          ]
27004        }
27005      }
27006    },
27007    "NetworksUpdatePeeringRequest": {
27008      "id": "NetworksUpdatePeeringRequest",
27009      "type": "object",
27010      "properties": {
27011        "networkPeering": {
27012          "$ref": "NetworkPeering"
27013        }
27014      }
27015    },
27016    "NetworksAddPeeringRequest": {
27017      "id": "NetworksAddPeeringRequest",
27018      "type": "object",
27019      "properties": {
27020        "name": {
27021          "description": "Name of the peering, which should conform to RFC1035.",
27022          "annotations": {
27023            "required": [
27024              "compute.networks.addPeering"
27025            ]
27026          },
27027          "type": "string"
27028        },
27029        "peerNetwork": {
27030          "description": "URL of the peer network. It can be either full URL or partial URL. The peer network may belong to a different project. If the partial URL does not contain project, it is assumed that the peer network is in the same project as the current network.",
27031          "type": "string"
27032        },
27033        "autoCreateRoutes": {
27034          "description": "This field will be deprecated soon. Use exchange_subnet_routes in network_peering instead. Indicates whether full mesh connectivity is created and managed automatically between peered networks. Currently this field should always be true since Google Compute Engine will automatically create and manage subnetwork routes between two networks when peering state is ACTIVE.",
27035          "type": "boolean"
27036        },
27037        "networkPeering": {
27038          "description": "Network peering parameters. In order to specify route policies for peering using import and export custom routes, you must specify all peering related parameters (name, peer network, exchange_subnet_routes) in the network_peering field. The corresponding fields in NetworksAddPeeringRequest will be deprecated soon.",
27039          "$ref": "NetworkPeering"
27040        }
27041      }
27042    },
27043    "NetworksRemovePeeringRequest": {
27044      "id": "NetworksRemovePeeringRequest",
27045      "type": "object",
27046      "properties": {
27047        "name": {
27048          "description": "Name of the peering, which should conform to RFC1035.",
27049          "type": "string"
27050        }
27051      }
27052    },
27053    "NetworksGetEffectiveFirewallsResponse": {
27054      "id": "NetworksGetEffectiveFirewallsResponse",
27055      "type": "object",
27056      "properties": {
27057        "firewalls": {
27058          "description": "Effective firewalls on the network.",
27059          "type": "array",
27060          "items": {
27061            "$ref": "Firewall"
27062          }
27063        },
27064        "firewallPolicys": {
27065          "description": "Effective firewalls from firewall policy.",
27066          "type": "array",
27067          "items": {
27068            "$ref": "NetworksGetEffectiveFirewallsResponseEffectiveFirewallPolicy"
27069          }
27070        }
27071      }
27072    },
27073    "NetworksGetEffectiveFirewallsResponseEffectiveFirewallPolicy": {
27074      "id": "NetworksGetEffectiveFirewallsResponseEffectiveFirewallPolicy",
27075      "type": "object",
27076      "properties": {
27077        "name": {
27078          "description": "[Output Only] The name of the firewall policy.",
27079          "type": "string"
27080        },
27081        "type": {
27082          "description": "[Output Only] The type of the firewall policy.",
27083          "type": "string",
27084          "enumDescriptions": [
27085            "",
27086            "",
27087            ""
27088          ],
27089          "enum": [
27090            "HIERARCHY",
27091            "NETWORK",
27092            "UNSPECIFIED"
27093          ]
27094        },
27095        "shortName": {
27096          "description": "[Output Only] The short name of the firewall policy.",
27097          "type": "string"
27098        },
27099        "displayName": {
27100          "description": "[Output Only] Deprecated, please use short name instead. The display name of the firewall policy.",
27101          "deprecated": true,
27102          "type": "string"
27103        },
27104        "rules": {
27105          "description": "The rules that apply to the network.",
27106          "type": "array",
27107          "items": {
27108            "$ref": "FirewallPolicyRule"
27109          }
27110        }
27111      }
27112    },
27113    "ExchangedPeeringRoutesList": {
27114      "id": "ExchangedPeeringRoutesList",
27115      "type": "object",
27116      "properties": {
27117        "kind": {
27118          "description": "[Output Only] Type of resource. Always compute#exchangedPeeringRoutesList for exchanged peering routes lists.",
27119          "default": "compute#exchangedPeeringRoutesList",
27120          "type": "string"
27121        },
27122        "id": {
27123          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
27124          "type": "string"
27125        },
27126        "items": {
27127          "description": "A list of ExchangedPeeringRoute resources.",
27128          "type": "array",
27129          "items": {
27130            "$ref": "ExchangedPeeringRoute"
27131          }
27132        },
27133        "nextPageToken": {
27134          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
27135          "type": "string"
27136        },
27137        "selfLink": {
27138          "description": "[Output Only] Server-defined URL for this resource.",
27139          "type": "string"
27140        },
27141        "warning": {
27142          "description": "[Output Only] Informational warning message.",
27143          "type": "object",
27144          "properties": {
27145            "code": {
27146              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
27147              "type": "string",
27148              "enumDescriptions": [
27149                "Warning about failed cleanup of transient changes made by a failed operation.",
27150                "A link to a deprecated resource was created.",
27151                "When deploying and at least one of the resources has a type marked as deprecated",
27152                "The user created a boot disk that is larger than image size.",
27153                "When deploying and at least one of the resources has a type marked as experimental",
27154                "Warning that is present in an external api call",
27155                "Warning that value of a field has been overridden. Deprecated unused field.",
27156                "The operation involved use of an injected kernel, which is deprecated.",
27157                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
27158                "When deploying a deployment with a exceedingly large number of resources",
27159                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
27160                "A resource depends on a missing type",
27161                "The route's nextHopIp address is not assigned to an instance on the network.",
27162                "The route's next hop instance cannot ip forward.",
27163                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
27164                "The route's nextHopInstance URL refers to an instance that does not exist.",
27165                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
27166                "The route's next hop instance does not have a status of RUNNING.",
27167                "Error which is not critical. We decided to continue the process despite the mentioned error.",
27168                "No results are present on a particular list page.",
27169                "Success is reported, but some results may be missing due to errors",
27170                "The user attempted to use a resource that requires a TOS they have not accepted.",
27171                "Warning that a resource is in use.",
27172                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
27173                "When a resource schema validation is ignored.",
27174                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
27175                "When undeclared properties in the schema are present",
27176                "A given scope cannot be reached."
27177              ],
27178              "enumDeprecated": [
27179                false,
27180                false,
27181                false,
27182                false,
27183                false,
27184                false,
27185                true,
27186                false,
27187                false,
27188                false,
27189                false,
27190                false,
27191                false,
27192                false,
27193                false,
27194                false,
27195                false,
27196                false,
27197                false,
27198                false,
27199                false,
27200                false,
27201                false,
27202                false,
27203                false,
27204                false,
27205                false,
27206                false
27207              ],
27208              "enum": [
27209                "CLEANUP_FAILED",
27210                "DEPRECATED_RESOURCE_USED",
27211                "DEPRECATED_TYPE_USED",
27212                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
27213                "EXPERIMENTAL_TYPE_USED",
27214                "EXTERNAL_API_WARNING",
27215                "FIELD_VALUE_OVERRIDEN",
27216                "INJECTED_KERNELS_DEPRECATED",
27217                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
27218                "LARGE_DEPLOYMENT_WARNING",
27219                "LIST_OVERHEAD_QUOTA_EXCEED",
27220                "MISSING_TYPE_DEPENDENCY",
27221                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
27222                "NEXT_HOP_CANNOT_IP_FORWARD",
27223                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
27224                "NEXT_HOP_INSTANCE_NOT_FOUND",
27225                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
27226                "NEXT_HOP_NOT_RUNNING",
27227                "NOT_CRITICAL_ERROR",
27228                "NO_RESULTS_ON_PAGE",
27229                "PARTIAL_SUCCESS",
27230                "REQUIRED_TOS_AGREEMENT",
27231                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
27232                "RESOURCE_NOT_DELETED",
27233                "SCHEMA_VALIDATION_IGNORED",
27234                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
27235                "UNDECLARED_PROPERTIES",
27236                "UNREACHABLE"
27237              ]
27238            },
27239            "message": {
27240              "description": "[Output Only] A human-readable description of the warning code.",
27241              "type": "string"
27242            },
27243            "data": {
27244              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
27245              "type": "array",
27246              "items": {
27247                "type": "object",
27248                "properties": {
27249                  "key": {
27250                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
27251                    "type": "string"
27252                  },
27253                  "value": {
27254                    "description": "[Output Only] A warning data value corresponding to the key.",
27255                    "type": "string"
27256                  }
27257                }
27258              }
27259            }
27260          }
27261        }
27262      }
27263    },
27264    "ExchangedPeeringRoute": {
27265      "id": "ExchangedPeeringRoute",
27266      "type": "object",
27267      "properties": {
27268        "destRange": {
27269          "description": "The destination range of the route.",
27270          "type": "string"
27271        },
27272        "type": {
27273          "description": "The type of the peering route.",
27274          "type": "string",
27275          "enumDescriptions": [
27276            "For routes exported from local network.",
27277            "The peering route.",
27278            "The peering route corresponding to subnetwork range."
27279          ],
27280          "enum": [
27281            "DYNAMIC_PEERING_ROUTE",
27282            "STATIC_PEERING_ROUTE",
27283            "SUBNET_PEERING_ROUTE"
27284          ]
27285        },
27286        "nextHopRegion": {
27287          "description": "The region of peering route next hop, only applies to dynamic routes.",
27288          "type": "string"
27289        },
27290        "priority": {
27291          "description": "The priority of the peering route.",
27292          "type": "integer",
27293          "format": "uint32"
27294        },
27295        "imported": {
27296          "description": "True if the peering route has been imported from a peer. The actual import happens if the field networkPeering.importCustomRoutes is true for this network, and networkPeering.exportCustomRoutes is true for the peer network, and the import does not result in a route conflict.",
27297          "type": "boolean"
27298        }
27299      }
27300    },
27301    "NodeGroupList": {
27302      "id": "NodeGroupList",
27303      "description": "Contains a list of nodeGroups.",
27304      "type": "object",
27305      "properties": {
27306        "kind": {
27307          "description": "[Output Only] Type of resource.Always compute#nodeGroupList for lists of node groups.",
27308          "default": "compute#nodeGroupList",
27309          "type": "string"
27310        },
27311        "id": {
27312          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
27313          "type": "string"
27314        },
27315        "items": {
27316          "description": "A list of NodeGroup resources.",
27317          "type": "array",
27318          "items": {
27319            "$ref": "NodeGroup"
27320          }
27321        },
27322        "nextPageToken": {
27323          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
27324          "type": "string"
27325        },
27326        "selfLink": {
27327          "description": "[Output Only] Server-defined URL for this resource.",
27328          "type": "string"
27329        },
27330        "warning": {
27331          "description": "[Output Only] Informational warning message.",
27332          "type": "object",
27333          "properties": {
27334            "code": {
27335              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
27336              "type": "string",
27337              "enumDescriptions": [
27338                "Warning about failed cleanup of transient changes made by a failed operation.",
27339                "A link to a deprecated resource was created.",
27340                "When deploying and at least one of the resources has a type marked as deprecated",
27341                "The user created a boot disk that is larger than image size.",
27342                "When deploying and at least one of the resources has a type marked as experimental",
27343                "Warning that is present in an external api call",
27344                "Warning that value of a field has been overridden. Deprecated unused field.",
27345                "The operation involved use of an injected kernel, which is deprecated.",
27346                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
27347                "When deploying a deployment with a exceedingly large number of resources",
27348                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
27349                "A resource depends on a missing type",
27350                "The route's nextHopIp address is not assigned to an instance on the network.",
27351                "The route's next hop instance cannot ip forward.",
27352                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
27353                "The route's nextHopInstance URL refers to an instance that does not exist.",
27354                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
27355                "The route's next hop instance does not have a status of RUNNING.",
27356                "Error which is not critical. We decided to continue the process despite the mentioned error.",
27357                "No results are present on a particular list page.",
27358                "Success is reported, but some results may be missing due to errors",
27359                "The user attempted to use a resource that requires a TOS they have not accepted.",
27360                "Warning that a resource is in use.",
27361                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
27362                "When a resource schema validation is ignored.",
27363                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
27364                "When undeclared properties in the schema are present",
27365                "A given scope cannot be reached."
27366              ],
27367              "enumDeprecated": [
27368                false,
27369                false,
27370                false,
27371                false,
27372                false,
27373                false,
27374                true,
27375                false,
27376                false,
27377                false,
27378                false,
27379                false,
27380                false,
27381                false,
27382                false,
27383                false,
27384                false,
27385                false,
27386                false,
27387                false,
27388                false,
27389                false,
27390                false,
27391                false,
27392                false,
27393                false,
27394                false,
27395                false
27396              ],
27397              "enum": [
27398                "CLEANUP_FAILED",
27399                "DEPRECATED_RESOURCE_USED",
27400                "DEPRECATED_TYPE_USED",
27401                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
27402                "EXPERIMENTAL_TYPE_USED",
27403                "EXTERNAL_API_WARNING",
27404                "FIELD_VALUE_OVERRIDEN",
27405                "INJECTED_KERNELS_DEPRECATED",
27406                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
27407                "LARGE_DEPLOYMENT_WARNING",
27408                "LIST_OVERHEAD_QUOTA_EXCEED",
27409                "MISSING_TYPE_DEPENDENCY",
27410                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
27411                "NEXT_HOP_CANNOT_IP_FORWARD",
27412                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
27413                "NEXT_HOP_INSTANCE_NOT_FOUND",
27414                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
27415                "NEXT_HOP_NOT_RUNNING",
27416                "NOT_CRITICAL_ERROR",
27417                "NO_RESULTS_ON_PAGE",
27418                "PARTIAL_SUCCESS",
27419                "REQUIRED_TOS_AGREEMENT",
27420                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
27421                "RESOURCE_NOT_DELETED",
27422                "SCHEMA_VALIDATION_IGNORED",
27423                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
27424                "UNDECLARED_PROPERTIES",
27425                "UNREACHABLE"
27426              ]
27427            },
27428            "message": {
27429              "description": "[Output Only] A human-readable description of the warning code.",
27430              "type": "string"
27431            },
27432            "data": {
27433              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
27434              "type": "array",
27435              "items": {
27436                "type": "object",
27437                "properties": {
27438                  "key": {
27439                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
27440                    "type": "string"
27441                  },
27442                  "value": {
27443                    "description": "[Output Only] A warning data value corresponding to the key.",
27444                    "type": "string"
27445                  }
27446                }
27447              }
27448            }
27449          }
27450        }
27451      }
27452    },
27453    "NodeGroup": {
27454      "id": "NodeGroup",
27455      "description": "Represents a sole-tenant Node Group resource. A sole-tenant node is a physical server that is dedicated to hosting VM instances only for your specific project. Use sole-tenant nodes to keep your instances physically separated from instances in other projects, or to group your instances together on the same host hardware. For more information, read Sole-tenant nodes.",
27456      "type": "object",
27457      "properties": {
27458        "kind": {
27459          "description": "[Output Only] The type of the resource. Always compute#nodeGroup for node group.",
27460          "default": "compute#nodeGroup",
27461          "type": "string"
27462        },
27463        "id": {
27464          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
27465          "type": "string",
27466          "format": "uint64"
27467        },
27468        "creationTimestamp": {
27469          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
27470          "type": "string"
27471        },
27472        "name": {
27473          "description": "The name of the resource, provided by the client when initially creating the resource. The resource name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
27474          "type": "string"
27475        },
27476        "description": {
27477          "description": "An optional description of this resource. Provide this property when you create the resource.",
27478          "type": "string"
27479        },
27480        "nodeTemplate": {
27481          "description": "URL of the node template to create the node group from.",
27482          "type": "string"
27483        },
27484        "zone": {
27485          "description": "[Output Only] The name of the zone where the node group resides, such as us-central1-a.",
27486          "type": "string"
27487        },
27488        "selfLink": {
27489          "description": "[Output Only] Server-defined URL for the resource.",
27490          "type": "string"
27491        },
27492        "status": {
27493          "type": "string",
27494          "enumDescriptions": [
27495            "",
27496            "",
27497            "",
27498            ""
27499          ],
27500          "enum": [
27501            "CREATING",
27502            "DELETING",
27503            "INVALID",
27504            "READY"
27505          ]
27506        },
27507        "size": {
27508          "description": "[Output Only] The total number of nodes in the node group.",
27509          "type": "integer",
27510          "format": "int32"
27511        },
27512        "autoscalingPolicy": {
27513          "description": "Specifies how autoscaling should behave.",
27514          "$ref": "NodeGroupAutoscalingPolicy"
27515        },
27516        "maintenancePolicy": {
27517          "description": "Specifies how to handle instances when a node in the group undergoes maintenance. Set to one of: DEFAULT, RESTART_IN_PLACE, or MIGRATE_WITHIN_NODE_GROUP. The default value is DEFAULT. For more information, see Maintenance policies.",
27518          "type": "string",
27519          "enumDescriptions": [
27520            "Allow the node and corresponding instances to retain default maintenance behavior.",
27521            "",
27522            "When maintenance must be done on a node, the instances on that node will be moved to other nodes in the group. Instances with onHostMaintenance = MIGRATE will live migrate to their destinations while instances with onHostMaintenance = TERMINATE will terminate and then restart on their destination nodes if automaticRestart = true.",
27523            "Instances in this group will restart on the same node when maintenance has completed. Instances must have onHostMaintenance = TERMINATE, and they will only restart if automaticRestart = true."
27524          ],
27525          "enum": [
27526            "DEFAULT",
27527            "MAINTENANCE_POLICY_UNSPECIFIED",
27528            "MIGRATE_WITHIN_NODE_GROUP",
27529            "RESTART_IN_PLACE"
27530          ]
27531        },
27532        "locationHint": {
27533          "description": "An opaque location hint used to place the Node close to other resources. This field is for use by internal tools that use the public API. The location hint here on the NodeGroup overrides any location_hint present in the NodeTemplate.",
27534          "type": "string"
27535        },
27536        "fingerprint": {
27537          "type": "string",
27538          "format": "byte"
27539        },
27540        "maintenanceWindow": {
27541          "$ref": "NodeGroupMaintenanceWindow"
27542        },
27543        "shareSettings": {
27544          "description": "Share-settings for the node group",
27545          "$ref": "ShareSettings"
27546        }
27547      }
27548    },
27549    "NodeGroupAutoscalingPolicy": {
27550      "id": "NodeGroupAutoscalingPolicy",
27551      "type": "object",
27552      "properties": {
27553        "mode": {
27554          "description": "The autoscaling mode. Set to one of: ON, OFF, or ONLY_SCALE_OUT. For more information, see Autoscaler modes.",
27555          "type": "string",
27556          "enumDescriptions": [
27557            "",
27558            "Autoscaling is disabled.",
27559            "Autocaling is fully enabled.",
27560            "Autoscaling will only scale out and will not remove nodes."
27561          ],
27562          "enum": [
27563            "MODE_UNSPECIFIED",
27564            "OFF",
27565            "ON",
27566            "ONLY_SCALE_OUT"
27567          ]
27568        },
27569        "minNodes": {
27570          "description": "The minimum number of nodes that the group should have.",
27571          "type": "integer",
27572          "format": "int32"
27573        },
27574        "maxNodes": {
27575          "description": "The maximum number of nodes that the group should have. Must be set if autoscaling is enabled. Maximum value allowed is 100.",
27576          "type": "integer",
27577          "format": "int32"
27578        }
27579      }
27580    },
27581    "NodeGroupMaintenanceWindow": {
27582      "id": "NodeGroupMaintenanceWindow",
27583      "description": "Time window specified for daily maintenance operations. GCE's internal maintenance will be performed within this window.",
27584      "type": "object",
27585      "properties": {
27586        "startTime": {
27587          "description": "Start time of the window. This must be in UTC format that resolves to one of 00:00, 04:00, 08:00, 12:00, 16:00, or 20:00. For example, both 13:00-5 and 08:00 are valid.",
27588          "type": "string"
27589        },
27590        "maintenanceDuration": {
27591          "description": "[Output only] A predetermined duration for the window, automatically chosen to be the smallest possible in the given scenario.",
27592          "$ref": "Duration"
27593        }
27594      }
27595    },
27596    "NodeGroupAggregatedList": {
27597      "id": "NodeGroupAggregatedList",
27598      "type": "object",
27599      "properties": {
27600        "kind": {
27601          "description": "[Output Only] Type of resource.Always compute#nodeGroupAggregatedList for aggregated lists of node groups.",
27602          "default": "compute#nodeGroupAggregatedList",
27603          "type": "string"
27604        },
27605        "id": {
27606          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
27607          "type": "string"
27608        },
27609        "items": {
27610          "description": "A list of NodeGroupsScopedList resources.",
27611          "type": "object",
27612          "additionalProperties": {
27613            "description": "[Output Only] Name of the scope containing this set of node groups.",
27614            "$ref": "NodeGroupsScopedList"
27615          }
27616        },
27617        "nextPageToken": {
27618          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
27619          "type": "string"
27620        },
27621        "selfLink": {
27622          "description": "[Output Only] Server-defined URL for this resource.",
27623          "type": "string"
27624        },
27625        "warning": {
27626          "description": "[Output Only] Informational warning message.",
27627          "type": "object",
27628          "properties": {
27629            "code": {
27630              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
27631              "type": "string",
27632              "enumDescriptions": [
27633                "Warning about failed cleanup of transient changes made by a failed operation.",
27634                "A link to a deprecated resource was created.",
27635                "When deploying and at least one of the resources has a type marked as deprecated",
27636                "The user created a boot disk that is larger than image size.",
27637                "When deploying and at least one of the resources has a type marked as experimental",
27638                "Warning that is present in an external api call",
27639                "Warning that value of a field has been overridden. Deprecated unused field.",
27640                "The operation involved use of an injected kernel, which is deprecated.",
27641                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
27642                "When deploying a deployment with a exceedingly large number of resources",
27643                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
27644                "A resource depends on a missing type",
27645                "The route's nextHopIp address is not assigned to an instance on the network.",
27646                "The route's next hop instance cannot ip forward.",
27647                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
27648                "The route's nextHopInstance URL refers to an instance that does not exist.",
27649                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
27650                "The route's next hop instance does not have a status of RUNNING.",
27651                "Error which is not critical. We decided to continue the process despite the mentioned error.",
27652                "No results are present on a particular list page.",
27653                "Success is reported, but some results may be missing due to errors",
27654                "The user attempted to use a resource that requires a TOS they have not accepted.",
27655                "Warning that a resource is in use.",
27656                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
27657                "When a resource schema validation is ignored.",
27658                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
27659                "When undeclared properties in the schema are present",
27660                "A given scope cannot be reached."
27661              ],
27662              "enumDeprecated": [
27663                false,
27664                false,
27665                false,
27666                false,
27667                false,
27668                false,
27669                true,
27670                false,
27671                false,
27672                false,
27673                false,
27674                false,
27675                false,
27676                false,
27677                false,
27678                false,
27679                false,
27680                false,
27681                false,
27682                false,
27683                false,
27684                false,
27685                false,
27686                false,
27687                false,
27688                false,
27689                false,
27690                false
27691              ],
27692              "enum": [
27693                "CLEANUP_FAILED",
27694                "DEPRECATED_RESOURCE_USED",
27695                "DEPRECATED_TYPE_USED",
27696                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
27697                "EXPERIMENTAL_TYPE_USED",
27698                "EXTERNAL_API_WARNING",
27699                "FIELD_VALUE_OVERRIDEN",
27700                "INJECTED_KERNELS_DEPRECATED",
27701                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
27702                "LARGE_DEPLOYMENT_WARNING",
27703                "LIST_OVERHEAD_QUOTA_EXCEED",
27704                "MISSING_TYPE_DEPENDENCY",
27705                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
27706                "NEXT_HOP_CANNOT_IP_FORWARD",
27707                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
27708                "NEXT_HOP_INSTANCE_NOT_FOUND",
27709                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
27710                "NEXT_HOP_NOT_RUNNING",
27711                "NOT_CRITICAL_ERROR",
27712                "NO_RESULTS_ON_PAGE",
27713                "PARTIAL_SUCCESS",
27714                "REQUIRED_TOS_AGREEMENT",
27715                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
27716                "RESOURCE_NOT_DELETED",
27717                "SCHEMA_VALIDATION_IGNORED",
27718                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
27719                "UNDECLARED_PROPERTIES",
27720                "UNREACHABLE"
27721              ]
27722            },
27723            "message": {
27724              "description": "[Output Only] A human-readable description of the warning code.",
27725              "type": "string"
27726            },
27727            "data": {
27728              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
27729              "type": "array",
27730              "items": {
27731                "type": "object",
27732                "properties": {
27733                  "key": {
27734                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
27735                    "type": "string"
27736                  },
27737                  "value": {
27738                    "description": "[Output Only] A warning data value corresponding to the key.",
27739                    "type": "string"
27740                  }
27741                }
27742              }
27743            }
27744          }
27745        },
27746        "unreachables": {
27747          "description": "[Output Only] Unreachable resources.",
27748          "type": "array",
27749          "items": {
27750            "type": "string"
27751          }
27752        }
27753      }
27754    },
27755    "NodeGroupsScopedList": {
27756      "id": "NodeGroupsScopedList",
27757      "type": "object",
27758      "properties": {
27759        "nodeGroups": {
27760          "description": "[Output Only] A list of node groups contained in this scope.",
27761          "type": "array",
27762          "items": {
27763            "$ref": "NodeGroup"
27764          }
27765        },
27766        "warning": {
27767          "description": "[Output Only] An informational warning that appears when the nodeGroup list is empty.",
27768          "type": "object",
27769          "properties": {
27770            "code": {
27771              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
27772              "type": "string",
27773              "enumDescriptions": [
27774                "Warning about failed cleanup of transient changes made by a failed operation.",
27775                "A link to a deprecated resource was created.",
27776                "When deploying and at least one of the resources has a type marked as deprecated",
27777                "The user created a boot disk that is larger than image size.",
27778                "When deploying and at least one of the resources has a type marked as experimental",
27779                "Warning that is present in an external api call",
27780                "Warning that value of a field has been overridden. Deprecated unused field.",
27781                "The operation involved use of an injected kernel, which is deprecated.",
27782                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
27783                "When deploying a deployment with a exceedingly large number of resources",
27784                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
27785                "A resource depends on a missing type",
27786                "The route's nextHopIp address is not assigned to an instance on the network.",
27787                "The route's next hop instance cannot ip forward.",
27788                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
27789                "The route's nextHopInstance URL refers to an instance that does not exist.",
27790                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
27791                "The route's next hop instance does not have a status of RUNNING.",
27792                "Error which is not critical. We decided to continue the process despite the mentioned error.",
27793                "No results are present on a particular list page.",
27794                "Success is reported, but some results may be missing due to errors",
27795                "The user attempted to use a resource that requires a TOS they have not accepted.",
27796                "Warning that a resource is in use.",
27797                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
27798                "When a resource schema validation is ignored.",
27799                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
27800                "When undeclared properties in the schema are present",
27801                "A given scope cannot be reached."
27802              ],
27803              "enumDeprecated": [
27804                false,
27805                false,
27806                false,
27807                false,
27808                false,
27809                false,
27810                true,
27811                false,
27812                false,
27813                false,
27814                false,
27815                false,
27816                false,
27817                false,
27818                false,
27819                false,
27820                false,
27821                false,
27822                false,
27823                false,
27824                false,
27825                false,
27826                false,
27827                false,
27828                false,
27829                false,
27830                false,
27831                false
27832              ],
27833              "enum": [
27834                "CLEANUP_FAILED",
27835                "DEPRECATED_RESOURCE_USED",
27836                "DEPRECATED_TYPE_USED",
27837                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
27838                "EXPERIMENTAL_TYPE_USED",
27839                "EXTERNAL_API_WARNING",
27840                "FIELD_VALUE_OVERRIDEN",
27841                "INJECTED_KERNELS_DEPRECATED",
27842                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
27843                "LARGE_DEPLOYMENT_WARNING",
27844                "LIST_OVERHEAD_QUOTA_EXCEED",
27845                "MISSING_TYPE_DEPENDENCY",
27846                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
27847                "NEXT_HOP_CANNOT_IP_FORWARD",
27848                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
27849                "NEXT_HOP_INSTANCE_NOT_FOUND",
27850                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
27851                "NEXT_HOP_NOT_RUNNING",
27852                "NOT_CRITICAL_ERROR",
27853                "NO_RESULTS_ON_PAGE",
27854                "PARTIAL_SUCCESS",
27855                "REQUIRED_TOS_AGREEMENT",
27856                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
27857                "RESOURCE_NOT_DELETED",
27858                "SCHEMA_VALIDATION_IGNORED",
27859                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
27860                "UNDECLARED_PROPERTIES",
27861                "UNREACHABLE"
27862              ]
27863            },
27864            "message": {
27865              "description": "[Output Only] A human-readable description of the warning code.",
27866              "type": "string"
27867            },
27868            "data": {
27869              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
27870              "type": "array",
27871              "items": {
27872                "type": "object",
27873                "properties": {
27874                  "key": {
27875                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
27876                    "type": "string"
27877                  },
27878                  "value": {
27879                    "description": "[Output Only] A warning data value corresponding to the key.",
27880                    "type": "string"
27881                  }
27882                }
27883              }
27884            }
27885          }
27886        }
27887      }
27888    },
27889    "NodeGroupsAddNodesRequest": {
27890      "id": "NodeGroupsAddNodesRequest",
27891      "type": "object",
27892      "properties": {
27893        "additionalNodeCount": {
27894          "description": "Count of additional nodes to be added to the node group.",
27895          "type": "integer",
27896          "format": "int32"
27897        }
27898      }
27899    },
27900    "NodeGroupsDeleteNodesRequest": {
27901      "id": "NodeGroupsDeleteNodesRequest",
27902      "type": "object",
27903      "properties": {
27904        "nodes": {
27905          "description": "Names of the nodes to delete.",
27906          "type": "array",
27907          "items": {
27908            "type": "string"
27909          }
27910        }
27911      }
27912    },
27913    "NodeGroupsListNodes": {
27914      "id": "NodeGroupsListNodes",
27915      "type": "object",
27916      "properties": {
27917        "kind": {
27918          "description": "[Output Only] The resource type, which is always compute.nodeGroupsListNodes for the list of nodes in the specified node group.",
27919          "default": "compute#nodeGroupsListNodes",
27920          "type": "string"
27921        },
27922        "id": {
27923          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
27924          "type": "string"
27925        },
27926        "items": {
27927          "description": "A list of Node resources.",
27928          "type": "array",
27929          "items": {
27930            "$ref": "NodeGroupNode"
27931          }
27932        },
27933        "nextPageToken": {
27934          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
27935          "type": "string"
27936        },
27937        "selfLink": {
27938          "description": "[Output Only] Server-defined URL for this resource.",
27939          "type": "string"
27940        },
27941        "warning": {
27942          "description": "[Output Only] Informational warning message.",
27943          "type": "object",
27944          "properties": {
27945            "code": {
27946              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
27947              "type": "string",
27948              "enumDescriptions": [
27949                "Warning about failed cleanup of transient changes made by a failed operation.",
27950                "A link to a deprecated resource was created.",
27951                "When deploying and at least one of the resources has a type marked as deprecated",
27952                "The user created a boot disk that is larger than image size.",
27953                "When deploying and at least one of the resources has a type marked as experimental",
27954                "Warning that is present in an external api call",
27955                "Warning that value of a field has been overridden. Deprecated unused field.",
27956                "The operation involved use of an injected kernel, which is deprecated.",
27957                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
27958                "When deploying a deployment with a exceedingly large number of resources",
27959                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
27960                "A resource depends on a missing type",
27961                "The route's nextHopIp address is not assigned to an instance on the network.",
27962                "The route's next hop instance cannot ip forward.",
27963                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
27964                "The route's nextHopInstance URL refers to an instance that does not exist.",
27965                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
27966                "The route's next hop instance does not have a status of RUNNING.",
27967                "Error which is not critical. We decided to continue the process despite the mentioned error.",
27968                "No results are present on a particular list page.",
27969                "Success is reported, but some results may be missing due to errors",
27970                "The user attempted to use a resource that requires a TOS they have not accepted.",
27971                "Warning that a resource is in use.",
27972                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
27973                "When a resource schema validation is ignored.",
27974                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
27975                "When undeclared properties in the schema are present",
27976                "A given scope cannot be reached."
27977              ],
27978              "enumDeprecated": [
27979                false,
27980                false,
27981                false,
27982                false,
27983                false,
27984                false,
27985                true,
27986                false,
27987                false,
27988                false,
27989                false,
27990                false,
27991                false,
27992                false,
27993                false,
27994                false,
27995                false,
27996                false,
27997                false,
27998                false,
27999                false,
28000                false,
28001                false,
28002                false,
28003                false,
28004                false,
28005                false,
28006                false
28007              ],
28008              "enum": [
28009                "CLEANUP_FAILED",
28010                "DEPRECATED_RESOURCE_USED",
28011                "DEPRECATED_TYPE_USED",
28012                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
28013                "EXPERIMENTAL_TYPE_USED",
28014                "EXTERNAL_API_WARNING",
28015                "FIELD_VALUE_OVERRIDEN",
28016                "INJECTED_KERNELS_DEPRECATED",
28017                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
28018                "LARGE_DEPLOYMENT_WARNING",
28019                "LIST_OVERHEAD_QUOTA_EXCEED",
28020                "MISSING_TYPE_DEPENDENCY",
28021                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
28022                "NEXT_HOP_CANNOT_IP_FORWARD",
28023                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
28024                "NEXT_HOP_INSTANCE_NOT_FOUND",
28025                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
28026                "NEXT_HOP_NOT_RUNNING",
28027                "NOT_CRITICAL_ERROR",
28028                "NO_RESULTS_ON_PAGE",
28029                "PARTIAL_SUCCESS",
28030                "REQUIRED_TOS_AGREEMENT",
28031                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
28032                "RESOURCE_NOT_DELETED",
28033                "SCHEMA_VALIDATION_IGNORED",
28034                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
28035                "UNDECLARED_PROPERTIES",
28036                "UNREACHABLE"
28037              ]
28038            },
28039            "message": {
28040              "description": "[Output Only] A human-readable description of the warning code.",
28041              "type": "string"
28042            },
28043            "data": {
28044              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
28045              "type": "array",
28046              "items": {
28047                "type": "object",
28048                "properties": {
28049                  "key": {
28050                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
28051                    "type": "string"
28052                  },
28053                  "value": {
28054                    "description": "[Output Only] A warning data value corresponding to the key.",
28055                    "type": "string"
28056                  }
28057                }
28058              }
28059            }
28060          }
28061        }
28062      }
28063    },
28064    "NodeGroupNode": {
28065      "id": "NodeGroupNode",
28066      "type": "object",
28067      "properties": {
28068        "name": {
28069          "description": "The name of the node.",
28070          "type": "string"
28071        },
28072        "status": {
28073          "type": "string",
28074          "enumDescriptions": [
28075            "",
28076            "",
28077            "",
28078            "",
28079            ""
28080          ],
28081          "enum": [
28082            "CREATING",
28083            "DELETING",
28084            "INVALID",
28085            "READY",
28086            "REPAIRING"
28087          ]
28088        },
28089        "nodeType": {
28090          "description": "The type of this node.",
28091          "type": "string"
28092        },
28093        "serverBinding": {
28094          "description": "Binding properties for the physical server.",
28095          "$ref": "ServerBinding"
28096        },
28097        "serverId": {
28098          "description": "Server ID associated with this node.",
28099          "type": "string"
28100        },
28101        "disks": {
28102          "description": "Local disk configurations.",
28103          "type": "array",
28104          "items": {
28105            "$ref": "LocalDisk"
28106          }
28107        },
28108        "accelerators": {
28109          "description": "Accelerators for this node.",
28110          "type": "array",
28111          "items": {
28112            "$ref": "AcceleratorConfig"
28113          }
28114        },
28115        "instances": {
28116          "description": "Instances scheduled on this node.",
28117          "type": "array",
28118          "items": {
28119            "type": "string"
28120          }
28121        },
28122        "instanceConsumptionData": {
28123          "description": "Instance data that shows consumed resources on the node.",
28124          "type": "array",
28125          "items": {
28126            "$ref": "InstanceConsumptionData"
28127          }
28128        },
28129        "consumedResources": {
28130          "description": "Node resources that are reserved by all instances.",
28131          "$ref": "InstanceConsumptionInfo"
28132        },
28133        "totalResources": {
28134          "description": "Total amount of available resources on the node.",
28135          "$ref": "InstanceConsumptionInfo"
28136        },
28137        "cpuOvercommitType": {
28138          "description": "CPU overcommit.",
28139          "type": "string",
28140          "enumDescriptions": [
28141            "",
28142            "",
28143            ""
28144          ],
28145          "enum": [
28146            "CPU_OVERCOMMIT_TYPE_UNSPECIFIED",
28147            "ENABLED",
28148            "NONE"
28149          ]
28150        },
28151        "satisfiesPzs": {
28152          "description": "[Output Only] Reserved for future use.",
28153          "type": "boolean"
28154        }
28155      }
28156    },
28157    "ServerBinding": {
28158      "id": "ServerBinding",
28159      "type": "object",
28160      "properties": {
28161        "type": {
28162          "type": "string",
28163          "enumDescriptions": [
28164            "Node may associate with any physical server over its lifetime.",
28165            "Node may associate with minimal physical servers over its lifetime.",
28166            ""
28167          ],
28168          "enum": [
28169            "RESTART_NODE_ON_ANY_SERVER",
28170            "RESTART_NODE_ON_MINIMAL_SERVERS",
28171            "SERVER_BINDING_TYPE_UNSPECIFIED"
28172          ]
28173        }
28174      }
28175    },
28176    "LocalDisk": {
28177      "id": "LocalDisk",
28178      "type": "object",
28179      "properties": {
28180        "diskType": {
28181          "description": "Specifies the desired disk type on the node. This disk type must be a local storage type (e.g.: local-ssd). Note that for nodeTemplates, this should be the name of the disk type and not its URL.",
28182          "type": "string"
28183        },
28184        "diskSizeGb": {
28185          "description": "Specifies the size of the disk in base-2 GB.",
28186          "type": "integer",
28187          "format": "int32"
28188        },
28189        "diskCount": {
28190          "description": "Specifies the number of such disks.",
28191          "type": "integer",
28192          "format": "int32"
28193        }
28194      }
28195    },
28196    "InstanceConsumptionData": {
28197      "id": "InstanceConsumptionData",
28198      "type": "object",
28199      "properties": {
28200        "instance": {
28201          "description": "Server-defined URL for the instance.",
28202          "type": "string"
28203        },
28204        "consumptionInfo": {
28205          "description": "Resources consumed by the instance.",
28206          "$ref": "InstanceConsumptionInfo"
28207        }
28208      }
28209    },
28210    "InstanceConsumptionInfo": {
28211      "id": "InstanceConsumptionInfo",
28212      "type": "object",
28213      "properties": {
28214        "minNodeCpus": {
28215          "description": "The minimal guaranteed number of virtual CPUs that are reserved.",
28216          "type": "integer",
28217          "format": "int32"
28218        },
28219        "guestCpus": {
28220          "description": "The number of virtual CPUs that are available to the instance.",
28221          "type": "integer",
28222          "format": "int32"
28223        },
28224        "memoryMb": {
28225          "description": "The amount of physical memory available to the instance, defined in MiB.",
28226          "type": "integer",
28227          "format": "int32"
28228        },
28229        "localSsdGb": {
28230          "description": "The amount of local SSD storage available to the instance, defined in GiB.",
28231          "type": "integer",
28232          "format": "int32"
28233        }
28234      }
28235    },
28236    "NodeGroupsSetNodeTemplateRequest": {
28237      "id": "NodeGroupsSetNodeTemplateRequest",
28238      "type": "object",
28239      "properties": {
28240        "nodeTemplate": {
28241          "description": "Full or partial URL of the node template resource to be updated for this node group.",
28242          "type": "string"
28243        }
28244      }
28245    },
28246    "NodeGroupsSimulateMaintenanceEventRequest": {
28247      "id": "NodeGroupsSimulateMaintenanceEventRequest",
28248      "type": "object",
28249      "properties": {
28250        "nodes": {
28251          "description": "Names of the nodes to go under maintenance simulation.",
28252          "type": "array",
28253          "items": {
28254            "type": "string"
28255          }
28256        }
28257      }
28258    },
28259    "NodeTemplateList": {
28260      "id": "NodeTemplateList",
28261      "description": "Contains a list of node templates.",
28262      "type": "object",
28263      "properties": {
28264        "kind": {
28265          "description": "[Output Only] Type of resource.Always compute#nodeTemplateList for lists of node templates.",
28266          "default": "compute#nodeTemplateList",
28267          "type": "string"
28268        },
28269        "id": {
28270          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
28271          "type": "string"
28272        },
28273        "items": {
28274          "description": "A list of NodeTemplate resources.",
28275          "type": "array",
28276          "items": {
28277            "$ref": "NodeTemplate"
28278          }
28279        },
28280        "nextPageToken": {
28281          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
28282          "type": "string"
28283        },
28284        "selfLink": {
28285          "description": "[Output Only] Server-defined URL for this resource.",
28286          "type": "string"
28287        },
28288        "warning": {
28289          "description": "[Output Only] Informational warning message.",
28290          "type": "object",
28291          "properties": {
28292            "code": {
28293              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
28294              "type": "string",
28295              "enumDescriptions": [
28296                "Warning about failed cleanup of transient changes made by a failed operation.",
28297                "A link to a deprecated resource was created.",
28298                "When deploying and at least one of the resources has a type marked as deprecated",
28299                "The user created a boot disk that is larger than image size.",
28300                "When deploying and at least one of the resources has a type marked as experimental",
28301                "Warning that is present in an external api call",
28302                "Warning that value of a field has been overridden. Deprecated unused field.",
28303                "The operation involved use of an injected kernel, which is deprecated.",
28304                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
28305                "When deploying a deployment with a exceedingly large number of resources",
28306                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
28307                "A resource depends on a missing type",
28308                "The route's nextHopIp address is not assigned to an instance on the network.",
28309                "The route's next hop instance cannot ip forward.",
28310                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
28311                "The route's nextHopInstance URL refers to an instance that does not exist.",
28312                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
28313                "The route's next hop instance does not have a status of RUNNING.",
28314                "Error which is not critical. We decided to continue the process despite the mentioned error.",
28315                "No results are present on a particular list page.",
28316                "Success is reported, but some results may be missing due to errors",
28317                "The user attempted to use a resource that requires a TOS they have not accepted.",
28318                "Warning that a resource is in use.",
28319                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
28320                "When a resource schema validation is ignored.",
28321                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
28322                "When undeclared properties in the schema are present",
28323                "A given scope cannot be reached."
28324              ],
28325              "enumDeprecated": [
28326                false,
28327                false,
28328                false,
28329                false,
28330                false,
28331                false,
28332                true,
28333                false,
28334                false,
28335                false,
28336                false,
28337                false,
28338                false,
28339                false,
28340                false,
28341                false,
28342                false,
28343                false,
28344                false,
28345                false,
28346                false,
28347                false,
28348                false,
28349                false,
28350                false,
28351                false,
28352                false,
28353                false
28354              ],
28355              "enum": [
28356                "CLEANUP_FAILED",
28357                "DEPRECATED_RESOURCE_USED",
28358                "DEPRECATED_TYPE_USED",
28359                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
28360                "EXPERIMENTAL_TYPE_USED",
28361                "EXTERNAL_API_WARNING",
28362                "FIELD_VALUE_OVERRIDEN",
28363                "INJECTED_KERNELS_DEPRECATED",
28364                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
28365                "LARGE_DEPLOYMENT_WARNING",
28366                "LIST_OVERHEAD_QUOTA_EXCEED",
28367                "MISSING_TYPE_DEPENDENCY",
28368                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
28369                "NEXT_HOP_CANNOT_IP_FORWARD",
28370                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
28371                "NEXT_HOP_INSTANCE_NOT_FOUND",
28372                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
28373                "NEXT_HOP_NOT_RUNNING",
28374                "NOT_CRITICAL_ERROR",
28375                "NO_RESULTS_ON_PAGE",
28376                "PARTIAL_SUCCESS",
28377                "REQUIRED_TOS_AGREEMENT",
28378                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
28379                "RESOURCE_NOT_DELETED",
28380                "SCHEMA_VALIDATION_IGNORED",
28381                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
28382                "UNDECLARED_PROPERTIES",
28383                "UNREACHABLE"
28384              ]
28385            },
28386            "message": {
28387              "description": "[Output Only] A human-readable description of the warning code.",
28388              "type": "string"
28389            },
28390            "data": {
28391              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
28392              "type": "array",
28393              "items": {
28394                "type": "object",
28395                "properties": {
28396                  "key": {
28397                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
28398                    "type": "string"
28399                  },
28400                  "value": {
28401                    "description": "[Output Only] A warning data value corresponding to the key.",
28402                    "type": "string"
28403                  }
28404                }
28405              }
28406            }
28407          }
28408        }
28409      }
28410    },
28411    "NodeTemplate": {
28412      "id": "NodeTemplate",
28413      "description": "Represent a sole-tenant Node Template resource. You can use a template to define properties for nodes in a node group. For more information, read Creating node groups and instances.",
28414      "type": "object",
28415      "properties": {
28416        "kind": {
28417          "description": "[Output Only] The type of the resource. Always compute#nodeTemplate for node templates.",
28418          "default": "compute#nodeTemplate",
28419          "type": "string"
28420        },
28421        "id": {
28422          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
28423          "type": "string",
28424          "format": "uint64"
28425        },
28426        "creationTimestamp": {
28427          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
28428          "type": "string"
28429        },
28430        "name": {
28431          "description": "The name of the resource, provided by the client when initially creating the resource. The resource name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
28432          "type": "string"
28433        },
28434        "description": {
28435          "description": "An optional description of this resource. Provide this property when you create the resource.",
28436          "type": "string"
28437        },
28438        "nodeType": {
28439          "description": "The node type to use for nodes group that are created from this template.",
28440          "type": "string"
28441        },
28442        "nodeAffinityLabels": {
28443          "description": "Labels to use for node affinity, which will be used in instance scheduling.",
28444          "type": "object",
28445          "additionalProperties": {
28446            "type": "string"
28447          }
28448        },
28449        "status": {
28450          "description": "[Output Only] The status of the node template. One of the following values: CREATING, READY, and DELETING.",
28451          "type": "string",
28452          "enumDescriptions": [
28453            "Resources are being allocated.",
28454            "The node template is currently being deleted.",
28455            "Invalid status.",
28456            "The node template is ready."
28457          ],
28458          "enum": [
28459            "CREATING",
28460            "DELETING",
28461            "INVALID",
28462            "READY"
28463          ]
28464        },
28465        "statusMessage": {
28466          "description": "[Output Only] An optional, human-readable explanation of the status.",
28467          "type": "string"
28468        },
28469        "region": {
28470          "description": "[Output Only] The name of the region where the node template resides, such as us-central1.",
28471          "type": "string"
28472        },
28473        "selfLink": {
28474          "description": "[Output Only] Server-defined URL for the resource.",
28475          "type": "string"
28476        },
28477        "nodeTypeFlexibility": {
28478          "description": "Do not use. Instead, use the node_type property.",
28479          "$ref": "NodeTemplateNodeTypeFlexibility"
28480        },
28481        "serverBinding": {
28482          "description": "Sets the binding properties for the physical server. Valid values include: - *[Default]* RESTART_NODE_ON_ANY_SERVER: Restarts VMs on any available physical server - RESTART_NODE_ON_MINIMAL_SERVER: Restarts VMs on the same physical server whenever possible See Sole-tenant node options for more information.",
28483          "$ref": "ServerBinding"
28484        },
28485        "disks": {
28486          "type": "array",
28487          "items": {
28488            "$ref": "LocalDisk"
28489          }
28490        },
28491        "accelerators": {
28492          "type": "array",
28493          "items": {
28494            "$ref": "AcceleratorConfig"
28495          }
28496        },
28497        "cpuOvercommitType": {
28498          "description": "CPU overcommit.",
28499          "type": "string",
28500          "enumDescriptions": [
28501            "",
28502            "",
28503            ""
28504          ],
28505          "enum": [
28506            "CPU_OVERCOMMIT_TYPE_UNSPECIFIED",
28507            "ENABLED",
28508            "NONE"
28509          ]
28510        }
28511      }
28512    },
28513    "NodeTemplateNodeTypeFlexibility": {
28514      "id": "NodeTemplateNodeTypeFlexibility",
28515      "type": "object",
28516      "properties": {
28517        "cpus": {
28518          "type": "string"
28519        },
28520        "memory": {
28521          "type": "string"
28522        },
28523        "localSsd": {
28524          "type": "string"
28525        }
28526      }
28527    },
28528    "NodeTemplateAggregatedList": {
28529      "id": "NodeTemplateAggregatedList",
28530      "type": "object",
28531      "properties": {
28532        "kind": {
28533          "description": "[Output Only] Type of resource.Always compute#nodeTemplateAggregatedList for aggregated lists of node templates.",
28534          "default": "compute#nodeTemplateAggregatedList",
28535          "type": "string"
28536        },
28537        "id": {
28538          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
28539          "type": "string"
28540        },
28541        "items": {
28542          "description": "A list of NodeTemplatesScopedList resources.",
28543          "type": "object",
28544          "additionalProperties": {
28545            "description": "[Output Only] Name of the scope containing this set of node templates.",
28546            "$ref": "NodeTemplatesScopedList"
28547          }
28548        },
28549        "nextPageToken": {
28550          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
28551          "type": "string"
28552        },
28553        "selfLink": {
28554          "description": "[Output Only] Server-defined URL for this resource.",
28555          "type": "string"
28556        },
28557        "warning": {
28558          "description": "[Output Only] Informational warning message.",
28559          "type": "object",
28560          "properties": {
28561            "code": {
28562              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
28563              "type": "string",
28564              "enumDescriptions": [
28565                "Warning about failed cleanup of transient changes made by a failed operation.",
28566                "A link to a deprecated resource was created.",
28567                "When deploying and at least one of the resources has a type marked as deprecated",
28568                "The user created a boot disk that is larger than image size.",
28569                "When deploying and at least one of the resources has a type marked as experimental",
28570                "Warning that is present in an external api call",
28571                "Warning that value of a field has been overridden. Deprecated unused field.",
28572                "The operation involved use of an injected kernel, which is deprecated.",
28573                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
28574                "When deploying a deployment with a exceedingly large number of resources",
28575                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
28576                "A resource depends on a missing type",
28577                "The route's nextHopIp address is not assigned to an instance on the network.",
28578                "The route's next hop instance cannot ip forward.",
28579                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
28580                "The route's nextHopInstance URL refers to an instance that does not exist.",
28581                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
28582                "The route's next hop instance does not have a status of RUNNING.",
28583                "Error which is not critical. We decided to continue the process despite the mentioned error.",
28584                "No results are present on a particular list page.",
28585                "Success is reported, but some results may be missing due to errors",
28586                "The user attempted to use a resource that requires a TOS they have not accepted.",
28587                "Warning that a resource is in use.",
28588                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
28589                "When a resource schema validation is ignored.",
28590                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
28591                "When undeclared properties in the schema are present",
28592                "A given scope cannot be reached."
28593              ],
28594              "enumDeprecated": [
28595                false,
28596                false,
28597                false,
28598                false,
28599                false,
28600                false,
28601                true,
28602                false,
28603                false,
28604                false,
28605                false,
28606                false,
28607                false,
28608                false,
28609                false,
28610                false,
28611                false,
28612                false,
28613                false,
28614                false,
28615                false,
28616                false,
28617                false,
28618                false,
28619                false,
28620                false,
28621                false,
28622                false
28623              ],
28624              "enum": [
28625                "CLEANUP_FAILED",
28626                "DEPRECATED_RESOURCE_USED",
28627                "DEPRECATED_TYPE_USED",
28628                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
28629                "EXPERIMENTAL_TYPE_USED",
28630                "EXTERNAL_API_WARNING",
28631                "FIELD_VALUE_OVERRIDEN",
28632                "INJECTED_KERNELS_DEPRECATED",
28633                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
28634                "LARGE_DEPLOYMENT_WARNING",
28635                "LIST_OVERHEAD_QUOTA_EXCEED",
28636                "MISSING_TYPE_DEPENDENCY",
28637                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
28638                "NEXT_HOP_CANNOT_IP_FORWARD",
28639                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
28640                "NEXT_HOP_INSTANCE_NOT_FOUND",
28641                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
28642                "NEXT_HOP_NOT_RUNNING",
28643                "NOT_CRITICAL_ERROR",
28644                "NO_RESULTS_ON_PAGE",
28645                "PARTIAL_SUCCESS",
28646                "REQUIRED_TOS_AGREEMENT",
28647                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
28648                "RESOURCE_NOT_DELETED",
28649                "SCHEMA_VALIDATION_IGNORED",
28650                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
28651                "UNDECLARED_PROPERTIES",
28652                "UNREACHABLE"
28653              ]
28654            },
28655            "message": {
28656              "description": "[Output Only] A human-readable description of the warning code.",
28657              "type": "string"
28658            },
28659            "data": {
28660              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
28661              "type": "array",
28662              "items": {
28663                "type": "object",
28664                "properties": {
28665                  "key": {
28666                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
28667                    "type": "string"
28668                  },
28669                  "value": {
28670                    "description": "[Output Only] A warning data value corresponding to the key.",
28671                    "type": "string"
28672                  }
28673                }
28674              }
28675            }
28676          }
28677        },
28678        "unreachables": {
28679          "description": "[Output Only] Unreachable resources.",
28680          "type": "array",
28681          "items": {
28682            "type": "string"
28683          }
28684        }
28685      }
28686    },
28687    "NodeTemplatesScopedList": {
28688      "id": "NodeTemplatesScopedList",
28689      "type": "object",
28690      "properties": {
28691        "nodeTemplates": {
28692          "description": "[Output Only] A list of node templates contained in this scope.",
28693          "type": "array",
28694          "items": {
28695            "$ref": "NodeTemplate"
28696          }
28697        },
28698        "warning": {
28699          "description": "[Output Only] An informational warning that appears when the node templates list is empty.",
28700          "type": "object",
28701          "properties": {
28702            "code": {
28703              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
28704              "type": "string",
28705              "enumDescriptions": [
28706                "Warning about failed cleanup of transient changes made by a failed operation.",
28707                "A link to a deprecated resource was created.",
28708                "When deploying and at least one of the resources has a type marked as deprecated",
28709                "The user created a boot disk that is larger than image size.",
28710                "When deploying and at least one of the resources has a type marked as experimental",
28711                "Warning that is present in an external api call",
28712                "Warning that value of a field has been overridden. Deprecated unused field.",
28713                "The operation involved use of an injected kernel, which is deprecated.",
28714                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
28715                "When deploying a deployment with a exceedingly large number of resources",
28716                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
28717                "A resource depends on a missing type",
28718                "The route's nextHopIp address is not assigned to an instance on the network.",
28719                "The route's next hop instance cannot ip forward.",
28720                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
28721                "The route's nextHopInstance URL refers to an instance that does not exist.",
28722                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
28723                "The route's next hop instance does not have a status of RUNNING.",
28724                "Error which is not critical. We decided to continue the process despite the mentioned error.",
28725                "No results are present on a particular list page.",
28726                "Success is reported, but some results may be missing due to errors",
28727                "The user attempted to use a resource that requires a TOS they have not accepted.",
28728                "Warning that a resource is in use.",
28729                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
28730                "When a resource schema validation is ignored.",
28731                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
28732                "When undeclared properties in the schema are present",
28733                "A given scope cannot be reached."
28734              ],
28735              "enumDeprecated": [
28736                false,
28737                false,
28738                false,
28739                false,
28740                false,
28741                false,
28742                true,
28743                false,
28744                false,
28745                false,
28746                false,
28747                false,
28748                false,
28749                false,
28750                false,
28751                false,
28752                false,
28753                false,
28754                false,
28755                false,
28756                false,
28757                false,
28758                false,
28759                false,
28760                false,
28761                false,
28762                false,
28763                false
28764              ],
28765              "enum": [
28766                "CLEANUP_FAILED",
28767                "DEPRECATED_RESOURCE_USED",
28768                "DEPRECATED_TYPE_USED",
28769                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
28770                "EXPERIMENTAL_TYPE_USED",
28771                "EXTERNAL_API_WARNING",
28772                "FIELD_VALUE_OVERRIDEN",
28773                "INJECTED_KERNELS_DEPRECATED",
28774                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
28775                "LARGE_DEPLOYMENT_WARNING",
28776                "LIST_OVERHEAD_QUOTA_EXCEED",
28777                "MISSING_TYPE_DEPENDENCY",
28778                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
28779                "NEXT_HOP_CANNOT_IP_FORWARD",
28780                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
28781                "NEXT_HOP_INSTANCE_NOT_FOUND",
28782                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
28783                "NEXT_HOP_NOT_RUNNING",
28784                "NOT_CRITICAL_ERROR",
28785                "NO_RESULTS_ON_PAGE",
28786                "PARTIAL_SUCCESS",
28787                "REQUIRED_TOS_AGREEMENT",
28788                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
28789                "RESOURCE_NOT_DELETED",
28790                "SCHEMA_VALIDATION_IGNORED",
28791                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
28792                "UNDECLARED_PROPERTIES",
28793                "UNREACHABLE"
28794              ]
28795            },
28796            "message": {
28797              "description": "[Output Only] A human-readable description of the warning code.",
28798              "type": "string"
28799            },
28800            "data": {
28801              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
28802              "type": "array",
28803              "items": {
28804                "type": "object",
28805                "properties": {
28806                  "key": {
28807                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
28808                    "type": "string"
28809                  },
28810                  "value": {
28811                    "description": "[Output Only] A warning data value corresponding to the key.",
28812                    "type": "string"
28813                  }
28814                }
28815              }
28816            }
28817          }
28818        }
28819      }
28820    },
28821    "NodeTypeList": {
28822      "id": "NodeTypeList",
28823      "description": "Contains a list of node types.",
28824      "type": "object",
28825      "properties": {
28826        "kind": {
28827          "description": "[Output Only] Type of resource.Always compute#nodeTypeList for lists of node types.",
28828          "default": "compute#nodeTypeList",
28829          "type": "string"
28830        },
28831        "id": {
28832          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
28833          "type": "string"
28834        },
28835        "items": {
28836          "description": "A list of NodeType resources.",
28837          "type": "array",
28838          "items": {
28839            "$ref": "NodeType"
28840          }
28841        },
28842        "nextPageToken": {
28843          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
28844          "type": "string"
28845        },
28846        "selfLink": {
28847          "description": "[Output Only] Server-defined URL for this resource.",
28848          "type": "string"
28849        },
28850        "warning": {
28851          "description": "[Output Only] Informational warning message.",
28852          "type": "object",
28853          "properties": {
28854            "code": {
28855              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
28856              "type": "string",
28857              "enumDescriptions": [
28858                "Warning about failed cleanup of transient changes made by a failed operation.",
28859                "A link to a deprecated resource was created.",
28860                "When deploying and at least one of the resources has a type marked as deprecated",
28861                "The user created a boot disk that is larger than image size.",
28862                "When deploying and at least one of the resources has a type marked as experimental",
28863                "Warning that is present in an external api call",
28864                "Warning that value of a field has been overridden. Deprecated unused field.",
28865                "The operation involved use of an injected kernel, which is deprecated.",
28866                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
28867                "When deploying a deployment with a exceedingly large number of resources",
28868                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
28869                "A resource depends on a missing type",
28870                "The route's nextHopIp address is not assigned to an instance on the network.",
28871                "The route's next hop instance cannot ip forward.",
28872                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
28873                "The route's nextHopInstance URL refers to an instance that does not exist.",
28874                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
28875                "The route's next hop instance does not have a status of RUNNING.",
28876                "Error which is not critical. We decided to continue the process despite the mentioned error.",
28877                "No results are present on a particular list page.",
28878                "Success is reported, but some results may be missing due to errors",
28879                "The user attempted to use a resource that requires a TOS they have not accepted.",
28880                "Warning that a resource is in use.",
28881                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
28882                "When a resource schema validation is ignored.",
28883                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
28884                "When undeclared properties in the schema are present",
28885                "A given scope cannot be reached."
28886              ],
28887              "enumDeprecated": [
28888                false,
28889                false,
28890                false,
28891                false,
28892                false,
28893                false,
28894                true,
28895                false,
28896                false,
28897                false,
28898                false,
28899                false,
28900                false,
28901                false,
28902                false,
28903                false,
28904                false,
28905                false,
28906                false,
28907                false,
28908                false,
28909                false,
28910                false,
28911                false,
28912                false,
28913                false,
28914                false,
28915                false
28916              ],
28917              "enum": [
28918                "CLEANUP_FAILED",
28919                "DEPRECATED_RESOURCE_USED",
28920                "DEPRECATED_TYPE_USED",
28921                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
28922                "EXPERIMENTAL_TYPE_USED",
28923                "EXTERNAL_API_WARNING",
28924                "FIELD_VALUE_OVERRIDEN",
28925                "INJECTED_KERNELS_DEPRECATED",
28926                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
28927                "LARGE_DEPLOYMENT_WARNING",
28928                "LIST_OVERHEAD_QUOTA_EXCEED",
28929                "MISSING_TYPE_DEPENDENCY",
28930                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
28931                "NEXT_HOP_CANNOT_IP_FORWARD",
28932                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
28933                "NEXT_HOP_INSTANCE_NOT_FOUND",
28934                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
28935                "NEXT_HOP_NOT_RUNNING",
28936                "NOT_CRITICAL_ERROR",
28937                "NO_RESULTS_ON_PAGE",
28938                "PARTIAL_SUCCESS",
28939                "REQUIRED_TOS_AGREEMENT",
28940                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
28941                "RESOURCE_NOT_DELETED",
28942                "SCHEMA_VALIDATION_IGNORED",
28943                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
28944                "UNDECLARED_PROPERTIES",
28945                "UNREACHABLE"
28946              ]
28947            },
28948            "message": {
28949              "description": "[Output Only] A human-readable description of the warning code.",
28950              "type": "string"
28951            },
28952            "data": {
28953              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
28954              "type": "array",
28955              "items": {
28956                "type": "object",
28957                "properties": {
28958                  "key": {
28959                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
28960                    "type": "string"
28961                  },
28962                  "value": {
28963                    "description": "[Output Only] A warning data value corresponding to the key.",
28964                    "type": "string"
28965                  }
28966                }
28967              }
28968            }
28969          }
28970        }
28971      }
28972    },
28973    "NodeType": {
28974      "id": "NodeType",
28975      "description": "Represent a sole-tenant Node Type resource. Each node within a node group must have a node type. A node type specifies the total amount of cores and memory for that node. Currently, the only available node type is n1-node-96-624 node type that has 96 vCPUs and 624 GB of memory, available in multiple zones. For more information read Node types.",
28976      "type": "object",
28977      "properties": {
28978        "kind": {
28979          "description": "[Output Only] The type of the resource. Always compute#nodeType for node types.",
28980          "default": "compute#nodeType",
28981          "type": "string"
28982        },
28983        "id": {
28984          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
28985          "type": "string",
28986          "format": "uint64"
28987        },
28988        "creationTimestamp": {
28989          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
28990          "type": "string"
28991        },
28992        "name": {
28993          "description": "[Output Only] Name of the resource.",
28994          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
28995          "type": "string"
28996        },
28997        "description": {
28998          "description": "[Output Only] An optional textual description of the resource.",
28999          "type": "string"
29000        },
29001        "cpuPlatform": {
29002          "description": "[Output Only] The CPU platform used by this node type.",
29003          "type": "string"
29004        },
29005        "guestCpus": {
29006          "description": "[Output Only] The number of virtual CPUs that are available to the node type.",
29007          "type": "integer",
29008          "format": "int32"
29009        },
29010        "memoryMb": {
29011          "description": "[Output Only] The amount of physical memory available to the node type, defined in MB.",
29012          "type": "integer",
29013          "format": "int32"
29014        },
29015        "localSsdGb": {
29016          "description": "[Output Only] Local SSD available to the node type, defined in GB.",
29017          "type": "integer",
29018          "format": "int32"
29019        },
29020        "deprecated": {
29021          "description": "[Output Only] The deprecation status associated with this node type.",
29022          "$ref": "DeprecationStatus"
29023        },
29024        "zone": {
29025          "description": "[Output Only] The name of the zone where the node type resides, such as us-central1-a.",
29026          "type": "string"
29027        },
29028        "selfLink": {
29029          "description": "[Output Only] Server-defined URL for the resource.",
29030          "type": "string"
29031        }
29032      }
29033    },
29034    "NodeTypeAggregatedList": {
29035      "id": "NodeTypeAggregatedList",
29036      "type": "object",
29037      "properties": {
29038        "kind": {
29039          "description": "[Output Only] Type of resource.Always compute#nodeTypeAggregatedList for aggregated lists of node types.",
29040          "default": "compute#nodeTypeAggregatedList",
29041          "type": "string"
29042        },
29043        "id": {
29044          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
29045          "type": "string"
29046        },
29047        "items": {
29048          "description": "A list of NodeTypesScopedList resources.",
29049          "type": "object",
29050          "additionalProperties": {
29051            "description": "[Output Only] Name of the scope containing this set of node types.",
29052            "$ref": "NodeTypesScopedList"
29053          }
29054        },
29055        "nextPageToken": {
29056          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
29057          "type": "string"
29058        },
29059        "selfLink": {
29060          "description": "[Output Only] Server-defined URL for this resource.",
29061          "type": "string"
29062        },
29063        "warning": {
29064          "description": "[Output Only] Informational warning message.",
29065          "type": "object",
29066          "properties": {
29067            "code": {
29068              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
29069              "type": "string",
29070              "enumDescriptions": [
29071                "Warning about failed cleanup of transient changes made by a failed operation.",
29072                "A link to a deprecated resource was created.",
29073                "When deploying and at least one of the resources has a type marked as deprecated",
29074                "The user created a boot disk that is larger than image size.",
29075                "When deploying and at least one of the resources has a type marked as experimental",
29076                "Warning that is present in an external api call",
29077                "Warning that value of a field has been overridden. Deprecated unused field.",
29078                "The operation involved use of an injected kernel, which is deprecated.",
29079                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
29080                "When deploying a deployment with a exceedingly large number of resources",
29081                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
29082                "A resource depends on a missing type",
29083                "The route's nextHopIp address is not assigned to an instance on the network.",
29084                "The route's next hop instance cannot ip forward.",
29085                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
29086                "The route's nextHopInstance URL refers to an instance that does not exist.",
29087                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
29088                "The route's next hop instance does not have a status of RUNNING.",
29089                "Error which is not critical. We decided to continue the process despite the mentioned error.",
29090                "No results are present on a particular list page.",
29091                "Success is reported, but some results may be missing due to errors",
29092                "The user attempted to use a resource that requires a TOS they have not accepted.",
29093                "Warning that a resource is in use.",
29094                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
29095                "When a resource schema validation is ignored.",
29096                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
29097                "When undeclared properties in the schema are present",
29098                "A given scope cannot be reached."
29099              ],
29100              "enumDeprecated": [
29101                false,
29102                false,
29103                false,
29104                false,
29105                false,
29106                false,
29107                true,
29108                false,
29109                false,
29110                false,
29111                false,
29112                false,
29113                false,
29114                false,
29115                false,
29116                false,
29117                false,
29118                false,
29119                false,
29120                false,
29121                false,
29122                false,
29123                false,
29124                false,
29125                false,
29126                false,
29127                false,
29128                false
29129              ],
29130              "enum": [
29131                "CLEANUP_FAILED",
29132                "DEPRECATED_RESOURCE_USED",
29133                "DEPRECATED_TYPE_USED",
29134                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
29135                "EXPERIMENTAL_TYPE_USED",
29136                "EXTERNAL_API_WARNING",
29137                "FIELD_VALUE_OVERRIDEN",
29138                "INJECTED_KERNELS_DEPRECATED",
29139                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
29140                "LARGE_DEPLOYMENT_WARNING",
29141                "LIST_OVERHEAD_QUOTA_EXCEED",
29142                "MISSING_TYPE_DEPENDENCY",
29143                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
29144                "NEXT_HOP_CANNOT_IP_FORWARD",
29145                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
29146                "NEXT_HOP_INSTANCE_NOT_FOUND",
29147                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
29148                "NEXT_HOP_NOT_RUNNING",
29149                "NOT_CRITICAL_ERROR",
29150                "NO_RESULTS_ON_PAGE",
29151                "PARTIAL_SUCCESS",
29152                "REQUIRED_TOS_AGREEMENT",
29153                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
29154                "RESOURCE_NOT_DELETED",
29155                "SCHEMA_VALIDATION_IGNORED",
29156                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
29157                "UNDECLARED_PROPERTIES",
29158                "UNREACHABLE"
29159              ]
29160            },
29161            "message": {
29162              "description": "[Output Only] A human-readable description of the warning code.",
29163              "type": "string"
29164            },
29165            "data": {
29166              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
29167              "type": "array",
29168              "items": {
29169                "type": "object",
29170                "properties": {
29171                  "key": {
29172                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
29173                    "type": "string"
29174                  },
29175                  "value": {
29176                    "description": "[Output Only] A warning data value corresponding to the key.",
29177                    "type": "string"
29178                  }
29179                }
29180              }
29181            }
29182          }
29183        },
29184        "unreachables": {
29185          "description": "[Output Only] Unreachable resources.",
29186          "type": "array",
29187          "items": {
29188            "type": "string"
29189          }
29190        }
29191      }
29192    },
29193    "NodeTypesScopedList": {
29194      "id": "NodeTypesScopedList",
29195      "type": "object",
29196      "properties": {
29197        "nodeTypes": {
29198          "description": "[Output Only] A list of node types contained in this scope.",
29199          "type": "array",
29200          "items": {
29201            "$ref": "NodeType"
29202          }
29203        },
29204        "warning": {
29205          "description": "[Output Only] An informational warning that appears when the node types list is empty.",
29206          "type": "object",
29207          "properties": {
29208            "code": {
29209              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
29210              "type": "string",
29211              "enumDescriptions": [
29212                "Warning about failed cleanup of transient changes made by a failed operation.",
29213                "A link to a deprecated resource was created.",
29214                "When deploying and at least one of the resources has a type marked as deprecated",
29215                "The user created a boot disk that is larger than image size.",
29216                "When deploying and at least one of the resources has a type marked as experimental",
29217                "Warning that is present in an external api call",
29218                "Warning that value of a field has been overridden. Deprecated unused field.",
29219                "The operation involved use of an injected kernel, which is deprecated.",
29220                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
29221                "When deploying a deployment with a exceedingly large number of resources",
29222                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
29223                "A resource depends on a missing type",
29224                "The route's nextHopIp address is not assigned to an instance on the network.",
29225                "The route's next hop instance cannot ip forward.",
29226                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
29227                "The route's nextHopInstance URL refers to an instance that does not exist.",
29228                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
29229                "The route's next hop instance does not have a status of RUNNING.",
29230                "Error which is not critical. We decided to continue the process despite the mentioned error.",
29231                "No results are present on a particular list page.",
29232                "Success is reported, but some results may be missing due to errors",
29233                "The user attempted to use a resource that requires a TOS they have not accepted.",
29234                "Warning that a resource is in use.",
29235                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
29236                "When a resource schema validation is ignored.",
29237                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
29238                "When undeclared properties in the schema are present",
29239                "A given scope cannot be reached."
29240              ],
29241              "enumDeprecated": [
29242                false,
29243                false,
29244                false,
29245                false,
29246                false,
29247                false,
29248                true,
29249                false,
29250                false,
29251                false,
29252                false,
29253                false,
29254                false,
29255                false,
29256                false,
29257                false,
29258                false,
29259                false,
29260                false,
29261                false,
29262                false,
29263                false,
29264                false,
29265                false,
29266                false,
29267                false,
29268                false,
29269                false
29270              ],
29271              "enum": [
29272                "CLEANUP_FAILED",
29273                "DEPRECATED_RESOURCE_USED",
29274                "DEPRECATED_TYPE_USED",
29275                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
29276                "EXPERIMENTAL_TYPE_USED",
29277                "EXTERNAL_API_WARNING",
29278                "FIELD_VALUE_OVERRIDEN",
29279                "INJECTED_KERNELS_DEPRECATED",
29280                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
29281                "LARGE_DEPLOYMENT_WARNING",
29282                "LIST_OVERHEAD_QUOTA_EXCEED",
29283                "MISSING_TYPE_DEPENDENCY",
29284                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
29285                "NEXT_HOP_CANNOT_IP_FORWARD",
29286                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
29287                "NEXT_HOP_INSTANCE_NOT_FOUND",
29288                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
29289                "NEXT_HOP_NOT_RUNNING",
29290                "NOT_CRITICAL_ERROR",
29291                "NO_RESULTS_ON_PAGE",
29292                "PARTIAL_SUCCESS",
29293                "REQUIRED_TOS_AGREEMENT",
29294                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
29295                "RESOURCE_NOT_DELETED",
29296                "SCHEMA_VALIDATION_IGNORED",
29297                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
29298                "UNDECLARED_PROPERTIES",
29299                "UNREACHABLE"
29300              ]
29301            },
29302            "message": {
29303              "description": "[Output Only] A human-readable description of the warning code.",
29304              "type": "string"
29305            },
29306            "data": {
29307              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
29308              "type": "array",
29309              "items": {
29310                "type": "object",
29311                "properties": {
29312                  "key": {
29313                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
29314                    "type": "string"
29315                  },
29316                  "value": {
29317                    "description": "[Output Only] A warning data value corresponding to the key.",
29318                    "type": "string"
29319                  }
29320                }
29321              }
29322            }
29323          }
29324        }
29325      }
29326    },
29327    "NotificationEndpointList": {
29328      "id": "NotificationEndpointList",
29329      "type": "object",
29330      "properties": {
29331        "kind": {
29332          "description": "[Output Only] Type of the resource. Always compute#notificationEndpoint for notification endpoints.",
29333          "default": "compute#notificationEndpointList",
29334          "type": "string"
29335        },
29336        "id": {
29337          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
29338          "type": "string"
29339        },
29340        "items": {
29341          "description": "A list of NotificationEndpoint resources.",
29342          "type": "array",
29343          "items": {
29344            "$ref": "NotificationEndpoint"
29345          }
29346        },
29347        "nextPageToken": {
29348          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
29349          "type": "string"
29350        },
29351        "selfLink": {
29352          "description": "[Output Only] Server-defined URL for this resource.",
29353          "type": "string"
29354        },
29355        "warning": {
29356          "description": "[Output Only] Informational warning message.",
29357          "type": "object",
29358          "properties": {
29359            "code": {
29360              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
29361              "type": "string",
29362              "enumDescriptions": [
29363                "Warning about failed cleanup of transient changes made by a failed operation.",
29364                "A link to a deprecated resource was created.",
29365                "When deploying and at least one of the resources has a type marked as deprecated",
29366                "The user created a boot disk that is larger than image size.",
29367                "When deploying and at least one of the resources has a type marked as experimental",
29368                "Warning that is present in an external api call",
29369                "Warning that value of a field has been overridden. Deprecated unused field.",
29370                "The operation involved use of an injected kernel, which is deprecated.",
29371                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
29372                "When deploying a deployment with a exceedingly large number of resources",
29373                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
29374                "A resource depends on a missing type",
29375                "The route's nextHopIp address is not assigned to an instance on the network.",
29376                "The route's next hop instance cannot ip forward.",
29377                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
29378                "The route's nextHopInstance URL refers to an instance that does not exist.",
29379                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
29380                "The route's next hop instance does not have a status of RUNNING.",
29381                "Error which is not critical. We decided to continue the process despite the mentioned error.",
29382                "No results are present on a particular list page.",
29383                "Success is reported, but some results may be missing due to errors",
29384                "The user attempted to use a resource that requires a TOS they have not accepted.",
29385                "Warning that a resource is in use.",
29386                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
29387                "When a resource schema validation is ignored.",
29388                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
29389                "When undeclared properties in the schema are present",
29390                "A given scope cannot be reached."
29391              ],
29392              "enumDeprecated": [
29393                false,
29394                false,
29395                false,
29396                false,
29397                false,
29398                false,
29399                true,
29400                false,
29401                false,
29402                false,
29403                false,
29404                false,
29405                false,
29406                false,
29407                false,
29408                false,
29409                false,
29410                false,
29411                false,
29412                false,
29413                false,
29414                false,
29415                false,
29416                false,
29417                false,
29418                false,
29419                false,
29420                false
29421              ],
29422              "enum": [
29423                "CLEANUP_FAILED",
29424                "DEPRECATED_RESOURCE_USED",
29425                "DEPRECATED_TYPE_USED",
29426                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
29427                "EXPERIMENTAL_TYPE_USED",
29428                "EXTERNAL_API_WARNING",
29429                "FIELD_VALUE_OVERRIDEN",
29430                "INJECTED_KERNELS_DEPRECATED",
29431                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
29432                "LARGE_DEPLOYMENT_WARNING",
29433                "LIST_OVERHEAD_QUOTA_EXCEED",
29434                "MISSING_TYPE_DEPENDENCY",
29435                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
29436                "NEXT_HOP_CANNOT_IP_FORWARD",
29437                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
29438                "NEXT_HOP_INSTANCE_NOT_FOUND",
29439                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
29440                "NEXT_HOP_NOT_RUNNING",
29441                "NOT_CRITICAL_ERROR",
29442                "NO_RESULTS_ON_PAGE",
29443                "PARTIAL_SUCCESS",
29444                "REQUIRED_TOS_AGREEMENT",
29445                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
29446                "RESOURCE_NOT_DELETED",
29447                "SCHEMA_VALIDATION_IGNORED",
29448                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
29449                "UNDECLARED_PROPERTIES",
29450                "UNREACHABLE"
29451              ]
29452            },
29453            "message": {
29454              "description": "[Output Only] A human-readable description of the warning code.",
29455              "type": "string"
29456            },
29457            "data": {
29458              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
29459              "type": "array",
29460              "items": {
29461                "type": "object",
29462                "properties": {
29463                  "key": {
29464                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
29465                    "type": "string"
29466                  },
29467                  "value": {
29468                    "description": "[Output Only] A warning data value corresponding to the key.",
29469                    "type": "string"
29470                  }
29471                }
29472              }
29473            }
29474          }
29475        }
29476      }
29477    },
29478    "NotificationEndpoint": {
29479      "id": "NotificationEndpoint",
29480      "description": "Represents a notification endpoint. A notification endpoint resource defines an endpoint to receive notifications when there are status changes detected by the associated health check service. For more information, see Health checks overview.",
29481      "type": "object",
29482      "properties": {
29483        "kind": {
29484          "description": "[Output Only] Type of the resource. Always compute#notificationEndpoint for notification endpoints.",
29485          "default": "compute#notificationEndpoint",
29486          "type": "string"
29487        },
29488        "id": {
29489          "description": "[Output Only] A unique identifier for this resource type. The server generates this identifier.",
29490          "type": "string",
29491          "format": "uint64"
29492        },
29493        "creationTimestamp": {
29494          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
29495          "type": "string"
29496        },
29497        "name": {
29498          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
29499          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
29500          "type": "string"
29501        },
29502        "description": {
29503          "description": "An optional description of this resource. Provide this property when you create the resource.",
29504          "type": "string"
29505        },
29506        "selfLink": {
29507          "description": "[Output Only] Server-defined URL for the resource.",
29508          "type": "string"
29509        },
29510        "region": {
29511          "description": "[Output Only] URL of the region where the notification endpoint resides. This field applies only to the regional resource. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
29512          "type": "string"
29513        },
29514        "grpcSettings": {
29515          "description": "Settings of the gRPC notification endpoint including the endpoint URL and the retry duration.",
29516          "$ref": "NotificationEndpointGrpcSettings"
29517        }
29518      }
29519    },
29520    "NotificationEndpointGrpcSettings": {
29521      "id": "NotificationEndpointGrpcSettings",
29522      "description": "Represents a gRPC setting that describes one gRPC notification endpoint and the retry duration attempting to send notification to this endpoint.",
29523      "type": "object",
29524      "properties": {
29525        "endpoint": {
29526          "description": "Endpoint to which gRPC notifications are sent. This must be a valid gRPCLB DNS name.",
29527          "type": "string"
29528        },
29529        "retryDurationSec": {
29530          "description": "How much time (in seconds) is spent attempting notification retries until a successful response is received. Default is 30s. Limit is 20m (1200s). Must be a positive number.",
29531          "type": "integer",
29532          "format": "uint32"
29533        },
29534        "payloadName": {
29535          "description": "Optional. If specified, this field is used to populate the \"name\" field in gRPC requests.",
29536          "type": "string"
29537        },
29538        "authority": {
29539          "description": "Optional. If specified, this field is used to set the authority header by the sender of notifications. See https://tools.ietf.org/html/rfc7540#section-8.1.2.3",
29540          "type": "string"
29541        },
29542        "resendInterval": {
29543          "description": "Optional. This field is used to configure how often to send a full update of all non-healthy backends. If unspecified, full updates are not sent. If specified, must be in the range between 600 seconds to 3600 seconds. Nanos are disallowed. Can only be set for regional notification endpoints.",
29544          "$ref": "Duration"
29545        }
29546      }
29547    },
29548    "PacketMirroring": {
29549      "id": "PacketMirroring",
29550      "description": "Represents a Packet Mirroring resource. Packet Mirroring clones the traffic of specified instances in your Virtual Private Cloud (VPC) network and forwards it to a collector destination, such as an instance group of an internal TCP/UDP load balancer, for analysis or examination. For more information about setting up Packet Mirroring, see Using Packet Mirroring.",
29551      "type": "object",
29552      "properties": {
29553        "kind": {
29554          "description": "[Output Only] Type of the resource. Always compute#packetMirroring for packet mirrorings.",
29555          "default": "compute#packetMirroring",
29556          "type": "string"
29557        },
29558        "id": {
29559          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
29560          "type": "string",
29561          "format": "uint64"
29562        },
29563        "creationTimestamp": {
29564          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
29565          "type": "string"
29566        },
29567        "selfLink": {
29568          "description": "[Output Only] Server-defined URL for the resource.",
29569          "type": "string"
29570        },
29571        "name": {
29572          "description": "Name of the resource; provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
29573          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
29574          "annotations": {
29575            "required": [
29576              "compute.packetMirrorings.insert"
29577            ]
29578          },
29579          "type": "string"
29580        },
29581        "description": {
29582          "description": "An optional description of this resource. Provide this property when you create the resource.",
29583          "type": "string"
29584        },
29585        "region": {
29586          "description": "[Output Only] URI of the region where the packetMirroring resides.",
29587          "type": "string"
29588        },
29589        "network": {
29590          "description": "Specifies the mirrored VPC network. Only packets in this network will be mirrored. All mirrored VMs should have a NIC in the given network. All mirrored subnetworks should belong to the given network.",
29591          "annotations": {
29592            "required": [
29593              "compute.packetMirrorings.insert"
29594            ]
29595          },
29596          "$ref": "PacketMirroringNetworkInfo"
29597        },
29598        "priority": {
29599          "description": "The priority of applying this configuration. Priority is used to break ties in cases where there is more than one matching rule. In the case of two rules that apply for a given Instance, the one with the lowest-numbered priority value wins. Default value is 1000. Valid range is 0 through 65535.",
29600          "type": "integer",
29601          "format": "uint32"
29602        },
29603        "collectorIlb": {
29604          "description": "The Forwarding Rule resource of type loadBalancingScheme=INTERNAL that will be used as collector for mirrored traffic. The specified forwarding rule must have isMirroringCollector set to true.",
29605          "$ref": "PacketMirroringForwardingRuleInfo"
29606        },
29607        "mirroredResources": {
29608          "description": "PacketMirroring mirroredResourceInfos. MirroredResourceInfo specifies a set of mirrored VM instances, subnetworks and/or tags for which traffic from/to all VM instances will be mirrored.",
29609          "$ref": "PacketMirroringMirroredResourceInfo"
29610        },
29611        "filter": {
29612          "description": "Filter for mirrored traffic. If unspecified, all traffic is mirrored.",
29613          "$ref": "PacketMirroringFilter"
29614        },
29615        "enable": {
29616          "description": "Indicates whether or not this packet mirroring takes effect. If set to FALSE, this packet mirroring policy will not be enforced on the network. The default is TRUE.",
29617          "type": "string",
29618          "enumDescriptions": [
29619            "",
29620            ""
29621          ],
29622          "enum": [
29623            "FALSE",
29624            "TRUE"
29625          ]
29626        }
29627      }
29628    },
29629    "PacketMirroringNetworkInfo": {
29630      "id": "PacketMirroringNetworkInfo",
29631      "type": "object",
29632      "properties": {
29633        "url": {
29634          "description": "URL of the network resource.",
29635          "type": "string"
29636        },
29637        "canonicalUrl": {
29638          "description": "[Output Only] Unique identifier for the network; defined by the server.",
29639          "type": "string"
29640        }
29641      }
29642    },
29643    "PacketMirroringForwardingRuleInfo": {
29644      "id": "PacketMirroringForwardingRuleInfo",
29645      "type": "object",
29646      "properties": {
29647        "url": {
29648          "description": "Resource URL to the forwarding rule representing the ILB configured as destination of the mirrored traffic.",
29649          "type": "string"
29650        },
29651        "canonicalUrl": {
29652          "description": "[Output Only] Unique identifier for the forwarding rule; defined by the server.",
29653          "type": "string"
29654        }
29655      }
29656    },
29657    "PacketMirroringMirroredResourceInfo": {
29658      "id": "PacketMirroringMirroredResourceInfo",
29659      "type": "object",
29660      "properties": {
29661        "subnetworks": {
29662          "description": "A set of subnetworks for which traffic from/to all VM instances will be mirrored. They must live in the same region as this packetMirroring. You may specify a maximum of 5 subnetworks.",
29663          "type": "array",
29664          "items": {
29665            "$ref": "PacketMirroringMirroredResourceInfoSubnetInfo"
29666          }
29667        },
29668        "instances": {
29669          "description": "A set of virtual machine instances that are being mirrored. They must live in zones contained in the same region as this packetMirroring. Note that this config will apply only to those network interfaces of the Instances that belong to the network specified in this packetMirroring. You may specify a maximum of 50 Instances.",
29670          "type": "array",
29671          "items": {
29672            "$ref": "PacketMirroringMirroredResourceInfoInstanceInfo"
29673          }
29674        },
29675        "tags": {
29676          "description": "A set of mirrored tags. Traffic from/to all VM instances that have one or more of these tags will be mirrored.",
29677          "type": "array",
29678          "items": {
29679            "type": "string"
29680          }
29681        }
29682      }
29683    },
29684    "PacketMirroringMirroredResourceInfoSubnetInfo": {
29685      "id": "PacketMirroringMirroredResourceInfoSubnetInfo",
29686      "type": "object",
29687      "properties": {
29688        "url": {
29689          "description": "Resource URL to the subnetwork for which traffic from/to all VM instances will be mirrored.",
29690          "type": "string"
29691        },
29692        "canonicalUrl": {
29693          "description": "[Output Only] Unique identifier for the subnetwork; defined by the server.",
29694          "type": "string"
29695        }
29696      }
29697    },
29698    "PacketMirroringMirroredResourceInfoInstanceInfo": {
29699      "id": "PacketMirroringMirroredResourceInfoInstanceInfo",
29700      "type": "object",
29701      "properties": {
29702        "url": {
29703          "description": "Resource URL to the virtual machine instance which is being mirrored.",
29704          "type": "string"
29705        },
29706        "canonicalUrl": {
29707          "description": "[Output Only] Unique identifier for the instance; defined by the server.",
29708          "type": "string"
29709        }
29710      }
29711    },
29712    "PacketMirroringFilter": {
29713      "id": "PacketMirroringFilter",
29714      "type": "object",
29715      "properties": {
29716        "cidrRanges": {
29717          "description": "One or more IPv4 or IPv6 CIDR ranges that apply as filter on the source (ingress) or destination (egress) IP in the IP header. If no ranges are specified, all IPv4 traffic that matches the specified IPProtocols is mirrored. If neither cidrRanges nor IPProtocols is specified, all IPv4 traffic is mirrored. To mirror all IPv4 and IPv6 traffic, use \"0.0.0.0/0,::/0\". Note: Support for IPv6 traffic is in preview.",
29718          "type": "array",
29719          "items": {
29720            "type": "string"
29721          }
29722        },
29723        "IPProtocols": {
29724          "description": "Protocols that apply as filter on mirrored traffic. If no protocols are specified, all traffic that matches the specified CIDR ranges is mirrored. If neither cidrRanges nor IPProtocols is specified, all IPv4 traffic is mirrored.",
29725          "type": "array",
29726          "items": {
29727            "type": "string"
29728          }
29729        },
29730        "direction": {
29731          "description": "Direction of traffic to mirror, either INGRESS, EGRESS, or BOTH. The default is BOTH.",
29732          "type": "string",
29733          "enumDescriptions": [
29734            "Default, both directions are mirrored.",
29735            "Only egress traffic is mirrored.",
29736            "Only ingress traffic is mirrored."
29737          ],
29738          "enum": [
29739            "BOTH",
29740            "EGRESS",
29741            "INGRESS"
29742          ]
29743        }
29744      }
29745    },
29746    "PacketMirroringList": {
29747      "id": "PacketMirroringList",
29748      "description": "Contains a list of PacketMirroring resources.",
29749      "type": "object",
29750      "properties": {
29751        "kind": {
29752          "description": "[Output Only] Type of resource. Always compute#packetMirroring for packetMirrorings.",
29753          "default": "compute#packetMirroringList",
29754          "type": "string"
29755        },
29756        "id": {
29757          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
29758          "type": "string"
29759        },
29760        "items": {
29761          "description": "A list of PacketMirroring resources.",
29762          "type": "array",
29763          "items": {
29764            "$ref": "PacketMirroring"
29765          }
29766        },
29767        "nextPageToken": {
29768          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
29769          "type": "string"
29770        },
29771        "selfLink": {
29772          "description": "[Output Only] Server-defined URL for this resource.",
29773          "type": "string"
29774        },
29775        "warning": {
29776          "description": "[Output Only] Informational warning message.",
29777          "type": "object",
29778          "properties": {
29779            "code": {
29780              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
29781              "type": "string",
29782              "enumDescriptions": [
29783                "Warning about failed cleanup of transient changes made by a failed operation.",
29784                "A link to a deprecated resource was created.",
29785                "When deploying and at least one of the resources has a type marked as deprecated",
29786                "The user created a boot disk that is larger than image size.",
29787                "When deploying and at least one of the resources has a type marked as experimental",
29788                "Warning that is present in an external api call",
29789                "Warning that value of a field has been overridden. Deprecated unused field.",
29790                "The operation involved use of an injected kernel, which is deprecated.",
29791                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
29792                "When deploying a deployment with a exceedingly large number of resources",
29793                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
29794                "A resource depends on a missing type",
29795                "The route's nextHopIp address is not assigned to an instance on the network.",
29796                "The route's next hop instance cannot ip forward.",
29797                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
29798                "The route's nextHopInstance URL refers to an instance that does not exist.",
29799                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
29800                "The route's next hop instance does not have a status of RUNNING.",
29801                "Error which is not critical. We decided to continue the process despite the mentioned error.",
29802                "No results are present on a particular list page.",
29803                "Success is reported, but some results may be missing due to errors",
29804                "The user attempted to use a resource that requires a TOS they have not accepted.",
29805                "Warning that a resource is in use.",
29806                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
29807                "When a resource schema validation is ignored.",
29808                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
29809                "When undeclared properties in the schema are present",
29810                "A given scope cannot be reached."
29811              ],
29812              "enumDeprecated": [
29813                false,
29814                false,
29815                false,
29816                false,
29817                false,
29818                false,
29819                true,
29820                false,
29821                false,
29822                false,
29823                false,
29824                false,
29825                false,
29826                false,
29827                false,
29828                false,
29829                false,
29830                false,
29831                false,
29832                false,
29833                false,
29834                false,
29835                false,
29836                false,
29837                false,
29838                false,
29839                false,
29840                false
29841              ],
29842              "enum": [
29843                "CLEANUP_FAILED",
29844                "DEPRECATED_RESOURCE_USED",
29845                "DEPRECATED_TYPE_USED",
29846                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
29847                "EXPERIMENTAL_TYPE_USED",
29848                "EXTERNAL_API_WARNING",
29849                "FIELD_VALUE_OVERRIDEN",
29850                "INJECTED_KERNELS_DEPRECATED",
29851                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
29852                "LARGE_DEPLOYMENT_WARNING",
29853                "LIST_OVERHEAD_QUOTA_EXCEED",
29854                "MISSING_TYPE_DEPENDENCY",
29855                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
29856                "NEXT_HOP_CANNOT_IP_FORWARD",
29857                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
29858                "NEXT_HOP_INSTANCE_NOT_FOUND",
29859                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
29860                "NEXT_HOP_NOT_RUNNING",
29861                "NOT_CRITICAL_ERROR",
29862                "NO_RESULTS_ON_PAGE",
29863                "PARTIAL_SUCCESS",
29864                "REQUIRED_TOS_AGREEMENT",
29865                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
29866                "RESOURCE_NOT_DELETED",
29867                "SCHEMA_VALIDATION_IGNORED",
29868                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
29869                "UNDECLARED_PROPERTIES",
29870                "UNREACHABLE"
29871              ]
29872            },
29873            "message": {
29874              "description": "[Output Only] A human-readable description of the warning code.",
29875              "type": "string"
29876            },
29877            "data": {
29878              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
29879              "type": "array",
29880              "items": {
29881                "type": "object",
29882                "properties": {
29883                  "key": {
29884                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
29885                    "type": "string"
29886                  },
29887                  "value": {
29888                    "description": "[Output Only] A warning data value corresponding to the key.",
29889                    "type": "string"
29890                  }
29891                }
29892              }
29893            }
29894          }
29895        }
29896      }
29897    },
29898    "PacketMirroringAggregatedList": {
29899      "id": "PacketMirroringAggregatedList",
29900      "description": "Contains a list of packetMirrorings.",
29901      "type": "object",
29902      "properties": {
29903        "kind": {
29904          "description": "Type of resource.",
29905          "default": "compute#packetMirroringAggregatedList",
29906          "type": "string"
29907        },
29908        "id": {
29909          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
29910          "type": "string"
29911        },
29912        "items": {
29913          "description": "A list of PacketMirroring resources.",
29914          "type": "object",
29915          "additionalProperties": {
29916            "description": "Name of the scope containing this set of packetMirrorings.",
29917            "$ref": "PacketMirroringsScopedList"
29918          }
29919        },
29920        "nextPageToken": {
29921          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
29922          "type": "string"
29923        },
29924        "selfLink": {
29925          "description": "[Output Only] Server-defined URL for this resource.",
29926          "type": "string"
29927        },
29928        "warning": {
29929          "description": "[Output Only] Informational warning message.",
29930          "type": "object",
29931          "properties": {
29932            "code": {
29933              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
29934              "type": "string",
29935              "enumDescriptions": [
29936                "Warning about failed cleanup of transient changes made by a failed operation.",
29937                "A link to a deprecated resource was created.",
29938                "When deploying and at least one of the resources has a type marked as deprecated",
29939                "The user created a boot disk that is larger than image size.",
29940                "When deploying and at least one of the resources has a type marked as experimental",
29941                "Warning that is present in an external api call",
29942                "Warning that value of a field has been overridden. Deprecated unused field.",
29943                "The operation involved use of an injected kernel, which is deprecated.",
29944                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
29945                "When deploying a deployment with a exceedingly large number of resources",
29946                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
29947                "A resource depends on a missing type",
29948                "The route's nextHopIp address is not assigned to an instance on the network.",
29949                "The route's next hop instance cannot ip forward.",
29950                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
29951                "The route's nextHopInstance URL refers to an instance that does not exist.",
29952                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
29953                "The route's next hop instance does not have a status of RUNNING.",
29954                "Error which is not critical. We decided to continue the process despite the mentioned error.",
29955                "No results are present on a particular list page.",
29956                "Success is reported, but some results may be missing due to errors",
29957                "The user attempted to use a resource that requires a TOS they have not accepted.",
29958                "Warning that a resource is in use.",
29959                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
29960                "When a resource schema validation is ignored.",
29961                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
29962                "When undeclared properties in the schema are present",
29963                "A given scope cannot be reached."
29964              ],
29965              "enumDeprecated": [
29966                false,
29967                false,
29968                false,
29969                false,
29970                false,
29971                false,
29972                true,
29973                false,
29974                false,
29975                false,
29976                false,
29977                false,
29978                false,
29979                false,
29980                false,
29981                false,
29982                false,
29983                false,
29984                false,
29985                false,
29986                false,
29987                false,
29988                false,
29989                false,
29990                false,
29991                false,
29992                false,
29993                false
29994              ],
29995              "enum": [
29996                "CLEANUP_FAILED",
29997                "DEPRECATED_RESOURCE_USED",
29998                "DEPRECATED_TYPE_USED",
29999                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
30000                "EXPERIMENTAL_TYPE_USED",
30001                "EXTERNAL_API_WARNING",
30002                "FIELD_VALUE_OVERRIDEN",
30003                "INJECTED_KERNELS_DEPRECATED",
30004                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
30005                "LARGE_DEPLOYMENT_WARNING",
30006                "LIST_OVERHEAD_QUOTA_EXCEED",
30007                "MISSING_TYPE_DEPENDENCY",
30008                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
30009                "NEXT_HOP_CANNOT_IP_FORWARD",
30010                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
30011                "NEXT_HOP_INSTANCE_NOT_FOUND",
30012                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
30013                "NEXT_HOP_NOT_RUNNING",
30014                "NOT_CRITICAL_ERROR",
30015                "NO_RESULTS_ON_PAGE",
30016                "PARTIAL_SUCCESS",
30017                "REQUIRED_TOS_AGREEMENT",
30018                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
30019                "RESOURCE_NOT_DELETED",
30020                "SCHEMA_VALIDATION_IGNORED",
30021                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
30022                "UNDECLARED_PROPERTIES",
30023                "UNREACHABLE"
30024              ]
30025            },
30026            "message": {
30027              "description": "[Output Only] A human-readable description of the warning code.",
30028              "type": "string"
30029            },
30030            "data": {
30031              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
30032              "type": "array",
30033              "items": {
30034                "type": "object",
30035                "properties": {
30036                  "key": {
30037                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
30038                    "type": "string"
30039                  },
30040                  "value": {
30041                    "description": "[Output Only] A warning data value corresponding to the key.",
30042                    "type": "string"
30043                  }
30044                }
30045              }
30046            }
30047          }
30048        },
30049        "unreachables": {
30050          "description": "[Output Only] Unreachable resources.",
30051          "type": "array",
30052          "items": {
30053            "type": "string"
30054          }
30055        }
30056      }
30057    },
30058    "PacketMirroringsScopedList": {
30059      "id": "PacketMirroringsScopedList",
30060      "type": "object",
30061      "properties": {
30062        "packetMirrorings": {
30063          "description": "A list of packetMirrorings contained in this scope.",
30064          "type": "array",
30065          "items": {
30066            "$ref": "PacketMirroring"
30067          }
30068        },
30069        "warning": {
30070          "description": "Informational warning which replaces the list of packetMirrorings when the list is empty.",
30071          "type": "object",
30072          "properties": {
30073            "code": {
30074              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
30075              "type": "string",
30076              "enumDescriptions": [
30077                "Warning about failed cleanup of transient changes made by a failed operation.",
30078                "A link to a deprecated resource was created.",
30079                "When deploying and at least one of the resources has a type marked as deprecated",
30080                "The user created a boot disk that is larger than image size.",
30081                "When deploying and at least one of the resources has a type marked as experimental",
30082                "Warning that is present in an external api call",
30083                "Warning that value of a field has been overridden. Deprecated unused field.",
30084                "The operation involved use of an injected kernel, which is deprecated.",
30085                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
30086                "When deploying a deployment with a exceedingly large number of resources",
30087                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
30088                "A resource depends on a missing type",
30089                "The route's nextHopIp address is not assigned to an instance on the network.",
30090                "The route's next hop instance cannot ip forward.",
30091                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
30092                "The route's nextHopInstance URL refers to an instance that does not exist.",
30093                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
30094                "The route's next hop instance does not have a status of RUNNING.",
30095                "Error which is not critical. We decided to continue the process despite the mentioned error.",
30096                "No results are present on a particular list page.",
30097                "Success is reported, but some results may be missing due to errors",
30098                "The user attempted to use a resource that requires a TOS they have not accepted.",
30099                "Warning that a resource is in use.",
30100                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
30101                "When a resource schema validation is ignored.",
30102                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
30103                "When undeclared properties in the schema are present",
30104                "A given scope cannot be reached."
30105              ],
30106              "enumDeprecated": [
30107                false,
30108                false,
30109                false,
30110                false,
30111                false,
30112                false,
30113                true,
30114                false,
30115                false,
30116                false,
30117                false,
30118                false,
30119                false,
30120                false,
30121                false,
30122                false,
30123                false,
30124                false,
30125                false,
30126                false,
30127                false,
30128                false,
30129                false,
30130                false,
30131                false,
30132                false,
30133                false,
30134                false
30135              ],
30136              "enum": [
30137                "CLEANUP_FAILED",
30138                "DEPRECATED_RESOURCE_USED",
30139                "DEPRECATED_TYPE_USED",
30140                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
30141                "EXPERIMENTAL_TYPE_USED",
30142                "EXTERNAL_API_WARNING",
30143                "FIELD_VALUE_OVERRIDEN",
30144                "INJECTED_KERNELS_DEPRECATED",
30145                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
30146                "LARGE_DEPLOYMENT_WARNING",
30147                "LIST_OVERHEAD_QUOTA_EXCEED",
30148                "MISSING_TYPE_DEPENDENCY",
30149                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
30150                "NEXT_HOP_CANNOT_IP_FORWARD",
30151                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
30152                "NEXT_HOP_INSTANCE_NOT_FOUND",
30153                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
30154                "NEXT_HOP_NOT_RUNNING",
30155                "NOT_CRITICAL_ERROR",
30156                "NO_RESULTS_ON_PAGE",
30157                "PARTIAL_SUCCESS",
30158                "REQUIRED_TOS_AGREEMENT",
30159                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
30160                "RESOURCE_NOT_DELETED",
30161                "SCHEMA_VALIDATION_IGNORED",
30162                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
30163                "UNDECLARED_PROPERTIES",
30164                "UNREACHABLE"
30165              ]
30166            },
30167            "message": {
30168              "description": "[Output Only] A human-readable description of the warning code.",
30169              "type": "string"
30170            },
30171            "data": {
30172              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
30173              "type": "array",
30174              "items": {
30175                "type": "object",
30176                "properties": {
30177                  "key": {
30178                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
30179                    "type": "string"
30180                  },
30181                  "value": {
30182                    "description": "[Output Only] A warning data value corresponding to the key.",
30183                    "type": "string"
30184                  }
30185                }
30186              }
30187            }
30188          }
30189        }
30190      }
30191    },
30192    "Project": {
30193      "id": "Project",
30194      "description": "Represents a Project resource. A project is used to organize resources in a Google Cloud Platform environment. For more information, read about the Resource Hierarchy.",
30195      "type": "object",
30196      "properties": {
30197        "kind": {
30198          "description": "[Output Only] Type of the resource. Always compute#project for projects.",
30199          "default": "compute#project",
30200          "type": "string"
30201        },
30202        "id": {
30203          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server. This is *not* the project ID, and is just a unique ID used by Compute Engine to identify resources.",
30204          "type": "string",
30205          "format": "uint64"
30206        },
30207        "creationTimestamp": {
30208          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
30209          "type": "string"
30210        },
30211        "name": {
30212          "description": "The project ID. For example: my-example-project. Use the project ID to make requests to Compute Engine.",
30213          "type": "string"
30214        },
30215        "description": {
30216          "description": "An optional textual description of the resource.",
30217          "type": "string"
30218        },
30219        "commonInstanceMetadata": {
30220          "description": "Metadata key/value pairs available to all instances contained in this project. See Custom metadata for more information.",
30221          "$ref": "Metadata"
30222        },
30223        "quotas": {
30224          "description": "[Output Only] Quotas assigned to this project.",
30225          "type": "array",
30226          "items": {
30227            "$ref": "Quota"
30228          }
30229        },
30230        "usageExportLocation": {
30231          "description": "The naming prefix for daily usage reports and the Google Cloud Storage bucket where they are stored.",
30232          "$ref": "UsageExportLocation"
30233        },
30234        "enabledFeatures": {
30235          "description": "Restricted features enabled for use on this project.",
30236          "type": "array",
30237          "items": {
30238            "type": "string"
30239          }
30240        },
30241        "selfLink": {
30242          "description": "[Output Only] Server-defined URL for the resource.",
30243          "type": "string"
30244        },
30245        "defaultServiceAccount": {
30246          "description": "[Output Only] Default service account used by VMs running in this project.",
30247          "type": "string"
30248        },
30249        "xpnProjectStatus": {
30250          "description": "[Output Only] The role this project has in a shared VPC configuration. Currently, only projects with the host role, which is specified by the value HOST, are differentiated.",
30251          "type": "string",
30252          "enumDescriptions": [
30253            "",
30254            ""
30255          ],
30256          "enum": [
30257            "HOST",
30258            "UNSPECIFIED_XPN_PROJECT_STATUS"
30259          ]
30260        },
30261        "defaultNetworkTier": {
30262          "description": "This signifies the default network tier used for configuring resources of the project and can only take the following values: PREMIUM, STANDARD. Initially the default network tier is PREMIUM.",
30263          "type": "string",
30264          "enumDescriptions": [
30265            "Public internet quality with fixed bandwidth.",
30266            "High quality, Google-grade network tier, support for all networking products.",
30267            "Public internet quality, only limited support for other networking products.",
30268            "(Output only) Temporary tier for FIXED_STANDARD when fixed standard tier is expired or not configured."
30269          ],
30270          "enum": [
30271            "FIXED_STANDARD",
30272            "PREMIUM",
30273            "STANDARD",
30274            "STANDARD_OVERRIDES_FIXED_STANDARD"
30275          ]
30276        },
30277        "vmDnsSetting": {
30278          "description": "[Output Only] Default internal DNS setting used by VMs running in this project.",
30279          "type": "string",
30280          "enumDescriptions": [
30281            "",
30282            "",
30283            "",
30284            ""
30285          ],
30286          "enum": [
30287            "GLOBAL_DEFAULT",
30288            "UNSPECIFIED_VM_DNS_SETTING",
30289            "ZONAL_DEFAULT",
30290            "ZONAL_ONLY"
30291          ]
30292        },
30293        "cloudArmorTier": {
30294          "description": "[Output Only] The Cloud Armor tier for this project. It can be one of the following values: CA_STANDARD, CA_ENTERPRISE_PAYGO. If this field is not specified, it is assumed to be CA_STANDARD.",
30295          "type": "string",
30296          "enumDescriptions": [
30297            "Enterprise tier protection billed annually.",
30298            "Enterprise tier protection billed monthly.",
30299            "Standard protection."
30300          ],
30301          "enum": [
30302            "CA_ENTERPRISE_ANNUAL",
30303            "CA_ENTERPRISE_PAYGO",
30304            "CA_STANDARD"
30305          ]
30306        }
30307      }
30308    },
30309    "Quota": {
30310      "id": "Quota",
30311      "description": "A quotas entry.",
30312      "type": "object",
30313      "properties": {
30314        "metric": {
30315          "description": "[Output Only] Name of the quota metric.",
30316          "type": "string",
30317          "enumDescriptions": [
30318            "",
30319            "",
30320            "",
30321            "",
30322            "",
30323            "",
30324            "",
30325            "",
30326            "",
30327            "",
30328            "",
30329            "",
30330            "",
30331            "",
30332            "",
30333            "",
30334            "",
30335            "",
30336            "",
30337            "",
30338            "",
30339            "",
30340            "",
30341            "",
30342            "",
30343            "",
30344            "",
30345            "",
30346            "",
30347            "",
30348            "",
30349            "",
30350            "",
30351            "",
30352            "Guest CPUs",
30353            "",
30354            "",
30355            "",
30356            "",
30357            "",
30358            "",
30359            "",
30360            "",
30361            "",
30362            "",
30363            "",
30364            "",
30365            "",
30366            "",
30367            "",
30368            "",
30369            "",
30370            "",
30371            "",
30372            "",
30373            "",
30374            "",
30375            "",
30376            "",
30377            "",
30378            "",
30379            "",
30380            "",
30381            "",
30382            "",
30383            "",
30384            "",
30385            "",
30386            "",
30387            "",
30388            "",
30389            "",
30390            "",
30391            "",
30392            "",
30393            "",
30394            "",
30395            "",
30396            "",
30397            "",
30398            "",
30399            "",
30400            "",
30401            "",
30402            "",
30403            "",
30404            "",
30405            "",
30406            "",
30407            "",
30408            "",
30409            "",
30410            "",
30411            "",
30412            "",
30413            "",
30414            "",
30415            "",
30416            "",
30417            "",
30418            "",
30419            "",
30420            "",
30421            "",
30422            "",
30423            "",
30424            "",
30425            "",
30426            "",
30427            "",
30428            "",
30429            "",
30430            "",
30431            "",
30432            "",
30433            "",
30434            "",
30435            "",
30436            "",
30437            "",
30438            "",
30439            "",
30440            "",
30441            "",
30442            "",
30443            "",
30444            "",
30445            "",
30446            "",
30447            "",
30448            "",
30449            "",
30450            "",
30451            "",
30452            "",
30453            "The total number of snapshots allowed for a single project.",
30454            "",
30455            "",
30456            "",
30457            "",
30458            "",
30459            "",
30460            "",
30461            "",
30462            "",
30463            "",
30464            "",
30465            "",
30466            "",
30467            "",
30468            "",
30469            "",
30470            "",
30471            "",
30472            "",
30473            "",
30474            "",
30475            ""
30476          ],
30477          "enum": [
30478            "A2_CPUS",
30479            "AFFINITY_GROUPS",
30480            "AUTOSCALERS",
30481            "BACKEND_BUCKETS",
30482            "BACKEND_SERVICES",
30483            "C2D_CPUS",
30484            "C2_CPUS",
30485            "C3_CPUS",
30486            "COMMITMENTS",
30487            "COMMITTED_A2_CPUS",
30488            "COMMITTED_C2D_CPUS",
30489            "COMMITTED_C2_CPUS",
30490            "COMMITTED_C3_CPUS",
30491            "COMMITTED_CPUS",
30492            "COMMITTED_E2_CPUS",
30493            "COMMITTED_LICENSES",
30494            "COMMITTED_LOCAL_SSD_TOTAL_GB",
30495            "COMMITTED_M3_CPUS",
30496            "COMMITTED_MEMORY_OPTIMIZED_CPUS",
30497            "COMMITTED_N2A_CPUS",
30498            "COMMITTED_N2D_CPUS",
30499            "COMMITTED_N2_CPUS",
30500            "COMMITTED_NVIDIA_A100_80GB_GPUS",
30501            "COMMITTED_NVIDIA_A100_GPUS",
30502            "COMMITTED_NVIDIA_H100_GPUS",
30503            "COMMITTED_NVIDIA_K80_GPUS",
30504            "COMMITTED_NVIDIA_L4_GPUS",
30505            "COMMITTED_NVIDIA_P100_GPUS",
30506            "COMMITTED_NVIDIA_P4_GPUS",
30507            "COMMITTED_NVIDIA_T4_GPUS",
30508            "COMMITTED_NVIDIA_V100_GPUS",
30509            "COMMITTED_T2A_CPUS",
30510            "COMMITTED_T2D_CPUS",
30511            "COMMITTED_Z3_CPUS",
30512            "CPUS",
30513            "CPUS_ALL_REGIONS",
30514            "DISKS_TOTAL_GB",
30515            "E2_CPUS",
30516            "EXTERNAL_MANAGED_FORWARDING_RULES",
30517            "EXTERNAL_NETWORK_LB_FORWARDING_RULES",
30518            "EXTERNAL_PROTOCOL_FORWARDING_RULES",
30519            "EXTERNAL_VPN_GATEWAYS",
30520            "FIREWALLS",
30521            "FORWARDING_RULES",
30522            "GLOBAL_EXTERNAL_MANAGED_BACKEND_SERVICES",
30523            "GLOBAL_EXTERNAL_MANAGED_FORWARDING_RULES",
30524            "GLOBAL_EXTERNAL_PROXY_LB_BACKEND_SERVICES",
30525            "GLOBAL_INTERNAL_ADDRESSES",
30526            "GLOBAL_INTERNAL_MANAGED_BACKEND_SERVICES",
30527            "GLOBAL_INTERNAL_TRAFFIC_DIRECTOR_BACKEND_SERVICES",
30528            "GPUS_ALL_REGIONS",
30529            "HEALTH_CHECKS",
30530            "IMAGES",
30531            "INSTANCES",
30532            "INSTANCE_GROUPS",
30533            "INSTANCE_GROUP_MANAGERS",
30534            "INSTANCE_TEMPLATES",
30535            "INTERCONNECTS",
30536            "INTERCONNECT_ATTACHMENTS_PER_REGION",
30537            "INTERCONNECT_ATTACHMENTS_TOTAL_MBPS",
30538            "INTERCONNECT_TOTAL_GBPS",
30539            "INTERNAL_ADDRESSES",
30540            "INTERNAL_TRAFFIC_DIRECTOR_FORWARDING_RULES",
30541            "IN_PLACE_SNAPSHOTS",
30542            "IN_USE_ADDRESSES",
30543            "IN_USE_BACKUP_SCHEDULES",
30544            "IN_USE_SNAPSHOT_SCHEDULES",
30545            "LOCAL_SSD_TOTAL_GB",
30546            "M1_CPUS",
30547            "M2_CPUS",
30548            "M3_CPUS",
30549            "MACHINE_IMAGES",
30550            "N2A_CPUS",
30551            "N2D_CPUS",
30552            "N2_CPUS",
30553            "NETWORKS",
30554            "NETWORK_ATTACHMENTS",
30555            "NETWORK_ENDPOINT_GROUPS",
30556            "NETWORK_FIREWALL_POLICIES",
30557            "NET_LB_SECURITY_POLICIES_PER_REGION",
30558            "NET_LB_SECURITY_POLICY_RULES_PER_REGION",
30559            "NET_LB_SECURITY_POLICY_RULE_ATTRIBUTES_PER_REGION",
30560            "NODE_GROUPS",
30561            "NODE_TEMPLATES",
30562            "NVIDIA_A100_80GB_GPUS",
30563            "NVIDIA_A100_GPUS",
30564            "NVIDIA_K80_GPUS",
30565            "NVIDIA_L4_GPUS",
30566            "NVIDIA_P100_GPUS",
30567            "NVIDIA_P100_VWS_GPUS",
30568            "NVIDIA_P4_GPUS",
30569            "NVIDIA_P4_VWS_GPUS",
30570            "NVIDIA_T4_GPUS",
30571            "NVIDIA_T4_VWS_GPUS",
30572            "NVIDIA_V100_GPUS",
30573            "PACKET_MIRRORINGS",
30574            "PD_EXTREME_TOTAL_PROVISIONED_IOPS",
30575            "PREEMPTIBLE_CPUS",
30576            "PREEMPTIBLE_LOCAL_SSD_GB",
30577            "PREEMPTIBLE_NVIDIA_A100_80GB_GPUS",
30578            "PREEMPTIBLE_NVIDIA_A100_GPUS",
30579            "PREEMPTIBLE_NVIDIA_H100_GPUS",
30580            "PREEMPTIBLE_NVIDIA_K80_GPUS",
30581            "PREEMPTIBLE_NVIDIA_L4_GPUS",
30582            "PREEMPTIBLE_NVIDIA_P100_GPUS",
30583            "PREEMPTIBLE_NVIDIA_P100_VWS_GPUS",
30584            "PREEMPTIBLE_NVIDIA_P4_GPUS",
30585            "PREEMPTIBLE_NVIDIA_P4_VWS_GPUS",
30586            "PREEMPTIBLE_NVIDIA_T4_GPUS",
30587            "PREEMPTIBLE_NVIDIA_T4_VWS_GPUS",
30588            "PREEMPTIBLE_NVIDIA_V100_GPUS",
30589            "PREEMPTIBLE_TPU_LITE_DEVICE_V5",
30590            "PREEMPTIBLE_TPU_LITE_PODSLICE_V5",
30591            "PREEMPTIBLE_TPU_PODSLICE_V4",
30592            "PSC_ILB_CONSUMER_FORWARDING_RULES_PER_PRODUCER_NETWORK",
30593            "PSC_INTERNAL_LB_FORWARDING_RULES",
30594            "PUBLIC_ADVERTISED_PREFIXES",
30595            "PUBLIC_DELEGATED_PREFIXES",
30596            "REGIONAL_AUTOSCALERS",
30597            "REGIONAL_EXTERNAL_MANAGED_BACKEND_SERVICES",
30598            "REGIONAL_EXTERNAL_NETWORK_LB_BACKEND_SERVICES",
30599            "REGIONAL_INSTANCE_GROUP_MANAGERS",
30600            "REGIONAL_INTERNAL_LB_BACKEND_SERVICES",
30601            "REGIONAL_INTERNAL_MANAGED_BACKEND_SERVICES",
30602            "RESERVATIONS",
30603            "RESOURCE_POLICIES",
30604            "ROUTERS",
30605            "ROUTES",
30606            "SECURITY_POLICIES",
30607            "SECURITY_POLICIES_PER_REGION",
30608            "SECURITY_POLICY_ADVANCED_RULES_PER_REGION",
30609            "SECURITY_POLICY_CEVAL_RULES",
30610            "SECURITY_POLICY_RULES",
30611            "SECURITY_POLICY_RULES_PER_REGION",
30612            "SERVICE_ATTACHMENTS",
30613            "SNAPSHOTS",
30614            "SSD_TOTAL_GB",
30615            "SSL_CERTIFICATES",
30616            "STATIC_ADDRESSES",
30617            "STATIC_BYOIP_ADDRESSES",
30618            "STATIC_EXTERNAL_IPV6_ADDRESS_RANGES",
30619            "SUBNETWORKS",
30620            "T2A_CPUS",
30621            "T2D_CPUS",
30622            "TARGET_HTTPS_PROXIES",
30623            "TARGET_HTTP_PROXIES",
30624            "TARGET_INSTANCES",
30625            "TARGET_POOLS",
30626            "TARGET_SSL_PROXIES",
30627            "TARGET_TCP_PROXIES",
30628            "TARGET_VPN_GATEWAYS",
30629            "TPU_LITE_DEVICE_V5",
30630            "TPU_LITE_PODSLICE_V5",
30631            "TPU_PODSLICE_V4",
30632            "URL_MAPS",
30633            "VPN_GATEWAYS",
30634            "VPN_TUNNELS",
30635            "XPN_SERVICE_PROJECTS"
30636          ]
30637        },
30638        "limit": {
30639          "description": "[Output Only] Quota limit for this metric.",
30640          "type": "number",
30641          "format": "double"
30642        },
30643        "usage": {
30644          "description": "[Output Only] Current usage of this metric.",
30645          "type": "number",
30646          "format": "double"
30647        },
30648        "owner": {
30649          "description": "[Output Only] Owning resource. This is the resource on which this quota is applied.",
30650          "type": "string"
30651        }
30652      }
30653    },
30654    "UsageExportLocation": {
30655      "id": "UsageExportLocation",
30656      "description": "The location in Cloud Storage and naming method of the daily usage report. Contains bucket_name and report_name prefix.",
30657      "type": "object",
30658      "properties": {
30659        "bucketName": {
30660          "description": "The name of an existing bucket in Cloud Storage where the usage report object is stored. The Google Service Account is granted write access to this bucket. This can either be the bucket name by itself, such as example-bucket, or the bucket name with gs:// or https://storage.googleapis.com/ in front of it, such as gs://example-bucket.",
30661          "type": "string"
30662        },
30663        "reportNamePrefix": {
30664          "description": "An optional prefix for the name of the usage report object stored in bucketName. If not supplied, defaults to usage_gce. The report is stored as a CSV file named report_name_prefix_gce_YYYYMMDD.csv where YYYYMMDD is the day of the usage according to Pacific Time. If you supply a prefix, it should conform to Cloud Storage object naming conventions.",
30665          "type": "string"
30666        }
30667      }
30668    },
30669    "InstanceMoveRequest": {
30670      "id": "InstanceMoveRequest",
30671      "type": "object",
30672      "properties": {
30673        "targetInstance": {
30674          "description": "The URL of the target instance to move. This can be a full or partial URL. For example, the following are all valid URLs to an instance: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /instances/instance - projects/project/zones/zone/instances/instance - zones/zone/instances/instance ",
30675          "type": "string"
30676        },
30677        "destinationZone": {
30678          "description": "The URL of the destination zone to move the instance. This can be a full or partial URL. For example, the following are all valid URLs to a zone: - https://www.googleapis.com/compute/v1/projects/project/zones/zone - projects/project/zones/zone - zones/zone ",
30679          "type": "string"
30680        }
30681      }
30682    },
30683    "DiskMoveRequest": {
30684      "id": "DiskMoveRequest",
30685      "type": "object",
30686      "properties": {
30687        "targetDisk": {
30688          "description": "The URL of the target disk to move. This can be a full or partial URL. For example, the following are all valid URLs to a disk: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /disks/disk - projects/project/zones/zone/disks/disk - zones/zone/disks/disk ",
30689          "type": "string"
30690        },
30691        "destinationZone": {
30692          "description": "The URL of the destination zone to move the disk. This can be a full or partial URL. For example, the following are all valid URLs to a zone: - https://www.googleapis.com/compute/v1/projects/project/zones/zone - projects/project/zones/zone - zones/zone ",
30693          "type": "string"
30694        }
30695      }
30696    },
30697    "ProjectsListXpnHostsRequest": {
30698      "id": "ProjectsListXpnHostsRequest",
30699      "type": "object",
30700      "properties": {
30701        "organization": {
30702          "description": "Optional organization ID managed by Cloud Resource Manager, for which to list shared VPC host projects. If not specified, the organization will be inferred from the project.",
30703          "type": "string"
30704        }
30705      }
30706    },
30707    "XpnHostList": {
30708      "id": "XpnHostList",
30709      "type": "object",
30710      "properties": {
30711        "kind": {
30712          "description": "[Output Only] Type of resource. Always compute#xpnHostList for lists of shared VPC hosts.",
30713          "default": "compute#xpnHostList",
30714          "type": "string"
30715        },
30716        "id": {
30717          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
30718          "type": "string"
30719        },
30720        "items": {
30721          "description": "[Output Only] A list of shared VPC host project URLs.",
30722          "type": "array",
30723          "items": {
30724            "$ref": "Project"
30725          }
30726        },
30727        "nextPageToken": {
30728          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
30729          "type": "string"
30730        },
30731        "selfLink": {
30732          "description": "[Output Only] Server-defined URL for this resource.",
30733          "type": "string"
30734        },
30735        "warning": {
30736          "description": "[Output Only] Informational warning message.",
30737          "type": "object",
30738          "properties": {
30739            "code": {
30740              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
30741              "type": "string",
30742              "enumDescriptions": [
30743                "Warning about failed cleanup of transient changes made by a failed operation.",
30744                "A link to a deprecated resource was created.",
30745                "When deploying and at least one of the resources has a type marked as deprecated",
30746                "The user created a boot disk that is larger than image size.",
30747                "When deploying and at least one of the resources has a type marked as experimental",
30748                "Warning that is present in an external api call",
30749                "Warning that value of a field has been overridden. Deprecated unused field.",
30750                "The operation involved use of an injected kernel, which is deprecated.",
30751                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
30752                "When deploying a deployment with a exceedingly large number of resources",
30753                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
30754                "A resource depends on a missing type",
30755                "The route's nextHopIp address is not assigned to an instance on the network.",
30756                "The route's next hop instance cannot ip forward.",
30757                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
30758                "The route's nextHopInstance URL refers to an instance that does not exist.",
30759                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
30760                "The route's next hop instance does not have a status of RUNNING.",
30761                "Error which is not critical. We decided to continue the process despite the mentioned error.",
30762                "No results are present on a particular list page.",
30763                "Success is reported, but some results may be missing due to errors",
30764                "The user attempted to use a resource that requires a TOS they have not accepted.",
30765                "Warning that a resource is in use.",
30766                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
30767                "When a resource schema validation is ignored.",
30768                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
30769                "When undeclared properties in the schema are present",
30770                "A given scope cannot be reached."
30771              ],
30772              "enumDeprecated": [
30773                false,
30774                false,
30775                false,
30776                false,
30777                false,
30778                false,
30779                true,
30780                false,
30781                false,
30782                false,
30783                false,
30784                false,
30785                false,
30786                false,
30787                false,
30788                false,
30789                false,
30790                false,
30791                false,
30792                false,
30793                false,
30794                false,
30795                false,
30796                false,
30797                false,
30798                false,
30799                false,
30800                false
30801              ],
30802              "enum": [
30803                "CLEANUP_FAILED",
30804                "DEPRECATED_RESOURCE_USED",
30805                "DEPRECATED_TYPE_USED",
30806                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
30807                "EXPERIMENTAL_TYPE_USED",
30808                "EXTERNAL_API_WARNING",
30809                "FIELD_VALUE_OVERRIDEN",
30810                "INJECTED_KERNELS_DEPRECATED",
30811                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
30812                "LARGE_DEPLOYMENT_WARNING",
30813                "LIST_OVERHEAD_QUOTA_EXCEED",
30814                "MISSING_TYPE_DEPENDENCY",
30815                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
30816                "NEXT_HOP_CANNOT_IP_FORWARD",
30817                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
30818                "NEXT_HOP_INSTANCE_NOT_FOUND",
30819                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
30820                "NEXT_HOP_NOT_RUNNING",
30821                "NOT_CRITICAL_ERROR",
30822                "NO_RESULTS_ON_PAGE",
30823                "PARTIAL_SUCCESS",
30824                "REQUIRED_TOS_AGREEMENT",
30825                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
30826                "RESOURCE_NOT_DELETED",
30827                "SCHEMA_VALIDATION_IGNORED",
30828                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
30829                "UNDECLARED_PROPERTIES",
30830                "UNREACHABLE"
30831              ]
30832            },
30833            "message": {
30834              "description": "[Output Only] A human-readable description of the warning code.",
30835              "type": "string"
30836            },
30837            "data": {
30838              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
30839              "type": "array",
30840              "items": {
30841                "type": "object",
30842                "properties": {
30843                  "key": {
30844                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
30845                    "type": "string"
30846                  },
30847                  "value": {
30848                    "description": "[Output Only] A warning data value corresponding to the key.",
30849                    "type": "string"
30850                  }
30851                }
30852              }
30853            }
30854          }
30855        }
30856      }
30857    },
30858    "ProjectsEnableXpnResourceRequest": {
30859      "id": "ProjectsEnableXpnResourceRequest",
30860      "type": "object",
30861      "properties": {
30862        "xpnResource": {
30863          "description": "Service resource (a.k.a service project) ID.",
30864          "$ref": "XpnResourceId"
30865        }
30866      }
30867    },
30868    "XpnResourceId": {
30869      "id": "XpnResourceId",
30870      "description": "Service resource (a.k.a service project) ID.",
30871      "type": "object",
30872      "properties": {
30873        "type": {
30874          "description": "The type of the service resource.",
30875          "type": "string",
30876          "enumDescriptions": [
30877            "",
30878            ""
30879          ],
30880          "enum": [
30881            "PROJECT",
30882            "XPN_RESOURCE_TYPE_UNSPECIFIED"
30883          ]
30884        },
30885        "id": {
30886          "description": "The ID of the service resource. In the case of projects, this field supports project id (e.g., my-project-123) and project number (e.g. 12345678).",
30887          "type": "string"
30888        }
30889      }
30890    },
30891    "ProjectsDisableXpnResourceRequest": {
30892      "id": "ProjectsDisableXpnResourceRequest",
30893      "type": "object",
30894      "properties": {
30895        "xpnResource": {
30896          "description": "Service resource (a.k.a service project) ID.",
30897          "$ref": "XpnResourceId"
30898        }
30899      }
30900    },
30901    "ProjectsGetXpnResources": {
30902      "id": "ProjectsGetXpnResources",
30903      "type": "object",
30904      "properties": {
30905        "kind": {
30906          "description": "[Output Only] Type of resource. Always compute#projectsGetXpnResources for lists of service resources (a.k.a service projects)",
30907          "default": "compute#projectsGetXpnResources",
30908          "type": "string"
30909        },
30910        "resources": {
30911          "description": "Service resources (a.k.a service projects) attached to this project as their shared VPC host.",
30912          "type": "array",
30913          "items": {
30914            "$ref": "XpnResourceId"
30915          }
30916        },
30917        "nextPageToken": {
30918          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
30919          "type": "string"
30920        }
30921      }
30922    },
30923    "ProjectsSetDefaultNetworkTierRequest": {
30924      "id": "ProjectsSetDefaultNetworkTierRequest",
30925      "type": "object",
30926      "properties": {
30927        "networkTier": {
30928          "description": "Default network tier to be set.",
30929          "type": "string",
30930          "enumDescriptions": [
30931            "Public internet quality with fixed bandwidth.",
30932            "High quality, Google-grade network tier, support for all networking products.",
30933            "Public internet quality, only limited support for other networking products.",
30934            "(Output only) Temporary tier for FIXED_STANDARD when fixed standard tier is expired or not configured."
30935          ],
30936          "enum": [
30937            "FIXED_STANDARD",
30938            "PREMIUM",
30939            "STANDARD",
30940            "STANDARD_OVERRIDES_FIXED_STANDARD"
30941          ]
30942        }
30943      }
30944    },
30945    "ProjectsSetCloudArmorTierRequest": {
30946      "id": "ProjectsSetCloudArmorTierRequest",
30947      "type": "object",
30948      "properties": {
30949        "cloudArmorTier": {
30950          "description": "Managed protection tier to be set.",
30951          "type": "string",
30952          "enumDescriptions": [
30953            "Enterprise tier protection billed annually.",
30954            "Enterprise tier protection billed monthly.",
30955            "Standard protection."
30956          ],
30957          "enum": [
30958            "CA_ENTERPRISE_ANNUAL",
30959            "CA_ENTERPRISE_PAYGO",
30960            "CA_STANDARD"
30961          ]
30962        }
30963      }
30964    },
30965    "PublicAdvertisedPrefixList": {
30966      "id": "PublicAdvertisedPrefixList",
30967      "type": "object",
30968      "properties": {
30969        "kind": {
30970          "description": "[Output Only] Type of the resource. Always compute#publicAdvertisedPrefix for public advertised prefixes.",
30971          "default": "compute#publicAdvertisedPrefixList",
30972          "type": "string"
30973        },
30974        "id": {
30975          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
30976          "type": "string"
30977        },
30978        "items": {
30979          "description": "A list of PublicAdvertisedPrefix resources.",
30980          "type": "array",
30981          "items": {
30982            "$ref": "PublicAdvertisedPrefix"
30983          }
30984        },
30985        "nextPageToken": {
30986          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
30987          "type": "string"
30988        },
30989        "selfLink": {
30990          "description": "[Output Only] Server-defined URL for this resource.",
30991          "type": "string"
30992        },
30993        "warning": {
30994          "description": "[Output Only] Informational warning message.",
30995          "type": "object",
30996          "properties": {
30997            "code": {
30998              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
30999              "type": "string",
31000              "enumDescriptions": [
31001                "Warning about failed cleanup of transient changes made by a failed operation.",
31002                "A link to a deprecated resource was created.",
31003                "When deploying and at least one of the resources has a type marked as deprecated",
31004                "The user created a boot disk that is larger than image size.",
31005                "When deploying and at least one of the resources has a type marked as experimental",
31006                "Warning that is present in an external api call",
31007                "Warning that value of a field has been overridden. Deprecated unused field.",
31008                "The operation involved use of an injected kernel, which is deprecated.",
31009                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
31010                "When deploying a deployment with a exceedingly large number of resources",
31011                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
31012                "A resource depends on a missing type",
31013                "The route's nextHopIp address is not assigned to an instance on the network.",
31014                "The route's next hop instance cannot ip forward.",
31015                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
31016                "The route's nextHopInstance URL refers to an instance that does not exist.",
31017                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
31018                "The route's next hop instance does not have a status of RUNNING.",
31019                "Error which is not critical. We decided to continue the process despite the mentioned error.",
31020                "No results are present on a particular list page.",
31021                "Success is reported, but some results may be missing due to errors",
31022                "The user attempted to use a resource that requires a TOS they have not accepted.",
31023                "Warning that a resource is in use.",
31024                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
31025                "When a resource schema validation is ignored.",
31026                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
31027                "When undeclared properties in the schema are present",
31028                "A given scope cannot be reached."
31029              ],
31030              "enumDeprecated": [
31031                false,
31032                false,
31033                false,
31034                false,
31035                false,
31036                false,
31037                true,
31038                false,
31039                false,
31040                false,
31041                false,
31042                false,
31043                false,
31044                false,
31045                false,
31046                false,
31047                false,
31048                false,
31049                false,
31050                false,
31051                false,
31052                false,
31053                false,
31054                false,
31055                false,
31056                false,
31057                false,
31058                false
31059              ],
31060              "enum": [
31061                "CLEANUP_FAILED",
31062                "DEPRECATED_RESOURCE_USED",
31063                "DEPRECATED_TYPE_USED",
31064                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
31065                "EXPERIMENTAL_TYPE_USED",
31066                "EXTERNAL_API_WARNING",
31067                "FIELD_VALUE_OVERRIDEN",
31068                "INJECTED_KERNELS_DEPRECATED",
31069                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
31070                "LARGE_DEPLOYMENT_WARNING",
31071                "LIST_OVERHEAD_QUOTA_EXCEED",
31072                "MISSING_TYPE_DEPENDENCY",
31073                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
31074                "NEXT_HOP_CANNOT_IP_FORWARD",
31075                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
31076                "NEXT_HOP_INSTANCE_NOT_FOUND",
31077                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
31078                "NEXT_HOP_NOT_RUNNING",
31079                "NOT_CRITICAL_ERROR",
31080                "NO_RESULTS_ON_PAGE",
31081                "PARTIAL_SUCCESS",
31082                "REQUIRED_TOS_AGREEMENT",
31083                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
31084                "RESOURCE_NOT_DELETED",
31085                "SCHEMA_VALIDATION_IGNORED",
31086                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
31087                "UNDECLARED_PROPERTIES",
31088                "UNREACHABLE"
31089              ]
31090            },
31091            "message": {
31092              "description": "[Output Only] A human-readable description of the warning code.",
31093              "type": "string"
31094            },
31095            "data": {
31096              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
31097              "type": "array",
31098              "items": {
31099                "type": "object",
31100                "properties": {
31101                  "key": {
31102                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
31103                    "type": "string"
31104                  },
31105                  "value": {
31106                    "description": "[Output Only] A warning data value corresponding to the key.",
31107                    "type": "string"
31108                  }
31109                }
31110              }
31111            }
31112          }
31113        }
31114      }
31115    },
31116    "PublicAdvertisedPrefix": {
31117      "id": "PublicAdvertisedPrefix",
31118      "description": "A public advertised prefix represents an aggregated IP prefix or netblock which customers bring to cloud. The IP prefix is a single unit of route advertisement and is announced globally to the internet.",
31119      "type": "object",
31120      "properties": {
31121        "kind": {
31122          "description": "[Output Only] Type of the resource. Always compute#publicAdvertisedPrefix for public advertised prefixes.",
31123          "default": "compute#publicAdvertisedPrefix",
31124          "type": "string"
31125        },
31126        "id": {
31127          "description": "[Output Only] The unique identifier for the resource type. The server generates this identifier.",
31128          "type": "string",
31129          "format": "uint64"
31130        },
31131        "creationTimestamp": {
31132          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
31133          "type": "string"
31134        },
31135        "name": {
31136          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
31137          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
31138          "annotations": {
31139            "required": [
31140              "compute.publicAdvertisedPrefixes.insert"
31141            ]
31142          },
31143          "type": "string"
31144        },
31145        "description": {
31146          "description": "An optional description of this resource. Provide this property when you create the resource.",
31147          "type": "string"
31148        },
31149        "selfLink": {
31150          "description": "[Output Only] Server-defined URL for the resource.",
31151          "type": "string"
31152        },
31153        "ipCidrRange": {
31154          "description": "The address range, in CIDR format, represented by this public advertised prefix.",
31155          "type": "string"
31156        },
31157        "dnsVerificationIp": {
31158          "description": "The address to be used for reverse DNS verification.",
31159          "type": "string"
31160        },
31161        "sharedSecret": {
31162          "description": "[Output Only] The shared secret to be used for reverse DNS verification.",
31163          "type": "string"
31164        },
31165        "status": {
31166          "description": "The status of the public advertised prefix. Possible values include: - `INITIAL`: RPKI validation is complete. - `PTR_CONFIGURED`: User has configured the PTR. - `VALIDATED`: Reverse DNS lookup is successful. - `REVERSE_DNS_LOOKUP_FAILED`: Reverse DNS lookup failed. - `PREFIX_CONFIGURATION_IN_PROGRESS`: The prefix is being configured. - `PREFIX_CONFIGURATION_COMPLETE`: The prefix is fully configured. - `PREFIX_REMOVAL_IN_PROGRESS`: The prefix is being removed. ",
31167          "type": "string",
31168          "enumDescriptions": [
31169            "The prefix is announced to Internet.",
31170            "RPKI validation is complete.",
31171            "The prefix is fully configured.",
31172            "The prefix is being configured.",
31173            "The prefix is being removed.",
31174            "User has configured the PTR.",
31175            "The prefix is currently withdrawn but ready to be announced.",
31176            "Reverse DNS lookup failed.",
31177            "Reverse DNS lookup is successful."
31178          ],
31179          "enum": [
31180            "ANNOUNCED_TO_INTERNET",
31181            "INITIAL",
31182            "PREFIX_CONFIGURATION_COMPLETE",
31183            "PREFIX_CONFIGURATION_IN_PROGRESS",
31184            "PREFIX_REMOVAL_IN_PROGRESS",
31185            "PTR_CONFIGURED",
31186            "READY_TO_ANNOUNCE",
31187            "REVERSE_DNS_LOOKUP_FAILED",
31188            "VALIDATED"
31189          ]
31190        },
31191        "pdpScope": {
31192          "description": "Specifies how child public delegated prefix will be scoped. It could be one of following values: - `REGIONAL`: The public delegated prefix is regional only. The provisioning will take a few minutes. - `GLOBAL`: The public delegated prefix is global only. The provisioning will take ~4 weeks. - `GLOBAL_AND_REGIONAL` [output only]: The public delegated prefixes is BYOIP V1 legacy prefix. This is output only value and no longer supported in BYOIP V2. ",
31193          "type": "string",
31194          "enumDescriptions": [
31195            "The public delegated prefix is global only. The provisioning will take ~4 weeks.",
31196            "The public delegated prefixes is BYOIP V1 legacy prefix. This is output only value and no longer supported in BYOIP V2.",
31197            "The public delegated prefix is regional only. The provisioning will take a few minutes."
31198          ],
31199          "enum": [
31200            "GLOBAL",
31201            "GLOBAL_AND_REGIONAL",
31202            "REGIONAL"
31203          ]
31204        },
31205        "publicDelegatedPrefixs": {
31206          "description": "[Output Only] The list of public delegated prefixes that exist for this public advertised prefix.",
31207          "type": "array",
31208          "items": {
31209            "$ref": "PublicAdvertisedPrefixPublicDelegatedPrefix"
31210          }
31211        },
31212        "fingerprint": {
31213          "description": "Fingerprint of this resource. A hash of the contents stored in this object. This field is used in optimistic locking. This field will be ignored when inserting a new PublicAdvertisedPrefix. An up-to-date fingerprint must be provided in order to update the PublicAdvertisedPrefix, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve a PublicAdvertisedPrefix.",
31214          "type": "string",
31215          "format": "byte"
31216        },
31217        "byoipApiVersion": {
31218          "description": "[Output Only] The version of BYOIP API.",
31219          "type": "string",
31220          "enumDescriptions": [
31221            "This public advertised prefix can be used to create both regional and global public delegated prefixes. It usually takes 4 weeks to create or delete a public delegated prefix. The BGP status cannot be changed.",
31222            "This public advertised prefix can only be used to create regional public delegated prefixes. Public delegated prefix creation and deletion takes minutes and the BGP status can be modified."
31223          ],
31224          "enum": [
31225            "V1",
31226            "V2"
31227          ]
31228        }
31229      }
31230    },
31231    "PublicAdvertisedPrefixPublicDelegatedPrefix": {
31232      "id": "PublicAdvertisedPrefixPublicDelegatedPrefix",
31233      "description": "Represents a CIDR range which can be used to assign addresses.",
31234      "type": "object",
31235      "properties": {
31236        "name": {
31237          "description": "The name of the public delegated prefix",
31238          "type": "string"
31239        },
31240        "region": {
31241          "description": "The region of the public delegated prefix if it is regional. If absent, the prefix is global.",
31242          "type": "string"
31243        },
31244        "project": {
31245          "description": "The project number of the public delegated prefix",
31246          "type": "string"
31247        },
31248        "status": {
31249          "description": "The status of the public delegated prefix. Possible values are: INITIALIZING: The public delegated prefix is being initialized and addresses cannot be created yet. ANNOUNCED: The public delegated prefix is active.",
31250          "type": "string"
31251        },
31252        "ipRange": {
31253          "description": "The IP address range of the public delegated prefix",
31254          "type": "string"
31255        }
31256      }
31257    },
31258    "PublicDelegatedPrefixList": {
31259      "id": "PublicDelegatedPrefixList",
31260      "type": "object",
31261      "properties": {
31262        "kind": {
31263          "description": "[Output Only] Type of the resource. Always compute#publicDelegatedPrefixList for public delegated prefixes.",
31264          "default": "compute#publicDelegatedPrefixList",
31265          "type": "string"
31266        },
31267        "id": {
31268          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
31269          "type": "string"
31270        },
31271        "items": {
31272          "description": "A list of PublicDelegatedPrefix resources.",
31273          "type": "array",
31274          "items": {
31275            "$ref": "PublicDelegatedPrefix"
31276          }
31277        },
31278        "nextPageToken": {
31279          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
31280          "type": "string"
31281        },
31282        "selfLink": {
31283          "description": "[Output Only] Server-defined URL for this resource.",
31284          "type": "string"
31285        },
31286        "warning": {
31287          "description": "[Output Only] Informational warning message.",
31288          "type": "object",
31289          "properties": {
31290            "code": {
31291              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
31292              "type": "string",
31293              "enumDescriptions": [
31294                "Warning about failed cleanup of transient changes made by a failed operation.",
31295                "A link to a deprecated resource was created.",
31296                "When deploying and at least one of the resources has a type marked as deprecated",
31297                "The user created a boot disk that is larger than image size.",
31298                "When deploying and at least one of the resources has a type marked as experimental",
31299                "Warning that is present in an external api call",
31300                "Warning that value of a field has been overridden. Deprecated unused field.",
31301                "The operation involved use of an injected kernel, which is deprecated.",
31302                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
31303                "When deploying a deployment with a exceedingly large number of resources",
31304                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
31305                "A resource depends on a missing type",
31306                "The route's nextHopIp address is not assigned to an instance on the network.",
31307                "The route's next hop instance cannot ip forward.",
31308                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
31309                "The route's nextHopInstance URL refers to an instance that does not exist.",
31310                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
31311                "The route's next hop instance does not have a status of RUNNING.",
31312                "Error which is not critical. We decided to continue the process despite the mentioned error.",
31313                "No results are present on a particular list page.",
31314                "Success is reported, but some results may be missing due to errors",
31315                "The user attempted to use a resource that requires a TOS they have not accepted.",
31316                "Warning that a resource is in use.",
31317                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
31318                "When a resource schema validation is ignored.",
31319                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
31320                "When undeclared properties in the schema are present",
31321                "A given scope cannot be reached."
31322              ],
31323              "enumDeprecated": [
31324                false,
31325                false,
31326                false,
31327                false,
31328                false,
31329                false,
31330                true,
31331                false,
31332                false,
31333                false,
31334                false,
31335                false,
31336                false,
31337                false,
31338                false,
31339                false,
31340                false,
31341                false,
31342                false,
31343                false,
31344                false,
31345                false,
31346                false,
31347                false,
31348                false,
31349                false,
31350                false,
31351                false
31352              ],
31353              "enum": [
31354                "CLEANUP_FAILED",
31355                "DEPRECATED_RESOURCE_USED",
31356                "DEPRECATED_TYPE_USED",
31357                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
31358                "EXPERIMENTAL_TYPE_USED",
31359                "EXTERNAL_API_WARNING",
31360                "FIELD_VALUE_OVERRIDEN",
31361                "INJECTED_KERNELS_DEPRECATED",
31362                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
31363                "LARGE_DEPLOYMENT_WARNING",
31364                "LIST_OVERHEAD_QUOTA_EXCEED",
31365                "MISSING_TYPE_DEPENDENCY",
31366                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
31367                "NEXT_HOP_CANNOT_IP_FORWARD",
31368                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
31369                "NEXT_HOP_INSTANCE_NOT_FOUND",
31370                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
31371                "NEXT_HOP_NOT_RUNNING",
31372                "NOT_CRITICAL_ERROR",
31373                "NO_RESULTS_ON_PAGE",
31374                "PARTIAL_SUCCESS",
31375                "REQUIRED_TOS_AGREEMENT",
31376                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
31377                "RESOURCE_NOT_DELETED",
31378                "SCHEMA_VALIDATION_IGNORED",
31379                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
31380                "UNDECLARED_PROPERTIES",
31381                "UNREACHABLE"
31382              ]
31383            },
31384            "message": {
31385              "description": "[Output Only] A human-readable description of the warning code.",
31386              "type": "string"
31387            },
31388            "data": {
31389              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
31390              "type": "array",
31391              "items": {
31392                "type": "object",
31393                "properties": {
31394                  "key": {
31395                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
31396                    "type": "string"
31397                  },
31398                  "value": {
31399                    "description": "[Output Only] A warning data value corresponding to the key.",
31400                    "type": "string"
31401                  }
31402                }
31403              }
31404            }
31405          }
31406        }
31407      }
31408    },
31409    "PublicDelegatedPrefix": {
31410      "id": "PublicDelegatedPrefix",
31411      "description": "A PublicDelegatedPrefix resource represents an IP block within a PublicAdvertisedPrefix that is configured within a single cloud scope (global or region). IPs in the block can be allocated to resources within that scope. Public delegated prefixes may be further broken up into smaller IP blocks in the same scope as the parent block.",
31412      "type": "object",
31413      "properties": {
31414        "kind": {
31415          "description": "[Output Only] Type of the resource. Always compute#publicDelegatedPrefix for public delegated prefixes.",
31416          "default": "compute#publicDelegatedPrefix",
31417          "type": "string"
31418        },
31419        "id": {
31420          "description": "[Output Only] The unique identifier for the resource type. The server generates this identifier.",
31421          "type": "string",
31422          "format": "uint64"
31423        },
31424        "creationTimestamp": {
31425          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
31426          "type": "string"
31427        },
31428        "name": {
31429          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
31430          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
31431          "annotations": {
31432            "required": [
31433              "compute.publicDelegatedPrefixes.insert"
31434            ]
31435          },
31436          "type": "string"
31437        },
31438        "description": {
31439          "description": "An optional description of this resource. Provide this property when you create the resource.",
31440          "type": "string"
31441        },
31442        "selfLink": {
31443          "description": "[Output Only] Server-defined URL for the resource.",
31444          "type": "string"
31445        },
31446        "region": {
31447          "description": "[Output Only] URL of the region where the public delegated prefix resides. This field applies only to the region resource. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
31448          "type": "string"
31449        },
31450        "ipCidrRange": {
31451          "description": "The IP address range, in CIDR format, represented by this public delegated prefix.",
31452          "type": "string"
31453        },
31454        "status": {
31455          "description": "[Output Only] The status of the public delegated prefix, which can be one of following values: - `INITIALIZING` The public delegated prefix is being initialized and addresses cannot be created yet. - `READY_TO_ANNOUNCE` The public delegated prefix is a live migration prefix and is active. - `ANNOUNCED` The public delegated prefix is active. - `DELETING` The public delegated prefix is being deprovsioned. ",
31456          "type": "string",
31457          "enumDescriptions": [
31458            "The public delegated prefix is active.",
31459            "The prefix is announced within Google network.",
31460            "The prefix is announced to Internet and within Google.",
31461            "The public delegated prefix is being deprovsioned.",
31462            "The public delegated prefix is being initialized and addresses cannot be created yet.",
31463            "The public delegated prefix is currently withdrawn but ready to be announced."
31464          ],
31465          "enum": [
31466            "ANNOUNCED",
31467            "ANNOUNCED_TO_GOOGLE",
31468            "ANNOUNCED_TO_INTERNET",
31469            "DELETING",
31470            "INITIALIZING",
31471            "READY_TO_ANNOUNCE"
31472          ]
31473        },
31474        "parentPrefix": {
31475          "description": "The URL of parent prefix. Either PublicAdvertisedPrefix or PublicDelegatedPrefix.",
31476          "type": "string"
31477        },
31478        "publicDelegatedSubPrefixs": {
31479          "description": "The list of sub public delegated prefixes that exist for this public delegated prefix.",
31480          "type": "array",
31481          "items": {
31482            "$ref": "PublicDelegatedPrefixPublicDelegatedSubPrefix"
31483          }
31484        },
31485        "isLiveMigration": {
31486          "description": "If true, the prefix will be live migrated.",
31487          "type": "boolean"
31488        },
31489        "fingerprint": {
31490          "description": "Fingerprint of this resource. A hash of the contents stored in this object. This field is used in optimistic locking. This field will be ignored when inserting a new PublicDelegatedPrefix. An up-to-date fingerprint must be provided in order to update the PublicDelegatedPrefix, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve a PublicDelegatedPrefix.",
31491          "type": "string",
31492          "format": "byte"
31493        },
31494        "byoipApiVersion": {
31495          "description": "[Output Only] The version of BYOIP API.",
31496          "type": "string",
31497          "enumDescriptions": [
31498            "This public delegated prefix usually takes 4 weeks to delete, and the BGP status cannot be changed. Announce and Withdraw APIs can not be used on this prefix.",
31499            "This public delegated prefix takes minutes to delete. Announce and Withdraw APIs can be used on this prefix to change the BGP status."
31500          ],
31501          "enum": [
31502            "V1",
31503            "V2"
31504          ]
31505        }
31506      }
31507    },
31508    "PublicDelegatedPrefixPublicDelegatedSubPrefix": {
31509      "id": "PublicDelegatedPrefixPublicDelegatedSubPrefix",
31510      "description": "Represents a sub PublicDelegatedPrefix.",
31511      "type": "object",
31512      "properties": {
31513        "name": {
31514          "description": "The name of the sub public delegated prefix.",
31515          "type": "string"
31516        },
31517        "description": {
31518          "description": "An optional description of this resource. Provide this property when you create the resource.",
31519          "type": "string"
31520        },
31521        "region": {
31522          "description": "[Output Only] The region of the sub public delegated prefix if it is regional. If absent, the sub prefix is global.",
31523          "type": "string"
31524        },
31525        "status": {
31526          "description": "[Output Only] The status of the sub public delegated prefix.",
31527          "type": "string",
31528          "enumDescriptions": [
31529            "",
31530            ""
31531          ],
31532          "enum": [
31533            "ACTIVE",
31534            "INACTIVE"
31535          ]
31536        },
31537        "ipCidrRange": {
31538          "description": "The IP address range, in CIDR format, represented by this sub public delegated prefix.",
31539          "type": "string"
31540        },
31541        "delegateeProject": {
31542          "description": "Name of the project scoping this PublicDelegatedSubPrefix.",
31543          "type": "string"
31544        },
31545        "isAddress": {
31546          "description": "Whether the sub prefix is delegated to create Address resources in the delegatee project.",
31547          "type": "boolean"
31548        }
31549      }
31550    },
31551    "PublicDelegatedPrefixAggregatedList": {
31552      "id": "PublicDelegatedPrefixAggregatedList",
31553      "type": "object",
31554      "properties": {
31555        "kind": {
31556          "description": "[Output Only] Type of the resource. Always compute#publicDelegatedPrefixAggregatedList for aggregated lists of public delegated prefixes.",
31557          "default": "compute#publicDelegatedPrefixAggregatedList",
31558          "type": "string"
31559        },
31560        "id": {
31561          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
31562          "type": "string"
31563        },
31564        "items": {
31565          "description": "A list of PublicDelegatedPrefixesScopedList resources.",
31566          "type": "object",
31567          "additionalProperties": {
31568            "description": "[Output Only] Name of the scope containing this set of PublicDelegatedPrefixes.",
31569            "$ref": "PublicDelegatedPrefixesScopedList"
31570          }
31571        },
31572        "nextPageToken": {
31573          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
31574          "type": "string"
31575        },
31576        "selfLink": {
31577          "description": "[Output Only] Server-defined URL for this resource.",
31578          "type": "string"
31579        },
31580        "warning": {
31581          "description": "[Output Only] Informational warning message.",
31582          "type": "object",
31583          "properties": {
31584            "code": {
31585              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
31586              "type": "string",
31587              "enumDescriptions": [
31588                "Warning about failed cleanup of transient changes made by a failed operation.",
31589                "A link to a deprecated resource was created.",
31590                "When deploying and at least one of the resources has a type marked as deprecated",
31591                "The user created a boot disk that is larger than image size.",
31592                "When deploying and at least one of the resources has a type marked as experimental",
31593                "Warning that is present in an external api call",
31594                "Warning that value of a field has been overridden. Deprecated unused field.",
31595                "The operation involved use of an injected kernel, which is deprecated.",
31596                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
31597                "When deploying a deployment with a exceedingly large number of resources",
31598                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
31599                "A resource depends on a missing type",
31600                "The route's nextHopIp address is not assigned to an instance on the network.",
31601                "The route's next hop instance cannot ip forward.",
31602                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
31603                "The route's nextHopInstance URL refers to an instance that does not exist.",
31604                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
31605                "The route's next hop instance does not have a status of RUNNING.",
31606                "Error which is not critical. We decided to continue the process despite the mentioned error.",
31607                "No results are present on a particular list page.",
31608                "Success is reported, but some results may be missing due to errors",
31609                "The user attempted to use a resource that requires a TOS they have not accepted.",
31610                "Warning that a resource is in use.",
31611                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
31612                "When a resource schema validation is ignored.",
31613                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
31614                "When undeclared properties in the schema are present",
31615                "A given scope cannot be reached."
31616              ],
31617              "enumDeprecated": [
31618                false,
31619                false,
31620                false,
31621                false,
31622                false,
31623                false,
31624                true,
31625                false,
31626                false,
31627                false,
31628                false,
31629                false,
31630                false,
31631                false,
31632                false,
31633                false,
31634                false,
31635                false,
31636                false,
31637                false,
31638                false,
31639                false,
31640                false,
31641                false,
31642                false,
31643                false,
31644                false,
31645                false
31646              ],
31647              "enum": [
31648                "CLEANUP_FAILED",
31649                "DEPRECATED_RESOURCE_USED",
31650                "DEPRECATED_TYPE_USED",
31651                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
31652                "EXPERIMENTAL_TYPE_USED",
31653                "EXTERNAL_API_WARNING",
31654                "FIELD_VALUE_OVERRIDEN",
31655                "INJECTED_KERNELS_DEPRECATED",
31656                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
31657                "LARGE_DEPLOYMENT_WARNING",
31658                "LIST_OVERHEAD_QUOTA_EXCEED",
31659                "MISSING_TYPE_DEPENDENCY",
31660                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
31661                "NEXT_HOP_CANNOT_IP_FORWARD",
31662                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
31663                "NEXT_HOP_INSTANCE_NOT_FOUND",
31664                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
31665                "NEXT_HOP_NOT_RUNNING",
31666                "NOT_CRITICAL_ERROR",
31667                "NO_RESULTS_ON_PAGE",
31668                "PARTIAL_SUCCESS",
31669                "REQUIRED_TOS_AGREEMENT",
31670                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
31671                "RESOURCE_NOT_DELETED",
31672                "SCHEMA_VALIDATION_IGNORED",
31673                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
31674                "UNDECLARED_PROPERTIES",
31675                "UNREACHABLE"
31676              ]
31677            },
31678            "message": {
31679              "description": "[Output Only] A human-readable description of the warning code.",
31680              "type": "string"
31681            },
31682            "data": {
31683              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
31684              "type": "array",
31685              "items": {
31686                "type": "object",
31687                "properties": {
31688                  "key": {
31689                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
31690                    "type": "string"
31691                  },
31692                  "value": {
31693                    "description": "[Output Only] A warning data value corresponding to the key.",
31694                    "type": "string"
31695                  }
31696                }
31697              }
31698            }
31699          }
31700        },
31701        "unreachables": {
31702          "description": "[Output Only] Unreachable resources.",
31703          "type": "array",
31704          "items": {
31705            "type": "string"
31706          }
31707        }
31708      }
31709    },
31710    "PublicDelegatedPrefixesScopedList": {
31711      "id": "PublicDelegatedPrefixesScopedList",
31712      "type": "object",
31713      "properties": {
31714        "publicDelegatedPrefixes": {
31715          "description": "[Output Only] A list of PublicDelegatedPrefixes contained in this scope.",
31716          "type": "array",
31717          "items": {
31718            "$ref": "PublicDelegatedPrefix"
31719          }
31720        },
31721        "warning": {
31722          "description": "[Output Only] Informational warning which replaces the list of public delegated prefixes when the list is empty.",
31723          "type": "object",
31724          "properties": {
31725            "code": {
31726              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
31727              "type": "string",
31728              "enumDescriptions": [
31729                "Warning about failed cleanup of transient changes made by a failed operation.",
31730                "A link to a deprecated resource was created.",
31731                "When deploying and at least one of the resources has a type marked as deprecated",
31732                "The user created a boot disk that is larger than image size.",
31733                "When deploying and at least one of the resources has a type marked as experimental",
31734                "Warning that is present in an external api call",
31735                "Warning that value of a field has been overridden. Deprecated unused field.",
31736                "The operation involved use of an injected kernel, which is deprecated.",
31737                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
31738                "When deploying a deployment with a exceedingly large number of resources",
31739                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
31740                "A resource depends on a missing type",
31741                "The route's nextHopIp address is not assigned to an instance on the network.",
31742                "The route's next hop instance cannot ip forward.",
31743                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
31744                "The route's nextHopInstance URL refers to an instance that does not exist.",
31745                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
31746                "The route's next hop instance does not have a status of RUNNING.",
31747                "Error which is not critical. We decided to continue the process despite the mentioned error.",
31748                "No results are present on a particular list page.",
31749                "Success is reported, but some results may be missing due to errors",
31750                "The user attempted to use a resource that requires a TOS they have not accepted.",
31751                "Warning that a resource is in use.",
31752                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
31753                "When a resource schema validation is ignored.",
31754                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
31755                "When undeclared properties in the schema are present",
31756                "A given scope cannot be reached."
31757              ],
31758              "enumDeprecated": [
31759                false,
31760                false,
31761                false,
31762                false,
31763                false,
31764                false,
31765                true,
31766                false,
31767                false,
31768                false,
31769                false,
31770                false,
31771                false,
31772                false,
31773                false,
31774                false,
31775                false,
31776                false,
31777                false,
31778                false,
31779                false,
31780                false,
31781                false,
31782                false,
31783                false,
31784                false,
31785                false,
31786                false
31787              ],
31788              "enum": [
31789                "CLEANUP_FAILED",
31790                "DEPRECATED_RESOURCE_USED",
31791                "DEPRECATED_TYPE_USED",
31792                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
31793                "EXPERIMENTAL_TYPE_USED",
31794                "EXTERNAL_API_WARNING",
31795                "FIELD_VALUE_OVERRIDEN",
31796                "INJECTED_KERNELS_DEPRECATED",
31797                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
31798                "LARGE_DEPLOYMENT_WARNING",
31799                "LIST_OVERHEAD_QUOTA_EXCEED",
31800                "MISSING_TYPE_DEPENDENCY",
31801                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
31802                "NEXT_HOP_CANNOT_IP_FORWARD",
31803                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
31804                "NEXT_HOP_INSTANCE_NOT_FOUND",
31805                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
31806                "NEXT_HOP_NOT_RUNNING",
31807                "NOT_CRITICAL_ERROR",
31808                "NO_RESULTS_ON_PAGE",
31809                "PARTIAL_SUCCESS",
31810                "REQUIRED_TOS_AGREEMENT",
31811                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
31812                "RESOURCE_NOT_DELETED",
31813                "SCHEMA_VALIDATION_IGNORED",
31814                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
31815                "UNDECLARED_PROPERTIES",
31816                "UNREACHABLE"
31817              ]
31818            },
31819            "message": {
31820              "description": "[Output Only] A human-readable description of the warning code.",
31821              "type": "string"
31822            },
31823            "data": {
31824              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
31825              "type": "array",
31826              "items": {
31827                "type": "object",
31828                "properties": {
31829                  "key": {
31830                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
31831                    "type": "string"
31832                  },
31833                  "value": {
31834                    "description": "[Output Only] A warning data value corresponding to the key.",
31835                    "type": "string"
31836                  }
31837                }
31838              }
31839            }
31840          }
31841        }
31842      }
31843    },
31844    "RegionList": {
31845      "id": "RegionList",
31846      "description": "Contains a list of region resources.",
31847      "type": "object",
31848      "properties": {
31849        "kind": {
31850          "description": "[Output Only] Type of resource. Always compute#regionList for lists of regions.",
31851          "default": "compute#regionList",
31852          "type": "string"
31853        },
31854        "id": {
31855          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
31856          "type": "string"
31857        },
31858        "items": {
31859          "description": "A list of Region resources.",
31860          "type": "array",
31861          "items": {
31862            "$ref": "Region"
31863          }
31864        },
31865        "nextPageToken": {
31866          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
31867          "type": "string"
31868        },
31869        "selfLink": {
31870          "description": "[Output Only] Server-defined URL for this resource.",
31871          "type": "string"
31872        },
31873        "warning": {
31874          "description": "[Output Only] Informational warning message.",
31875          "type": "object",
31876          "properties": {
31877            "code": {
31878              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
31879              "type": "string",
31880              "enumDescriptions": [
31881                "Warning about failed cleanup of transient changes made by a failed operation.",
31882                "A link to a deprecated resource was created.",
31883                "When deploying and at least one of the resources has a type marked as deprecated",
31884                "The user created a boot disk that is larger than image size.",
31885                "When deploying and at least one of the resources has a type marked as experimental",
31886                "Warning that is present in an external api call",
31887                "Warning that value of a field has been overridden. Deprecated unused field.",
31888                "The operation involved use of an injected kernel, which is deprecated.",
31889                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
31890                "When deploying a deployment with a exceedingly large number of resources",
31891                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
31892                "A resource depends on a missing type",
31893                "The route's nextHopIp address is not assigned to an instance on the network.",
31894                "The route's next hop instance cannot ip forward.",
31895                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
31896                "The route's nextHopInstance URL refers to an instance that does not exist.",
31897                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
31898                "The route's next hop instance does not have a status of RUNNING.",
31899                "Error which is not critical. We decided to continue the process despite the mentioned error.",
31900                "No results are present on a particular list page.",
31901                "Success is reported, but some results may be missing due to errors",
31902                "The user attempted to use a resource that requires a TOS they have not accepted.",
31903                "Warning that a resource is in use.",
31904                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
31905                "When a resource schema validation is ignored.",
31906                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
31907                "When undeclared properties in the schema are present",
31908                "A given scope cannot be reached."
31909              ],
31910              "enumDeprecated": [
31911                false,
31912                false,
31913                false,
31914                false,
31915                false,
31916                false,
31917                true,
31918                false,
31919                false,
31920                false,
31921                false,
31922                false,
31923                false,
31924                false,
31925                false,
31926                false,
31927                false,
31928                false,
31929                false,
31930                false,
31931                false,
31932                false,
31933                false,
31934                false,
31935                false,
31936                false,
31937                false,
31938                false
31939              ],
31940              "enum": [
31941                "CLEANUP_FAILED",
31942                "DEPRECATED_RESOURCE_USED",
31943                "DEPRECATED_TYPE_USED",
31944                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
31945                "EXPERIMENTAL_TYPE_USED",
31946                "EXTERNAL_API_WARNING",
31947                "FIELD_VALUE_OVERRIDEN",
31948                "INJECTED_KERNELS_DEPRECATED",
31949                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
31950                "LARGE_DEPLOYMENT_WARNING",
31951                "LIST_OVERHEAD_QUOTA_EXCEED",
31952                "MISSING_TYPE_DEPENDENCY",
31953                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
31954                "NEXT_HOP_CANNOT_IP_FORWARD",
31955                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
31956                "NEXT_HOP_INSTANCE_NOT_FOUND",
31957                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
31958                "NEXT_HOP_NOT_RUNNING",
31959                "NOT_CRITICAL_ERROR",
31960                "NO_RESULTS_ON_PAGE",
31961                "PARTIAL_SUCCESS",
31962                "REQUIRED_TOS_AGREEMENT",
31963                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
31964                "RESOURCE_NOT_DELETED",
31965                "SCHEMA_VALIDATION_IGNORED",
31966                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
31967                "UNDECLARED_PROPERTIES",
31968                "UNREACHABLE"
31969              ]
31970            },
31971            "message": {
31972              "description": "[Output Only] A human-readable description of the warning code.",
31973              "type": "string"
31974            },
31975            "data": {
31976              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
31977              "type": "array",
31978              "items": {
31979                "type": "object",
31980                "properties": {
31981                  "key": {
31982                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
31983                    "type": "string"
31984                  },
31985                  "value": {
31986                    "description": "[Output Only] A warning data value corresponding to the key.",
31987                    "type": "string"
31988                  }
31989                }
31990              }
31991            }
31992          }
31993        }
31994      }
31995    },
31996    "Region": {
31997      "id": "Region",
31998      "description": "Represents a Region resource. A region is a geographical area where a resource is located. For more information, read Regions and Zones.",
31999      "type": "object",
32000      "properties": {
32001        "kind": {
32002          "description": "[Output Only] Type of the resource. Always compute#region for regions.",
32003          "default": "compute#region",
32004          "type": "string"
32005        },
32006        "id": {
32007          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
32008          "type": "string",
32009          "format": "uint64"
32010        },
32011        "creationTimestamp": {
32012          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
32013          "type": "string"
32014        },
32015        "name": {
32016          "description": "[Output Only] Name of the resource.",
32017          "type": "string"
32018        },
32019        "description": {
32020          "description": "[Output Only] Textual description of the resource.",
32021          "type": "string"
32022        },
32023        "status": {
32024          "description": "[Output Only] Status of the region, either UP or DOWN.",
32025          "type": "string",
32026          "enumDescriptions": [
32027            "",
32028            ""
32029          ],
32030          "enum": [
32031            "DOWN",
32032            "UP"
32033          ]
32034        },
32035        "zones": {
32036          "description": "[Output Only] A list of zones available in this region, in the form of resource URLs.",
32037          "type": "array",
32038          "items": {
32039            "type": "string"
32040          }
32041        },
32042        "quotas": {
32043          "description": "[Output Only] Quotas assigned to this region.",
32044          "type": "array",
32045          "items": {
32046            "$ref": "Quota"
32047          }
32048        },
32049        "deprecated": {
32050          "description": "[Output Only] The deprecation status associated with this region.",
32051          "$ref": "DeprecationStatus"
32052        },
32053        "selfLink": {
32054          "description": "[Output Only] Server-defined URL for the resource.",
32055          "type": "string"
32056        },
32057        "supportsPzs": {
32058          "description": "[Output Only] Reserved for future use.",
32059          "type": "boolean"
32060        }
32061      }
32062    },
32063    "ResourcePolicyList": {
32064      "id": "ResourcePolicyList",
32065      "type": "object",
32066      "properties": {
32067        "kind": {
32068          "description": "[Output Only] Type of resource.Always compute#resourcePoliciesList for listsof resourcePolicies",
32069          "default": "compute#resourcePolicyList",
32070          "type": "string"
32071        },
32072        "id": {
32073          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
32074          "type": "string"
32075        },
32076        "items": {
32077          "description": "[Output Only] A list of ResourcePolicy resources.",
32078          "type": "array",
32079          "items": {
32080            "$ref": "ResourcePolicy"
32081          }
32082        },
32083        "nextPageToken": {
32084          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
32085          "type": "string"
32086        },
32087        "warning": {
32088          "description": "[Output Only] Informational warning message.",
32089          "type": "object",
32090          "properties": {
32091            "code": {
32092              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
32093              "type": "string",
32094              "enumDescriptions": [
32095                "Warning about failed cleanup of transient changes made by a failed operation.",
32096                "A link to a deprecated resource was created.",
32097                "When deploying and at least one of the resources has a type marked as deprecated",
32098                "The user created a boot disk that is larger than image size.",
32099                "When deploying and at least one of the resources has a type marked as experimental",
32100                "Warning that is present in an external api call",
32101                "Warning that value of a field has been overridden. Deprecated unused field.",
32102                "The operation involved use of an injected kernel, which is deprecated.",
32103                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
32104                "When deploying a deployment with a exceedingly large number of resources",
32105                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
32106                "A resource depends on a missing type",
32107                "The route's nextHopIp address is not assigned to an instance on the network.",
32108                "The route's next hop instance cannot ip forward.",
32109                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
32110                "The route's nextHopInstance URL refers to an instance that does not exist.",
32111                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
32112                "The route's next hop instance does not have a status of RUNNING.",
32113                "Error which is not critical. We decided to continue the process despite the mentioned error.",
32114                "No results are present on a particular list page.",
32115                "Success is reported, but some results may be missing due to errors",
32116                "The user attempted to use a resource that requires a TOS they have not accepted.",
32117                "Warning that a resource is in use.",
32118                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
32119                "When a resource schema validation is ignored.",
32120                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
32121                "When undeclared properties in the schema are present",
32122                "A given scope cannot be reached."
32123              ],
32124              "enumDeprecated": [
32125                false,
32126                false,
32127                false,
32128                false,
32129                false,
32130                false,
32131                true,
32132                false,
32133                false,
32134                false,
32135                false,
32136                false,
32137                false,
32138                false,
32139                false,
32140                false,
32141                false,
32142                false,
32143                false,
32144                false,
32145                false,
32146                false,
32147                false,
32148                false,
32149                false,
32150                false,
32151                false,
32152                false
32153              ],
32154              "enum": [
32155                "CLEANUP_FAILED",
32156                "DEPRECATED_RESOURCE_USED",
32157                "DEPRECATED_TYPE_USED",
32158                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
32159                "EXPERIMENTAL_TYPE_USED",
32160                "EXTERNAL_API_WARNING",
32161                "FIELD_VALUE_OVERRIDEN",
32162                "INJECTED_KERNELS_DEPRECATED",
32163                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
32164                "LARGE_DEPLOYMENT_WARNING",
32165                "LIST_OVERHEAD_QUOTA_EXCEED",
32166                "MISSING_TYPE_DEPENDENCY",
32167                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
32168                "NEXT_HOP_CANNOT_IP_FORWARD",
32169                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
32170                "NEXT_HOP_INSTANCE_NOT_FOUND",
32171                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
32172                "NEXT_HOP_NOT_RUNNING",
32173                "NOT_CRITICAL_ERROR",
32174                "NO_RESULTS_ON_PAGE",
32175                "PARTIAL_SUCCESS",
32176                "REQUIRED_TOS_AGREEMENT",
32177                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
32178                "RESOURCE_NOT_DELETED",
32179                "SCHEMA_VALIDATION_IGNORED",
32180                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
32181                "UNDECLARED_PROPERTIES",
32182                "UNREACHABLE"
32183              ]
32184            },
32185            "message": {
32186              "description": "[Output Only] A human-readable description of the warning code.",
32187              "type": "string"
32188            },
32189            "data": {
32190              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
32191              "type": "array",
32192              "items": {
32193                "type": "object",
32194                "properties": {
32195                  "key": {
32196                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
32197                    "type": "string"
32198                  },
32199                  "value": {
32200                    "description": "[Output Only] A warning data value corresponding to the key.",
32201                    "type": "string"
32202                  }
32203                }
32204              }
32205            }
32206          }
32207        },
32208        "selfLink": {
32209          "description": "[Output Only] Server-defined URL for this resource.",
32210          "type": "string"
32211        },
32212        "etag": {
32213          "type": "string"
32214        }
32215      }
32216    },
32217    "ResourcePolicy": {
32218      "id": "ResourcePolicy",
32219      "description": "Represents a Resource Policy resource. You can use resource policies to schedule actions for some Compute Engine resources. For example, you can use them to schedule persistent disk snapshots.",
32220      "type": "object",
32221      "properties": {
32222        "kind": {
32223          "description": "[Output Only] Type of the resource. Always compute#resource_policies for resource policies.",
32224          "default": "compute#resourcePolicy",
32225          "type": "string"
32226        },
32227        "id": {
32228          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
32229          "type": "string",
32230          "format": "uint64"
32231        },
32232        "creationTimestamp": {
32233          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
32234          "type": "string"
32235        },
32236        "selfLink": {
32237          "description": "[Output Only] Server-defined fully-qualified URL for this resource.",
32238          "type": "string"
32239        },
32240        "region": {
32241          "type": "string"
32242        },
32243        "description": {
32244          "type": "string"
32245        },
32246        "name": {
32247          "description": "The name of the resource, provided by the client when initially creating the resource. The resource name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
32248          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
32249          "annotations": {
32250            "required": [
32251              "compute.instances.insert"
32252            ]
32253          },
32254          "type": "string"
32255        },
32256        "snapshotSchedulePolicy": {
32257          "description": "Resource policy for persistent disks for creating snapshots.",
32258          "$ref": "ResourcePolicySnapshotSchedulePolicy"
32259        },
32260        "groupPlacementPolicy": {
32261          "description": "Resource policy for instances for placement configuration.",
32262          "$ref": "ResourcePolicyGroupPlacementPolicy"
32263        },
32264        "instanceSchedulePolicy": {
32265          "description": "Resource policy for scheduling instance operations.",
32266          "$ref": "ResourcePolicyInstanceSchedulePolicy"
32267        },
32268        "diskConsistencyGroupPolicy": {
32269          "description": "Resource policy for disk consistency groups.",
32270          "$ref": "ResourcePolicyDiskConsistencyGroupPolicy"
32271        },
32272        "status": {
32273          "description": "[Output Only] The status of resource policy creation.",
32274          "type": "string",
32275          "enumDescriptions": [
32276            "Resource policy is being created.",
32277            "Resource policy is being deleted.",
32278            "Resource policy is expired and will not run again.",
32279            "",
32280            "Resource policy is ready to be used."
32281          ],
32282          "enum": [
32283            "CREATING",
32284            "DELETING",
32285            "EXPIRED",
32286            "INVALID",
32287            "READY"
32288          ]
32289        },
32290        "resourceStatus": {
32291          "description": "[Output Only] The system status of the resource policy.",
32292          "$ref": "ResourcePolicyResourceStatus"
32293        }
32294      }
32295    },
32296    "ResourcePolicySnapshotSchedulePolicy": {
32297      "id": "ResourcePolicySnapshotSchedulePolicy",
32298      "description": "A snapshot schedule policy specifies when and how frequently snapshots are to be created for the target disk. Also specifies how many and how long these scheduled snapshots should be retained.",
32299      "type": "object",
32300      "properties": {
32301        "schedule": {
32302          "description": "A Vm Maintenance Policy specifies what kind of infrastructure maintenance we are allowed to perform on this VM and when. Schedule that is applied to disks covered by this policy.",
32303          "$ref": "ResourcePolicySnapshotSchedulePolicySchedule"
32304        },
32305        "retentionPolicy": {
32306          "description": "Retention policy applied to snapshots created by this resource policy.",
32307          "$ref": "ResourcePolicySnapshotSchedulePolicyRetentionPolicy"
32308        },
32309        "snapshotProperties": {
32310          "description": "Properties with which snapshots are created such as labels, encryption keys.",
32311          "$ref": "ResourcePolicySnapshotSchedulePolicySnapshotProperties"
32312        }
32313      }
32314    },
32315    "ResourcePolicySnapshotSchedulePolicySchedule": {
32316      "id": "ResourcePolicySnapshotSchedulePolicySchedule",
32317      "description": "A schedule for disks where the schedueled operations are performed.",
32318      "type": "object",
32319      "properties": {
32320        "hourlySchedule": {
32321          "$ref": "ResourcePolicyHourlyCycle"
32322        },
32323        "dailySchedule": {
32324          "$ref": "ResourcePolicyDailyCycle"
32325        },
32326        "weeklySchedule": {
32327          "$ref": "ResourcePolicyWeeklyCycle"
32328        }
32329      }
32330    },
32331    "ResourcePolicyHourlyCycle": {
32332      "id": "ResourcePolicyHourlyCycle",
32333      "description": "Time window specified for hourly operations.",
32334      "type": "object",
32335      "properties": {
32336        "hoursInCycle": {
32337          "description": "Defines a schedule with units measured in hours. The value determines how many hours pass between the start of each cycle.",
32338          "type": "integer",
32339          "format": "int32"
32340        },
32341        "startTime": {
32342          "description": "Time within the window to start the operations. It must be in format \"HH:MM\", where HH : [00-23] and MM : [00-00] GMT.",
32343          "type": "string"
32344        },
32345        "duration": {
32346          "description": "[Output only] Duration of the time window, automatically chosen to be smallest possible in the given scenario.",
32347          "type": "string"
32348        }
32349      }
32350    },
32351    "ResourcePolicyDailyCycle": {
32352      "id": "ResourcePolicyDailyCycle",
32353      "description": "Time window specified for daily operations.",
32354      "type": "object",
32355      "properties": {
32356        "daysInCycle": {
32357          "description": "Defines a schedule with units measured in days. The value determines how many days pass between the start of each cycle.",
32358          "type": "integer",
32359          "format": "int32"
32360        },
32361        "startTime": {
32362          "description": "Start time of the window. This must be in UTC format that resolves to one of 00:00, 04:00, 08:00, 12:00, 16:00, or 20:00. For example, both 13:00-5 and 08:00 are valid.",
32363          "type": "string"
32364        },
32365        "duration": {
32366          "description": "[Output only] A predetermined duration for the window, automatically chosen to be the smallest possible in the given scenario.",
32367          "type": "string"
32368        }
32369      }
32370    },
32371    "ResourcePolicyWeeklyCycle": {
32372      "id": "ResourcePolicyWeeklyCycle",
32373      "description": "Time window specified for weekly operations.",
32374      "type": "object",
32375      "properties": {
32376        "dayOfWeeks": {
32377          "description": "Up to 7 intervals/windows, one for each day of the week.",
32378          "type": "array",
32379          "items": {
32380            "$ref": "ResourcePolicyWeeklyCycleDayOfWeek"
32381          }
32382        }
32383      }
32384    },
32385    "ResourcePolicyWeeklyCycleDayOfWeek": {
32386      "id": "ResourcePolicyWeeklyCycleDayOfWeek",
32387      "type": "object",
32388      "properties": {
32389        "day": {
32390          "description": "Defines a schedule that runs on specific days of the week. Specify one or more days. The following options are available: MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY, SATURDAY, SUNDAY.",
32391          "type": "string",
32392          "enumDescriptions": [
32393            "",
32394            "",
32395            "",
32396            "",
32397            "",
32398            "",
32399            "",
32400            ""
32401          ],
32402          "enum": [
32403            "FRIDAY",
32404            "INVALID",
32405            "MONDAY",
32406            "SATURDAY",
32407            "SUNDAY",
32408            "THURSDAY",
32409            "TUESDAY",
32410            "WEDNESDAY"
32411          ]
32412        },
32413        "startTime": {
32414          "description": "Time within the window to start the operations. It must be in format \"HH:MM\", where HH : [00-23] and MM : [00-00] GMT.",
32415          "type": "string"
32416        },
32417        "duration": {
32418          "description": "[Output only] Duration of the time window, automatically chosen to be smallest possible in the given scenario.",
32419          "type": "string"
32420        }
32421      }
32422    },
32423    "ResourcePolicySnapshotSchedulePolicyRetentionPolicy": {
32424      "id": "ResourcePolicySnapshotSchedulePolicyRetentionPolicy",
32425      "description": "Policy for retention of scheduled snapshots.",
32426      "type": "object",
32427      "properties": {
32428        "maxRetentionDays": {
32429          "description": "Maximum age of the snapshot that is allowed to be kept.",
32430          "type": "integer",
32431          "format": "int32"
32432        },
32433        "onSourceDiskDelete": {
32434          "description": "Specifies the behavior to apply to scheduled snapshots when the source disk is deleted.",
32435          "type": "string",
32436          "enumDescriptions": [
32437            "",
32438            "",
32439            ""
32440          ],
32441          "enum": [
32442            "APPLY_RETENTION_POLICY",
32443            "KEEP_AUTO_SNAPSHOTS",
32444            "UNSPECIFIED_ON_SOURCE_DISK_DELETE"
32445          ]
32446        }
32447      }
32448    },
32449    "ResourcePolicySnapshotSchedulePolicySnapshotProperties": {
32450      "id": "ResourcePolicySnapshotSchedulePolicySnapshotProperties",
32451      "description": "Specified snapshot properties for scheduled snapshots created by this policy.",
32452      "type": "object",
32453      "properties": {
32454        "labels": {
32455          "description": "Labels to apply to scheduled snapshots. These can be later modified by the setLabels method. Label values may be empty.",
32456          "type": "object",
32457          "additionalProperties": {
32458            "type": "string"
32459          }
32460        },
32461        "storageLocations": {
32462          "description": "Cloud Storage bucket storage location of the auto snapshot (regional or multi-regional).",
32463          "type": "array",
32464          "items": {
32465            "type": "string"
32466          }
32467        },
32468        "guestFlush": {
32469          "description": "Indication to perform a 'guest aware' snapshot.",
32470          "type": "boolean"
32471        },
32472        "chainName": {
32473          "description": "Chain name that the snapshot is created in.",
32474          "type": "string"
32475        }
32476      }
32477    },
32478    "ResourcePolicyGroupPlacementPolicy": {
32479      "id": "ResourcePolicyGroupPlacementPolicy",
32480      "description": "A GroupPlacementPolicy specifies resource placement configuration. It specifies the failure bucket separation as well as network locality",
32481      "type": "object",
32482      "properties": {
32483        "vmCount": {
32484          "description": "Number of VMs in this placement group. Google does not recommend that you use this field unless you use a compact policy and you want your policy to work only if it contains this exact number of VMs.",
32485          "type": "integer",
32486          "format": "int32"
32487        },
32488        "availabilityDomainCount": {
32489          "description": "The number of availability domains to spread instances across. If two instances are in different availability domain, they are not in the same low latency network.",
32490          "type": "integer",
32491          "format": "int32"
32492        },
32493        "collocation": {
32494          "description": "Specifies network collocation",
32495          "type": "string",
32496          "enumDescriptions": [
32497            "",
32498            ""
32499          ],
32500          "enum": [
32501            "COLLOCATED",
32502            "UNSPECIFIED_COLLOCATION"
32503          ]
32504        }
32505      }
32506    },
32507    "ResourcePolicyInstanceSchedulePolicy": {
32508      "id": "ResourcePolicyInstanceSchedulePolicy",
32509      "description": "An InstanceSchedulePolicy specifies when and how frequent certain operations are performed on the instance.",
32510      "type": "object",
32511      "properties": {
32512        "vmStartSchedule": {
32513          "description": "Specifies the schedule for starting instances.",
32514          "$ref": "ResourcePolicyInstanceSchedulePolicySchedule"
32515        },
32516        "vmStopSchedule": {
32517          "description": "Specifies the schedule for stopping instances.",
32518          "$ref": "ResourcePolicyInstanceSchedulePolicySchedule"
32519        },
32520        "timeZone": {
32521          "description": "Specifies the time zone to be used in interpreting Schedule.schedule. The value of this field must be a time zone name from the tz database: https://wikipedia.org/wiki/Tz_database.",
32522          "type": "string"
32523        },
32524        "startTime": {
32525          "description": "The start time of the schedule. The timestamp is an RFC3339 string.",
32526          "type": "string"
32527        },
32528        "expirationTime": {
32529          "description": "The expiration time of the schedule. The timestamp is an RFC3339 string.",
32530          "type": "string"
32531        }
32532      }
32533    },
32534    "ResourcePolicyInstanceSchedulePolicySchedule": {
32535      "id": "ResourcePolicyInstanceSchedulePolicySchedule",
32536      "description": "Schedule for an instance operation.",
32537      "type": "object",
32538      "properties": {
32539        "schedule": {
32540          "description": "Specifies the frequency for the operation, using the unix-cron format.",
32541          "type": "string"
32542        }
32543      }
32544    },
32545    "ResourcePolicyDiskConsistencyGroupPolicy": {
32546      "id": "ResourcePolicyDiskConsistencyGroupPolicy",
32547      "description": "Resource policy for disk consistency groups.",
32548      "type": "object",
32549      "properties": {}
32550    },
32551    "ResourcePolicyResourceStatus": {
32552      "id": "ResourcePolicyResourceStatus",
32553      "description": "Contains output only fields. Use this sub-message for all output fields set on ResourcePolicy. The internal structure of this \"status\" field should mimic the structure of ResourcePolicy proto specification.",
32554      "type": "object",
32555      "properties": {
32556        "instanceSchedulePolicy": {
32557          "description": "[Output Only] Specifies a set of output values reffering to the instance_schedule_policy system status. This field should have the same name as corresponding policy field.",
32558          "$ref": "ResourcePolicyResourceStatusInstanceSchedulePolicyStatus"
32559        }
32560      }
32561    },
32562    "ResourcePolicyResourceStatusInstanceSchedulePolicyStatus": {
32563      "id": "ResourcePolicyResourceStatusInstanceSchedulePolicyStatus",
32564      "type": "object",
32565      "properties": {
32566        "nextRunStartTime": {
32567          "description": "[Output Only] The next time the schedule is planned to run. The actual time might be slightly different. The timestamp is an RFC3339 string.",
32568          "type": "string"
32569        },
32570        "lastRunStartTime": {
32571          "description": "[Output Only] The last time the schedule successfully ran. The timestamp is an RFC3339 string.",
32572          "type": "string"
32573        }
32574      }
32575    },
32576    "ResourcePolicyAggregatedList": {
32577      "id": "ResourcePolicyAggregatedList",
32578      "description": "Contains a list of resourcePolicies.",
32579      "type": "object",
32580      "properties": {
32581        "kind": {
32582          "description": "Type of resource.",
32583          "default": "compute#resourcePolicyAggregatedList",
32584          "type": "string"
32585        },
32586        "id": {
32587          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
32588          "type": "string"
32589        },
32590        "items": {
32591          "description": "A list of ResourcePolicy resources.",
32592          "type": "object",
32593          "additionalProperties": {
32594            "description": "Name of the scope containing this set of resourcePolicies.",
32595            "$ref": "ResourcePoliciesScopedList"
32596          }
32597        },
32598        "nextPageToken": {
32599          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
32600          "type": "string"
32601        },
32602        "selfLink": {
32603          "description": "[Output Only] Server-defined URL for this resource.",
32604          "type": "string"
32605        },
32606        "warning": {
32607          "description": "[Output Only] Informational warning message.",
32608          "type": "object",
32609          "properties": {
32610            "code": {
32611              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
32612              "type": "string",
32613              "enumDescriptions": [
32614                "Warning about failed cleanup of transient changes made by a failed operation.",
32615                "A link to a deprecated resource was created.",
32616                "When deploying and at least one of the resources has a type marked as deprecated",
32617                "The user created a boot disk that is larger than image size.",
32618                "When deploying and at least one of the resources has a type marked as experimental",
32619                "Warning that is present in an external api call",
32620                "Warning that value of a field has been overridden. Deprecated unused field.",
32621                "The operation involved use of an injected kernel, which is deprecated.",
32622                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
32623                "When deploying a deployment with a exceedingly large number of resources",
32624                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
32625                "A resource depends on a missing type",
32626                "The route's nextHopIp address is not assigned to an instance on the network.",
32627                "The route's next hop instance cannot ip forward.",
32628                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
32629                "The route's nextHopInstance URL refers to an instance that does not exist.",
32630                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
32631                "The route's next hop instance does not have a status of RUNNING.",
32632                "Error which is not critical. We decided to continue the process despite the mentioned error.",
32633                "No results are present on a particular list page.",
32634                "Success is reported, but some results may be missing due to errors",
32635                "The user attempted to use a resource that requires a TOS they have not accepted.",
32636                "Warning that a resource is in use.",
32637                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
32638                "When a resource schema validation is ignored.",
32639                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
32640                "When undeclared properties in the schema are present",
32641                "A given scope cannot be reached."
32642              ],
32643              "enumDeprecated": [
32644                false,
32645                false,
32646                false,
32647                false,
32648                false,
32649                false,
32650                true,
32651                false,
32652                false,
32653                false,
32654                false,
32655                false,
32656                false,
32657                false,
32658                false,
32659                false,
32660                false,
32661                false,
32662                false,
32663                false,
32664                false,
32665                false,
32666                false,
32667                false,
32668                false,
32669                false,
32670                false,
32671                false
32672              ],
32673              "enum": [
32674                "CLEANUP_FAILED",
32675                "DEPRECATED_RESOURCE_USED",
32676                "DEPRECATED_TYPE_USED",
32677                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
32678                "EXPERIMENTAL_TYPE_USED",
32679                "EXTERNAL_API_WARNING",
32680                "FIELD_VALUE_OVERRIDEN",
32681                "INJECTED_KERNELS_DEPRECATED",
32682                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
32683                "LARGE_DEPLOYMENT_WARNING",
32684                "LIST_OVERHEAD_QUOTA_EXCEED",
32685                "MISSING_TYPE_DEPENDENCY",
32686                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
32687                "NEXT_HOP_CANNOT_IP_FORWARD",
32688                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
32689                "NEXT_HOP_INSTANCE_NOT_FOUND",
32690                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
32691                "NEXT_HOP_NOT_RUNNING",
32692                "NOT_CRITICAL_ERROR",
32693                "NO_RESULTS_ON_PAGE",
32694                "PARTIAL_SUCCESS",
32695                "REQUIRED_TOS_AGREEMENT",
32696                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
32697                "RESOURCE_NOT_DELETED",
32698                "SCHEMA_VALIDATION_IGNORED",
32699                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
32700                "UNDECLARED_PROPERTIES",
32701                "UNREACHABLE"
32702              ]
32703            },
32704            "message": {
32705              "description": "[Output Only] A human-readable description of the warning code.",
32706              "type": "string"
32707            },
32708            "data": {
32709              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
32710              "type": "array",
32711              "items": {
32712                "type": "object",
32713                "properties": {
32714                  "key": {
32715                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
32716                    "type": "string"
32717                  },
32718                  "value": {
32719                    "description": "[Output Only] A warning data value corresponding to the key.",
32720                    "type": "string"
32721                  }
32722                }
32723              }
32724            }
32725          }
32726        },
32727        "etag": {
32728          "type": "string"
32729        },
32730        "unreachables": {
32731          "description": "[Output Only] Unreachable resources.",
32732          "type": "array",
32733          "items": {
32734            "type": "string"
32735          }
32736        }
32737      }
32738    },
32739    "ResourcePoliciesScopedList": {
32740      "id": "ResourcePoliciesScopedList",
32741      "type": "object",
32742      "properties": {
32743        "resourcePolicies": {
32744          "description": "A list of resourcePolicies contained in this scope.",
32745          "type": "array",
32746          "items": {
32747            "$ref": "ResourcePolicy"
32748          }
32749        },
32750        "warning": {
32751          "description": "Informational warning which replaces the list of resourcePolicies when the list is empty.",
32752          "type": "object",
32753          "properties": {
32754            "code": {
32755              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
32756              "type": "string",
32757              "enumDescriptions": [
32758                "Warning about failed cleanup of transient changes made by a failed operation.",
32759                "A link to a deprecated resource was created.",
32760                "When deploying and at least one of the resources has a type marked as deprecated",
32761                "The user created a boot disk that is larger than image size.",
32762                "When deploying and at least one of the resources has a type marked as experimental",
32763                "Warning that is present in an external api call",
32764                "Warning that value of a field has been overridden. Deprecated unused field.",
32765                "The operation involved use of an injected kernel, which is deprecated.",
32766                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
32767                "When deploying a deployment with a exceedingly large number of resources",
32768                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
32769                "A resource depends on a missing type",
32770                "The route's nextHopIp address is not assigned to an instance on the network.",
32771                "The route's next hop instance cannot ip forward.",
32772                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
32773                "The route's nextHopInstance URL refers to an instance that does not exist.",
32774                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
32775                "The route's next hop instance does not have a status of RUNNING.",
32776                "Error which is not critical. We decided to continue the process despite the mentioned error.",
32777                "No results are present on a particular list page.",
32778                "Success is reported, but some results may be missing due to errors",
32779                "The user attempted to use a resource that requires a TOS they have not accepted.",
32780                "Warning that a resource is in use.",
32781                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
32782                "When a resource schema validation is ignored.",
32783                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
32784                "When undeclared properties in the schema are present",
32785                "A given scope cannot be reached."
32786              ],
32787              "enumDeprecated": [
32788                false,
32789                false,
32790                false,
32791                false,
32792                false,
32793                false,
32794                true,
32795                false,
32796                false,
32797                false,
32798                false,
32799                false,
32800                false,
32801                false,
32802                false,
32803                false,
32804                false,
32805                false,
32806                false,
32807                false,
32808                false,
32809                false,
32810                false,
32811                false,
32812                false,
32813                false,
32814                false,
32815                false
32816              ],
32817              "enum": [
32818                "CLEANUP_FAILED",
32819                "DEPRECATED_RESOURCE_USED",
32820                "DEPRECATED_TYPE_USED",
32821                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
32822                "EXPERIMENTAL_TYPE_USED",
32823                "EXTERNAL_API_WARNING",
32824                "FIELD_VALUE_OVERRIDEN",
32825                "INJECTED_KERNELS_DEPRECATED",
32826                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
32827                "LARGE_DEPLOYMENT_WARNING",
32828                "LIST_OVERHEAD_QUOTA_EXCEED",
32829                "MISSING_TYPE_DEPENDENCY",
32830                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
32831                "NEXT_HOP_CANNOT_IP_FORWARD",
32832                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
32833                "NEXT_HOP_INSTANCE_NOT_FOUND",
32834                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
32835                "NEXT_HOP_NOT_RUNNING",
32836                "NOT_CRITICAL_ERROR",
32837                "NO_RESULTS_ON_PAGE",
32838                "PARTIAL_SUCCESS",
32839                "REQUIRED_TOS_AGREEMENT",
32840                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
32841                "RESOURCE_NOT_DELETED",
32842                "SCHEMA_VALIDATION_IGNORED",
32843                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
32844                "UNDECLARED_PROPERTIES",
32845                "UNREACHABLE"
32846              ]
32847            },
32848            "message": {
32849              "description": "[Output Only] A human-readable description of the warning code.",
32850              "type": "string"
32851            },
32852            "data": {
32853              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
32854              "type": "array",
32855              "items": {
32856                "type": "object",
32857                "properties": {
32858                  "key": {
32859                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
32860                    "type": "string"
32861                  },
32862                  "value": {
32863                    "description": "[Output Only] A warning data value corresponding to the key.",
32864                    "type": "string"
32865                  }
32866                }
32867              }
32868            }
32869          }
32870        }
32871      }
32872    },
32873    "RouteList": {
32874      "id": "RouteList",
32875      "description": "Contains a list of Route resources.",
32876      "type": "object",
32877      "properties": {
32878        "kind": {
32879          "description": "Type of resource.",
32880          "default": "compute#routeList",
32881          "type": "string"
32882        },
32883        "id": {
32884          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
32885          "type": "string"
32886        },
32887        "items": {
32888          "description": "A list of Route resources.",
32889          "type": "array",
32890          "items": {
32891            "$ref": "Route"
32892          }
32893        },
32894        "nextPageToken": {
32895          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
32896          "type": "string"
32897        },
32898        "selfLink": {
32899          "description": "[Output Only] Server-defined URL for this resource.",
32900          "type": "string"
32901        },
32902        "warning": {
32903          "description": "[Output Only] Informational warning message.",
32904          "type": "object",
32905          "properties": {
32906            "code": {
32907              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
32908              "type": "string",
32909              "enumDescriptions": [
32910                "Warning about failed cleanup of transient changes made by a failed operation.",
32911                "A link to a deprecated resource was created.",
32912                "When deploying and at least one of the resources has a type marked as deprecated",
32913                "The user created a boot disk that is larger than image size.",
32914                "When deploying and at least one of the resources has a type marked as experimental",
32915                "Warning that is present in an external api call",
32916                "Warning that value of a field has been overridden. Deprecated unused field.",
32917                "The operation involved use of an injected kernel, which is deprecated.",
32918                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
32919                "When deploying a deployment with a exceedingly large number of resources",
32920                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
32921                "A resource depends on a missing type",
32922                "The route's nextHopIp address is not assigned to an instance on the network.",
32923                "The route's next hop instance cannot ip forward.",
32924                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
32925                "The route's nextHopInstance URL refers to an instance that does not exist.",
32926                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
32927                "The route's next hop instance does not have a status of RUNNING.",
32928                "Error which is not critical. We decided to continue the process despite the mentioned error.",
32929                "No results are present on a particular list page.",
32930                "Success is reported, but some results may be missing due to errors",
32931                "The user attempted to use a resource that requires a TOS they have not accepted.",
32932                "Warning that a resource is in use.",
32933                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
32934                "When a resource schema validation is ignored.",
32935                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
32936                "When undeclared properties in the schema are present",
32937                "A given scope cannot be reached."
32938              ],
32939              "enumDeprecated": [
32940                false,
32941                false,
32942                false,
32943                false,
32944                false,
32945                false,
32946                true,
32947                false,
32948                false,
32949                false,
32950                false,
32951                false,
32952                false,
32953                false,
32954                false,
32955                false,
32956                false,
32957                false,
32958                false,
32959                false,
32960                false,
32961                false,
32962                false,
32963                false,
32964                false,
32965                false,
32966                false,
32967                false
32968              ],
32969              "enum": [
32970                "CLEANUP_FAILED",
32971                "DEPRECATED_RESOURCE_USED",
32972                "DEPRECATED_TYPE_USED",
32973                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
32974                "EXPERIMENTAL_TYPE_USED",
32975                "EXTERNAL_API_WARNING",
32976                "FIELD_VALUE_OVERRIDEN",
32977                "INJECTED_KERNELS_DEPRECATED",
32978                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
32979                "LARGE_DEPLOYMENT_WARNING",
32980                "LIST_OVERHEAD_QUOTA_EXCEED",
32981                "MISSING_TYPE_DEPENDENCY",
32982                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
32983                "NEXT_HOP_CANNOT_IP_FORWARD",
32984                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
32985                "NEXT_HOP_INSTANCE_NOT_FOUND",
32986                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
32987                "NEXT_HOP_NOT_RUNNING",
32988                "NOT_CRITICAL_ERROR",
32989                "NO_RESULTS_ON_PAGE",
32990                "PARTIAL_SUCCESS",
32991                "REQUIRED_TOS_AGREEMENT",
32992                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
32993                "RESOURCE_NOT_DELETED",
32994                "SCHEMA_VALIDATION_IGNORED",
32995                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
32996                "UNDECLARED_PROPERTIES",
32997                "UNREACHABLE"
32998              ]
32999            },
33000            "message": {
33001              "description": "[Output Only] A human-readable description of the warning code.",
33002              "type": "string"
33003            },
33004            "data": {
33005              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
33006              "type": "array",
33007              "items": {
33008                "type": "object",
33009                "properties": {
33010                  "key": {
33011                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
33012                    "type": "string"
33013                  },
33014                  "value": {
33015                    "description": "[Output Only] A warning data value corresponding to the key.",
33016                    "type": "string"
33017                  }
33018                }
33019              }
33020            }
33021          }
33022        }
33023      }
33024    },
33025    "Route": {
33026      "id": "Route",
33027      "description": "Represents a Route resource. A route defines a path from VM instances in the VPC network to a specific destination. This destination can be inside or outside the VPC network. For more information, read the Routes overview.",
33028      "type": "object",
33029      "properties": {
33030        "kind": {
33031          "description": "[Output Only] Type of this resource. Always compute#routes for Route resources.",
33032          "default": "compute#route",
33033          "type": "string"
33034        },
33035        "id": {
33036          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
33037          "type": "string",
33038          "format": "uint64"
33039        },
33040        "creationTimestamp": {
33041          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
33042          "type": "string"
33043        },
33044        "name": {
33045          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?`. The first character must be a lowercase letter, and all following characters (except for the last character) must be a dash, lowercase letter, or digit. The last character must be a lowercase letter or digit.",
33046          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
33047          "annotations": {
33048            "required": [
33049              "compute.routes.insert"
33050            ]
33051          },
33052          "type": "string"
33053        },
33054        "description": {
33055          "description": "An optional description of this resource. Provide this field when you create the resource.",
33056          "type": "string"
33057        },
33058        "network": {
33059          "description": "Fully-qualified URL of the network that this route applies to.",
33060          "annotations": {
33061            "required": [
33062              "compute.routes.insert"
33063            ]
33064          },
33065          "type": "string"
33066        },
33067        "tags": {
33068          "description": "A list of instance tags to which this route applies.",
33069          "annotations": {
33070            "required": [
33071              "compute.routes.insert"
33072            ]
33073          },
33074          "type": "array",
33075          "items": {
33076            "type": "string"
33077          }
33078        },
33079        "destRange": {
33080          "description": "The destination range of outgoing packets that this route applies to. Both IPv4 and IPv6 are supported. Must specify an IPv4 range (e.g. 192.0.2.0/24) or an IPv6 range in RFC 4291 format (e.g. 2001:db8::/32). IPv6 range will be displayed using RFC 5952 compressed format.",
33081          "annotations": {
33082            "required": [
33083              "compute.routes.insert"
33084            ]
33085          },
33086          "type": "string"
33087        },
33088        "priority": {
33089          "description": "The priority of this route. Priority is used to break ties in cases where there is more than one matching route of equal prefix length. In cases where multiple routes have equal prefix length, the one with the lowest-numbered priority value wins. The default value is `1000`. The priority value must be from `0` to `65535`, inclusive.",
33090          "annotations": {
33091            "required": [
33092              "compute.routes.insert"
33093            ]
33094          },
33095          "type": "integer",
33096          "format": "uint32"
33097        },
33098        "nextHopInstance": {
33099          "description": "The URL to an instance that should handle matching packets. You can specify this as a full or partial URL. For example: https://www.googleapis.com/compute/v1/projects/project/zones/zone/instances/",
33100          "type": "string"
33101        },
33102        "nextHopIp": {
33103          "description": "The network IP address of an instance that should handle matching packets. Both IPv6 address and IPv4 addresses are supported. Must specify an IPv4 address in dot-decimal notation (e.g. 192.0.2.99) or an IPv6 address in RFC 4291 format (e.g. 2001:db8::2d9:51:0:0 or 2001:db8:0:0:2d9:51:0:0). IPv6 addresses will be displayed using RFC 5952 compressed format (e.g. 2001:db8::2d9:51:0:0). Should never be an IPv4-mapped IPv6 address.",
33104          "type": "string"
33105        },
33106        "nextHopNetwork": {
33107          "description": "The URL of the local network if it should handle matching packets.",
33108          "type": "string"
33109        },
33110        "nextHopGateway": {
33111          "description": "The URL to a gateway that should handle matching packets. You can only specify the internet gateway using a full or partial valid URL: projects/ project/global/gateways/default-internet-gateway",
33112          "type": "string"
33113        },
33114        "nextHopPeering": {
33115          "description": "[Output Only] The network peering name that should handle matching packets, which should conform to RFC1035.",
33116          "type": "string"
33117        },
33118        "nextHopIlb": {
33119          "description": "The URL to a forwarding rule of type loadBalancingScheme=INTERNAL that should handle matching packets or the IP address of the forwarding Rule. For example, the following are all valid URLs: - 10.128.0.56 - https://www.googleapis.com/compute/v1/projects/project/regions/region /forwardingRules/forwardingRule - regions/region/forwardingRules/forwardingRule ",
33120          "type": "string"
33121        },
33122        "warnings": {
33123          "description": "[Output Only] If potential misconfigurations are detected for this route, this field will be populated with warning messages.",
33124          "type": "array",
33125          "items": {
33126            "type": "object",
33127            "properties": {
33128              "code": {
33129                "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
33130                "type": "string",
33131                "enumDescriptions": [
33132                  "Warning about failed cleanup of transient changes made by a failed operation.",
33133                  "A link to a deprecated resource was created.",
33134                  "When deploying and at least one of the resources has a type marked as deprecated",
33135                  "The user created a boot disk that is larger than image size.",
33136                  "When deploying and at least one of the resources has a type marked as experimental",
33137                  "Warning that is present in an external api call",
33138                  "Warning that value of a field has been overridden. Deprecated unused field.",
33139                  "The operation involved use of an injected kernel, which is deprecated.",
33140                  "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
33141                  "When deploying a deployment with a exceedingly large number of resources",
33142                  "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
33143                  "A resource depends on a missing type",
33144                  "The route's nextHopIp address is not assigned to an instance on the network.",
33145                  "The route's next hop instance cannot ip forward.",
33146                  "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
33147                  "The route's nextHopInstance URL refers to an instance that does not exist.",
33148                  "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
33149                  "The route's next hop instance does not have a status of RUNNING.",
33150                  "Error which is not critical. We decided to continue the process despite the mentioned error.",
33151                  "No results are present on a particular list page.",
33152                  "Success is reported, but some results may be missing due to errors",
33153                  "The user attempted to use a resource that requires a TOS they have not accepted.",
33154                  "Warning that a resource is in use.",
33155                  "One or more of the resources set to auto-delete could not be deleted because they were in use.",
33156                  "When a resource schema validation is ignored.",
33157                  "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
33158                  "When undeclared properties in the schema are present",
33159                  "A given scope cannot be reached."
33160                ],
33161                "enumDeprecated": [
33162                  false,
33163                  false,
33164                  false,
33165                  false,
33166                  false,
33167                  false,
33168                  true,
33169                  false,
33170                  false,
33171                  false,
33172                  false,
33173                  false,
33174                  false,
33175                  false,
33176                  false,
33177                  false,
33178                  false,
33179                  false,
33180                  false,
33181                  false,
33182                  false,
33183                  false,
33184                  false,
33185                  false,
33186                  false,
33187                  false,
33188                  false,
33189                  false
33190                ],
33191                "enum": [
33192                  "CLEANUP_FAILED",
33193                  "DEPRECATED_RESOURCE_USED",
33194                  "DEPRECATED_TYPE_USED",
33195                  "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
33196                  "EXPERIMENTAL_TYPE_USED",
33197                  "EXTERNAL_API_WARNING",
33198                  "FIELD_VALUE_OVERRIDEN",
33199                  "INJECTED_KERNELS_DEPRECATED",
33200                  "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
33201                  "LARGE_DEPLOYMENT_WARNING",
33202                  "LIST_OVERHEAD_QUOTA_EXCEED",
33203                  "MISSING_TYPE_DEPENDENCY",
33204                  "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
33205                  "NEXT_HOP_CANNOT_IP_FORWARD",
33206                  "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
33207                  "NEXT_HOP_INSTANCE_NOT_FOUND",
33208                  "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
33209                  "NEXT_HOP_NOT_RUNNING",
33210                  "NOT_CRITICAL_ERROR",
33211                  "NO_RESULTS_ON_PAGE",
33212                  "PARTIAL_SUCCESS",
33213                  "REQUIRED_TOS_AGREEMENT",
33214                  "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
33215                  "RESOURCE_NOT_DELETED",
33216                  "SCHEMA_VALIDATION_IGNORED",
33217                  "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
33218                  "UNDECLARED_PROPERTIES",
33219                  "UNREACHABLE"
33220                ]
33221              },
33222              "message": {
33223                "description": "[Output Only] A human-readable description of the warning code.",
33224                "type": "string"
33225              },
33226              "data": {
33227                "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
33228                "type": "array",
33229                "items": {
33230                  "type": "object",
33231                  "properties": {
33232                    "key": {
33233                      "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
33234                      "type": "string"
33235                    },
33236                    "value": {
33237                      "description": "[Output Only] A warning data value corresponding to the key.",
33238                      "type": "string"
33239                    }
33240                  }
33241                }
33242              }
33243            }
33244          }
33245        },
33246        "nextHopVpnTunnel": {
33247          "description": "The URL to a VpnTunnel that should handle matching packets.",
33248          "type": "string"
33249        },
33250        "nextHopHub": {
33251          "description": "[Output Only] The full resource name of the Network Connectivity Center hub that will handle matching packets.",
33252          "type": "string"
33253        },
33254        "selfLink": {
33255          "description": "[Output Only] Server-defined fully-qualified URL for this resource.",
33256          "type": "string"
33257        },
33258        "routeType": {
33259          "description": "[Output Only] The type of this route, which can be one of the following values: - 'TRANSIT' for a transit route that this router learned from another Cloud Router and will readvertise to one of its BGP peers - 'SUBNET' for a route from a subnet of the VPC - 'BGP' for a route learned from a BGP peer of this router - 'STATIC' for a static route",
33260          "type": "string",
33261          "enumDescriptions": [
33262            "",
33263            "",
33264            "",
33265            ""
33266          ],
33267          "enum": [
33268            "BGP",
33269            "STATIC",
33270            "SUBNET",
33271            "TRANSIT"
33272          ]
33273        },
33274        "asPaths": {
33275          "description": "[Output Only] AS path.",
33276          "type": "array",
33277          "items": {
33278            "$ref": "RouteAsPath"
33279          }
33280        },
33281        "routeStatus": {
33282          "description": "[Output only] The status of the route.",
33283          "type": "string",
33284          "enumDescriptions": [
33285            "This route is processed and active.",
33286            "The route is dropped due to the VPC exceeding the dynamic route limit. For dynamic route limit, please refer to the Learned route example",
33287            "This route is processed but inactive due to failure from the backend. The backend may have rejected the route",
33288            "This route is being processed internally. The status will change once processed."
33289          ],
33290          "enum": [
33291            "ACTIVE",
33292            "DROPPED",
33293            "INACTIVE",
33294            "PENDING"
33295          ]
33296        }
33297      }
33298    },
33299    "RouteAsPath": {
33300      "id": "RouteAsPath",
33301      "type": "object",
33302      "properties": {
33303        "pathSegmentType": {
33304          "description": "[Output Only] The type of the AS Path, which can be one of the following values: - 'AS_SET': unordered set of autonomous systems that the route in has traversed - 'AS_SEQUENCE': ordered set of autonomous systems that the route has traversed - 'AS_CONFED_SEQUENCE': ordered set of Member Autonomous Systems in the local confederation that the route has traversed - 'AS_CONFED_SET': unordered set of Member Autonomous Systems in the local confederation that the route has traversed ",
33305          "type": "string",
33306          "enumDescriptions": [
33307            "",
33308            "",
33309            "",
33310            ""
33311          ],
33312          "enum": [
33313            "AS_CONFED_SEQUENCE",
33314            "AS_CONFED_SET",
33315            "AS_SEQUENCE",
33316            "AS_SET"
33317          ]
33318        },
33319        "asLists": {
33320          "description": "[Output Only] The AS numbers of the AS Path.",
33321          "type": "array",
33322          "items": {
33323            "type": "integer",
33324            "format": "uint32"
33325          }
33326        }
33327      }
33328    },
33329    "Router": {
33330      "id": "Router",
33331      "description": "Represents a Cloud Router resource. For more information about Cloud Router, read the Cloud Router overview.",
33332      "type": "object",
33333      "properties": {
33334        "kind": {
33335          "description": "[Output Only] Type of resource. Always compute#router for routers.",
33336          "default": "compute#router",
33337          "type": "string"
33338        },
33339        "id": {
33340          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
33341          "type": "string",
33342          "format": "uint64"
33343        },
33344        "creationTimestamp": {
33345          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
33346          "type": "string"
33347        },
33348        "name": {
33349          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
33350          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
33351          "annotations": {
33352            "required": [
33353              "compute.routers.insert"
33354            ]
33355          },
33356          "type": "string"
33357        },
33358        "description": {
33359          "description": "An optional description of this resource. Provide this property when you create the resource.",
33360          "type": "string"
33361        },
33362        "region": {
33363          "description": "[Output Only] URI of the region where the router resides. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
33364          "type": "string"
33365        },
33366        "network": {
33367          "description": "URI of the network to which this router belongs.",
33368          "annotations": {
33369            "required": [
33370              "compute.routers.insert",
33371              "compute.routers.update"
33372            ]
33373          },
33374          "type": "string"
33375        },
33376        "interfaces": {
33377          "description": "Router interfaces. To create a BGP peer that uses a router interface, the interface must have one of the following fields specified: - linkedVpnTunnel - linkedInterconnectAttachment - subnetwork You can create a router interface without any of these fields specified. However, you cannot create a BGP peer that uses that interface.",
33378          "type": "array",
33379          "items": {
33380            "$ref": "RouterInterface"
33381          }
33382        },
33383        "bgpPeers": {
33384          "description": "BGP information that must be configured into the routing stack to establish BGP peering. This information must specify the peer ASN and either the interface name, IP address, or peer IP address. Please refer to RFC4273.",
33385          "type": "array",
33386          "items": {
33387            "$ref": "RouterBgpPeer"
33388          }
33389        },
33390        "bgp": {
33391          "description": "BGP information specific to this router.",
33392          "$ref": "RouterBgp"
33393        },
33394        "selfLink": {
33395          "description": "[Output Only] Server-defined URL for the resource.",
33396          "type": "string"
33397        },
33398        "nats": {
33399          "description": "A list of NAT services created in this router.",
33400          "type": "array",
33401          "items": {
33402            "$ref": "RouterNat"
33403          }
33404        },
33405        "encryptedInterconnectRouter": {
33406          "description": "Indicates if a router is dedicated for use with encrypted VLAN attachments (interconnectAttachments).",
33407          "type": "boolean"
33408        },
33409        "md5AuthenticationKeys": {
33410          "description": "Keys used for MD5 authentication.",
33411          "type": "array",
33412          "items": {
33413            "$ref": "RouterMd5AuthenticationKey"
33414          }
33415        }
33416      }
33417    },
33418    "RouterInterface": {
33419      "id": "RouterInterface",
33420      "type": "object",
33421      "properties": {
33422        "name": {
33423          "description": "Name of this interface entry. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
33424          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
33425          "annotations": {
33426            "required": [
33427              "compute.routers.insert"
33428            ]
33429          },
33430          "type": "string"
33431        },
33432        "linkedVpnTunnel": {
33433          "description": "URI of the linked VPN tunnel, which must be in the same region as the router. Each interface can have one linked resource, which can be a VPN tunnel, an Interconnect attachment, or a subnetwork.",
33434          "type": "string"
33435        },
33436        "linkedInterconnectAttachment": {
33437          "description": "URI of the linked Interconnect attachment. It must be in the same region as the router. Each interface can have one linked resource, which can be a VPN tunnel, an Interconnect attachment, or a subnetwork.",
33438          "type": "string"
33439        },
33440        "ipRange": {
33441          "description": "IP address and range of the interface. The IP range must be in the RFC3927 link-local IP address space. The value must be a CIDR-formatted string, for example: 169.254.0.1/30. NOTE: Do not truncate the address as it represents the IP address of the interface.",
33442          "type": "string"
33443        },
33444        "managementType": {
33445          "description": "[Output Only] The resource that configures and manages this interface. - MANAGED_BY_USER is the default value and can be managed directly by users. - MANAGED_BY_ATTACHMENT is an interface that is configured and managed by Cloud Interconnect, specifically, by an InterconnectAttachment of type PARTNER. Google automatically creates, updates, and deletes this type of interface when the PARTNER InterconnectAttachment is created, updated, or deleted. ",
33446          "type": "string",
33447          "enumDescriptions": [
33448            "The interface is automatically created for PARTNER type InterconnectAttachment, Google will automatically create/update/delete this interface when the PARTNER InterconnectAttachment is created/provisioned/deleted. This type of interface cannot be manually managed by user.",
33449            "Default value, the interface is manually created and managed by user."
33450          ],
33451          "enum": [
33452            "MANAGED_BY_ATTACHMENT",
33453            "MANAGED_BY_USER"
33454          ]
33455        },
33456        "privateIpAddress": {
33457          "description": "The regional private internal IP address that is used to establish BGP sessions to a VM instance acting as a third-party Router Appliance, such as a Next Gen Firewall, a Virtual Router, or an SD-WAN VM.",
33458          "type": "string"
33459        },
33460        "redundantInterface": {
33461          "description": "Name of the interface that will be redundant with the current interface you are creating. The redundantInterface must belong to the same Cloud Router as the interface here. To establish the BGP session to a Router Appliance VM, you must create two BGP peers. The two BGP peers must be attached to two separate interfaces that are redundant with each other. The redundant_interface must be 1-63 characters long, and comply with RFC1035. Specifically, the redundant_interface must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
33462          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
33463          "type": "string"
33464        },
33465        "subnetwork": {
33466          "description": "The URI of the subnetwork resource that this interface belongs to, which must be in the same region as the Cloud Router. When you establish a BGP session to a VM instance using this interface, the VM instance must belong to the same subnetwork as the subnetwork specified here.",
33467          "type": "string"
33468        }
33469      }
33470    },
33471    "RouterBgpPeer": {
33472      "id": "RouterBgpPeer",
33473      "type": "object",
33474      "properties": {
33475        "name": {
33476          "description": "Name of this BGP peer. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
33477          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
33478          "annotations": {
33479            "required": [
33480              "compute.routers.insert"
33481            ]
33482          },
33483          "type": "string"
33484        },
33485        "interfaceName": {
33486          "description": "Name of the interface the BGP peer is associated with.",
33487          "type": "string"
33488        },
33489        "ipAddress": {
33490          "description": "IP address of the interface inside Google Cloud Platform. Only IPv4 is supported.",
33491          "type": "string"
33492        },
33493        "peerIpAddress": {
33494          "description": "IP address of the BGP interface outside Google Cloud Platform. Only IPv4 is supported.",
33495          "type": "string"
33496        },
33497        "peerAsn": {
33498          "description": "Peer BGP Autonomous System Number (ASN). Each BGP interface may use a different value.",
33499          "annotations": {
33500            "required": [
33501              "compute.routers.insert"
33502            ]
33503          },
33504          "type": "integer",
33505          "format": "uint32"
33506        },
33507        "advertisedRoutePriority": {
33508          "description": "The priority of routes advertised to this BGP peer. Where there is more than one matching route of maximum length, the routes with the lowest priority value win.",
33509          "type": "integer",
33510          "format": "uint32"
33511        },
33512        "advertiseMode": {
33513          "description": "User-specified flag to indicate which mode to use for advertisement.",
33514          "type": "string",
33515          "enumDescriptions": [
33516            "",
33517            ""
33518          ],
33519          "enum": [
33520            "CUSTOM",
33521            "DEFAULT"
33522          ]
33523        },
33524        "advertisedGroups": {
33525          "description": "User-specified list of prefix groups to advertise in custom mode, which currently supports the following option: - ALL_SUBNETS: Advertises all of the router's own VPC subnets. This excludes any routes learned for subnets that use VPC Network Peering. Note that this field can only be populated if advertise_mode is CUSTOM and overrides the list defined for the router (in the \"bgp\" message). These groups are advertised in addition to any specified prefixes. Leave this field blank to advertise no custom groups.",
33526          "type": "array",
33527          "items": {
33528            "type": "string",
33529            "enumDescriptions": [
33530              "Advertise all available subnets (including peer VPC subnets)."
33531            ],
33532            "enum": [
33533              "ALL_SUBNETS"
33534            ]
33535          }
33536        },
33537        "advertisedIpRanges": {
33538          "description": "User-specified list of individual IP ranges to advertise in custom mode. This field can only be populated if advertise_mode is CUSTOM and overrides the list defined for the router (in the \"bgp\" message). These IP ranges are advertised in addition to any specified groups. Leave this field blank to advertise no custom IP ranges.",
33539          "type": "array",
33540          "items": {
33541            "$ref": "RouterAdvertisedIpRange"
33542          }
33543        },
33544        "managementType": {
33545          "description": "[Output Only] The resource that configures and manages this BGP peer. - MANAGED_BY_USER is the default value and can be managed by you or other users - MANAGED_BY_ATTACHMENT is a BGP peer that is configured and managed by Cloud Interconnect, specifically by an InterconnectAttachment of type PARTNER. Google automatically creates, updates, and deletes this type of BGP peer when the PARTNER InterconnectAttachment is created, updated, or deleted. ",
33546          "type": "string",
33547          "enumDescriptions": [
33548            "The BGP peer is automatically created for PARTNER type InterconnectAttachment; Google will automatically create/delete this BGP peer when the PARTNER InterconnectAttachment is created/deleted, and Google will update the ipAddress and peerIpAddress when the PARTNER InterconnectAttachment is provisioned. This type of BGP peer cannot be created or deleted, but can be modified for all fields except for name, ipAddress and peerIpAddress.",
33549            "Default value, the BGP peer is manually created and managed by user."
33550          ],
33551          "enum": [
33552            "MANAGED_BY_ATTACHMENT",
33553            "MANAGED_BY_USER"
33554          ]
33555        },
33556        "enable": {
33557          "description": "The status of the BGP peer connection. If set to FALSE, any active session with the peer is terminated and all associated routing information is removed. If set to TRUE, the peer connection can be established with routing information. The default is TRUE.",
33558          "type": "string",
33559          "enumDescriptions": [
33560            "",
33561            ""
33562          ],
33563          "enum": [
33564            "FALSE",
33565            "TRUE"
33566          ]
33567        },
33568        "bfd": {
33569          "description": "BFD configuration for the BGP peering.",
33570          "$ref": "RouterBgpPeerBfd"
33571        },
33572        "routerApplianceInstance": {
33573          "description": "URI of the VM instance that is used as third-party router appliances such as Next Gen Firewalls, Virtual Routers, or Router Appliances. The VM instance must be located in zones contained in the same region as this Cloud Router. The VM instance is the peer side of the BGP session.",
33574          "type": "string"
33575        },
33576        "enableIpv6": {
33577          "description": "Enable IPv6 traffic over BGP Peer. If not specified, it is disabled by default.",
33578          "type": "boolean"
33579        },
33580        "ipv6NexthopAddress": {
33581          "description": "IPv6 address of the interface inside Google Cloud Platform.",
33582          "type": "string"
33583        },
33584        "peerIpv6NexthopAddress": {
33585          "description": "IPv6 address of the BGP interface outside Google Cloud Platform.",
33586          "type": "string"
33587        },
33588        "md5AuthenticationKeyName": {
33589          "description": "Present if MD5 authentication is enabled for the peering. Must be the name of one of the entries in the Router.md5_authentication_keys. The field must comply with RFC1035.",
33590          "type": "string"
33591        },
33592        "customLearnedRoutePriority": {
33593          "description": "The user-defined custom learned route priority for a BGP session. This value is applied to all custom learned route ranges for the session. You can choose a value from `0` to `65335`. If you don't provide a value, Google Cloud assigns a priority of `100` to the ranges.",
33594          "type": "integer",
33595          "format": "int32"
33596        },
33597        "customLearnedIpRanges": {
33598          "description": "A list of user-defined custom learned route IP address ranges for a BGP session.",
33599          "type": "array",
33600          "items": {
33601            "$ref": "RouterBgpPeerCustomLearnedIpRange"
33602          }
33603        }
33604      }
33605    },
33606    "RouterAdvertisedIpRange": {
33607      "id": "RouterAdvertisedIpRange",
33608      "description": "Description-tagged IP ranges for the router to advertise.",
33609      "type": "object",
33610      "properties": {
33611        "range": {
33612          "description": "The IP range to advertise. The value must be a CIDR-formatted string.",
33613          "type": "string"
33614        },
33615        "description": {
33616          "description": "User-specified description for the IP range.",
33617          "type": "string"
33618        }
33619      }
33620    },
33621    "RouterBgpPeerBfd": {
33622      "id": "RouterBgpPeerBfd",
33623      "type": "object",
33624      "properties": {
33625        "sessionInitializationMode": {
33626          "description": "The BFD session initialization mode for this BGP peer. If set to ACTIVE, the Cloud Router will initiate the BFD session for this BGP peer. If set to PASSIVE, the Cloud Router will wait for the peer router to initiate the BFD session for this BGP peer. If set to DISABLED, BFD is disabled for this BGP peer. The default is DISABLED.",
33627          "type": "string",
33628          "enumDescriptions": [
33629            "",
33630            "",
33631            ""
33632          ],
33633          "enum": [
33634            "ACTIVE",
33635            "DISABLED",
33636            "PASSIVE"
33637          ]
33638        },
33639        "minTransmitInterval": {
33640          "description": "The minimum interval, in milliseconds, between BFD control packets transmitted to the peer router. The actual value is negotiated between the two routers and is equal to the greater of this value and the corresponding receive interval of the other router. If set, this value must be between 1000 and 30000. The default is 1000.",
33641          "type": "integer",
33642          "format": "uint32"
33643        },
33644        "minReceiveInterval": {
33645          "description": "The minimum interval, in milliseconds, between BFD control packets received from the peer router. The actual value is negotiated between the two routers and is equal to the greater of this value and the transmit interval of the other router. If set, this value must be between 1000 and 30000. The default is 1000.",
33646          "type": "integer",
33647          "format": "uint32"
33648        },
33649        "multiplier": {
33650          "description": "The number of consecutive BFD packets that must be missed before BFD declares that a peer is unavailable. If set, the value must be a value between 5 and 16. The default is 5.",
33651          "type": "integer",
33652          "format": "uint32"
33653        }
33654      }
33655    },
33656    "RouterBgpPeerCustomLearnedIpRange": {
33657      "id": "RouterBgpPeerCustomLearnedIpRange",
33658      "type": "object",
33659      "properties": {
33660        "range": {
33661          "description": "The custom learned route IP address range. Must be a valid CIDR-formatted prefix. If an IP address is provided without a subnet mask, it is interpreted as, for IPv4, a `/32` singular IP address range, and, for IPv6, `/128`.",
33662          "type": "string"
33663        }
33664      }
33665    },
33666    "RouterBgp": {
33667      "id": "RouterBgp",
33668      "type": "object",
33669      "properties": {
33670        "asn": {
33671          "description": "Local BGP Autonomous System Number (ASN). Must be an RFC6996 private ASN, either 16-bit or 32-bit. The value will be fixed for this router resource. All VPN tunnels that link to this router will have the same local ASN.",
33672          "type": "integer",
33673          "format": "uint32"
33674        },
33675        "advertiseMode": {
33676          "description": "User-specified flag to indicate which mode to use for advertisement. The options are DEFAULT or CUSTOM.",
33677          "type": "string",
33678          "enumDescriptions": [
33679            "",
33680            ""
33681          ],
33682          "enum": [
33683            "CUSTOM",
33684            "DEFAULT"
33685          ]
33686        },
33687        "advertisedGroups": {
33688          "description": "User-specified list of prefix groups to advertise in custom mode. This field can only be populated if advertise_mode is CUSTOM and is advertised to all peers of the router. These groups will be advertised in addition to any specified prefixes. Leave this field blank to advertise no custom groups.",
33689          "type": "array",
33690          "items": {
33691            "type": "string",
33692            "enumDescriptions": [
33693              "Advertise all available subnets (including peer VPC subnets)."
33694            ],
33695            "enum": [
33696              "ALL_SUBNETS"
33697            ]
33698          }
33699        },
33700        "advertisedIpRanges": {
33701          "description": "User-specified list of individual IP ranges to advertise in custom mode. This field can only be populated if advertise_mode is CUSTOM and is advertised to all peers of the router. These IP ranges will be advertised in addition to any specified groups. Leave this field blank to advertise no custom IP ranges.",
33702          "type": "array",
33703          "items": {
33704            "$ref": "RouterAdvertisedIpRange"
33705          }
33706        },
33707        "keepaliveInterval": {
33708          "description": "The interval in seconds between BGP keepalive messages that are sent to the peer. Hold time is three times the interval at which keepalive messages are sent, and the hold time is the maximum number of seconds allowed to elapse between successive keepalive messages that BGP receives from a peer. BGP will use the smaller of either the local hold time value or the peer's hold time value as the hold time for the BGP connection between the two peers. If set, this value must be between 20 and 60. The default is 20.",
33709          "type": "integer",
33710          "format": "uint32"
33711        }
33712      }
33713    },
33714    "RouterNat": {
33715      "id": "RouterNat",
33716      "description": "Represents a Nat resource. It enables the VMs within the specified subnetworks to access Internet without external IP addresses. It specifies a list of subnetworks (and the ranges within) that want to use NAT. Customers can also provide the external IPs that would be used for NAT. GCP would auto-allocate ephemeral IPs if no external IPs are provided.",
33717      "type": "object",
33718      "properties": {
33719        "name": {
33720          "description": "Unique name of this Nat service. The name must be 1-63 characters long and comply with RFC1035.",
33721          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
33722          "type": "string"
33723        },
33724        "type": {
33725          "description": "Indicates whether this NAT is used for public or private IP translation. If unspecified, it defaults to PUBLIC.",
33726          "type": "string",
33727          "enumDescriptions": [
33728            "NAT used for private IP translation.",
33729            "NAT used for public IP translation. This is the default."
33730          ],
33731          "enum": [
33732            "PRIVATE",
33733            "PUBLIC"
33734          ]
33735        },
33736        "autoNetworkTier": {
33737          "description": "The network tier to use when automatically reserving NAT IP addresses. Must be one of: PREMIUM, STANDARD. If not specified, then the current project-level default tier is used.",
33738          "type": "string",
33739          "enumDescriptions": [
33740            "Public internet quality with fixed bandwidth.",
33741            "High quality, Google-grade network tier, support for all networking products.",
33742            "Public internet quality, only limited support for other networking products.",
33743            "(Output only) Temporary tier for FIXED_STANDARD when fixed standard tier is expired or not configured."
33744          ],
33745          "enum": [
33746            "FIXED_STANDARD",
33747            "PREMIUM",
33748            "STANDARD",
33749            "STANDARD_OVERRIDES_FIXED_STANDARD"
33750          ]
33751        },
33752        "endpointTypes": {
33753          "description": "List of NAT-ted endpoint types supported by the Nat Gateway. If the list is empty, then it will be equivalent to include ENDPOINT_TYPE_VM",
33754          "type": "array",
33755          "items": {
33756            "type": "string",
33757            "enumDescriptions": [
33758              "This is used for regional Application Load Balancers (internal and external) and regional proxy Network Load Balancers (internal and external) endpoints.",
33759              "This is used for Secure Web Gateway endpoints.",
33760              "This is the default."
33761            ],
33762            "enum": [
33763              "ENDPOINT_TYPE_MANAGED_PROXY_LB",
33764              "ENDPOINT_TYPE_SWG",
33765              "ENDPOINT_TYPE_VM"
33766            ]
33767          }
33768        },
33769        "sourceSubnetworkIpRangesToNat": {
33770          "description": "Specify the Nat option, which can take one of the following values: - ALL_SUBNETWORKS_ALL_IP_RANGES: All of the IP ranges in every Subnetwork are allowed to Nat. - ALL_SUBNETWORKS_ALL_PRIMARY_IP_RANGES: All of the primary IP ranges in every Subnetwork are allowed to Nat. - LIST_OF_SUBNETWORKS: A list of Subnetworks are allowed to Nat (specified in the field subnetwork below) The default is SUBNETWORK_IP_RANGE_TO_NAT_OPTION_UNSPECIFIED. Note that if this field contains ALL_SUBNETWORKS_ALL_IP_RANGES then there should not be any other Router.Nat section in any Router for this network in this region.",
33771          "type": "string",
33772          "enumDescriptions": [
33773            "All the IP ranges in every Subnetwork are allowed to Nat.",
33774            "All the primary IP ranges in every Subnetwork are allowed to Nat.",
33775            "A list of Subnetworks are allowed to Nat (specified in the field subnetwork below)"
33776          ],
33777          "enum": [
33778            "ALL_SUBNETWORKS_ALL_IP_RANGES",
33779            "ALL_SUBNETWORKS_ALL_PRIMARY_IP_RANGES",
33780            "LIST_OF_SUBNETWORKS"
33781          ]
33782        },
33783        "subnetworks": {
33784          "description": "A list of Subnetwork resources whose traffic should be translated by NAT Gateway. It is used only when LIST_OF_SUBNETWORKS is selected for the SubnetworkIpRangeToNatOption above.",
33785          "type": "array",
33786          "items": {
33787            "$ref": "RouterNatSubnetworkToNat"
33788          }
33789        },
33790        "natIps": {
33791          "description": "A list of URLs of the IP resources used for this Nat service. These IP addresses must be valid static external IP addresses assigned to the project.",
33792          "type": "array",
33793          "items": {
33794            "type": "string"
33795          }
33796        },
33797        "drainNatIps": {
33798          "description": "A list of URLs of the IP resources to be drained. These IPs must be valid static external IPs that have been assigned to the NAT. These IPs should be used for updating/patching a NAT only.",
33799          "type": "array",
33800          "items": {
33801            "type": "string"
33802          }
33803        },
33804        "natIpAllocateOption": {
33805          "description": "Specify the NatIpAllocateOption, which can take one of the following values: - MANUAL_ONLY: Uses only Nat IP addresses provided by customers. When there are not enough specified Nat IPs, the Nat service fails for new VMs. - AUTO_ONLY: Nat IPs are allocated by Google Cloud Platform; customers can't specify any Nat IPs. When choosing AUTO_ONLY, then nat_ip should be empty. ",
33806          "type": "string",
33807          "enumDescriptions": [
33808            "Nat IPs are allocated by GCP; customers can not specify any Nat IPs.",
33809            "Only use Nat IPs provided by customers. When specified Nat IPs are not enough then the Nat service fails for new VMs."
33810          ],
33811          "enum": [
33812            "AUTO_ONLY",
33813            "MANUAL_ONLY"
33814          ]
33815        },
33816        "minPortsPerVm": {
33817          "description": "Minimum number of ports allocated to a VM from this NAT config. If not set, a default number of ports is allocated to a VM. This is rounded up to the nearest power of 2. For example, if the value of this field is 50, at least 64 ports are allocated to a VM.",
33818          "type": "integer",
33819          "format": "int32"
33820        },
33821        "maxPortsPerVm": {
33822          "description": "Maximum number of ports allocated to a VM from this NAT config when Dynamic Port Allocation is enabled. If Dynamic Port Allocation is not enabled, this field has no effect. If Dynamic Port Allocation is enabled, and this field is set, it must be set to a power of two greater than minPortsPerVm, or 64 if minPortsPerVm is not set. If Dynamic Port Allocation is enabled and this field is not set, a maximum of 65536 ports will be allocated to a VM from this NAT config.",
33823          "type": "integer",
33824          "format": "int32"
33825        },
33826        "enableDynamicPortAllocation": {
33827          "description": "Enable Dynamic Port Allocation. If not specified, it is disabled by default. If set to true, - Dynamic Port Allocation will be enabled on this NAT config. - enableEndpointIndependentMapping cannot be set to true. - If minPorts is set, minPortsPerVm must be set to a power of two greater than or equal to 32. If minPortsPerVm is not set, a minimum of 32 ports will be allocated to a VM from this NAT config. ",
33828          "type": "boolean"
33829        },
33830        "udpIdleTimeoutSec": {
33831          "description": "Timeout (in seconds) for UDP connections. Defaults to 30s if not set.",
33832          "type": "integer",
33833          "format": "int32"
33834        },
33835        "icmpIdleTimeoutSec": {
33836          "description": "Timeout (in seconds) for ICMP connections. Defaults to 30s if not set.",
33837          "type": "integer",
33838          "format": "int32"
33839        },
33840        "tcpEstablishedIdleTimeoutSec": {
33841          "description": "Timeout (in seconds) for TCP established connections. Defaults to 1200s if not set.",
33842          "type": "integer",
33843          "format": "int32"
33844        },
33845        "tcpTransitoryIdleTimeoutSec": {
33846          "description": "Timeout (in seconds) for TCP transitory connections. Defaults to 30s if not set.",
33847          "type": "integer",
33848          "format": "int32"
33849        },
33850        "tcpTimeWaitTimeoutSec": {
33851          "description": "Timeout (in seconds) for TCP connections that are in TIME_WAIT state. Defaults to 120s if not set.",
33852          "type": "integer",
33853          "format": "int32"
33854        },
33855        "logConfig": {
33856          "description": "Configure logging on this NAT.",
33857          "$ref": "RouterNatLogConfig"
33858        },
33859        "rules": {
33860          "description": "A list of rules associated with this NAT.",
33861          "type": "array",
33862          "items": {
33863            "$ref": "RouterNatRule"
33864          }
33865        },
33866        "enableEndpointIndependentMapping": {
33867          "type": "boolean"
33868        }
33869      }
33870    },
33871    "RouterNatSubnetworkToNat": {
33872      "id": "RouterNatSubnetworkToNat",
33873      "description": "Defines the IP ranges that want to use NAT for a subnetwork.",
33874      "type": "object",
33875      "properties": {
33876        "name": {
33877          "description": "URL for the subnetwork resource that will use NAT.",
33878          "type": "string"
33879        },
33880        "sourceIpRangesToNat": {
33881          "description": "Specify the options for NAT ranges in the Subnetwork. All options of a single value are valid except NAT_IP_RANGE_OPTION_UNSPECIFIED. The only valid option with multiple values is: [\"PRIMARY_IP_RANGE\", \"LIST_OF_SECONDARY_IP_RANGES\"] Default: [ALL_IP_RANGES]",
33882          "type": "array",
33883          "items": {
33884            "type": "string",
33885            "enumDescriptions": [
33886              "The primary and all the secondary ranges are allowed to Nat.",
33887              "A list of secondary ranges are allowed to Nat.",
33888              "The primary range is allowed to Nat."
33889            ],
33890            "enum": [
33891              "ALL_IP_RANGES",
33892              "LIST_OF_SECONDARY_IP_RANGES",
33893              "PRIMARY_IP_RANGE"
33894            ]
33895          }
33896        },
33897        "secondaryIpRangeNames": {
33898          "description": "A list of the secondary ranges of the Subnetwork that are allowed to use NAT. This can be populated only if \"LIST_OF_SECONDARY_IP_RANGES\" is one of the values in source_ip_ranges_to_nat.",
33899          "type": "array",
33900          "items": {
33901            "type": "string"
33902          }
33903        }
33904      }
33905    },
33906    "RouterNatLogConfig": {
33907      "id": "RouterNatLogConfig",
33908      "description": "Configuration of logging on a NAT.",
33909      "type": "object",
33910      "properties": {
33911        "enable": {
33912          "description": "Indicates whether or not to export logs. This is false by default.",
33913          "type": "boolean"
33914        },
33915        "filter": {
33916          "description": "Specify the desired filtering of logs on this NAT. If unspecified, logs are exported for all connections handled by this NAT. This option can take one of the following values: - ERRORS_ONLY: Export logs only for connection failures. - TRANSLATIONS_ONLY: Export logs only for successful connections. - ALL: Export logs for all connections, successful and unsuccessful. ",
33917          "type": "string",
33918          "enumDescriptions": [
33919            "Export logs for all (successful and unsuccessful) connections.",
33920            "Export logs for connection failures only.",
33921            "Export logs for successful connections only."
33922          ],
33923          "enum": [
33924            "ALL",
33925            "ERRORS_ONLY",
33926            "TRANSLATIONS_ONLY"
33927          ]
33928        }
33929      }
33930    },
33931    "RouterNatRule": {
33932      "id": "RouterNatRule",
33933      "type": "object",
33934      "properties": {
33935        "ruleNumber": {
33936          "description": "An integer uniquely identifying a rule in the list. The rule number must be a positive value between 0 and 65000, and must be unique among rules within a NAT.",
33937          "type": "integer",
33938          "format": "uint32"
33939        },
33940        "description": {
33941          "description": "An optional description of this rule.",
33942          "type": "string"
33943        },
33944        "match": {
33945          "description": "CEL expression that specifies the match condition that egress traffic from a VM is evaluated against. If it evaluates to true, the corresponding `action` is enforced. The following examples are valid match expressions for public NAT: \"inIpRange(destination.ip, '1.1.0.0/16') || inIpRange(destination.ip, '2.2.0.0/16')\" \"destination.ip == '1.1.0.1' || destination.ip == '8.8.8.8'\" The following example is a valid match expression for private NAT: \"nexthop.hub == '//networkconnectivity.googleapis.com/projects/my-project/locations/global/hubs/hub-1'\"",
33946          "type": "string"
33947        },
33948        "action": {
33949          "description": "The action to be enforced for traffic that matches this rule.",
33950          "$ref": "RouterNatRuleAction"
33951        }
33952      }
33953    },
33954    "RouterNatRuleAction": {
33955      "id": "RouterNatRuleAction",
33956      "type": "object",
33957      "properties": {
33958        "sourceNatActiveIps": {
33959          "description": "A list of URLs of the IP resources used for this NAT rule. These IP addresses must be valid static external IP addresses assigned to the project. This field is used for public NAT.",
33960          "type": "array",
33961          "items": {
33962            "type": "string"
33963          }
33964        },
33965        "sourceNatDrainIps": {
33966          "description": "A list of URLs of the IP resources to be drained. These IPs must be valid static external IPs that have been assigned to the NAT. These IPs should be used for updating/patching a NAT rule only. This field is used for public NAT.",
33967          "type": "array",
33968          "items": {
33969            "type": "string"
33970          }
33971        },
33972        "sourceNatActiveRanges": {
33973          "description": "A list of URLs of the subnetworks used as source ranges for this NAT Rule. These subnetworks must have purpose set to PRIVATE_NAT. This field is used for private NAT.",
33974          "type": "array",
33975          "items": {
33976            "type": "string"
33977          }
33978        },
33979        "sourceNatDrainRanges": {
33980          "description": "A list of URLs of subnetworks representing source ranges to be drained. This is only supported on patch/update, and these subnetworks must have previously been used as active ranges in this NAT Rule. This field is used for private NAT.",
33981          "type": "array",
33982          "items": {
33983            "type": "string"
33984          }
33985        }
33986      }
33987    },
33988    "RouterMd5AuthenticationKey": {
33989      "id": "RouterMd5AuthenticationKey",
33990      "type": "object",
33991      "properties": {
33992        "name": {
33993          "description": "Name used to identify the key. Must be unique within a router. Must be referenced by exactly one bgpPeer. Must comply with RFC1035.",
33994          "annotations": {
33995            "required": [
33996              "compute.routers.insert",
33997              "compute.routers.update"
33998            ]
33999          },
34000          "type": "string"
34001        },
34002        "key": {
34003          "description": "[Input only] Value of the key. For patch and update calls, it can be skipped to copy the value from the previous configuration. This is allowed if the key with the same name existed before the operation. Maximum length is 80 characters. Can only contain printable ASCII characters.",
34004          "annotations": {
34005            "required": [
34006              "compute.routers.insert"
34007            ]
34008          },
34009          "type": "string"
34010        }
34011      }
34012    },
34013    "RouterList": {
34014      "id": "RouterList",
34015      "description": "Contains a list of Router resources.",
34016      "type": "object",
34017      "properties": {
34018        "kind": {
34019          "description": "[Output Only] Type of resource. Always compute#router for routers.",
34020          "default": "compute#routerList",
34021          "type": "string"
34022        },
34023        "id": {
34024          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
34025          "type": "string"
34026        },
34027        "items": {
34028          "description": "A list of Router resources.",
34029          "type": "array",
34030          "items": {
34031            "$ref": "Router"
34032          }
34033        },
34034        "nextPageToken": {
34035          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
34036          "type": "string"
34037        },
34038        "selfLink": {
34039          "description": "[Output Only] Server-defined URL for this resource.",
34040          "type": "string"
34041        },
34042        "warning": {
34043          "description": "[Output Only] Informational warning message.",
34044          "type": "object",
34045          "properties": {
34046            "code": {
34047              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
34048              "type": "string",
34049              "enumDescriptions": [
34050                "Warning about failed cleanup of transient changes made by a failed operation.",
34051                "A link to a deprecated resource was created.",
34052                "When deploying and at least one of the resources has a type marked as deprecated",
34053                "The user created a boot disk that is larger than image size.",
34054                "When deploying and at least one of the resources has a type marked as experimental",
34055                "Warning that is present in an external api call",
34056                "Warning that value of a field has been overridden. Deprecated unused field.",
34057                "The operation involved use of an injected kernel, which is deprecated.",
34058                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
34059                "When deploying a deployment with a exceedingly large number of resources",
34060                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
34061                "A resource depends on a missing type",
34062                "The route's nextHopIp address is not assigned to an instance on the network.",
34063                "The route's next hop instance cannot ip forward.",
34064                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
34065                "The route's nextHopInstance URL refers to an instance that does not exist.",
34066                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
34067                "The route's next hop instance does not have a status of RUNNING.",
34068                "Error which is not critical. We decided to continue the process despite the mentioned error.",
34069                "No results are present on a particular list page.",
34070                "Success is reported, but some results may be missing due to errors",
34071                "The user attempted to use a resource that requires a TOS they have not accepted.",
34072                "Warning that a resource is in use.",
34073                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
34074                "When a resource schema validation is ignored.",
34075                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
34076                "When undeclared properties in the schema are present",
34077                "A given scope cannot be reached."
34078              ],
34079              "enumDeprecated": [
34080                false,
34081                false,
34082                false,
34083                false,
34084                false,
34085                false,
34086                true,
34087                false,
34088                false,
34089                false,
34090                false,
34091                false,
34092                false,
34093                false,
34094                false,
34095                false,
34096                false,
34097                false,
34098                false,
34099                false,
34100                false,
34101                false,
34102                false,
34103                false,
34104                false,
34105                false,
34106                false,
34107                false
34108              ],
34109              "enum": [
34110                "CLEANUP_FAILED",
34111                "DEPRECATED_RESOURCE_USED",
34112                "DEPRECATED_TYPE_USED",
34113                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
34114                "EXPERIMENTAL_TYPE_USED",
34115                "EXTERNAL_API_WARNING",
34116                "FIELD_VALUE_OVERRIDEN",
34117                "INJECTED_KERNELS_DEPRECATED",
34118                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
34119                "LARGE_DEPLOYMENT_WARNING",
34120                "LIST_OVERHEAD_QUOTA_EXCEED",
34121                "MISSING_TYPE_DEPENDENCY",
34122                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
34123                "NEXT_HOP_CANNOT_IP_FORWARD",
34124                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
34125                "NEXT_HOP_INSTANCE_NOT_FOUND",
34126                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
34127                "NEXT_HOP_NOT_RUNNING",
34128                "NOT_CRITICAL_ERROR",
34129                "NO_RESULTS_ON_PAGE",
34130                "PARTIAL_SUCCESS",
34131                "REQUIRED_TOS_AGREEMENT",
34132                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
34133                "RESOURCE_NOT_DELETED",
34134                "SCHEMA_VALIDATION_IGNORED",
34135                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
34136                "UNDECLARED_PROPERTIES",
34137                "UNREACHABLE"
34138              ]
34139            },
34140            "message": {
34141              "description": "[Output Only] A human-readable description of the warning code.",
34142              "type": "string"
34143            },
34144            "data": {
34145              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
34146              "type": "array",
34147              "items": {
34148                "type": "object",
34149                "properties": {
34150                  "key": {
34151                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
34152                    "type": "string"
34153                  },
34154                  "value": {
34155                    "description": "[Output Only] A warning data value corresponding to the key.",
34156                    "type": "string"
34157                  }
34158                }
34159              }
34160            }
34161          }
34162        }
34163      }
34164    },
34165    "RouterAggregatedList": {
34166      "id": "RouterAggregatedList",
34167      "description": "Contains a list of routers.",
34168      "type": "object",
34169      "properties": {
34170        "kind": {
34171          "description": "Type of resource.",
34172          "default": "compute#routerAggregatedList",
34173          "type": "string"
34174        },
34175        "id": {
34176          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
34177          "type": "string"
34178        },
34179        "items": {
34180          "description": "A list of Router resources.",
34181          "type": "object",
34182          "additionalProperties": {
34183            "description": "Name of the scope containing this set of routers.",
34184            "$ref": "RoutersScopedList"
34185          }
34186        },
34187        "nextPageToken": {
34188          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
34189          "type": "string"
34190        },
34191        "selfLink": {
34192          "description": "[Output Only] Server-defined URL for this resource.",
34193          "type": "string"
34194        },
34195        "warning": {
34196          "description": "[Output Only] Informational warning message.",
34197          "type": "object",
34198          "properties": {
34199            "code": {
34200              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
34201              "type": "string",
34202              "enumDescriptions": [
34203                "Warning about failed cleanup of transient changes made by a failed operation.",
34204                "A link to a deprecated resource was created.",
34205                "When deploying and at least one of the resources has a type marked as deprecated",
34206                "The user created a boot disk that is larger than image size.",
34207                "When deploying and at least one of the resources has a type marked as experimental",
34208                "Warning that is present in an external api call",
34209                "Warning that value of a field has been overridden. Deprecated unused field.",
34210                "The operation involved use of an injected kernel, which is deprecated.",
34211                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
34212                "When deploying a deployment with a exceedingly large number of resources",
34213                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
34214                "A resource depends on a missing type",
34215                "The route's nextHopIp address is not assigned to an instance on the network.",
34216                "The route's next hop instance cannot ip forward.",
34217                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
34218                "The route's nextHopInstance URL refers to an instance that does not exist.",
34219                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
34220                "The route's next hop instance does not have a status of RUNNING.",
34221                "Error which is not critical. We decided to continue the process despite the mentioned error.",
34222                "No results are present on a particular list page.",
34223                "Success is reported, but some results may be missing due to errors",
34224                "The user attempted to use a resource that requires a TOS they have not accepted.",
34225                "Warning that a resource is in use.",
34226                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
34227                "When a resource schema validation is ignored.",
34228                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
34229                "When undeclared properties in the schema are present",
34230                "A given scope cannot be reached."
34231              ],
34232              "enumDeprecated": [
34233                false,
34234                false,
34235                false,
34236                false,
34237                false,
34238                false,
34239                true,
34240                false,
34241                false,
34242                false,
34243                false,
34244                false,
34245                false,
34246                false,
34247                false,
34248                false,
34249                false,
34250                false,
34251                false,
34252                false,
34253                false,
34254                false,
34255                false,
34256                false,
34257                false,
34258                false,
34259                false,
34260                false
34261              ],
34262              "enum": [
34263                "CLEANUP_FAILED",
34264                "DEPRECATED_RESOURCE_USED",
34265                "DEPRECATED_TYPE_USED",
34266                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
34267                "EXPERIMENTAL_TYPE_USED",
34268                "EXTERNAL_API_WARNING",
34269                "FIELD_VALUE_OVERRIDEN",
34270                "INJECTED_KERNELS_DEPRECATED",
34271                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
34272                "LARGE_DEPLOYMENT_WARNING",
34273                "LIST_OVERHEAD_QUOTA_EXCEED",
34274                "MISSING_TYPE_DEPENDENCY",
34275                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
34276                "NEXT_HOP_CANNOT_IP_FORWARD",
34277                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
34278                "NEXT_HOP_INSTANCE_NOT_FOUND",
34279                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
34280                "NEXT_HOP_NOT_RUNNING",
34281                "NOT_CRITICAL_ERROR",
34282                "NO_RESULTS_ON_PAGE",
34283                "PARTIAL_SUCCESS",
34284                "REQUIRED_TOS_AGREEMENT",
34285                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
34286                "RESOURCE_NOT_DELETED",
34287                "SCHEMA_VALIDATION_IGNORED",
34288                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
34289                "UNDECLARED_PROPERTIES",
34290                "UNREACHABLE"
34291              ]
34292            },
34293            "message": {
34294              "description": "[Output Only] A human-readable description of the warning code.",
34295              "type": "string"
34296            },
34297            "data": {
34298              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
34299              "type": "array",
34300              "items": {
34301                "type": "object",
34302                "properties": {
34303                  "key": {
34304                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
34305                    "type": "string"
34306                  },
34307                  "value": {
34308                    "description": "[Output Only] A warning data value corresponding to the key.",
34309                    "type": "string"
34310                  }
34311                }
34312              }
34313            }
34314          }
34315        },
34316        "unreachables": {
34317          "description": "[Output Only] Unreachable resources.",
34318          "type": "array",
34319          "items": {
34320            "type": "string"
34321          }
34322        }
34323      }
34324    },
34325    "RoutersScopedList": {
34326      "id": "RoutersScopedList",
34327      "type": "object",
34328      "properties": {
34329        "routers": {
34330          "description": "A list of routers contained in this scope.",
34331          "type": "array",
34332          "items": {
34333            "$ref": "Router"
34334          }
34335        },
34336        "warning": {
34337          "description": "Informational warning which replaces the list of routers when the list is empty.",
34338          "type": "object",
34339          "properties": {
34340            "code": {
34341              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
34342              "type": "string",
34343              "enumDescriptions": [
34344                "Warning about failed cleanup of transient changes made by a failed operation.",
34345                "A link to a deprecated resource was created.",
34346                "When deploying and at least one of the resources has a type marked as deprecated",
34347                "The user created a boot disk that is larger than image size.",
34348                "When deploying and at least one of the resources has a type marked as experimental",
34349                "Warning that is present in an external api call",
34350                "Warning that value of a field has been overridden. Deprecated unused field.",
34351                "The operation involved use of an injected kernel, which is deprecated.",
34352                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
34353                "When deploying a deployment with a exceedingly large number of resources",
34354                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
34355                "A resource depends on a missing type",
34356                "The route's nextHopIp address is not assigned to an instance on the network.",
34357                "The route's next hop instance cannot ip forward.",
34358                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
34359                "The route's nextHopInstance URL refers to an instance that does not exist.",
34360                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
34361                "The route's next hop instance does not have a status of RUNNING.",
34362                "Error which is not critical. We decided to continue the process despite the mentioned error.",
34363                "No results are present on a particular list page.",
34364                "Success is reported, but some results may be missing due to errors",
34365                "The user attempted to use a resource that requires a TOS they have not accepted.",
34366                "Warning that a resource is in use.",
34367                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
34368                "When a resource schema validation is ignored.",
34369                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
34370                "When undeclared properties in the schema are present",
34371                "A given scope cannot be reached."
34372              ],
34373              "enumDeprecated": [
34374                false,
34375                false,
34376                false,
34377                false,
34378                false,
34379                false,
34380                true,
34381                false,
34382                false,
34383                false,
34384                false,
34385                false,
34386                false,
34387                false,
34388                false,
34389                false,
34390                false,
34391                false,
34392                false,
34393                false,
34394                false,
34395                false,
34396                false,
34397                false,
34398                false,
34399                false,
34400                false,
34401                false
34402              ],
34403              "enum": [
34404                "CLEANUP_FAILED",
34405                "DEPRECATED_RESOURCE_USED",
34406                "DEPRECATED_TYPE_USED",
34407                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
34408                "EXPERIMENTAL_TYPE_USED",
34409                "EXTERNAL_API_WARNING",
34410                "FIELD_VALUE_OVERRIDEN",
34411                "INJECTED_KERNELS_DEPRECATED",
34412                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
34413                "LARGE_DEPLOYMENT_WARNING",
34414                "LIST_OVERHEAD_QUOTA_EXCEED",
34415                "MISSING_TYPE_DEPENDENCY",
34416                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
34417                "NEXT_HOP_CANNOT_IP_FORWARD",
34418                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
34419                "NEXT_HOP_INSTANCE_NOT_FOUND",
34420                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
34421                "NEXT_HOP_NOT_RUNNING",
34422                "NOT_CRITICAL_ERROR",
34423                "NO_RESULTS_ON_PAGE",
34424                "PARTIAL_SUCCESS",
34425                "REQUIRED_TOS_AGREEMENT",
34426                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
34427                "RESOURCE_NOT_DELETED",
34428                "SCHEMA_VALIDATION_IGNORED",
34429                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
34430                "UNDECLARED_PROPERTIES",
34431                "UNREACHABLE"
34432              ]
34433            },
34434            "message": {
34435              "description": "[Output Only] A human-readable description of the warning code.",
34436              "type": "string"
34437            },
34438            "data": {
34439              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
34440              "type": "array",
34441              "items": {
34442                "type": "object",
34443                "properties": {
34444                  "key": {
34445                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
34446                    "type": "string"
34447                  },
34448                  "value": {
34449                    "description": "[Output Only] A warning data value corresponding to the key.",
34450                    "type": "string"
34451                  }
34452                }
34453              }
34454            }
34455          }
34456        }
34457      }
34458    },
34459    "RouterStatusResponse": {
34460      "id": "RouterStatusResponse",
34461      "type": "object",
34462      "properties": {
34463        "kind": {
34464          "description": "Type of resource.",
34465          "default": "compute#routerStatusResponse",
34466          "type": "string"
34467        },
34468        "result": {
34469          "$ref": "RouterStatus"
34470        }
34471      }
34472    },
34473    "RouterStatus": {
34474      "id": "RouterStatus",
34475      "type": "object",
34476      "properties": {
34477        "network": {
34478          "description": "URI of the network to which this router belongs.",
34479          "type": "string"
34480        },
34481        "bestRoutes": {
34482          "description": "Best routes for this router's network.",
34483          "type": "array",
34484          "items": {
34485            "$ref": "Route"
34486          }
34487        },
34488        "bestRoutesForRouter": {
34489          "description": "Best routes learned by this router.",
34490          "type": "array",
34491          "items": {
34492            "$ref": "Route"
34493          }
34494        },
34495        "bgpPeerStatus": {
34496          "type": "array",
34497          "items": {
34498            "$ref": "RouterStatusBgpPeerStatus"
34499          }
34500        },
34501        "natStatus": {
34502          "type": "array",
34503          "items": {
34504            "$ref": "RouterStatusNatStatus"
34505          }
34506        }
34507      }
34508    },
34509    "RouterStatusBgpPeerStatus": {
34510      "id": "RouterStatusBgpPeerStatus",
34511      "type": "object",
34512      "properties": {
34513        "name": {
34514          "description": "Name of this BGP peer. Unique within the Routers resource.",
34515          "type": "string"
34516        },
34517        "linkedVpnTunnel": {
34518          "description": "URL of the VPN tunnel that this BGP peer controls.",
34519          "type": "string"
34520        },
34521        "routerApplianceInstance": {
34522          "description": "[Output only] URI of the VM instance that is used as third-party router appliances such as Next Gen Firewalls, Virtual Routers, or Router Appliances. The VM instance is the peer side of the BGP session.",
34523          "type": "string"
34524        },
34525        "ipAddress": {
34526          "description": "IP address of the local BGP interface.",
34527          "type": "string"
34528        },
34529        "peerIpAddress": {
34530          "description": "IP address of the remote BGP interface.",
34531          "type": "string"
34532        },
34533        "ipv6NexthopAddress": {
34534          "description": "IPv6 address of the local BGP interface.",
34535          "type": "string"
34536        },
34537        "peerIpv6NexthopAddress": {
34538          "description": "IPv6 address of the remote BGP interface.",
34539          "type": "string"
34540        },
34541        "enableIpv6": {
34542          "description": "Enable IPv6 traffic over BGP Peer. If not specified, it is disabled by default.",
34543          "type": "boolean"
34544        },
34545        "status": {
34546          "description": "Status of the BGP peer: {UP, DOWN}",
34547          "type": "string",
34548          "enumDescriptions": [
34549            "",
34550            "",
34551            ""
34552          ],
34553          "enum": [
34554            "DOWN",
34555            "UNKNOWN",
34556            "UP"
34557          ]
34558        },
34559        "state": {
34560          "description": "The state of the BGP session. For a list of possible values for this field, see BGP session states.",
34561          "type": "string"
34562        },
34563        "uptime": {
34564          "description": "Time this session has been up. Format: 14 years, 51 weeks, 6 days, 23 hours, 59 minutes, 59 seconds",
34565          "type": "string"
34566        },
34567        "uptimeSeconds": {
34568          "description": "Time this session has been up, in seconds. Format: 145",
34569          "type": "string"
34570        },
34571        "numLearnedRoutes": {
34572          "description": "Number of routes learned from the remote BGP Peer.",
34573          "type": "integer",
34574          "format": "uint32"
34575        },
34576        "advertisedRoutes": {
34577          "description": "Routes that were advertised to the remote BGP peer",
34578          "type": "array",
34579          "items": {
34580            "$ref": "Route"
34581          }
34582        },
34583        "bfdStatus": {
34584          "$ref": "BfdStatus"
34585        },
34586        "md5AuthEnabled": {
34587          "description": "Informs whether MD5 authentication is enabled on this BGP peer.",
34588          "type": "boolean"
34589        },
34590        "statusReason": {
34591          "description": "Indicates why particular status was returned.",
34592          "type": "string",
34593          "enumDescriptions": [
34594            "Indicates internal problems with configuration of MD5 authentication. This particular reason can only be returned when md5AuthEnabled is true and status is DOWN.",
34595            ""
34596          ],
34597          "enum": [
34598            "MD5_AUTH_INTERNAL_PROBLEM",
34599            "STATUS_REASON_UNSPECIFIED"
34600          ]
34601        }
34602      }
34603    },
34604    "BfdStatus": {
34605      "id": "BfdStatus",
34606      "description": "Next free: 15",
34607      "type": "object",
34608      "properties": {
34609        "uptimeMs": {
34610          "description": "Session uptime in milliseconds. Value will be 0 if session is not up.",
34611          "type": "string",
34612          "format": "int64"
34613        },
34614        "localState": {
34615          "description": "The current BFD session state as seen by the transmitting system. These states are specified in section 4.1 of RFC5880",
34616          "type": "string",
34617          "enumDescriptions": [
34618            "",
34619            "",
34620            "",
34621            "",
34622            ""
34623          ],
34624          "enum": [
34625            "ADMIN_DOWN",
34626            "DOWN",
34627            "INIT",
34628            "STATE_UNSPECIFIED",
34629            "UP"
34630          ]
34631        },
34632        "localDiagnostic": {
34633          "description": "The diagnostic code specifies the local system's reason for the last change in session state. This allows remote systems to determine the reason that the previous session failed, for example. These diagnostic codes are specified in section 4.1 of RFC5880",
34634          "type": "string",
34635          "enumDescriptions": [
34636            "",
34637            "",
34638            "",
34639            "",
34640            "",
34641            "",
34642            "",
34643            "",
34644            "",
34645            ""
34646          ],
34647          "enum": [
34648            "ADMINISTRATIVELY_DOWN",
34649            "CONCATENATED_PATH_DOWN",
34650            "CONTROL_DETECTION_TIME_EXPIRED",
34651            "DIAGNOSTIC_UNSPECIFIED",
34652            "ECHO_FUNCTION_FAILED",
34653            "FORWARDING_PLANE_RESET",
34654            "NEIGHBOR_SIGNALED_SESSION_DOWN",
34655            "NO_DIAGNOSTIC",
34656            "PATH_DOWN",
34657            "REVERSE_CONCATENATED_PATH_DOWN"
34658          ]
34659        },
34660        "controlPacketCounts": {
34661          "description": "Control packet counts for the current BFD session.",
34662          "$ref": "BfdStatusPacketCounts"
34663        },
34664        "txPacket": {
34665          "description": "The most recent Tx control packet for this BFD session.",
34666          "$ref": "BfdPacket"
34667        },
34668        "rxPacket": {
34669          "description": "The most recent Rx control packet for this BFD session.",
34670          "$ref": "BfdPacket"
34671        },
34672        "controlPacketIntervals": {
34673          "description": "Inter-packet time interval statistics for control packets.",
34674          "type": "array",
34675          "items": {
34676            "$ref": "PacketIntervals"
34677          }
34678        },
34679        "negotiatedLocalControlTxIntervalMs": {
34680          "description": "Negotiated transmit interval for control packets.",
34681          "type": "integer",
34682          "format": "uint32"
34683        },
34684        "bfdSessionInitializationMode": {
34685          "description": "The BFD session initialization mode for this BGP peer. If set to ACTIVE, the Cloud Router will initiate the BFD session for this BGP peer. If set to PASSIVE, the Cloud Router will wait for the peer router to initiate the BFD session for this BGP peer. If set to DISABLED, BFD is disabled for this BGP peer.",
34686          "type": "string",
34687          "enumDescriptions": [
34688            "",
34689            "",
34690            ""
34691          ],
34692          "enum": [
34693            "ACTIVE",
34694            "DISABLED",
34695            "PASSIVE"
34696          ]
34697        },
34698        "configUpdateTimestampMicros": {
34699          "description": "Unix timestamp of the most recent config update.",
34700          "type": "string",
34701          "format": "int64"
34702        }
34703      }
34704    },
34705    "BfdStatusPacketCounts": {
34706      "id": "BfdStatusPacketCounts",
34707      "type": "object",
34708      "properties": {
34709        "numTx": {
34710          "description": "Number of packets transmitted since the beginning of the current BFD session.",
34711          "type": "integer",
34712          "format": "uint32"
34713        },
34714        "numRx": {
34715          "description": "Number of packets received since the beginning of the current BFD session.",
34716          "type": "integer",
34717          "format": "uint32"
34718        },
34719        "numRxSuccessful": {
34720          "description": "Number of packets received that were successfully processed since the beginning of the current BFD session.",
34721          "type": "integer",
34722          "format": "uint32"
34723        },
34724        "numRxRejected": {
34725          "description": "Number of packets received that were rejected because of errors since the beginning of the current BFD session.",
34726          "type": "integer",
34727          "format": "uint32"
34728        }
34729      }
34730    },
34731    "BfdPacket": {
34732      "id": "BfdPacket",
34733      "type": "object",
34734      "properties": {
34735        "version": {
34736          "description": "The version number of the BFD protocol, as specified in section 4.1 of RFC5880.",
34737          "type": "integer",
34738          "format": "uint32"
34739        },
34740        "diagnostic": {
34741          "description": "The diagnostic code specifies the local system's reason for the last change in session state. This allows remote systems to determine the reason that the previous session failed, for example. These diagnostic codes are specified in section 4.1 of RFC5880",
34742          "type": "string",
34743          "enumDescriptions": [
34744            "",
34745            "",
34746            "",
34747            "",
34748            "",
34749            "",
34750            "",
34751            "",
34752            "",
34753            ""
34754          ],
34755          "enum": [
34756            "ADMINISTRATIVELY_DOWN",
34757            "CONCATENATED_PATH_DOWN",
34758            "CONTROL_DETECTION_TIME_EXPIRED",
34759            "DIAGNOSTIC_UNSPECIFIED",
34760            "ECHO_FUNCTION_FAILED",
34761            "FORWARDING_PLANE_RESET",
34762            "NEIGHBOR_SIGNALED_SESSION_DOWN",
34763            "NO_DIAGNOSTIC",
34764            "PATH_DOWN",
34765            "REVERSE_CONCATENATED_PATH_DOWN"
34766          ]
34767        },
34768        "state": {
34769          "description": "The current BFD session state as seen by the transmitting system. These states are specified in section 4.1 of RFC5880",
34770          "type": "string",
34771          "enumDescriptions": [
34772            "",
34773            "",
34774            "",
34775            "",
34776            ""
34777          ],
34778          "enum": [
34779            "ADMIN_DOWN",
34780            "DOWN",
34781            "INIT",
34782            "STATE_UNSPECIFIED",
34783            "UP"
34784          ]
34785        },
34786        "poll": {
34787          "description": "The Poll bit of the BFD packet. This is specified in section 4.1 of RFC5880",
34788          "type": "boolean"
34789        },
34790        "final": {
34791          "description": "The Final bit of the BFD packet. This is specified in section 4.1 of RFC5880",
34792          "type": "boolean"
34793        },
34794        "controlPlaneIndependent": {
34795          "description": "The Control Plane Independent bit of the BFD packet. This is specified in section 4.1 of RFC5880",
34796          "type": "boolean"
34797        },
34798        "authenticationPresent": {
34799          "description": "The Authentication Present bit of the BFD packet. This is specified in section 4.1 of RFC5880",
34800          "type": "boolean"
34801        },
34802        "demand": {
34803          "description": "The demand bit of the BFD packet. This is specified in section 4.1 of RFC5880",
34804          "type": "boolean"
34805        },
34806        "multipoint": {
34807          "description": "The multipoint bit of the BFD packet. This is specified in section 4.1 of RFC5880",
34808          "type": "boolean"
34809        },
34810        "multiplier": {
34811          "description": "The detection time multiplier of the BFD packet. This is specified in section 4.1 of RFC5880",
34812          "type": "integer",
34813          "format": "uint32"
34814        },
34815        "length": {
34816          "description": "The length of the BFD Control packet in bytes. This is specified in section 4.1 of RFC5880",
34817          "type": "integer",
34818          "format": "uint32"
34819        },
34820        "myDiscriminator": {
34821          "description": "The My Discriminator value in the BFD packet. This is specified in section 4.1 of RFC5880",
34822          "type": "integer",
34823          "format": "uint32"
34824        },
34825        "yourDiscriminator": {
34826          "description": "The Your Discriminator value in the BFD packet. This is specified in section 4.1 of RFC5880",
34827          "type": "integer",
34828          "format": "uint32"
34829        },
34830        "minTxIntervalMs": {
34831          "description": "The Desired Min TX Interval value in the BFD packet. This is specified in section 4.1 of RFC5880",
34832          "type": "integer",
34833          "format": "uint32"
34834        },
34835        "minRxIntervalMs": {
34836          "description": "The Required Min RX Interval value in the BFD packet. This is specified in section 4.1 of RFC5880",
34837          "type": "integer",
34838          "format": "uint32"
34839        },
34840        "minEchoRxIntervalMs": {
34841          "description": "The Required Min Echo RX Interval value in the BFD packet. This is specified in section 4.1 of RFC5880",
34842          "type": "integer",
34843          "format": "uint32"
34844        }
34845      }
34846    },
34847    "PacketIntervals": {
34848      "id": "PacketIntervals",
34849      "description": "Next free: 7",
34850      "type": "object",
34851      "properties": {
34852        "type": {
34853          "description": "The type of packets for which inter-packet intervals were computed.",
34854          "type": "string",
34855          "enumDescriptions": [
34856            "Only applies to Echo packets. This shows the intervals between sending and receiving the same packet.",
34857            "Intervals between received packets.",
34858            "Intervals between transmitted packets.",
34859            ""
34860          ],
34861          "enum": [
34862            "LOOPBACK",
34863            "RECEIVE",
34864            "TRANSMIT",
34865            "TYPE_UNSPECIFIED"
34866          ]
34867        },
34868        "duration": {
34869          "description": "From how long ago in the past these intervals were observed.",
34870          "type": "string",
34871          "enumDescriptions": [
34872            "",
34873            "",
34874            "From BfdSession object creation time.",
34875            ""
34876          ],
34877          "enum": [
34878            "DURATION_UNSPECIFIED",
34879            "HOUR",
34880            "MAX",
34881            "MINUTE"
34882          ]
34883        },
34884        "numIntervals": {
34885          "description": "Number of inter-packet intervals from which these statistics were derived.",
34886          "type": "string",
34887          "format": "int64"
34888        },
34889        "minMs": {
34890          "description": "Minimum observed inter-packet interval in milliseconds.",
34891          "type": "string",
34892          "format": "int64"
34893        },
34894        "maxMs": {
34895          "description": "Maximum observed inter-packet interval in milliseconds.",
34896          "type": "string",
34897          "format": "int64"
34898        },
34899        "avgMs": {
34900          "description": "Average observed inter-packet interval in milliseconds.",
34901          "type": "string",
34902          "format": "int64"
34903        }
34904      }
34905    },
34906    "RouterStatusNatStatus": {
34907      "id": "RouterStatusNatStatus",
34908      "description": "Status of a NAT contained in this router.",
34909      "type": "object",
34910      "properties": {
34911        "name": {
34912          "description": "Unique name of this NAT.",
34913          "type": "string"
34914        },
34915        "userAllocatedNatIpResources": {
34916          "description": "A list of fully qualified URLs of reserved IP address resources.",
34917          "type": "array",
34918          "items": {
34919            "type": "string"
34920          }
34921        },
34922        "drainUserAllocatedNatIps": {
34923          "description": "A list of IPs user-allocated for NAT that are in drain mode. Example: [\"1.1.1.1\", \"179.12.26.133\"].",
34924          "type": "array",
34925          "items": {
34926            "type": "string"
34927          }
34928        },
34929        "userAllocatedNatIps": {
34930          "description": "A list of IPs user-allocated for NAT. They will be raw IP strings like \"179.12.26.133\".",
34931          "type": "array",
34932          "items": {
34933            "type": "string"
34934          }
34935        },
34936        "autoAllocatedNatIps": {
34937          "description": "A list of IPs auto-allocated for NAT. Example: [\"1.1.1.1\", \"129.2.16.89\"]",
34938          "type": "array",
34939          "items": {
34940            "type": "string"
34941          }
34942        },
34943        "drainAutoAllocatedNatIps": {
34944          "description": "A list of IPs auto-allocated for NAT that are in drain mode. Example: [\"1.1.1.1\", \"179.12.26.133\"].",
34945          "type": "array",
34946          "items": {
34947            "type": "string"
34948          }
34949        },
34950        "minExtraNatIpsNeeded": {
34951          "description": "The number of extra IPs to allocate. This will be greater than 0 only if user-specified IPs are NOT enough to allow all configured VMs to use NAT. This value is meaningful only when auto-allocation of NAT IPs is *not* used.",
34952          "type": "integer",
34953          "format": "int32"
34954        },
34955        "numVmEndpointsWithNatMappings": {
34956          "description": "Number of VM endpoints (i.e., Nics) that can use NAT.",
34957          "type": "integer",
34958          "format": "int32"
34959        },
34960        "ruleStatus": {
34961          "description": "Status of rules in this NAT.",
34962          "type": "array",
34963          "items": {
34964            "$ref": "RouterStatusNatStatusNatRuleStatus"
34965          }
34966        }
34967      }
34968    },
34969    "RouterStatusNatStatusNatRuleStatus": {
34970      "id": "RouterStatusNatStatusNatRuleStatus",
34971      "description": "Status of a NAT Rule contained in this NAT.",
34972      "type": "object",
34973      "properties": {
34974        "ruleNumber": {
34975          "description": "Rule number of the rule.",
34976          "type": "integer",
34977          "format": "int32"
34978        },
34979        "activeNatIps": {
34980          "description": "A list of active IPs for NAT. Example: [\"1.1.1.1\", \"179.12.26.133\"].",
34981          "type": "array",
34982          "items": {
34983            "type": "string"
34984          }
34985        },
34986        "drainNatIps": {
34987          "description": "A list of IPs for NAT that are in drain mode. Example: [\"1.1.1.1\", \"179.12.26.133\"].",
34988          "type": "array",
34989          "items": {
34990            "type": "string"
34991          }
34992        },
34993        "minExtraIpsNeeded": {
34994          "description": "The number of extra IPs to allocate. This will be greater than 0 only if the existing IPs in this NAT Rule are NOT enough to allow all configured VMs to use NAT.",
34995          "type": "integer",
34996          "format": "int32"
34997        },
34998        "numVmEndpointsWithNatMappings": {
34999          "description": "Number of VM endpoints (i.e., NICs) that have NAT Mappings from this NAT Rule.",
35000          "type": "integer",
35001          "format": "int32"
35002        }
35003      }
35004    },
35005    "VmEndpointNatMappingsList": {
35006      "id": "VmEndpointNatMappingsList",
35007      "description": "Contains a list of VmEndpointNatMappings.",
35008      "type": "object",
35009      "properties": {
35010        "kind": {
35011          "description": "[Output Only] Type of resource. Always compute#vmEndpointNatMappingsList for lists of Nat mappings of VM endpoints.",
35012          "default": "compute#vmEndpointNatMappingsList",
35013          "type": "string"
35014        },
35015        "id": {
35016          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
35017          "type": "string"
35018        },
35019        "result": {
35020          "description": "[Output Only] A list of Nat mapping information of VM endpoints.",
35021          "type": "array",
35022          "items": {
35023            "$ref": "VmEndpointNatMappings"
35024          }
35025        },
35026        "nextPageToken": {
35027          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
35028          "type": "string"
35029        },
35030        "selfLink": {
35031          "description": "[Output Only] Server-defined URL for this resource.",
35032          "type": "string"
35033        },
35034        "warning": {
35035          "description": "[Output Only] Informational warning message.",
35036          "type": "object",
35037          "properties": {
35038            "code": {
35039              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
35040              "type": "string",
35041              "enumDescriptions": [
35042                "Warning about failed cleanup of transient changes made by a failed operation.",
35043                "A link to a deprecated resource was created.",
35044                "When deploying and at least one of the resources has a type marked as deprecated",
35045                "The user created a boot disk that is larger than image size.",
35046                "When deploying and at least one of the resources has a type marked as experimental",
35047                "Warning that is present in an external api call",
35048                "Warning that value of a field has been overridden. Deprecated unused field.",
35049                "The operation involved use of an injected kernel, which is deprecated.",
35050                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
35051                "When deploying a deployment with a exceedingly large number of resources",
35052                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
35053                "A resource depends on a missing type",
35054                "The route's nextHopIp address is not assigned to an instance on the network.",
35055                "The route's next hop instance cannot ip forward.",
35056                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
35057                "The route's nextHopInstance URL refers to an instance that does not exist.",
35058                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
35059                "The route's next hop instance does not have a status of RUNNING.",
35060                "Error which is not critical. We decided to continue the process despite the mentioned error.",
35061                "No results are present on a particular list page.",
35062                "Success is reported, but some results may be missing due to errors",
35063                "The user attempted to use a resource that requires a TOS they have not accepted.",
35064                "Warning that a resource is in use.",
35065                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
35066                "When a resource schema validation is ignored.",
35067                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
35068                "When undeclared properties in the schema are present",
35069                "A given scope cannot be reached."
35070              ],
35071              "enumDeprecated": [
35072                false,
35073                false,
35074                false,
35075                false,
35076                false,
35077                false,
35078                true,
35079                false,
35080                false,
35081                false,
35082                false,
35083                false,
35084                false,
35085                false,
35086                false,
35087                false,
35088                false,
35089                false,
35090                false,
35091                false,
35092                false,
35093                false,
35094                false,
35095                false,
35096                false,
35097                false,
35098                false,
35099                false
35100              ],
35101              "enum": [
35102                "CLEANUP_FAILED",
35103                "DEPRECATED_RESOURCE_USED",
35104                "DEPRECATED_TYPE_USED",
35105                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
35106                "EXPERIMENTAL_TYPE_USED",
35107                "EXTERNAL_API_WARNING",
35108                "FIELD_VALUE_OVERRIDEN",
35109                "INJECTED_KERNELS_DEPRECATED",
35110                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
35111                "LARGE_DEPLOYMENT_WARNING",
35112                "LIST_OVERHEAD_QUOTA_EXCEED",
35113                "MISSING_TYPE_DEPENDENCY",
35114                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
35115                "NEXT_HOP_CANNOT_IP_FORWARD",
35116                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
35117                "NEXT_HOP_INSTANCE_NOT_FOUND",
35118                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
35119                "NEXT_HOP_NOT_RUNNING",
35120                "NOT_CRITICAL_ERROR",
35121                "NO_RESULTS_ON_PAGE",
35122                "PARTIAL_SUCCESS",
35123                "REQUIRED_TOS_AGREEMENT",
35124                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
35125                "RESOURCE_NOT_DELETED",
35126                "SCHEMA_VALIDATION_IGNORED",
35127                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
35128                "UNDECLARED_PROPERTIES",
35129                "UNREACHABLE"
35130              ]
35131            },
35132            "message": {
35133              "description": "[Output Only] A human-readable description of the warning code.",
35134              "type": "string"
35135            },
35136            "data": {
35137              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
35138              "type": "array",
35139              "items": {
35140                "type": "object",
35141                "properties": {
35142                  "key": {
35143                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
35144                    "type": "string"
35145                  },
35146                  "value": {
35147                    "description": "[Output Only] A warning data value corresponding to the key.",
35148                    "type": "string"
35149                  }
35150                }
35151              }
35152            }
35153          }
35154        }
35155      }
35156    },
35157    "VmEndpointNatMappings": {
35158      "id": "VmEndpointNatMappings",
35159      "description": "Contain information of Nat mapping for a VM endpoint (i.e., NIC).",
35160      "type": "object",
35161      "properties": {
35162        "instanceName": {
35163          "description": "Name of the VM instance which the endpoint belongs to",
35164          "type": "string"
35165        },
35166        "interfaceNatMappings": {
35167          "type": "array",
35168          "items": {
35169            "$ref": "VmEndpointNatMappingsInterfaceNatMappings"
35170          }
35171        }
35172      }
35173    },
35174    "VmEndpointNatMappingsInterfaceNatMappings": {
35175      "id": "VmEndpointNatMappingsInterfaceNatMappings",
35176      "description": "Contain information of Nat mapping for an interface of this endpoint.",
35177      "type": "object",
35178      "properties": {
35179        "sourceVirtualIp": {
35180          "description": "Primary IP of the VM for this NIC.",
35181          "type": "string"
35182        },
35183        "sourceAliasIpRange": {
35184          "description": "Alias IP range for this interface endpoint. It will be a private (RFC 1918) IP range. Examples: \"10.33.4.55/32\", or \"192.168.5.0/24\".",
35185          "type": "string"
35186        },
35187        "numTotalNatPorts": {
35188          "description": "Total number of ports across all NAT IPs allocated to this interface. It equals to the aggregated port number in the field nat_ip_port_ranges.",
35189          "type": "integer",
35190          "format": "int32"
35191        },
35192        "natIpPortRanges": {
35193          "description": "A list of all IP:port-range mappings assigned to this interface. These ranges are inclusive, that is, both the first and the last ports can be used for NAT. Example: [\"2.2.2.2:12345-12355\", \"1.1.1.1:2234-2234\"].",
35194          "type": "array",
35195          "items": {
35196            "type": "string"
35197          }
35198        },
35199        "drainNatIpPortRanges": {
35200          "description": "List of all drain IP:port-range mappings assigned to this interface. These ranges are inclusive, that is, both the first and the last ports can be used for NAT. Example: [\"2.2.2.2:12345-12355\", \"1.1.1.1:2234-2234\"].",
35201          "type": "array",
35202          "items": {
35203            "type": "string"
35204          }
35205        },
35206        "numTotalDrainNatPorts": {
35207          "description": "Total number of drain ports across all NAT IPs allocated to this interface. It equals to the aggregated port number in the field drain_nat_ip_port_ranges.",
35208          "type": "integer",
35209          "format": "int32"
35210        },
35211        "ruleMappings": {
35212          "description": "Information about mappings provided by rules in this NAT.",
35213          "type": "array",
35214          "items": {
35215            "$ref": "VmEndpointNatMappingsInterfaceNatMappingsNatRuleMappings"
35216          }
35217        }
35218      }
35219    },
35220    "VmEndpointNatMappingsInterfaceNatMappingsNatRuleMappings": {
35221      "id": "VmEndpointNatMappingsInterfaceNatMappingsNatRuleMappings",
35222      "description": "Contains information of NAT Mappings provided by a NAT Rule.",
35223      "type": "object",
35224      "properties": {
35225        "ruleNumber": {
35226          "description": "Rule number of the NAT Rule.",
35227          "type": "integer",
35228          "format": "int32"
35229        },
35230        "numTotalNatPorts": {
35231          "description": "Total number of ports across all NAT IPs allocated to this interface by this rule. It equals the aggregated port number in the field nat_ip_port_ranges.",
35232          "type": "integer",
35233          "format": "int32"
35234        },
35235        "natIpPortRanges": {
35236          "description": "A list of all IP:port-range mappings assigned to this interface by this rule. These ranges are inclusive, that is, both the first and the last ports can be used for NAT. Example: [\"2.2.2.2:12345-12355\", \"1.1.1.1:2234-2234\"].",
35237          "type": "array",
35238          "items": {
35239            "type": "string"
35240          }
35241        },
35242        "drainNatIpPortRanges": {
35243          "description": "List of all drain IP:port-range mappings assigned to this interface by this rule. These ranges are inclusive, that is, both the first and the last ports can be used for NAT. Example: [\"2.2.2.2:12345-12355\", \"1.1.1.1:2234-2234\"].",
35244          "type": "array",
35245          "items": {
35246            "type": "string"
35247          }
35248        },
35249        "numTotalDrainNatPorts": {
35250          "description": "Total number of drain ports across all NAT IPs allocated to this interface by this rule. It equals the aggregated port number in the field drain_nat_ip_port_ranges.",
35251          "type": "integer",
35252          "format": "int32"
35253        }
35254      }
35255    },
35256    "NatIpInfoResponse": {
35257      "id": "NatIpInfoResponse",
35258      "type": "object",
35259      "properties": {
35260        "result": {
35261          "description": "[Output Only] A list of NAT IP information.",
35262          "type": "array",
35263          "items": {
35264            "$ref": "NatIpInfo"
35265          }
35266        }
35267      }
35268    },
35269    "NatIpInfo": {
35270      "id": "NatIpInfo",
35271      "description": "Contains NAT IP information of a NAT config (i.e. usage status, mode).",
35272      "type": "object",
35273      "properties": {
35274        "natName": {
35275          "description": "Name of the NAT config which the NAT IP belongs to.",
35276          "type": "string"
35277        },
35278        "natIpInfoMappings": {
35279          "description": "A list of all NAT IPs assigned to this NAT config.",
35280          "type": "array",
35281          "items": {
35282            "$ref": "NatIpInfoNatIpInfoMapping"
35283          }
35284        }
35285      }
35286    },
35287    "NatIpInfoNatIpInfoMapping": {
35288      "id": "NatIpInfoNatIpInfoMapping",
35289      "description": "Contains information of a NAT IP.",
35290      "type": "object",
35291      "properties": {
35292        "natIp": {
35293          "description": "NAT IP address. For example: 203.0.113.11.",
35294          "type": "string"
35295        },
35296        "usage": {
35297          "description": "Specifies whether NAT IP is currently serving at least one endpoint or not.",
35298          "type": "string",
35299          "enumDescriptions": [
35300            "",
35301            ""
35302          ],
35303          "enum": [
35304            "IN_USE",
35305            "UNUSED"
35306          ]
35307        },
35308        "mode": {
35309          "description": "Specifies whether NAT IP is auto or manual.",
35310          "type": "string",
35311          "enumDescriptions": [
35312            "",
35313            ""
35314          ],
35315          "enum": [
35316            "AUTO",
35317            "MANUAL"
35318          ]
35319        }
35320      }
35321    },
35322    "RoutersPreviewResponse": {
35323      "id": "RoutersPreviewResponse",
35324      "type": "object",
35325      "properties": {
35326        "resource": {
35327          "description": "Preview of given router.",
35328          "$ref": "Router"
35329        }
35330      }
35331    },
35332    "ServiceAttachmentAggregatedList": {
35333      "id": "ServiceAttachmentAggregatedList",
35334      "description": "Contains a list of ServiceAttachmentsScopedList.",
35335      "type": "object",
35336      "properties": {
35337        "kind": {
35338          "description": "Type of resource.",
35339          "default": "compute#serviceAttachmentAggregatedList",
35340          "type": "string"
35341        },
35342        "id": {
35343          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
35344          "type": "string"
35345        },
35346        "items": {
35347          "description": "A list of ServiceAttachmentsScopedList resources.",
35348          "type": "object",
35349          "additionalProperties": {
35350            "description": "Name of the scope containing this set of ServiceAttachments.",
35351            "$ref": "ServiceAttachmentsScopedList"
35352          }
35353        },
35354        "nextPageToken": {
35355          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
35356          "type": "string"
35357        },
35358        "selfLink": {
35359          "description": "[Output Only] Server-defined URL for this resource.",
35360          "type": "string"
35361        },
35362        "warning": {
35363          "description": "[Output Only] Informational warning message.",
35364          "type": "object",
35365          "properties": {
35366            "code": {
35367              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
35368              "type": "string",
35369              "enumDescriptions": [
35370                "Warning about failed cleanup of transient changes made by a failed operation.",
35371                "A link to a deprecated resource was created.",
35372                "When deploying and at least one of the resources has a type marked as deprecated",
35373                "The user created a boot disk that is larger than image size.",
35374                "When deploying and at least one of the resources has a type marked as experimental",
35375                "Warning that is present in an external api call",
35376                "Warning that value of a field has been overridden. Deprecated unused field.",
35377                "The operation involved use of an injected kernel, which is deprecated.",
35378                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
35379                "When deploying a deployment with a exceedingly large number of resources",
35380                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
35381                "A resource depends on a missing type",
35382                "The route's nextHopIp address is not assigned to an instance on the network.",
35383                "The route's next hop instance cannot ip forward.",
35384                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
35385                "The route's nextHopInstance URL refers to an instance that does not exist.",
35386                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
35387                "The route's next hop instance does not have a status of RUNNING.",
35388                "Error which is not critical. We decided to continue the process despite the mentioned error.",
35389                "No results are present on a particular list page.",
35390                "Success is reported, but some results may be missing due to errors",
35391                "The user attempted to use a resource that requires a TOS they have not accepted.",
35392                "Warning that a resource is in use.",
35393                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
35394                "When a resource schema validation is ignored.",
35395                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
35396                "When undeclared properties in the schema are present",
35397                "A given scope cannot be reached."
35398              ],
35399              "enumDeprecated": [
35400                false,
35401                false,
35402                false,
35403                false,
35404                false,
35405                false,
35406                true,
35407                false,
35408                false,
35409                false,
35410                false,
35411                false,
35412                false,
35413                false,
35414                false,
35415                false,
35416                false,
35417                false,
35418                false,
35419                false,
35420                false,
35421                false,
35422                false,
35423                false,
35424                false,
35425                false,
35426                false,
35427                false
35428              ],
35429              "enum": [
35430                "CLEANUP_FAILED",
35431                "DEPRECATED_RESOURCE_USED",
35432                "DEPRECATED_TYPE_USED",
35433                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
35434                "EXPERIMENTAL_TYPE_USED",
35435                "EXTERNAL_API_WARNING",
35436                "FIELD_VALUE_OVERRIDEN",
35437                "INJECTED_KERNELS_DEPRECATED",
35438                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
35439                "LARGE_DEPLOYMENT_WARNING",
35440                "LIST_OVERHEAD_QUOTA_EXCEED",
35441                "MISSING_TYPE_DEPENDENCY",
35442                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
35443                "NEXT_HOP_CANNOT_IP_FORWARD",
35444                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
35445                "NEXT_HOP_INSTANCE_NOT_FOUND",
35446                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
35447                "NEXT_HOP_NOT_RUNNING",
35448                "NOT_CRITICAL_ERROR",
35449                "NO_RESULTS_ON_PAGE",
35450                "PARTIAL_SUCCESS",
35451                "REQUIRED_TOS_AGREEMENT",
35452                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
35453                "RESOURCE_NOT_DELETED",
35454                "SCHEMA_VALIDATION_IGNORED",
35455                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
35456                "UNDECLARED_PROPERTIES",
35457                "UNREACHABLE"
35458              ]
35459            },
35460            "message": {
35461              "description": "[Output Only] A human-readable description of the warning code.",
35462              "type": "string"
35463            },
35464            "data": {
35465              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
35466              "type": "array",
35467              "items": {
35468                "type": "object",
35469                "properties": {
35470                  "key": {
35471                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
35472                    "type": "string"
35473                  },
35474                  "value": {
35475                    "description": "[Output Only] A warning data value corresponding to the key.",
35476                    "type": "string"
35477                  }
35478                }
35479              }
35480            }
35481          }
35482        },
35483        "unreachables": {
35484          "description": "[Output Only] Unreachable resources.",
35485          "type": "array",
35486          "items": {
35487            "type": "string"
35488          }
35489        }
35490      }
35491    },
35492    "ServiceAttachmentsScopedList": {
35493      "id": "ServiceAttachmentsScopedList",
35494      "type": "object",
35495      "properties": {
35496        "serviceAttachments": {
35497          "description": "A list of ServiceAttachments contained in this scope.",
35498          "type": "array",
35499          "items": {
35500            "$ref": "ServiceAttachment"
35501          }
35502        },
35503        "warning": {
35504          "description": "Informational warning which replaces the list of service attachments when the list is empty.",
35505          "type": "object",
35506          "properties": {
35507            "code": {
35508              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
35509              "type": "string",
35510              "enumDescriptions": [
35511                "Warning about failed cleanup of transient changes made by a failed operation.",
35512                "A link to a deprecated resource was created.",
35513                "When deploying and at least one of the resources has a type marked as deprecated",
35514                "The user created a boot disk that is larger than image size.",
35515                "When deploying and at least one of the resources has a type marked as experimental",
35516                "Warning that is present in an external api call",
35517                "Warning that value of a field has been overridden. Deprecated unused field.",
35518                "The operation involved use of an injected kernel, which is deprecated.",
35519                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
35520                "When deploying a deployment with a exceedingly large number of resources",
35521                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
35522                "A resource depends on a missing type",
35523                "The route's nextHopIp address is not assigned to an instance on the network.",
35524                "The route's next hop instance cannot ip forward.",
35525                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
35526                "The route's nextHopInstance URL refers to an instance that does not exist.",
35527                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
35528                "The route's next hop instance does not have a status of RUNNING.",
35529                "Error which is not critical. We decided to continue the process despite the mentioned error.",
35530                "No results are present on a particular list page.",
35531                "Success is reported, but some results may be missing due to errors",
35532                "The user attempted to use a resource that requires a TOS they have not accepted.",
35533                "Warning that a resource is in use.",
35534                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
35535                "When a resource schema validation is ignored.",
35536                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
35537                "When undeclared properties in the schema are present",
35538                "A given scope cannot be reached."
35539              ],
35540              "enumDeprecated": [
35541                false,
35542                false,
35543                false,
35544                false,
35545                false,
35546                false,
35547                true,
35548                false,
35549                false,
35550                false,
35551                false,
35552                false,
35553                false,
35554                false,
35555                false,
35556                false,
35557                false,
35558                false,
35559                false,
35560                false,
35561                false,
35562                false,
35563                false,
35564                false,
35565                false,
35566                false,
35567                false,
35568                false
35569              ],
35570              "enum": [
35571                "CLEANUP_FAILED",
35572                "DEPRECATED_RESOURCE_USED",
35573                "DEPRECATED_TYPE_USED",
35574                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
35575                "EXPERIMENTAL_TYPE_USED",
35576                "EXTERNAL_API_WARNING",
35577                "FIELD_VALUE_OVERRIDEN",
35578                "INJECTED_KERNELS_DEPRECATED",
35579                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
35580                "LARGE_DEPLOYMENT_WARNING",
35581                "LIST_OVERHEAD_QUOTA_EXCEED",
35582                "MISSING_TYPE_DEPENDENCY",
35583                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
35584                "NEXT_HOP_CANNOT_IP_FORWARD",
35585                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
35586                "NEXT_HOP_INSTANCE_NOT_FOUND",
35587                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
35588                "NEXT_HOP_NOT_RUNNING",
35589                "NOT_CRITICAL_ERROR",
35590                "NO_RESULTS_ON_PAGE",
35591                "PARTIAL_SUCCESS",
35592                "REQUIRED_TOS_AGREEMENT",
35593                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
35594                "RESOURCE_NOT_DELETED",
35595                "SCHEMA_VALIDATION_IGNORED",
35596                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
35597                "UNDECLARED_PROPERTIES",
35598                "UNREACHABLE"
35599              ]
35600            },
35601            "message": {
35602              "description": "[Output Only] A human-readable description of the warning code.",
35603              "type": "string"
35604            },
35605            "data": {
35606              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
35607              "type": "array",
35608              "items": {
35609                "type": "object",
35610                "properties": {
35611                  "key": {
35612                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
35613                    "type": "string"
35614                  },
35615                  "value": {
35616                    "description": "[Output Only] A warning data value corresponding to the key.",
35617                    "type": "string"
35618                  }
35619                }
35620              }
35621            }
35622          }
35623        }
35624      }
35625    },
35626    "ServiceAttachment": {
35627      "id": "ServiceAttachment",
35628      "description": "Represents a ServiceAttachment resource. A service attachment represents a service that a producer has exposed. It encapsulates the load balancer which fronts the service runs and a list of NAT IP ranges that the producers uses to represent the consumers connecting to the service.",
35629      "type": "object",
35630      "properties": {
35631        "kind": {
35632          "description": "[Output Only] Type of the resource. Always compute#serviceAttachment for service attachments.",
35633          "default": "compute#serviceAttachment",
35634          "type": "string"
35635        },
35636        "id": {
35637          "description": "[Output Only] The unique identifier for the resource type. The server generates this identifier.",
35638          "type": "string",
35639          "format": "uint64"
35640        },
35641        "creationTimestamp": {
35642          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
35643          "type": "string"
35644        },
35645        "name": {
35646          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
35647          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
35648          "annotations": {
35649            "required": [
35650              "compute.serviceAttachments.insert"
35651            ]
35652          },
35653          "type": "string"
35654        },
35655        "description": {
35656          "description": "An optional description of this resource. Provide this property when you create the resource.",
35657          "type": "string"
35658        },
35659        "selfLink": {
35660          "description": "[Output Only] Server-defined URL for the resource.",
35661          "type": "string"
35662        },
35663        "region": {
35664          "description": "[Output Only] URL of the region where the service attachment resides. This field applies only to the region resource. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
35665          "type": "string"
35666        },
35667        "producerForwardingRule": {
35668          "description": "The URL of a forwarding rule with loadBalancingScheme INTERNAL* that is serving the endpoint identified by this service attachment.",
35669          "deprecated": true,
35670          "type": "string"
35671        },
35672        "targetService": {
35673          "description": "The URL of a service serving the endpoint identified by this service attachment.",
35674          "type": "string"
35675        },
35676        "connectionPreference": {
35677          "description": "The connection preference of service attachment. The value can be set to ACCEPT_AUTOMATIC. An ACCEPT_AUTOMATIC service attachment is one that always accepts the connection from consumer forwarding rules.",
35678          "type": "string",
35679          "enumDescriptions": [
35680            "",
35681            "",
35682            ""
35683          ],
35684          "enum": [
35685            "ACCEPT_AUTOMATIC",
35686            "ACCEPT_MANUAL",
35687            "CONNECTION_PREFERENCE_UNSPECIFIED"
35688          ]
35689        },
35690        "connectedEndpoints": {
35691          "description": "[Output Only] An array of connections for all the consumers connected to this service attachment.",
35692          "type": "array",
35693          "items": {
35694            "$ref": "ServiceAttachmentConnectedEndpoint"
35695          }
35696        },
35697        "natSubnets": {
35698          "description": "An array of URLs where each entry is the URL of a subnet provided by the service producer to use for NAT in this service attachment.",
35699          "type": "array",
35700          "items": {
35701            "type": "string"
35702          }
35703        },
35704        "enableProxyProtocol": {
35705          "description": "If true, enable the proxy protocol which is for supplying client TCP/IP address data in TCP connections that traverse proxies on their way to destination servers.",
35706          "type": "boolean"
35707        },
35708        "consumerRejectLists": {
35709          "description": "Projects that are not allowed to connect to this service attachment. The project can be specified using its id or number.",
35710          "type": "array",
35711          "items": {
35712            "type": "string"
35713          }
35714        },
35715        "consumerAcceptLists": {
35716          "description": "Projects that are allowed to connect to this service attachment.",
35717          "type": "array",
35718          "items": {
35719            "$ref": "ServiceAttachmentConsumerProjectLimit"
35720          }
35721        },
35722        "pscServiceAttachmentId": {
35723          "description": "[Output Only] An 128-bit global unique ID of the PSC service attachment.",
35724          "$ref": "Uint128"
35725        },
35726        "fingerprint": {
35727          "description": "Fingerprint of this resource. A hash of the contents stored in this object. This field is used in optimistic locking. This field will be ignored when inserting a ServiceAttachment. An up-to-date fingerprint must be provided in order to patch/update the ServiceAttachment; otherwise, the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve the ServiceAttachment.",
35728          "type": "string",
35729          "format": "byte"
35730        },
35731        "domainNames": {
35732          "description": "If specified, the domain name will be used during the integration between the PSC connected endpoints and the Cloud DNS. For example, this is a valid domain name: \"p.mycompany.com.\". Current max number of domain names supported is 1.",
35733          "type": "array",
35734          "items": {
35735            "type": "string"
35736          }
35737        },
35738        "reconcileConnections": {
35739          "description": "This flag determines whether a consumer accept/reject list change can reconcile the statuses of existing ACCEPTED or REJECTED PSC endpoints. - If false, connection policy update will only affect existing PENDING PSC endpoints. Existing ACCEPTED/REJECTED endpoints will remain untouched regardless how the connection policy is modified . - If true, update will affect both PENDING and ACCEPTED/REJECTED PSC endpoints. For example, an ACCEPTED PSC endpoint will be moved to REJECTED if its project is added to the reject list. For newly created service attachment, this boolean defaults to false.",
35740          "type": "boolean"
35741        }
35742      }
35743    },
35744    "ServiceAttachmentConnectedEndpoint": {
35745      "id": "ServiceAttachmentConnectedEndpoint",
35746      "description": "[Output Only] A connection connected to this service attachment.",
35747      "type": "object",
35748      "properties": {
35749        "status": {
35750          "description": "The status of a connected endpoint to this service attachment.",
35751          "type": "string",
35752          "enumDescriptions": [
35753            "The connection has been accepted by the producer.",
35754            "The connection has been closed by the producer.",
35755            "The connection has been accepted by the producer, but the producer needs to take further action before the forwarding rule can serve traffic.",
35756            "The connection is pending acceptance by the producer.",
35757            "The consumer is still connected but not using the connection.",
35758            ""
35759          ],
35760          "enum": [
35761            "ACCEPTED",
35762            "CLOSED",
35763            "NEEDS_ATTENTION",
35764            "PENDING",
35765            "REJECTED",
35766            "STATUS_UNSPECIFIED"
35767          ]
35768        },
35769        "pscConnectionId": {
35770          "description": "The PSC connection id of the connected endpoint.",
35771          "type": "string",
35772          "format": "uint64"
35773        },
35774        "endpoint": {
35775          "description": "The url of a connected endpoint.",
35776          "type": "string"
35777        },
35778        "consumerNetwork": {
35779          "description": "The url of the consumer network.",
35780          "type": "string"
35781        }
35782      }
35783    },
35784    "ServiceAttachmentConsumerProjectLimit": {
35785      "id": "ServiceAttachmentConsumerProjectLimit",
35786      "type": "object",
35787      "properties": {
35788        "projectIdOrNum": {
35789          "description": "The project id or number for the project to set the limit for.",
35790          "type": "string"
35791        },
35792        "networkUrl": {
35793          "description": "The network URL for the network to set the limit for.",
35794          "type": "string"
35795        },
35796        "connectionLimit": {
35797          "description": "The value of the limit to set.",
35798          "type": "integer",
35799          "format": "uint32"
35800        }
35801      }
35802    },
35803    "Uint128": {
35804      "id": "Uint128",
35805      "type": "object",
35806      "properties": {
35807        "high": {
35808          "type": "string",
35809          "format": "uint64"
35810        },
35811        "low": {
35812          "type": "string",
35813          "format": "uint64"
35814        }
35815      }
35816    },
35817    "ServiceAttachmentList": {
35818      "id": "ServiceAttachmentList",
35819      "type": "object",
35820      "properties": {
35821        "kind": {
35822          "description": "[Output Only] Type of the resource. Always compute#serviceAttachment for service attachments.",
35823          "default": "compute#serviceAttachmentList",
35824          "type": "string"
35825        },
35826        "id": {
35827          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
35828          "type": "string"
35829        },
35830        "items": {
35831          "description": "A list of ServiceAttachment resources.",
35832          "type": "array",
35833          "items": {
35834            "$ref": "ServiceAttachment"
35835          }
35836        },
35837        "nextPageToken": {
35838          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
35839          "type": "string"
35840        },
35841        "selfLink": {
35842          "description": "[Output Only] Server-defined URL for this resource.",
35843          "type": "string"
35844        },
35845        "warning": {
35846          "description": "[Output Only] Informational warning message.",
35847          "type": "object",
35848          "properties": {
35849            "code": {
35850              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
35851              "type": "string",
35852              "enumDescriptions": [
35853                "Warning about failed cleanup of transient changes made by a failed operation.",
35854                "A link to a deprecated resource was created.",
35855                "When deploying and at least one of the resources has a type marked as deprecated",
35856                "The user created a boot disk that is larger than image size.",
35857                "When deploying and at least one of the resources has a type marked as experimental",
35858                "Warning that is present in an external api call",
35859                "Warning that value of a field has been overridden. Deprecated unused field.",
35860                "The operation involved use of an injected kernel, which is deprecated.",
35861                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
35862                "When deploying a deployment with a exceedingly large number of resources",
35863                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
35864                "A resource depends on a missing type",
35865                "The route's nextHopIp address is not assigned to an instance on the network.",
35866                "The route's next hop instance cannot ip forward.",
35867                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
35868                "The route's nextHopInstance URL refers to an instance that does not exist.",
35869                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
35870                "The route's next hop instance does not have a status of RUNNING.",
35871                "Error which is not critical. We decided to continue the process despite the mentioned error.",
35872                "No results are present on a particular list page.",
35873                "Success is reported, but some results may be missing due to errors",
35874                "The user attempted to use a resource that requires a TOS they have not accepted.",
35875                "Warning that a resource is in use.",
35876                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
35877                "When a resource schema validation is ignored.",
35878                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
35879                "When undeclared properties in the schema are present",
35880                "A given scope cannot be reached."
35881              ],
35882              "enumDeprecated": [
35883                false,
35884                false,
35885                false,
35886                false,
35887                false,
35888                false,
35889                true,
35890                false,
35891                false,
35892                false,
35893                false,
35894                false,
35895                false,
35896                false,
35897                false,
35898                false,
35899                false,
35900                false,
35901                false,
35902                false,
35903                false,
35904                false,
35905                false,
35906                false,
35907                false,
35908                false,
35909                false,
35910                false
35911              ],
35912              "enum": [
35913                "CLEANUP_FAILED",
35914                "DEPRECATED_RESOURCE_USED",
35915                "DEPRECATED_TYPE_USED",
35916                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
35917                "EXPERIMENTAL_TYPE_USED",
35918                "EXTERNAL_API_WARNING",
35919                "FIELD_VALUE_OVERRIDEN",
35920                "INJECTED_KERNELS_DEPRECATED",
35921                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
35922                "LARGE_DEPLOYMENT_WARNING",
35923                "LIST_OVERHEAD_QUOTA_EXCEED",
35924                "MISSING_TYPE_DEPENDENCY",
35925                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
35926                "NEXT_HOP_CANNOT_IP_FORWARD",
35927                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
35928                "NEXT_HOP_INSTANCE_NOT_FOUND",
35929                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
35930                "NEXT_HOP_NOT_RUNNING",
35931                "NOT_CRITICAL_ERROR",
35932                "NO_RESULTS_ON_PAGE",
35933                "PARTIAL_SUCCESS",
35934                "REQUIRED_TOS_AGREEMENT",
35935                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
35936                "RESOURCE_NOT_DELETED",
35937                "SCHEMA_VALIDATION_IGNORED",
35938                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
35939                "UNDECLARED_PROPERTIES",
35940                "UNREACHABLE"
35941              ]
35942            },
35943            "message": {
35944              "description": "[Output Only] A human-readable description of the warning code.",
35945              "type": "string"
35946            },
35947            "data": {
35948              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
35949              "type": "array",
35950              "items": {
35951                "type": "object",
35952                "properties": {
35953                  "key": {
35954                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
35955                    "type": "string"
35956                  },
35957                  "value": {
35958                    "description": "[Output Only] A warning data value corresponding to the key.",
35959                    "type": "string"
35960                  }
35961                }
35962              }
35963            }
35964          }
35965        }
35966      }
35967    },
35968    "SnapshotSettings": {
35969      "id": "SnapshotSettings",
35970      "type": "object",
35971      "properties": {
35972        "storageLocation": {
35973          "description": "Policy of which storage location is going to be resolved, and additional data that particularizes how the policy is going to be carried out.",
35974          "$ref": "SnapshotSettingsStorageLocationSettings"
35975        }
35976      }
35977    },
35978    "SnapshotSettingsStorageLocationSettings": {
35979      "id": "SnapshotSettingsStorageLocationSettings",
35980      "type": "object",
35981      "properties": {
35982        "policy": {
35983          "description": "The chosen location policy.",
35984          "type": "string",
35985          "enumDescriptions": [
35986            "Store snapshot in the same region as with the originating disk. No additional parameters are needed.",
35987            "Store snapshot to the nearest multi region GCS bucket, relative to the originating disk. No additional parameters are needed.",
35988            "Store snapshot in the specific locations, as specified by the user. The list of regions to store must be defined under the `locations` field.",
35989            ""
35990          ],
35991          "enum": [
35992            "LOCAL_REGION",
35993            "NEAREST_MULTI_REGION",
35994            "SPECIFIC_LOCATIONS",
35995            "STORAGE_LOCATION_POLICY_UNSPECIFIED"
35996          ]
35997        },
35998        "locations": {
35999          "description": "When the policy is SPECIFIC_LOCATIONS, snapshots will be stored in the locations listed in this field. Keys are GCS bucket locations.",
36000          "type": "object",
36001          "additionalProperties": {
36002            "$ref": "SnapshotSettingsStorageLocationSettingsStorageLocationPreference"
36003          }
36004        }
36005      }
36006    },
36007    "SnapshotSettingsStorageLocationSettingsStorageLocationPreference": {
36008      "id": "SnapshotSettingsStorageLocationSettingsStorageLocationPreference",
36009      "description": "A structure for specifying storage locations.",
36010      "type": "object",
36011      "properties": {
36012        "name": {
36013          "description": "Name of the location. It should be one of the GCS buckets.",
36014          "type": "string"
36015        }
36016      }
36017    },
36018    "SslCertificateList": {
36019      "id": "SslCertificateList",
36020      "description": "Contains a list of SslCertificate resources.",
36021      "type": "object",
36022      "properties": {
36023        "kind": {
36024          "description": "Type of resource.",
36025          "default": "compute#sslCertificateList",
36026          "type": "string"
36027        },
36028        "id": {
36029          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
36030          "type": "string"
36031        },
36032        "items": {
36033          "description": "A list of SslCertificate resources.",
36034          "type": "array",
36035          "items": {
36036            "$ref": "SslCertificate"
36037          }
36038        },
36039        "nextPageToken": {
36040          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
36041          "type": "string"
36042        },
36043        "selfLink": {
36044          "description": "[Output Only] Server-defined URL for this resource.",
36045          "type": "string"
36046        },
36047        "warning": {
36048          "description": "[Output Only] Informational warning message.",
36049          "type": "object",
36050          "properties": {
36051            "code": {
36052              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
36053              "type": "string",
36054              "enumDescriptions": [
36055                "Warning about failed cleanup of transient changes made by a failed operation.",
36056                "A link to a deprecated resource was created.",
36057                "When deploying and at least one of the resources has a type marked as deprecated",
36058                "The user created a boot disk that is larger than image size.",
36059                "When deploying and at least one of the resources has a type marked as experimental",
36060                "Warning that is present in an external api call",
36061                "Warning that value of a field has been overridden. Deprecated unused field.",
36062                "The operation involved use of an injected kernel, which is deprecated.",
36063                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
36064                "When deploying a deployment with a exceedingly large number of resources",
36065                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
36066                "A resource depends on a missing type",
36067                "The route's nextHopIp address is not assigned to an instance on the network.",
36068                "The route's next hop instance cannot ip forward.",
36069                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
36070                "The route's nextHopInstance URL refers to an instance that does not exist.",
36071                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
36072                "The route's next hop instance does not have a status of RUNNING.",
36073                "Error which is not critical. We decided to continue the process despite the mentioned error.",
36074                "No results are present on a particular list page.",
36075                "Success is reported, but some results may be missing due to errors",
36076                "The user attempted to use a resource that requires a TOS they have not accepted.",
36077                "Warning that a resource is in use.",
36078                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
36079                "When a resource schema validation is ignored.",
36080                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
36081                "When undeclared properties in the schema are present",
36082                "A given scope cannot be reached."
36083              ],
36084              "enumDeprecated": [
36085                false,
36086                false,
36087                false,
36088                false,
36089                false,
36090                false,
36091                true,
36092                false,
36093                false,
36094                false,
36095                false,
36096                false,
36097                false,
36098                false,
36099                false,
36100                false,
36101                false,
36102                false,
36103                false,
36104                false,
36105                false,
36106                false,
36107                false,
36108                false,
36109                false,
36110                false,
36111                false,
36112                false
36113              ],
36114              "enum": [
36115                "CLEANUP_FAILED",
36116                "DEPRECATED_RESOURCE_USED",
36117                "DEPRECATED_TYPE_USED",
36118                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
36119                "EXPERIMENTAL_TYPE_USED",
36120                "EXTERNAL_API_WARNING",
36121                "FIELD_VALUE_OVERRIDEN",
36122                "INJECTED_KERNELS_DEPRECATED",
36123                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
36124                "LARGE_DEPLOYMENT_WARNING",
36125                "LIST_OVERHEAD_QUOTA_EXCEED",
36126                "MISSING_TYPE_DEPENDENCY",
36127                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
36128                "NEXT_HOP_CANNOT_IP_FORWARD",
36129                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
36130                "NEXT_HOP_INSTANCE_NOT_FOUND",
36131                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
36132                "NEXT_HOP_NOT_RUNNING",
36133                "NOT_CRITICAL_ERROR",
36134                "NO_RESULTS_ON_PAGE",
36135                "PARTIAL_SUCCESS",
36136                "REQUIRED_TOS_AGREEMENT",
36137                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
36138                "RESOURCE_NOT_DELETED",
36139                "SCHEMA_VALIDATION_IGNORED",
36140                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
36141                "UNDECLARED_PROPERTIES",
36142                "UNREACHABLE"
36143              ]
36144            },
36145            "message": {
36146              "description": "[Output Only] A human-readable description of the warning code.",
36147              "type": "string"
36148            },
36149            "data": {
36150              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
36151              "type": "array",
36152              "items": {
36153                "type": "object",
36154                "properties": {
36155                  "key": {
36156                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
36157                    "type": "string"
36158                  },
36159                  "value": {
36160                    "description": "[Output Only] A warning data value corresponding to the key.",
36161                    "type": "string"
36162                  }
36163                }
36164              }
36165            }
36166          }
36167        }
36168      }
36169    },
36170    "SslCertificate": {
36171      "id": "SslCertificate",
36172      "description": "Represents an SSL certificate resource. Google Compute Engine has two SSL certificate resources: * [Global](/compute/docs/reference/rest/v1/sslCertificates) * [Regional](/compute/docs/reference/rest/v1/regionSslCertificates) The global SSL certificates (sslCertificates) are used by: - Global external Application Load Balancers - Classic Application Load Balancers - Proxy Network Load Balancers (with target SSL proxies) The regional SSL certificates (regionSslCertificates) are used by: - Regional external Application Load Balancers - Regional internal Application Load Balancers Optionally, certificate file contents that you upload can contain a set of up to five PEM-encoded certificates. The API call creates an object (sslCertificate) that holds this data. You can use SSL keys and certificates to secure connections to a load balancer. For more information, read Creating and using SSL certificates, SSL certificates quotas and limits, and Troubleshooting SSL certificates.",
36173      "type": "object",
36174      "properties": {
36175        "kind": {
36176          "description": "[Output Only] Type of the resource. Always compute#sslCertificate for SSL certificates.",
36177          "default": "compute#sslCertificate",
36178          "type": "string"
36179        },
36180        "id": {
36181          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
36182          "type": "string",
36183          "format": "uint64"
36184        },
36185        "creationTimestamp": {
36186          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
36187          "type": "string"
36188        },
36189        "name": {
36190          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
36191          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
36192          "type": "string"
36193        },
36194        "description": {
36195          "description": "An optional description of this resource. Provide this property when you create the resource.",
36196          "type": "string"
36197        },
36198        "selfLink": {
36199          "description": "[Output only] Server-defined URL for the resource.",
36200          "type": "string"
36201        },
36202        "certificate": {
36203          "description": "A value read into memory from a certificate file. The certificate file must be in PEM format. The certificate chain must be no greater than 5 certs long. The chain must include at least one intermediate cert.",
36204          "type": "string"
36205        },
36206        "privateKey": {
36207          "description": "A value read into memory from a write-only private key file. The private key file must be in PEM format. For security, only insert requests include this field.",
36208          "type": "string"
36209        },
36210        "managed": {
36211          "description": "Configuration and status of a managed SSL certificate.",
36212          "$ref": "SslCertificateManagedSslCertificate"
36213        },
36214        "selfManaged": {
36215          "description": "Configuration and status of a self-managed SSL certificate.",
36216          "$ref": "SslCertificateSelfManagedSslCertificate"
36217        },
36218        "type": {
36219          "description": "(Optional) Specifies the type of SSL certificate, either \"SELF_MANAGED\" or \"MANAGED\". If not specified, the certificate is self-managed and the fields certificate and private_key are used.",
36220          "type": "string",
36221          "enumDescriptions": [
36222            "Google-managed SSLCertificate.",
36223            "Certificate uploaded by user.",
36224            ""
36225          ],
36226          "enum": [
36227            "MANAGED",
36228            "SELF_MANAGED",
36229            "TYPE_UNSPECIFIED"
36230          ]
36231        },
36232        "subjectAlternativeNames": {
36233          "description": "[Output Only] Domains associated with the certificate via Subject Alternative Name.",
36234          "type": "array",
36235          "items": {
36236            "type": "string"
36237          }
36238        },
36239        "expireTime": {
36240          "description": "[Output Only] Expire time of the certificate. RFC3339",
36241          "type": "string"
36242        },
36243        "region": {
36244          "description": "[Output Only] URL of the region where the regional SSL Certificate resides. This field is not applicable to global SSL Certificate.",
36245          "type": "string"
36246        }
36247      }
36248    },
36249    "SslCertificateManagedSslCertificate": {
36250      "id": "SslCertificateManagedSslCertificate",
36251      "description": "Configuration and status of a managed SSL certificate.",
36252      "type": "object",
36253      "properties": {
36254        "domains": {
36255          "description": "The domains for which a managed SSL certificate will be generated. Each Google-managed SSL certificate supports up to the [maximum number of domains per Google-managed SSL certificate](/load-balancing/docs/quotas#ssl_certificates).",
36256          "type": "array",
36257          "items": {
36258            "type": "string"
36259          }
36260        },
36261        "status": {
36262          "description": "[Output only] Status of the managed certificate resource.",
36263          "type": "string",
36264          "enumDescriptions": [
36265            "The certificate management is working, and a certificate has been provisioned.",
36266            "",
36267            "The certificate management is working. GCP will attempt to provision the first certificate.",
36268            "Certificate provisioning failed due to an issue with the DNS or load balancing configuration. For details of which domain failed, consult domain_status field.",
36269            "Certificate provisioning failed due to an issue with the DNS or load balancing configuration. It won't be retried. To try again delete and create a new managed SslCertificate resource. For details of which domain failed, consult domain_status field.",
36270            "Renewal of the certificate has failed due to an issue with the DNS or load balancing configuration. The existing cert is still serving; however, it will expire shortly. To provision a renewed certificate, delete and create a new managed SslCertificate resource. For details on which domain failed, consult domain_status field."
36271          ],
36272          "enum": [
36273            "ACTIVE",
36274            "MANAGED_CERTIFICATE_STATUS_UNSPECIFIED",
36275            "PROVISIONING",
36276            "PROVISIONING_FAILED",
36277            "PROVISIONING_FAILED_PERMANENTLY",
36278            "RENEWAL_FAILED"
36279          ]
36280        },
36281        "domainStatus": {
36282          "description": "[Output only] Detailed statuses of the domains specified for managed certificate resource.",
36283          "type": "object",
36284          "additionalProperties": {
36285            "type": "string",
36286            "enumDescriptions": [
36287              "A managed certificate can be provisioned, no issues for this domain.",
36288              "",
36289              "Failed to check CAA records for the domain.",
36290              "Certificate issuance forbidden by an explicit CAA record for the domain.",
36291              "There seems to be problem with the user's DNS or load balancer configuration for this domain.",
36292              "Reached rate-limit for certificates per top-level private domain.",
36293              "Certificate provisioning for this domain is under way. GCP will attempt to provision the first certificate."
36294            ],
36295            "enum": [
36296              "ACTIVE",
36297              "DOMAIN_STATUS_UNSPECIFIED",
36298              "FAILED_CAA_CHECKING",
36299              "FAILED_CAA_FORBIDDEN",
36300              "FAILED_NOT_VISIBLE",
36301              "FAILED_RATE_LIMITED",
36302              "PROVISIONING"
36303            ]
36304          }
36305        }
36306      }
36307    },
36308    "SslCertificateSelfManagedSslCertificate": {
36309      "id": "SslCertificateSelfManagedSslCertificate",
36310      "description": "Configuration and status of a self-managed SSL certificate.",
36311      "type": "object",
36312      "properties": {
36313        "certificate": {
36314          "description": "A local certificate file. The certificate must be in PEM format. The certificate chain must be no greater than 5 certs long. The chain must include at least one intermediate cert.",
36315          "type": "string"
36316        },
36317        "privateKey": {
36318          "description": "A write-only private key in PEM format. Only insert requests will include this field.",
36319          "type": "string"
36320        }
36321      }
36322    },
36323    "SslCertificateAggregatedList": {
36324      "id": "SslCertificateAggregatedList",
36325      "type": "object",
36326      "properties": {
36327        "kind": {
36328          "description": "[Output Only] Type of resource. Always compute#sslCertificateAggregatedList for lists of SSL Certificates.",
36329          "default": "compute#sslCertificateAggregatedList",
36330          "type": "string"
36331        },
36332        "id": {
36333          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
36334          "type": "string"
36335        },
36336        "items": {
36337          "description": "A list of SslCertificatesScopedList resources.",
36338          "type": "object",
36339          "additionalProperties": {
36340            "description": "Name of the scope containing this set of SslCertificates.",
36341            "$ref": "SslCertificatesScopedList"
36342          }
36343        },
36344        "nextPageToken": {
36345          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
36346          "type": "string"
36347        },
36348        "selfLink": {
36349          "description": "[Output Only] Server-defined URL for this resource.",
36350          "type": "string"
36351        },
36352        "warning": {
36353          "description": "[Output Only] Informational warning message.",
36354          "type": "object",
36355          "properties": {
36356            "code": {
36357              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
36358              "type": "string",
36359              "enumDescriptions": [
36360                "Warning about failed cleanup of transient changes made by a failed operation.",
36361                "A link to a deprecated resource was created.",
36362                "When deploying and at least one of the resources has a type marked as deprecated",
36363                "The user created a boot disk that is larger than image size.",
36364                "When deploying and at least one of the resources has a type marked as experimental",
36365                "Warning that is present in an external api call",
36366                "Warning that value of a field has been overridden. Deprecated unused field.",
36367                "The operation involved use of an injected kernel, which is deprecated.",
36368                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
36369                "When deploying a deployment with a exceedingly large number of resources",
36370                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
36371                "A resource depends on a missing type",
36372                "The route's nextHopIp address is not assigned to an instance on the network.",
36373                "The route's next hop instance cannot ip forward.",
36374                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
36375                "The route's nextHopInstance URL refers to an instance that does not exist.",
36376                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
36377                "The route's next hop instance does not have a status of RUNNING.",
36378                "Error which is not critical. We decided to continue the process despite the mentioned error.",
36379                "No results are present on a particular list page.",
36380                "Success is reported, but some results may be missing due to errors",
36381                "The user attempted to use a resource that requires a TOS they have not accepted.",
36382                "Warning that a resource is in use.",
36383                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
36384                "When a resource schema validation is ignored.",
36385                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
36386                "When undeclared properties in the schema are present",
36387                "A given scope cannot be reached."
36388              ],
36389              "enumDeprecated": [
36390                false,
36391                false,
36392                false,
36393                false,
36394                false,
36395                false,
36396                true,
36397                false,
36398                false,
36399                false,
36400                false,
36401                false,
36402                false,
36403                false,
36404                false,
36405                false,
36406                false,
36407                false,
36408                false,
36409                false,
36410                false,
36411                false,
36412                false,
36413                false,
36414                false,
36415                false,
36416                false,
36417                false
36418              ],
36419              "enum": [
36420                "CLEANUP_FAILED",
36421                "DEPRECATED_RESOURCE_USED",
36422                "DEPRECATED_TYPE_USED",
36423                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
36424                "EXPERIMENTAL_TYPE_USED",
36425                "EXTERNAL_API_WARNING",
36426                "FIELD_VALUE_OVERRIDEN",
36427                "INJECTED_KERNELS_DEPRECATED",
36428                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
36429                "LARGE_DEPLOYMENT_WARNING",
36430                "LIST_OVERHEAD_QUOTA_EXCEED",
36431                "MISSING_TYPE_DEPENDENCY",
36432                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
36433                "NEXT_HOP_CANNOT_IP_FORWARD",
36434                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
36435                "NEXT_HOP_INSTANCE_NOT_FOUND",
36436                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
36437                "NEXT_HOP_NOT_RUNNING",
36438                "NOT_CRITICAL_ERROR",
36439                "NO_RESULTS_ON_PAGE",
36440                "PARTIAL_SUCCESS",
36441                "REQUIRED_TOS_AGREEMENT",
36442                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
36443                "RESOURCE_NOT_DELETED",
36444                "SCHEMA_VALIDATION_IGNORED",
36445                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
36446                "UNDECLARED_PROPERTIES",
36447                "UNREACHABLE"
36448              ]
36449            },
36450            "message": {
36451              "description": "[Output Only] A human-readable description of the warning code.",
36452              "type": "string"
36453            },
36454            "data": {
36455              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
36456              "type": "array",
36457              "items": {
36458                "type": "object",
36459                "properties": {
36460                  "key": {
36461                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
36462                    "type": "string"
36463                  },
36464                  "value": {
36465                    "description": "[Output Only] A warning data value corresponding to the key.",
36466                    "type": "string"
36467                  }
36468                }
36469              }
36470            }
36471          }
36472        },
36473        "unreachables": {
36474          "description": "[Output Only] Unreachable resources.",
36475          "type": "array",
36476          "items": {
36477            "type": "string"
36478          }
36479        }
36480      }
36481    },
36482    "SslCertificatesScopedList": {
36483      "id": "SslCertificatesScopedList",
36484      "type": "object",
36485      "properties": {
36486        "sslCertificates": {
36487          "description": "List of SslCertificates contained in this scope.",
36488          "type": "array",
36489          "items": {
36490            "$ref": "SslCertificate"
36491          }
36492        },
36493        "warning": {
36494          "description": "Informational warning which replaces the list of backend services when the list is empty.",
36495          "type": "object",
36496          "properties": {
36497            "code": {
36498              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
36499              "type": "string",
36500              "enumDescriptions": [
36501                "Warning about failed cleanup of transient changes made by a failed operation.",
36502                "A link to a deprecated resource was created.",
36503                "When deploying and at least one of the resources has a type marked as deprecated",
36504                "The user created a boot disk that is larger than image size.",
36505                "When deploying and at least one of the resources has a type marked as experimental",
36506                "Warning that is present in an external api call",
36507                "Warning that value of a field has been overridden. Deprecated unused field.",
36508                "The operation involved use of an injected kernel, which is deprecated.",
36509                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
36510                "When deploying a deployment with a exceedingly large number of resources",
36511                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
36512                "A resource depends on a missing type",
36513                "The route's nextHopIp address is not assigned to an instance on the network.",
36514                "The route's next hop instance cannot ip forward.",
36515                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
36516                "The route's nextHopInstance URL refers to an instance that does not exist.",
36517                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
36518                "The route's next hop instance does not have a status of RUNNING.",
36519                "Error which is not critical. We decided to continue the process despite the mentioned error.",
36520                "No results are present on a particular list page.",
36521                "Success is reported, but some results may be missing due to errors",
36522                "The user attempted to use a resource that requires a TOS they have not accepted.",
36523                "Warning that a resource is in use.",
36524                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
36525                "When a resource schema validation is ignored.",
36526                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
36527                "When undeclared properties in the schema are present",
36528                "A given scope cannot be reached."
36529              ],
36530              "enumDeprecated": [
36531                false,
36532                false,
36533                false,
36534                false,
36535                false,
36536                false,
36537                true,
36538                false,
36539                false,
36540                false,
36541                false,
36542                false,
36543                false,
36544                false,
36545                false,
36546                false,
36547                false,
36548                false,
36549                false,
36550                false,
36551                false,
36552                false,
36553                false,
36554                false,
36555                false,
36556                false,
36557                false,
36558                false
36559              ],
36560              "enum": [
36561                "CLEANUP_FAILED",
36562                "DEPRECATED_RESOURCE_USED",
36563                "DEPRECATED_TYPE_USED",
36564                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
36565                "EXPERIMENTAL_TYPE_USED",
36566                "EXTERNAL_API_WARNING",
36567                "FIELD_VALUE_OVERRIDEN",
36568                "INJECTED_KERNELS_DEPRECATED",
36569                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
36570                "LARGE_DEPLOYMENT_WARNING",
36571                "LIST_OVERHEAD_QUOTA_EXCEED",
36572                "MISSING_TYPE_DEPENDENCY",
36573                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
36574                "NEXT_HOP_CANNOT_IP_FORWARD",
36575                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
36576                "NEXT_HOP_INSTANCE_NOT_FOUND",
36577                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
36578                "NEXT_HOP_NOT_RUNNING",
36579                "NOT_CRITICAL_ERROR",
36580                "NO_RESULTS_ON_PAGE",
36581                "PARTIAL_SUCCESS",
36582                "REQUIRED_TOS_AGREEMENT",
36583                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
36584                "RESOURCE_NOT_DELETED",
36585                "SCHEMA_VALIDATION_IGNORED",
36586                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
36587                "UNDECLARED_PROPERTIES",
36588                "UNREACHABLE"
36589              ]
36590            },
36591            "message": {
36592              "description": "[Output Only] A human-readable description of the warning code.",
36593              "type": "string"
36594            },
36595            "data": {
36596              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
36597              "type": "array",
36598              "items": {
36599                "type": "object",
36600                "properties": {
36601                  "key": {
36602                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
36603                    "type": "string"
36604                  },
36605                  "value": {
36606                    "description": "[Output Only] A warning data value corresponding to the key.",
36607                    "type": "string"
36608                  }
36609                }
36610              }
36611            }
36612          }
36613        }
36614      }
36615    },
36616    "SslPoliciesList": {
36617      "id": "SslPoliciesList",
36618      "type": "object",
36619      "properties": {
36620        "kind": {
36621          "description": "[Output Only] Type of the resource. Always compute#sslPoliciesList for lists of sslPolicies.",
36622          "default": "compute#sslPoliciesList",
36623          "type": "string"
36624        },
36625        "id": {
36626          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
36627          "type": "string"
36628        },
36629        "items": {
36630          "description": "A list of SslPolicy resources.",
36631          "type": "array",
36632          "items": {
36633            "$ref": "SslPolicy"
36634          }
36635        },
36636        "nextPageToken": {
36637          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
36638          "type": "string"
36639        },
36640        "selfLink": {
36641          "description": "[Output Only] Server-defined URL for this resource.",
36642          "type": "string"
36643        },
36644        "warning": {
36645          "description": "[Output Only] Informational warning message.",
36646          "type": "object",
36647          "properties": {
36648            "code": {
36649              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
36650              "type": "string",
36651              "enumDescriptions": [
36652                "Warning about failed cleanup of transient changes made by a failed operation.",
36653                "A link to a deprecated resource was created.",
36654                "When deploying and at least one of the resources has a type marked as deprecated",
36655                "The user created a boot disk that is larger than image size.",
36656                "When deploying and at least one of the resources has a type marked as experimental",
36657                "Warning that is present in an external api call",
36658                "Warning that value of a field has been overridden. Deprecated unused field.",
36659                "The operation involved use of an injected kernel, which is deprecated.",
36660                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
36661                "When deploying a deployment with a exceedingly large number of resources",
36662                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
36663                "A resource depends on a missing type",
36664                "The route's nextHopIp address is not assigned to an instance on the network.",
36665                "The route's next hop instance cannot ip forward.",
36666                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
36667                "The route's nextHopInstance URL refers to an instance that does not exist.",
36668                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
36669                "The route's next hop instance does not have a status of RUNNING.",
36670                "Error which is not critical. We decided to continue the process despite the mentioned error.",
36671                "No results are present on a particular list page.",
36672                "Success is reported, but some results may be missing due to errors",
36673                "The user attempted to use a resource that requires a TOS they have not accepted.",
36674                "Warning that a resource is in use.",
36675                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
36676                "When a resource schema validation is ignored.",
36677                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
36678                "When undeclared properties in the schema are present",
36679                "A given scope cannot be reached."
36680              ],
36681              "enumDeprecated": [
36682                false,
36683                false,
36684                false,
36685                false,
36686                false,
36687                false,
36688                true,
36689                false,
36690                false,
36691                false,
36692                false,
36693                false,
36694                false,
36695                false,
36696                false,
36697                false,
36698                false,
36699                false,
36700                false,
36701                false,
36702                false,
36703                false,
36704                false,
36705                false,
36706                false,
36707                false,
36708                false,
36709                false
36710              ],
36711              "enum": [
36712                "CLEANUP_FAILED",
36713                "DEPRECATED_RESOURCE_USED",
36714                "DEPRECATED_TYPE_USED",
36715                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
36716                "EXPERIMENTAL_TYPE_USED",
36717                "EXTERNAL_API_WARNING",
36718                "FIELD_VALUE_OVERRIDEN",
36719                "INJECTED_KERNELS_DEPRECATED",
36720                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
36721                "LARGE_DEPLOYMENT_WARNING",
36722                "LIST_OVERHEAD_QUOTA_EXCEED",
36723                "MISSING_TYPE_DEPENDENCY",
36724                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
36725                "NEXT_HOP_CANNOT_IP_FORWARD",
36726                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
36727                "NEXT_HOP_INSTANCE_NOT_FOUND",
36728                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
36729                "NEXT_HOP_NOT_RUNNING",
36730                "NOT_CRITICAL_ERROR",
36731                "NO_RESULTS_ON_PAGE",
36732                "PARTIAL_SUCCESS",
36733                "REQUIRED_TOS_AGREEMENT",
36734                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
36735                "RESOURCE_NOT_DELETED",
36736                "SCHEMA_VALIDATION_IGNORED",
36737                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
36738                "UNDECLARED_PROPERTIES",
36739                "UNREACHABLE"
36740              ]
36741            },
36742            "message": {
36743              "description": "[Output Only] A human-readable description of the warning code.",
36744              "type": "string"
36745            },
36746            "data": {
36747              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
36748              "type": "array",
36749              "items": {
36750                "type": "object",
36751                "properties": {
36752                  "key": {
36753                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
36754                    "type": "string"
36755                  },
36756                  "value": {
36757                    "description": "[Output Only] A warning data value corresponding to the key.",
36758                    "type": "string"
36759                  }
36760                }
36761              }
36762            }
36763          }
36764        }
36765      }
36766    },
36767    "SslPolicy": {
36768      "id": "SslPolicy",
36769      "description": "Represents an SSL Policy resource. Use SSL policies to control SSL features, such as versions and cipher suites, that are offered by Application Load Balancers and proxy Network Load Balancers. For more information, read SSL policies overview.",
36770      "type": "object",
36771      "properties": {
36772        "kind": {
36773          "description": "[Output only] Type of the resource. Always compute#sslPolicyfor SSL policies.",
36774          "default": "compute#sslPolicy",
36775          "type": "string"
36776        },
36777        "id": {
36778          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
36779          "type": "string",
36780          "format": "uint64"
36781        },
36782        "creationTimestamp": {
36783          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
36784          "type": "string"
36785        },
36786        "selfLink": {
36787          "description": "[Output Only] Server-defined URL for the resource.",
36788          "type": "string"
36789        },
36790        "name": {
36791          "description": "Name of the resource. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
36792          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
36793          "type": "string"
36794        },
36795        "description": {
36796          "description": "An optional description of this resource. Provide this property when you create the resource.",
36797          "type": "string"
36798        },
36799        "profile": {
36800          "description": "Profile specifies the set of SSL features that can be used by the load balancer when negotiating SSL with clients. This can be one of COMPATIBLE, MODERN, RESTRICTED, or CUSTOM. If using CUSTOM, the set of SSL features to enable must be specified in the customFeatures field.",
36801          "type": "string",
36802          "enumDescriptions": [
36803            "Compatible profile. Allows the broadset set of clients, even those which support only out-of-date SSL features to negotiate with the load balancer.",
36804            "Custom profile. Allow only the set of allowed SSL features specified in the customFeatures field.",
36805            "Modern profile. Supports a wide set of SSL features, allowing modern clients to negotiate SSL with the load balancer.",
36806            "Restricted profile. Supports a reduced set of SSL features, intended to meet stricter compliance requirements."
36807          ],
36808          "enum": [
36809            "COMPATIBLE",
36810            "CUSTOM",
36811            "MODERN",
36812            "RESTRICTED"
36813          ]
36814        },
36815        "minTlsVersion": {
36816          "description": "The minimum version of SSL protocol that can be used by the clients to establish a connection with the load balancer. This can be one of TLS_1_0, TLS_1_1, TLS_1_2.",
36817          "type": "string",
36818          "enumDescriptions": [
36819            "TLS 1.0",
36820            "TLS 1.1",
36821            "TLS 1.2"
36822          ],
36823          "enum": [
36824            "TLS_1_0",
36825            "TLS_1_1",
36826            "TLS_1_2"
36827          ]
36828        },
36829        "enabledFeatures": {
36830          "description": "[Output Only] The list of features enabled in the SSL policy.",
36831          "type": "array",
36832          "items": {
36833            "type": "string"
36834          }
36835        },
36836        "customFeatures": {
36837          "description": "A list of features enabled when the selected profile is CUSTOM. The method returns the set of features that can be specified in this list. This field must be empty if the profile is not CUSTOM.",
36838          "type": "array",
36839          "items": {
36840            "type": "string"
36841          }
36842        },
36843        "fingerprint": {
36844          "description": "Fingerprint of this resource. A hash of the contents stored in this object. This field is used in optimistic locking. This field will be ignored when inserting a SslPolicy. An up-to-date fingerprint must be provided in order to update the SslPolicy, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve an SslPolicy.",
36845          "type": "string",
36846          "format": "byte"
36847        },
36848        "warnings": {
36849          "description": "[Output Only] If potential misconfigurations are detected for this SSL policy, this field will be populated with warning messages.",
36850          "type": "array",
36851          "items": {
36852            "type": "object",
36853            "properties": {
36854              "code": {
36855                "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
36856                "type": "string",
36857                "enumDescriptions": [
36858                  "Warning about failed cleanup of transient changes made by a failed operation.",
36859                  "A link to a deprecated resource was created.",
36860                  "When deploying and at least one of the resources has a type marked as deprecated",
36861                  "The user created a boot disk that is larger than image size.",
36862                  "When deploying and at least one of the resources has a type marked as experimental",
36863                  "Warning that is present in an external api call",
36864                  "Warning that value of a field has been overridden. Deprecated unused field.",
36865                  "The operation involved use of an injected kernel, which is deprecated.",
36866                  "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
36867                  "When deploying a deployment with a exceedingly large number of resources",
36868                  "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
36869                  "A resource depends on a missing type",
36870                  "The route's nextHopIp address is not assigned to an instance on the network.",
36871                  "The route's next hop instance cannot ip forward.",
36872                  "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
36873                  "The route's nextHopInstance URL refers to an instance that does not exist.",
36874                  "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
36875                  "The route's next hop instance does not have a status of RUNNING.",
36876                  "Error which is not critical. We decided to continue the process despite the mentioned error.",
36877                  "No results are present on a particular list page.",
36878                  "Success is reported, but some results may be missing due to errors",
36879                  "The user attempted to use a resource that requires a TOS they have not accepted.",
36880                  "Warning that a resource is in use.",
36881                  "One or more of the resources set to auto-delete could not be deleted because they were in use.",
36882                  "When a resource schema validation is ignored.",
36883                  "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
36884                  "When undeclared properties in the schema are present",
36885                  "A given scope cannot be reached."
36886                ],
36887                "enumDeprecated": [
36888                  false,
36889                  false,
36890                  false,
36891                  false,
36892                  false,
36893                  false,
36894                  true,
36895                  false,
36896                  false,
36897                  false,
36898                  false,
36899                  false,
36900                  false,
36901                  false,
36902                  false,
36903                  false,
36904                  false,
36905                  false,
36906                  false,
36907                  false,
36908                  false,
36909                  false,
36910                  false,
36911                  false,
36912                  false,
36913                  false,
36914                  false,
36915                  false
36916                ],
36917                "enum": [
36918                  "CLEANUP_FAILED",
36919                  "DEPRECATED_RESOURCE_USED",
36920                  "DEPRECATED_TYPE_USED",
36921                  "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
36922                  "EXPERIMENTAL_TYPE_USED",
36923                  "EXTERNAL_API_WARNING",
36924                  "FIELD_VALUE_OVERRIDEN",
36925                  "INJECTED_KERNELS_DEPRECATED",
36926                  "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
36927                  "LARGE_DEPLOYMENT_WARNING",
36928                  "LIST_OVERHEAD_QUOTA_EXCEED",
36929                  "MISSING_TYPE_DEPENDENCY",
36930                  "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
36931                  "NEXT_HOP_CANNOT_IP_FORWARD",
36932                  "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
36933                  "NEXT_HOP_INSTANCE_NOT_FOUND",
36934                  "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
36935                  "NEXT_HOP_NOT_RUNNING",
36936                  "NOT_CRITICAL_ERROR",
36937                  "NO_RESULTS_ON_PAGE",
36938                  "PARTIAL_SUCCESS",
36939                  "REQUIRED_TOS_AGREEMENT",
36940                  "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
36941                  "RESOURCE_NOT_DELETED",
36942                  "SCHEMA_VALIDATION_IGNORED",
36943                  "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
36944                  "UNDECLARED_PROPERTIES",
36945                  "UNREACHABLE"
36946                ]
36947              },
36948              "message": {
36949                "description": "[Output Only] A human-readable description of the warning code.",
36950                "type": "string"
36951              },
36952              "data": {
36953                "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
36954                "type": "array",
36955                "items": {
36956                  "type": "object",
36957                  "properties": {
36958                    "key": {
36959                      "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
36960                      "type": "string"
36961                    },
36962                    "value": {
36963                      "description": "[Output Only] A warning data value corresponding to the key.",
36964                      "type": "string"
36965                    }
36966                  }
36967                }
36968              }
36969            }
36970          }
36971        },
36972        "region": {
36973          "description": "[Output Only] URL of the region where the regional SSL policy resides. This field is not applicable to global SSL policies.",
36974          "type": "string"
36975        }
36976      }
36977    },
36978    "SslPoliciesListAvailableFeaturesResponse": {
36979      "id": "SslPoliciesListAvailableFeaturesResponse",
36980      "type": "object",
36981      "properties": {
36982        "features": {
36983          "type": "array",
36984          "items": {
36985            "type": "string"
36986          }
36987        }
36988      }
36989    },
36990    "SslPoliciesAggregatedList": {
36991      "id": "SslPoliciesAggregatedList",
36992      "type": "object",
36993      "properties": {
36994        "kind": {
36995          "description": "[Output Only] Type of resource. Always compute#sslPolicyAggregatedList for lists of SSL Policies.",
36996          "default": "compute#sslPoliciesAggregatedList",
36997          "type": "string"
36998        },
36999        "id": {
37000          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
37001          "type": "string"
37002        },
37003        "items": {
37004          "description": "A list of SslPoliciesScopedList resources.",
37005          "type": "object",
37006          "additionalProperties": {
37007            "description": "Name of the scope containing this set of SSL policies.",
37008            "$ref": "SslPoliciesScopedList"
37009          }
37010        },
37011        "nextPageToken": {
37012          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
37013          "type": "string"
37014        },
37015        "selfLink": {
37016          "description": "[Output Only] Server-defined URL for this resource.",
37017          "type": "string"
37018        },
37019        "warning": {
37020          "description": "[Output Only] Informational warning message.",
37021          "type": "object",
37022          "properties": {
37023            "code": {
37024              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
37025              "type": "string",
37026              "enumDescriptions": [
37027                "Warning about failed cleanup of transient changes made by a failed operation.",
37028                "A link to a deprecated resource was created.",
37029                "When deploying and at least one of the resources has a type marked as deprecated",
37030                "The user created a boot disk that is larger than image size.",
37031                "When deploying and at least one of the resources has a type marked as experimental",
37032                "Warning that is present in an external api call",
37033                "Warning that value of a field has been overridden. Deprecated unused field.",
37034                "The operation involved use of an injected kernel, which is deprecated.",
37035                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
37036                "When deploying a deployment with a exceedingly large number of resources",
37037                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
37038                "A resource depends on a missing type",
37039                "The route's nextHopIp address is not assigned to an instance on the network.",
37040                "The route's next hop instance cannot ip forward.",
37041                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
37042                "The route's nextHopInstance URL refers to an instance that does not exist.",
37043                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
37044                "The route's next hop instance does not have a status of RUNNING.",
37045                "Error which is not critical. We decided to continue the process despite the mentioned error.",
37046                "No results are present on a particular list page.",
37047                "Success is reported, but some results may be missing due to errors",
37048                "The user attempted to use a resource that requires a TOS they have not accepted.",
37049                "Warning that a resource is in use.",
37050                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
37051                "When a resource schema validation is ignored.",
37052                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
37053                "When undeclared properties in the schema are present",
37054                "A given scope cannot be reached."
37055              ],
37056              "enumDeprecated": [
37057                false,
37058                false,
37059                false,
37060                false,
37061                false,
37062                false,
37063                true,
37064                false,
37065                false,
37066                false,
37067                false,
37068                false,
37069                false,
37070                false,
37071                false,
37072                false,
37073                false,
37074                false,
37075                false,
37076                false,
37077                false,
37078                false,
37079                false,
37080                false,
37081                false,
37082                false,
37083                false,
37084                false
37085              ],
37086              "enum": [
37087                "CLEANUP_FAILED",
37088                "DEPRECATED_RESOURCE_USED",
37089                "DEPRECATED_TYPE_USED",
37090                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
37091                "EXPERIMENTAL_TYPE_USED",
37092                "EXTERNAL_API_WARNING",
37093                "FIELD_VALUE_OVERRIDEN",
37094                "INJECTED_KERNELS_DEPRECATED",
37095                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
37096                "LARGE_DEPLOYMENT_WARNING",
37097                "LIST_OVERHEAD_QUOTA_EXCEED",
37098                "MISSING_TYPE_DEPENDENCY",
37099                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
37100                "NEXT_HOP_CANNOT_IP_FORWARD",
37101                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
37102                "NEXT_HOP_INSTANCE_NOT_FOUND",
37103                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
37104                "NEXT_HOP_NOT_RUNNING",
37105                "NOT_CRITICAL_ERROR",
37106                "NO_RESULTS_ON_PAGE",
37107                "PARTIAL_SUCCESS",
37108                "REQUIRED_TOS_AGREEMENT",
37109                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
37110                "RESOURCE_NOT_DELETED",
37111                "SCHEMA_VALIDATION_IGNORED",
37112                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
37113                "UNDECLARED_PROPERTIES",
37114                "UNREACHABLE"
37115              ]
37116            },
37117            "message": {
37118              "description": "[Output Only] A human-readable description of the warning code.",
37119              "type": "string"
37120            },
37121            "data": {
37122              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
37123              "type": "array",
37124              "items": {
37125                "type": "object",
37126                "properties": {
37127                  "key": {
37128                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
37129                    "type": "string"
37130                  },
37131                  "value": {
37132                    "description": "[Output Only] A warning data value corresponding to the key.",
37133                    "type": "string"
37134                  }
37135                }
37136              }
37137            }
37138          }
37139        },
37140        "etag": {
37141          "type": "string"
37142        },
37143        "unreachables": {
37144          "description": "[Output Only] Unreachable resources.",
37145          "type": "array",
37146          "items": {
37147            "type": "string"
37148          }
37149        }
37150      }
37151    },
37152    "SslPoliciesScopedList": {
37153      "id": "SslPoliciesScopedList",
37154      "type": "object",
37155      "properties": {
37156        "sslPolicies": {
37157          "description": "A list of SslPolicies contained in this scope.",
37158          "type": "array",
37159          "items": {
37160            "$ref": "SslPolicy"
37161          }
37162        },
37163        "warning": {
37164          "description": "Informational warning which replaces the list of SSL policies when the list is empty.",
37165          "type": "object",
37166          "properties": {
37167            "code": {
37168              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
37169              "type": "string",
37170              "enumDescriptions": [
37171                "Warning about failed cleanup of transient changes made by a failed operation.",
37172                "A link to a deprecated resource was created.",
37173                "When deploying and at least one of the resources has a type marked as deprecated",
37174                "The user created a boot disk that is larger than image size.",
37175                "When deploying and at least one of the resources has a type marked as experimental",
37176                "Warning that is present in an external api call",
37177                "Warning that value of a field has been overridden. Deprecated unused field.",
37178                "The operation involved use of an injected kernel, which is deprecated.",
37179                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
37180                "When deploying a deployment with a exceedingly large number of resources",
37181                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
37182                "A resource depends on a missing type",
37183                "The route's nextHopIp address is not assigned to an instance on the network.",
37184                "The route's next hop instance cannot ip forward.",
37185                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
37186                "The route's nextHopInstance URL refers to an instance that does not exist.",
37187                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
37188                "The route's next hop instance does not have a status of RUNNING.",
37189                "Error which is not critical. We decided to continue the process despite the mentioned error.",
37190                "No results are present on a particular list page.",
37191                "Success is reported, but some results may be missing due to errors",
37192                "The user attempted to use a resource that requires a TOS they have not accepted.",
37193                "Warning that a resource is in use.",
37194                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
37195                "When a resource schema validation is ignored.",
37196                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
37197                "When undeclared properties in the schema are present",
37198                "A given scope cannot be reached."
37199              ],
37200              "enumDeprecated": [
37201                false,
37202                false,
37203                false,
37204                false,
37205                false,
37206                false,
37207                true,
37208                false,
37209                false,
37210                false,
37211                false,
37212                false,
37213                false,
37214                false,
37215                false,
37216                false,
37217                false,
37218                false,
37219                false,
37220                false,
37221                false,
37222                false,
37223                false,
37224                false,
37225                false,
37226                false,
37227                false,
37228                false
37229              ],
37230              "enum": [
37231                "CLEANUP_FAILED",
37232                "DEPRECATED_RESOURCE_USED",
37233                "DEPRECATED_TYPE_USED",
37234                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
37235                "EXPERIMENTAL_TYPE_USED",
37236                "EXTERNAL_API_WARNING",
37237                "FIELD_VALUE_OVERRIDEN",
37238                "INJECTED_KERNELS_DEPRECATED",
37239                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
37240                "LARGE_DEPLOYMENT_WARNING",
37241                "LIST_OVERHEAD_QUOTA_EXCEED",
37242                "MISSING_TYPE_DEPENDENCY",
37243                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
37244                "NEXT_HOP_CANNOT_IP_FORWARD",
37245                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
37246                "NEXT_HOP_INSTANCE_NOT_FOUND",
37247                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
37248                "NEXT_HOP_NOT_RUNNING",
37249                "NOT_CRITICAL_ERROR",
37250                "NO_RESULTS_ON_PAGE",
37251                "PARTIAL_SUCCESS",
37252                "REQUIRED_TOS_AGREEMENT",
37253                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
37254                "RESOURCE_NOT_DELETED",
37255                "SCHEMA_VALIDATION_IGNORED",
37256                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
37257                "UNDECLARED_PROPERTIES",
37258                "UNREACHABLE"
37259              ]
37260            },
37261            "message": {
37262              "description": "[Output Only] A human-readable description of the warning code.",
37263              "type": "string"
37264            },
37265            "data": {
37266              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
37267              "type": "array",
37268              "items": {
37269                "type": "object",
37270                "properties": {
37271                  "key": {
37272                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
37273                    "type": "string"
37274                  },
37275                  "value": {
37276                    "description": "[Output Only] A warning data value corresponding to the key.",
37277                    "type": "string"
37278                  }
37279                }
37280              }
37281            }
37282          }
37283        }
37284      }
37285    },
37286    "SubnetworkList": {
37287      "id": "SubnetworkList",
37288      "description": "Contains a list of Subnetwork resources.",
37289      "type": "object",
37290      "properties": {
37291        "kind": {
37292          "description": "[Output Only] Type of resource. Always compute#subnetworkList for lists of subnetworks.",
37293          "default": "compute#subnetworkList",
37294          "type": "string"
37295        },
37296        "id": {
37297          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
37298          "type": "string"
37299        },
37300        "items": {
37301          "description": "A list of Subnetwork resources.",
37302          "type": "array",
37303          "items": {
37304            "$ref": "Subnetwork"
37305          }
37306        },
37307        "nextPageToken": {
37308          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
37309          "type": "string"
37310        },
37311        "selfLink": {
37312          "description": "[Output Only] Server-defined URL for this resource.",
37313          "type": "string"
37314        },
37315        "warning": {
37316          "description": "[Output Only] Informational warning message.",
37317          "type": "object",
37318          "properties": {
37319            "code": {
37320              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
37321              "type": "string",
37322              "enumDescriptions": [
37323                "Warning about failed cleanup of transient changes made by a failed operation.",
37324                "A link to a deprecated resource was created.",
37325                "When deploying and at least one of the resources has a type marked as deprecated",
37326                "The user created a boot disk that is larger than image size.",
37327                "When deploying and at least one of the resources has a type marked as experimental",
37328                "Warning that is present in an external api call",
37329                "Warning that value of a field has been overridden. Deprecated unused field.",
37330                "The operation involved use of an injected kernel, which is deprecated.",
37331                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
37332                "When deploying a deployment with a exceedingly large number of resources",
37333                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
37334                "A resource depends on a missing type",
37335                "The route's nextHopIp address is not assigned to an instance on the network.",
37336                "The route's next hop instance cannot ip forward.",
37337                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
37338                "The route's nextHopInstance URL refers to an instance that does not exist.",
37339                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
37340                "The route's next hop instance does not have a status of RUNNING.",
37341                "Error which is not critical. We decided to continue the process despite the mentioned error.",
37342                "No results are present on a particular list page.",
37343                "Success is reported, but some results may be missing due to errors",
37344                "The user attempted to use a resource that requires a TOS they have not accepted.",
37345                "Warning that a resource is in use.",
37346                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
37347                "When a resource schema validation is ignored.",
37348                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
37349                "When undeclared properties in the schema are present",
37350                "A given scope cannot be reached."
37351              ],
37352              "enumDeprecated": [
37353                false,
37354                false,
37355                false,
37356                false,
37357                false,
37358                false,
37359                true,
37360                false,
37361                false,
37362                false,
37363                false,
37364                false,
37365                false,
37366                false,
37367                false,
37368                false,
37369                false,
37370                false,
37371                false,
37372                false,
37373                false,
37374                false,
37375                false,
37376                false,
37377                false,
37378                false,
37379                false,
37380                false
37381              ],
37382              "enum": [
37383                "CLEANUP_FAILED",
37384                "DEPRECATED_RESOURCE_USED",
37385                "DEPRECATED_TYPE_USED",
37386                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
37387                "EXPERIMENTAL_TYPE_USED",
37388                "EXTERNAL_API_WARNING",
37389                "FIELD_VALUE_OVERRIDEN",
37390                "INJECTED_KERNELS_DEPRECATED",
37391                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
37392                "LARGE_DEPLOYMENT_WARNING",
37393                "LIST_OVERHEAD_QUOTA_EXCEED",
37394                "MISSING_TYPE_DEPENDENCY",
37395                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
37396                "NEXT_HOP_CANNOT_IP_FORWARD",
37397                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
37398                "NEXT_HOP_INSTANCE_NOT_FOUND",
37399                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
37400                "NEXT_HOP_NOT_RUNNING",
37401                "NOT_CRITICAL_ERROR",
37402                "NO_RESULTS_ON_PAGE",
37403                "PARTIAL_SUCCESS",
37404                "REQUIRED_TOS_AGREEMENT",
37405                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
37406                "RESOURCE_NOT_DELETED",
37407                "SCHEMA_VALIDATION_IGNORED",
37408                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
37409                "UNDECLARED_PROPERTIES",
37410                "UNREACHABLE"
37411              ]
37412            },
37413            "message": {
37414              "description": "[Output Only] A human-readable description of the warning code.",
37415              "type": "string"
37416            },
37417            "data": {
37418              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
37419              "type": "array",
37420              "items": {
37421                "type": "object",
37422                "properties": {
37423                  "key": {
37424                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
37425                    "type": "string"
37426                  },
37427                  "value": {
37428                    "description": "[Output Only] A warning data value corresponding to the key.",
37429                    "type": "string"
37430                  }
37431                }
37432              }
37433            }
37434          }
37435        }
37436      }
37437    },
37438    "Subnetwork": {
37439      "id": "Subnetwork",
37440      "description": "Represents a Subnetwork resource. A subnetwork (also known as a subnet) is a logical partition of a Virtual Private Cloud network with one primary IP range and zero or more secondary IP ranges. For more information, read Virtual Private Cloud (VPC) Network.",
37441      "type": "object",
37442      "properties": {
37443        "kind": {
37444          "description": "[Output Only] Type of the resource. Always compute#subnetwork for Subnetwork resources.",
37445          "default": "compute#subnetwork",
37446          "type": "string"
37447        },
37448        "id": {
37449          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
37450          "type": "string",
37451          "format": "uint64"
37452        },
37453        "creationTimestamp": {
37454          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
37455          "type": "string"
37456        },
37457        "name": {
37458          "description": "The name of the resource, provided by the client when initially creating the resource. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
37459          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
37460          "type": "string"
37461        },
37462        "description": {
37463          "description": "An optional description of this resource. Provide this property when you create the resource. This field can be set only at resource creation time.",
37464          "type": "string"
37465        },
37466        "network": {
37467          "description": "The URL of the network to which this subnetwork belongs, provided by the client when initially creating the subnetwork. This field can be set only at resource creation time.",
37468          "type": "string"
37469        },
37470        "ipCidrRange": {
37471          "description": "The range of internal addresses that are owned by this subnetwork. Provide this property when you create the subnetwork. For example, 10.0.0.0/8 or 100.64.0.0/10. Ranges must be unique and non-overlapping within a network. Only IPv4 is supported. This field is set at resource creation time. The range can be any range listed in the Valid ranges list. The range can be expanded after creation using expandIpCidrRange.",
37472          "type": "string"
37473        },
37474        "reservedInternalRange": {
37475          "description": "The URL of the reserved internal range.",
37476          "type": "string"
37477        },
37478        "gatewayAddress": {
37479          "description": "[Output Only] The gateway address for default routes to reach destination addresses outside this subnetwork.",
37480          "type": "string"
37481        },
37482        "region": {
37483          "description": "URL of the region where the Subnetwork resides. This field can be set only at resource creation time.",
37484          "type": "string"
37485        },
37486        "selfLink": {
37487          "description": "[Output Only] Server-defined URL for the resource.",
37488          "type": "string"
37489        },
37490        "privateIpGoogleAccess": {
37491          "description": "Whether the VMs in this subnet can access Google services without assigned external IP addresses. This field can be both set at resource creation time and updated using setPrivateIpGoogleAccess.",
37492          "type": "boolean"
37493        },
37494        "secondaryIpRanges": {
37495          "description": "An array of configurations for secondary IP ranges for VM instances contained in this subnetwork. The primary IP of such VM must belong to the primary ipCidrRange of the subnetwork. The alias IPs may belong to either primary or secondary ranges. This field can be updated with a patch request.",
37496          "type": "array",
37497          "items": {
37498            "$ref": "SubnetworkSecondaryRange"
37499          }
37500        },
37501        "fingerprint": {
37502          "description": "Fingerprint of this resource. A hash of the contents stored in this object. This field is used in optimistic locking. This field will be ignored when inserting a Subnetwork. An up-to-date fingerprint must be provided in order to update the Subnetwork, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve a Subnetwork.",
37503          "type": "string",
37504          "format": "byte"
37505        },
37506        "enableFlowLogs": {
37507          "description": "Whether to enable flow logging for this subnetwork. If this field is not explicitly set, it will not appear in get listings. If not set the default behavior is determined by the org policy, if there is no org policy specified, then it will default to disabled. This field isn't supported if the subnet purpose field is set to REGIONAL_MANAGED_PROXY.",
37508          "type": "boolean"
37509        },
37510        "privateIpv6GoogleAccess": {
37511          "description": "This field is for internal use. This field can be both set at resource creation time and updated using patch.",
37512          "type": "string",
37513          "enumDescriptions": [
37514            "Disable private IPv6 access to/from Google services.",
37515            "Bidirectional private IPv6 access to/from Google services.",
37516            "Outbound private IPv6 access from VMs in this subnet to Google services."
37517          ],
37518          "enum": [
37519            "DISABLE_GOOGLE_ACCESS",
37520            "ENABLE_BIDIRECTIONAL_ACCESS_TO_GOOGLE",
37521            "ENABLE_OUTBOUND_VM_ACCESS_TO_GOOGLE"
37522          ]
37523        },
37524        "ipv6CidrRange": {
37525          "description": "[Output Only] This field is for internal use.",
37526          "type": "string"
37527        },
37528        "externalIpv6Prefix": {
37529          "description": "The external IPv6 address range that is owned by this subnetwork.",
37530          "type": "string"
37531        },
37532        "internalIpv6Prefix": {
37533          "description": "[Output Only] The internal IPv6 address range that is assigned to this subnetwork.",
37534          "type": "string"
37535        },
37536        "purpose": {
37537          "description": "The purpose of the resource. This field can be either PRIVATE, GLOBAL_MANAGED_PROXY, REGIONAL_MANAGED_PROXY, PRIVATE_SERVICE_CONNECT, or PRIVATE is the default purpose for user-created subnets or subnets that are automatically created in auto mode networks. Subnets with purpose set to GLOBAL_MANAGED_PROXY or REGIONAL_MANAGED_PROXY are user-created subnetworks that are reserved for Envoy-based load balancers. A subnet with purpose set to PRIVATE_SERVICE_CONNECT is used to publish services using Private Service Connect. If unspecified, the subnet purpose defaults to PRIVATE. The enableFlowLogs field isn't supported if the subnet purpose field is set to GLOBAL_MANAGED_PROXY or REGIONAL_MANAGED_PROXY.",
37538          "type": "string",
37539          "enumDescriptions": [
37540            "Subnet reserved for Global Envoy-based Load Balancing.",
37541            "Subnet reserved for Internal HTTP(S) Load Balancing. This is a legacy purpose, please use REGIONAL_MANAGED_PROXY instead.",
37542            "Regular user created or automatically created subnet.",
37543            "Subnetwork used as source range for Private NAT Gateways.",
37544            "Regular user created or automatically created subnet.",
37545            "Subnetworks created for Private Service Connect in the producer network.",
37546            "Subnetwork used for Regional Envoy-based Load Balancing."
37547          ],
37548          "enum": [
37549            "GLOBAL_MANAGED_PROXY",
37550            "INTERNAL_HTTPS_LOAD_BALANCER",
37551            "PRIVATE",
37552            "PRIVATE_NAT",
37553            "PRIVATE_RFC_1918",
37554            "PRIVATE_SERVICE_CONNECT",
37555            "REGIONAL_MANAGED_PROXY"
37556          ]
37557        },
37558        "role": {
37559          "description": "The role of subnetwork. Currently, this field is only used when purpose is set to GLOBAL_MANAGED_PROXY or REGIONAL_MANAGED_PROXY. The value can be set to ACTIVE or BACKUP. An ACTIVE subnetwork is one that is currently being used for Envoy-based load balancers in a region. A BACKUP subnetwork is one that is ready to be promoted to ACTIVE or is currently draining. This field can be updated with a patch request.",
37560          "type": "string",
37561          "enumDescriptions": [
37562            "The ACTIVE subnet that is currently used.",
37563            "The BACKUP subnet that could be promoted to ACTIVE."
37564          ],
37565          "enum": [
37566            "ACTIVE",
37567            "BACKUP"
37568          ]
37569        },
37570        "state": {
37571          "description": "[Output Only] The state of the subnetwork, which can be one of the following values: READY: Subnetwork is created and ready to use DRAINING: only applicable to subnetworks that have the purpose set to INTERNAL_HTTPS_LOAD_BALANCER and indicates that connections to the load balancer are being drained. A subnetwork that is draining cannot be used or modified until it reaches a status of READY",
37572          "type": "string",
37573          "enumDescriptions": [
37574            "Subnetwork is being drained.",
37575            "Subnetwork is ready for use."
37576          ],
37577          "enum": [
37578            "DRAINING",
37579            "READY"
37580          ]
37581        },
37582        "logConfig": {
37583          "description": "This field denotes the VPC flow logging options for this subnetwork. If logging is enabled, logs are exported to Cloud Logging.",
37584          "$ref": "SubnetworkLogConfig"
37585        },
37586        "stackType": {
37587          "description": "The stack type for the subnet. If set to IPV4_ONLY, new VMs in the subnet are assigned IPv4 addresses only. If set to IPV4_IPV6, new VMs in the subnet can be assigned both IPv4 and IPv6 addresses. If not specified, IPV4_ONLY is used. This field can be both set at resource creation time and updated using patch.",
37588          "type": "string",
37589          "enumDescriptions": [
37590            "New VMs in this subnet can have both IPv4 and IPv6 addresses.",
37591            "New VMs in this subnet will only be assigned IPv4 addresses."
37592          ],
37593          "enum": [
37594            "IPV4_IPV6",
37595            "IPV4_ONLY"
37596          ]
37597        },
37598        "ipv6AccessType": {
37599          "description": "The access type of IPv6 address this subnet holds. It's immutable and can only be specified during creation or the first time the subnet is updated into IPV4_IPV6 dual stack.",
37600          "type": "string",
37601          "enumDescriptions": [
37602            "VMs on this subnet will be assigned IPv6 addresses that are accessible via the Internet, as well as the VPC network.",
37603            "VMs on this subnet will be assigned IPv6 addresses that are only accessible over the VPC network."
37604          ],
37605          "enum": [
37606            "EXTERNAL",
37607            "INTERNAL"
37608          ]
37609        }
37610      }
37611    },
37612    "SubnetworkSecondaryRange": {
37613      "id": "SubnetworkSecondaryRange",
37614      "description": "Represents a secondary IP range of a subnetwork.",
37615      "type": "object",
37616      "properties": {
37617        "rangeName": {
37618          "description": "The name associated with this subnetwork secondary range, used when adding an alias IP range to a VM instance. The name must be 1-63 characters long, and comply with RFC1035. The name must be unique within the subnetwork.",
37619          "type": "string"
37620        },
37621        "ipCidrRange": {
37622          "description": "The range of IP addresses belonging to this subnetwork secondary range. Provide this property when you create the subnetwork. Ranges must be unique and non-overlapping with all primary and secondary IP ranges within a network. Only IPv4 is supported. The range can be any range listed in the Valid ranges list.",
37623          "type": "string"
37624        },
37625        "reservedInternalRange": {
37626          "description": "The URL of the reserved internal range.",
37627          "type": "string"
37628        }
37629      }
37630    },
37631    "SubnetworkLogConfig": {
37632      "id": "SubnetworkLogConfig",
37633      "description": "The available logging options for this subnetwork.",
37634      "type": "object",
37635      "properties": {
37636        "enable": {
37637          "description": "Whether to enable flow logging for this subnetwork. If this field is not explicitly set, it will not appear in get listings. If not set the default behavior is determined by the org policy, if there is no org policy specified, then it will default to disabled. Flow logging isn't supported if the subnet purpose field is set to REGIONAL_MANAGED_PROXY.",
37638          "type": "boolean"
37639        },
37640        "aggregationInterval": {
37641          "description": "Can only be specified if VPC flow logging for this subnetwork is enabled. Toggles the aggregation interval for collecting flow logs. Increasing the interval time will reduce the amount of generated flow logs for long lasting connections. Default is an interval of 5 seconds per connection.",
37642          "type": "string",
37643          "enumDescriptions": [
37644            "",
37645            "",
37646            "",
37647            "",
37648            "",
37649            ""
37650          ],
37651          "enum": [
37652            "INTERVAL_10_MIN",
37653            "INTERVAL_15_MIN",
37654            "INTERVAL_1_MIN",
37655            "INTERVAL_30_SEC",
37656            "INTERVAL_5_MIN",
37657            "INTERVAL_5_SEC"
37658          ]
37659        },
37660        "flowSampling": {
37661          "description": "Can only be specified if VPC flow logging for this subnetwork is enabled. The value of the field must be in [0, 1]. Set the sampling rate of VPC flow logs within the subnetwork where 1.0 means all collected logs are reported and 0.0 means no logs are reported. Default is 0.5 unless otherwise specified by the org policy, which means half of all collected logs are reported.",
37662          "type": "number",
37663          "format": "float"
37664        },
37665        "metadata": {
37666          "description": "Can only be specified if VPC flow logs for this subnetwork is enabled. Configures whether all, none or a subset of metadata fields should be added to the reported VPC flow logs. Default is EXCLUDE_ALL_METADATA.",
37667          "type": "string",
37668          "enumDescriptions": [
37669            "",
37670            "",
37671            ""
37672          ],
37673          "enum": [
37674            "CUSTOM_METADATA",
37675            "EXCLUDE_ALL_METADATA",
37676            "INCLUDE_ALL_METADATA"
37677          ]
37678        },
37679        "metadataFields": {
37680          "description": "Can only be specified if VPC flow logs for this subnetwork is enabled and \"metadata\" was set to CUSTOM_METADATA.",
37681          "type": "array",
37682          "items": {
37683            "type": "string"
37684          }
37685        },
37686        "filterExpr": {
37687          "description": "Can only be specified if VPC flow logs for this subnetwork is enabled. The filter expression is used to define which VPC flow logs should be exported to Cloud Logging.",
37688          "type": "string"
37689        }
37690      }
37691    },
37692    "SubnetworkAggregatedList": {
37693      "id": "SubnetworkAggregatedList",
37694      "type": "object",
37695      "properties": {
37696        "kind": {
37697          "description": "[Output Only] Type of resource. Always compute#subnetworkAggregatedList for aggregated lists of subnetworks.",
37698          "default": "compute#subnetworkAggregatedList",
37699          "type": "string"
37700        },
37701        "id": {
37702          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
37703          "type": "string"
37704        },
37705        "items": {
37706          "description": "A list of SubnetworksScopedList resources.",
37707          "type": "object",
37708          "additionalProperties": {
37709            "description": "Name of the scope containing this set of Subnetworks.",
37710            "$ref": "SubnetworksScopedList"
37711          }
37712        },
37713        "nextPageToken": {
37714          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
37715          "type": "string"
37716        },
37717        "selfLink": {
37718          "description": "[Output Only] Server-defined URL for this resource.",
37719          "type": "string"
37720        },
37721        "warning": {
37722          "description": "[Output Only] Informational warning message.",
37723          "type": "object",
37724          "properties": {
37725            "code": {
37726              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
37727              "type": "string",
37728              "enumDescriptions": [
37729                "Warning about failed cleanup of transient changes made by a failed operation.",
37730                "A link to a deprecated resource was created.",
37731                "When deploying and at least one of the resources has a type marked as deprecated",
37732                "The user created a boot disk that is larger than image size.",
37733                "When deploying and at least one of the resources has a type marked as experimental",
37734                "Warning that is present in an external api call",
37735                "Warning that value of a field has been overridden. Deprecated unused field.",
37736                "The operation involved use of an injected kernel, which is deprecated.",
37737                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
37738                "When deploying a deployment with a exceedingly large number of resources",
37739                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
37740                "A resource depends on a missing type",
37741                "The route's nextHopIp address is not assigned to an instance on the network.",
37742                "The route's next hop instance cannot ip forward.",
37743                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
37744                "The route's nextHopInstance URL refers to an instance that does not exist.",
37745                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
37746                "The route's next hop instance does not have a status of RUNNING.",
37747                "Error which is not critical. We decided to continue the process despite the mentioned error.",
37748                "No results are present on a particular list page.",
37749                "Success is reported, but some results may be missing due to errors",
37750                "The user attempted to use a resource that requires a TOS they have not accepted.",
37751                "Warning that a resource is in use.",
37752                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
37753                "When a resource schema validation is ignored.",
37754                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
37755                "When undeclared properties in the schema are present",
37756                "A given scope cannot be reached."
37757              ],
37758              "enumDeprecated": [
37759                false,
37760                false,
37761                false,
37762                false,
37763                false,
37764                false,
37765                true,
37766                false,
37767                false,
37768                false,
37769                false,
37770                false,
37771                false,
37772                false,
37773                false,
37774                false,
37775                false,
37776                false,
37777                false,
37778                false,
37779                false,
37780                false,
37781                false,
37782                false,
37783                false,
37784                false,
37785                false,
37786                false
37787              ],
37788              "enum": [
37789                "CLEANUP_FAILED",
37790                "DEPRECATED_RESOURCE_USED",
37791                "DEPRECATED_TYPE_USED",
37792                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
37793                "EXPERIMENTAL_TYPE_USED",
37794                "EXTERNAL_API_WARNING",
37795                "FIELD_VALUE_OVERRIDEN",
37796                "INJECTED_KERNELS_DEPRECATED",
37797                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
37798                "LARGE_DEPLOYMENT_WARNING",
37799                "LIST_OVERHEAD_QUOTA_EXCEED",
37800                "MISSING_TYPE_DEPENDENCY",
37801                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
37802                "NEXT_HOP_CANNOT_IP_FORWARD",
37803                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
37804                "NEXT_HOP_INSTANCE_NOT_FOUND",
37805                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
37806                "NEXT_HOP_NOT_RUNNING",
37807                "NOT_CRITICAL_ERROR",
37808                "NO_RESULTS_ON_PAGE",
37809                "PARTIAL_SUCCESS",
37810                "REQUIRED_TOS_AGREEMENT",
37811                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
37812                "RESOURCE_NOT_DELETED",
37813                "SCHEMA_VALIDATION_IGNORED",
37814                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
37815                "UNDECLARED_PROPERTIES",
37816                "UNREACHABLE"
37817              ]
37818            },
37819            "message": {
37820              "description": "[Output Only] A human-readable description of the warning code.",
37821              "type": "string"
37822            },
37823            "data": {
37824              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
37825              "type": "array",
37826              "items": {
37827                "type": "object",
37828                "properties": {
37829                  "key": {
37830                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
37831                    "type": "string"
37832                  },
37833                  "value": {
37834                    "description": "[Output Only] A warning data value corresponding to the key.",
37835                    "type": "string"
37836                  }
37837                }
37838              }
37839            }
37840          }
37841        },
37842        "unreachables": {
37843          "description": "[Output Only] Unreachable resources.",
37844          "type": "array",
37845          "items": {
37846            "type": "string"
37847          }
37848        }
37849      }
37850    },
37851    "SubnetworksScopedList": {
37852      "id": "SubnetworksScopedList",
37853      "type": "object",
37854      "properties": {
37855        "subnetworks": {
37856          "description": "A list of subnetworks contained in this scope.",
37857          "type": "array",
37858          "items": {
37859            "$ref": "Subnetwork"
37860          }
37861        },
37862        "warning": {
37863          "description": "An informational warning that appears when the list of addresses is empty.",
37864          "type": "object",
37865          "properties": {
37866            "code": {
37867              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
37868              "type": "string",
37869              "enumDescriptions": [
37870                "Warning about failed cleanup of transient changes made by a failed operation.",
37871                "A link to a deprecated resource was created.",
37872                "When deploying and at least one of the resources has a type marked as deprecated",
37873                "The user created a boot disk that is larger than image size.",
37874                "When deploying and at least one of the resources has a type marked as experimental",
37875                "Warning that is present in an external api call",
37876                "Warning that value of a field has been overridden. Deprecated unused field.",
37877                "The operation involved use of an injected kernel, which is deprecated.",
37878                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
37879                "When deploying a deployment with a exceedingly large number of resources",
37880                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
37881                "A resource depends on a missing type",
37882                "The route's nextHopIp address is not assigned to an instance on the network.",
37883                "The route's next hop instance cannot ip forward.",
37884                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
37885                "The route's nextHopInstance URL refers to an instance that does not exist.",
37886                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
37887                "The route's next hop instance does not have a status of RUNNING.",
37888                "Error which is not critical. We decided to continue the process despite the mentioned error.",
37889                "No results are present on a particular list page.",
37890                "Success is reported, but some results may be missing due to errors",
37891                "The user attempted to use a resource that requires a TOS they have not accepted.",
37892                "Warning that a resource is in use.",
37893                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
37894                "When a resource schema validation is ignored.",
37895                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
37896                "When undeclared properties in the schema are present",
37897                "A given scope cannot be reached."
37898              ],
37899              "enumDeprecated": [
37900                false,
37901                false,
37902                false,
37903                false,
37904                false,
37905                false,
37906                true,
37907                false,
37908                false,
37909                false,
37910                false,
37911                false,
37912                false,
37913                false,
37914                false,
37915                false,
37916                false,
37917                false,
37918                false,
37919                false,
37920                false,
37921                false,
37922                false,
37923                false,
37924                false,
37925                false,
37926                false,
37927                false
37928              ],
37929              "enum": [
37930                "CLEANUP_FAILED",
37931                "DEPRECATED_RESOURCE_USED",
37932                "DEPRECATED_TYPE_USED",
37933                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
37934                "EXPERIMENTAL_TYPE_USED",
37935                "EXTERNAL_API_WARNING",
37936                "FIELD_VALUE_OVERRIDEN",
37937                "INJECTED_KERNELS_DEPRECATED",
37938                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
37939                "LARGE_DEPLOYMENT_WARNING",
37940                "LIST_OVERHEAD_QUOTA_EXCEED",
37941                "MISSING_TYPE_DEPENDENCY",
37942                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
37943                "NEXT_HOP_CANNOT_IP_FORWARD",
37944                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
37945                "NEXT_HOP_INSTANCE_NOT_FOUND",
37946                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
37947                "NEXT_HOP_NOT_RUNNING",
37948                "NOT_CRITICAL_ERROR",
37949                "NO_RESULTS_ON_PAGE",
37950                "PARTIAL_SUCCESS",
37951                "REQUIRED_TOS_AGREEMENT",
37952                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
37953                "RESOURCE_NOT_DELETED",
37954                "SCHEMA_VALIDATION_IGNORED",
37955                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
37956                "UNDECLARED_PROPERTIES",
37957                "UNREACHABLE"
37958              ]
37959            },
37960            "message": {
37961              "description": "[Output Only] A human-readable description of the warning code.",
37962              "type": "string"
37963            },
37964            "data": {
37965              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
37966              "type": "array",
37967              "items": {
37968                "type": "object",
37969                "properties": {
37970                  "key": {
37971                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
37972                    "type": "string"
37973                  },
37974                  "value": {
37975                    "description": "[Output Only] A warning data value corresponding to the key.",
37976                    "type": "string"
37977                  }
37978                }
37979              }
37980            }
37981          }
37982        }
37983      }
37984    },
37985    "UsableSubnetworksAggregatedList": {
37986      "id": "UsableSubnetworksAggregatedList",
37987      "type": "object",
37988      "properties": {
37989        "kind": {
37990          "description": "[Output Only] Type of resource. Always compute#usableSubnetworksAggregatedList for aggregated lists of usable subnetworks.",
37991          "default": "compute#usableSubnetworksAggregatedList",
37992          "type": "string"
37993        },
37994        "id": {
37995          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
37996          "type": "string"
37997        },
37998        "items": {
37999          "description": "[Output] A list of usable subnetwork URLs.",
38000          "type": "array",
38001          "items": {
38002            "$ref": "UsableSubnetwork"
38003          }
38004        },
38005        "nextPageToken": {
38006          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results. In special cases listUsable may return 0 subnetworks and nextPageToken which still should be used to get the next page of results.",
38007          "type": "string"
38008        },
38009        "selfLink": {
38010          "description": "[Output Only] Server-defined URL for this resource.",
38011          "type": "string"
38012        },
38013        "warning": {
38014          "description": "[Output Only] Informational warning message.",
38015          "type": "object",
38016          "properties": {
38017            "code": {
38018              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
38019              "type": "string",
38020              "enumDescriptions": [
38021                "Warning about failed cleanup of transient changes made by a failed operation.",
38022                "A link to a deprecated resource was created.",
38023                "When deploying and at least one of the resources has a type marked as deprecated",
38024                "The user created a boot disk that is larger than image size.",
38025                "When deploying and at least one of the resources has a type marked as experimental",
38026                "Warning that is present in an external api call",
38027                "Warning that value of a field has been overridden. Deprecated unused field.",
38028                "The operation involved use of an injected kernel, which is deprecated.",
38029                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
38030                "When deploying a deployment with a exceedingly large number of resources",
38031                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
38032                "A resource depends on a missing type",
38033                "The route's nextHopIp address is not assigned to an instance on the network.",
38034                "The route's next hop instance cannot ip forward.",
38035                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
38036                "The route's nextHopInstance URL refers to an instance that does not exist.",
38037                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
38038                "The route's next hop instance does not have a status of RUNNING.",
38039                "Error which is not critical. We decided to continue the process despite the mentioned error.",
38040                "No results are present on a particular list page.",
38041                "Success is reported, but some results may be missing due to errors",
38042                "The user attempted to use a resource that requires a TOS they have not accepted.",
38043                "Warning that a resource is in use.",
38044                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
38045                "When a resource schema validation is ignored.",
38046                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
38047                "When undeclared properties in the schema are present",
38048                "A given scope cannot be reached."
38049              ],
38050              "enumDeprecated": [
38051                false,
38052                false,
38053                false,
38054                false,
38055                false,
38056                false,
38057                true,
38058                false,
38059                false,
38060                false,
38061                false,
38062                false,
38063                false,
38064                false,
38065                false,
38066                false,
38067                false,
38068                false,
38069                false,
38070                false,
38071                false,
38072                false,
38073                false,
38074                false,
38075                false,
38076                false,
38077                false,
38078                false
38079              ],
38080              "enum": [
38081                "CLEANUP_FAILED",
38082                "DEPRECATED_RESOURCE_USED",
38083                "DEPRECATED_TYPE_USED",
38084                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
38085                "EXPERIMENTAL_TYPE_USED",
38086                "EXTERNAL_API_WARNING",
38087                "FIELD_VALUE_OVERRIDEN",
38088                "INJECTED_KERNELS_DEPRECATED",
38089                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
38090                "LARGE_DEPLOYMENT_WARNING",
38091                "LIST_OVERHEAD_QUOTA_EXCEED",
38092                "MISSING_TYPE_DEPENDENCY",
38093                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
38094                "NEXT_HOP_CANNOT_IP_FORWARD",
38095                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
38096                "NEXT_HOP_INSTANCE_NOT_FOUND",
38097                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
38098                "NEXT_HOP_NOT_RUNNING",
38099                "NOT_CRITICAL_ERROR",
38100                "NO_RESULTS_ON_PAGE",
38101                "PARTIAL_SUCCESS",
38102                "REQUIRED_TOS_AGREEMENT",
38103                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
38104                "RESOURCE_NOT_DELETED",
38105                "SCHEMA_VALIDATION_IGNORED",
38106                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
38107                "UNDECLARED_PROPERTIES",
38108                "UNREACHABLE"
38109              ]
38110            },
38111            "message": {
38112              "description": "[Output Only] A human-readable description of the warning code.",
38113              "type": "string"
38114            },
38115            "data": {
38116              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
38117              "type": "array",
38118              "items": {
38119                "type": "object",
38120                "properties": {
38121                  "key": {
38122                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
38123                    "type": "string"
38124                  },
38125                  "value": {
38126                    "description": "[Output Only] A warning data value corresponding to the key.",
38127                    "type": "string"
38128                  }
38129                }
38130              }
38131            }
38132          }
38133        }
38134      }
38135    },
38136    "UsableSubnetwork": {
38137      "id": "UsableSubnetwork",
38138      "description": "Subnetwork which the current user has compute.subnetworks.use permission on.",
38139      "type": "object",
38140      "properties": {
38141        "subnetwork": {
38142          "description": "Subnetwork URL.",
38143          "type": "string"
38144        },
38145        "network": {
38146          "description": "Network URL.",
38147          "type": "string"
38148        },
38149        "ipCidrRange": {
38150          "description": "The range of internal addresses that are owned by this subnetwork.",
38151          "type": "string"
38152        },
38153        "secondaryIpRanges": {
38154          "description": "Secondary IP ranges.",
38155          "type": "array",
38156          "items": {
38157            "$ref": "UsableSubnetworkSecondaryRange"
38158          }
38159        },
38160        "stackType": {
38161          "description": "The stack type for the subnet. If set to IPV4_ONLY, new VMs in the subnet are assigned IPv4 addresses only. If set to IPV4_IPV6, new VMs in the subnet can be assigned both IPv4 and IPv6 addresses. If not specified, IPV4_ONLY is used. This field can be both set at resource creation time and updated using patch.",
38162          "type": "string",
38163          "enumDescriptions": [
38164            "New VMs in this subnet can have both IPv4 and IPv6 addresses.",
38165            "New VMs in this subnet will only be assigned IPv4 addresses."
38166          ],
38167          "enum": [
38168            "IPV4_IPV6",
38169            "IPV4_ONLY"
38170          ]
38171        },
38172        "ipv6AccessType": {
38173          "description": "The access type of IPv6 address this subnet holds. It's immutable and can only be specified during creation or the first time the subnet is updated into IPV4_IPV6 dual stack.",
38174          "type": "string",
38175          "enumDescriptions": [
38176            "VMs on this subnet will be assigned IPv6 addresses that are accessible via the Internet, as well as the VPC network.",
38177            "VMs on this subnet will be assigned IPv6 addresses that are only accessible over the VPC network."
38178          ],
38179          "enum": [
38180            "EXTERNAL",
38181            "INTERNAL"
38182          ]
38183        },
38184        "purpose": {
38185          "description": "The purpose of the resource. This field can be either PRIVATE, GLOBAL_MANAGED_PROXY, REGIONAL_MANAGED_PROXY, PRIVATE_SERVICE_CONNECT, or PRIVATE is the default purpose for user-created subnets or subnets that are automatically created in auto mode networks. Subnets with purpose set to GLOBAL_MANAGED_PROXY or REGIONAL_MANAGED_PROXY are user-created subnetworks that are reserved for Envoy-based load balancers. A subnet with purpose set to PRIVATE_SERVICE_CONNECT is used to publish services using Private Service Connect. If unspecified, the subnet purpose defaults to PRIVATE. The enableFlowLogs field isn't supported if the subnet purpose field is set to GLOBAL_MANAGED_PROXY or REGIONAL_MANAGED_PROXY.",
38186          "type": "string",
38187          "enumDescriptions": [
38188            "Subnet reserved for Global Envoy-based Load Balancing.",
38189            "Subnet reserved for Internal HTTP(S) Load Balancing. This is a legacy purpose, please use REGIONAL_MANAGED_PROXY instead.",
38190            "Regular user created or automatically created subnet.",
38191            "Subnetwork used as source range for Private NAT Gateways.",
38192            "Regular user created or automatically created subnet.",
38193            "Subnetworks created for Private Service Connect in the producer network.",
38194            "Subnetwork used for Regional Envoy-based Load Balancing."
38195          ],
38196          "enum": [
38197            "GLOBAL_MANAGED_PROXY",
38198            "INTERNAL_HTTPS_LOAD_BALANCER",
38199            "PRIVATE",
38200            "PRIVATE_NAT",
38201            "PRIVATE_RFC_1918",
38202            "PRIVATE_SERVICE_CONNECT",
38203            "REGIONAL_MANAGED_PROXY"
38204          ]
38205        },
38206        "role": {
38207          "description": "The role of subnetwork. Currently, this field is only used when purpose is set to GLOBAL_MANAGED_PROXY or REGIONAL_MANAGED_PROXY. The value can be set to ACTIVE or BACKUP. An ACTIVE subnetwork is one that is currently being used for Envoy-based load balancers in a region. A BACKUP subnetwork is one that is ready to be promoted to ACTIVE or is currently draining. This field can be updated with a patch request.",
38208          "type": "string",
38209          "enumDescriptions": [
38210            "The ACTIVE subnet that is currently used.",
38211            "The BACKUP subnet that could be promoted to ACTIVE."
38212          ],
38213          "enum": [
38214            "ACTIVE",
38215            "BACKUP"
38216          ]
38217        },
38218        "externalIpv6Prefix": {
38219          "description": "[Output Only] The external IPv6 address range that is assigned to this subnetwork.",
38220          "type": "string"
38221        },
38222        "internalIpv6Prefix": {
38223          "description": "[Output Only] The internal IPv6 address range that is assigned to this subnetwork.",
38224          "type": "string"
38225        }
38226      }
38227    },
38228    "UsableSubnetworkSecondaryRange": {
38229      "id": "UsableSubnetworkSecondaryRange",
38230      "description": "Secondary IP range of a usable subnetwork.",
38231      "type": "object",
38232      "properties": {
38233        "rangeName": {
38234          "description": "The name associated with this subnetwork secondary range, used when adding an alias IP range to a VM instance. The name must be 1-63 characters long, and comply with RFC1035. The name must be unique within the subnetwork.",
38235          "type": "string"
38236        },
38237        "ipCidrRange": {
38238          "description": "The range of IP addresses belonging to this subnetwork secondary range.",
38239          "type": "string"
38240        }
38241      }
38242    },
38243    "SubnetworksExpandIpCidrRangeRequest": {
38244      "id": "SubnetworksExpandIpCidrRangeRequest",
38245      "type": "object",
38246      "properties": {
38247        "ipCidrRange": {
38248          "description": "The IP (in CIDR format or netmask) of internal addresses that are legal on this Subnetwork. This range should be disjoint from other subnetworks within this network. This range can only be larger than (i.e. a superset of) the range previously defined before the update.",
38249          "type": "string"
38250        }
38251      }
38252    },
38253    "SubnetworksSetPrivateIpGoogleAccessRequest": {
38254      "id": "SubnetworksSetPrivateIpGoogleAccessRequest",
38255      "type": "object",
38256      "properties": {
38257        "privateIpGoogleAccess": {
38258          "type": "boolean"
38259        }
38260      }
38261    },
38262    "TargetGrpcProxyList": {
38263      "id": "TargetGrpcProxyList",
38264      "type": "object",
38265      "properties": {
38266        "kind": {
38267          "description": "[Output Only] Type of the resource. Always compute#targetGrpcProxy for target grpc proxies.",
38268          "default": "compute#targetGrpcProxyList",
38269          "type": "string"
38270        },
38271        "id": {
38272          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
38273          "type": "string"
38274        },
38275        "items": {
38276          "description": "A list of TargetGrpcProxy resources.",
38277          "type": "array",
38278          "items": {
38279            "$ref": "TargetGrpcProxy"
38280          }
38281        },
38282        "nextPageToken": {
38283          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
38284          "type": "string"
38285        },
38286        "selfLink": {
38287          "description": "[Output Only] Server-defined URL for this resource.",
38288          "type": "string"
38289        },
38290        "warning": {
38291          "description": "[Output Only] Informational warning message.",
38292          "type": "object",
38293          "properties": {
38294            "code": {
38295              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
38296              "type": "string",
38297              "enumDescriptions": [
38298                "Warning about failed cleanup of transient changes made by a failed operation.",
38299                "A link to a deprecated resource was created.",
38300                "When deploying and at least one of the resources has a type marked as deprecated",
38301                "The user created a boot disk that is larger than image size.",
38302                "When deploying and at least one of the resources has a type marked as experimental",
38303                "Warning that is present in an external api call",
38304                "Warning that value of a field has been overridden. Deprecated unused field.",
38305                "The operation involved use of an injected kernel, which is deprecated.",
38306                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
38307                "When deploying a deployment with a exceedingly large number of resources",
38308                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
38309                "A resource depends on a missing type",
38310                "The route's nextHopIp address is not assigned to an instance on the network.",
38311                "The route's next hop instance cannot ip forward.",
38312                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
38313                "The route's nextHopInstance URL refers to an instance that does not exist.",
38314                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
38315                "The route's next hop instance does not have a status of RUNNING.",
38316                "Error which is not critical. We decided to continue the process despite the mentioned error.",
38317                "No results are present on a particular list page.",
38318                "Success is reported, but some results may be missing due to errors",
38319                "The user attempted to use a resource that requires a TOS they have not accepted.",
38320                "Warning that a resource is in use.",
38321                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
38322                "When a resource schema validation is ignored.",
38323                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
38324                "When undeclared properties in the schema are present",
38325                "A given scope cannot be reached."
38326              ],
38327              "enumDeprecated": [
38328                false,
38329                false,
38330                false,
38331                false,
38332                false,
38333                false,
38334                true,
38335                false,
38336                false,
38337                false,
38338                false,
38339                false,
38340                false,
38341                false,
38342                false,
38343                false,
38344                false,
38345                false,
38346                false,
38347                false,
38348                false,
38349                false,
38350                false,
38351                false,
38352                false,
38353                false,
38354                false,
38355                false
38356              ],
38357              "enum": [
38358                "CLEANUP_FAILED",
38359                "DEPRECATED_RESOURCE_USED",
38360                "DEPRECATED_TYPE_USED",
38361                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
38362                "EXPERIMENTAL_TYPE_USED",
38363                "EXTERNAL_API_WARNING",
38364                "FIELD_VALUE_OVERRIDEN",
38365                "INJECTED_KERNELS_DEPRECATED",
38366                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
38367                "LARGE_DEPLOYMENT_WARNING",
38368                "LIST_OVERHEAD_QUOTA_EXCEED",
38369                "MISSING_TYPE_DEPENDENCY",
38370                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
38371                "NEXT_HOP_CANNOT_IP_FORWARD",
38372                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
38373                "NEXT_HOP_INSTANCE_NOT_FOUND",
38374                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
38375                "NEXT_HOP_NOT_RUNNING",
38376                "NOT_CRITICAL_ERROR",
38377                "NO_RESULTS_ON_PAGE",
38378                "PARTIAL_SUCCESS",
38379                "REQUIRED_TOS_AGREEMENT",
38380                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
38381                "RESOURCE_NOT_DELETED",
38382                "SCHEMA_VALIDATION_IGNORED",
38383                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
38384                "UNDECLARED_PROPERTIES",
38385                "UNREACHABLE"
38386              ]
38387            },
38388            "message": {
38389              "description": "[Output Only] A human-readable description of the warning code.",
38390              "type": "string"
38391            },
38392            "data": {
38393              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
38394              "type": "array",
38395              "items": {
38396                "type": "object",
38397                "properties": {
38398                  "key": {
38399                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
38400                    "type": "string"
38401                  },
38402                  "value": {
38403                    "description": "[Output Only] A warning data value corresponding to the key.",
38404                    "type": "string"
38405                  }
38406                }
38407              }
38408            }
38409          }
38410        }
38411      }
38412    },
38413    "TargetGrpcProxy": {
38414      "id": "TargetGrpcProxy",
38415      "description": "Represents a Target gRPC Proxy resource. A target gRPC proxy is a component of load balancers intended for load balancing gRPC traffic. Only global forwarding rules with load balancing scheme INTERNAL_SELF_MANAGED can reference a target gRPC proxy. The target gRPC Proxy references a URL map that specifies how traffic is routed to gRPC backend services.",
38416      "type": "object",
38417      "properties": {
38418        "kind": {
38419          "description": "[Output Only] Type of the resource. Always compute#targetGrpcProxy for target grpc proxies.",
38420          "default": "compute#targetGrpcProxy",
38421          "type": "string"
38422        },
38423        "id": {
38424          "description": "[Output Only] The unique identifier for the resource type. The server generates this identifier.",
38425          "type": "string",
38426          "format": "uint64"
38427        },
38428        "creationTimestamp": {
38429          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
38430          "type": "string"
38431        },
38432        "name": {
38433          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
38434          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
38435          "annotations": {
38436            "required": [
38437              "compute.targetGrpcProxies.insert"
38438            ]
38439          },
38440          "type": "string"
38441        },
38442        "description": {
38443          "description": "An optional description of this resource. Provide this property when you create the resource.",
38444          "type": "string"
38445        },
38446        "selfLink": {
38447          "description": "[Output Only] Server-defined URL for the resource.",
38448          "type": "string"
38449        },
38450        "selfLinkWithId": {
38451          "description": "[Output Only] Server-defined URL with id for the resource.",
38452          "type": "string"
38453        },
38454        "urlMap": {
38455          "description": "URL to the UrlMap resource that defines the mapping from URL to the BackendService. The protocol field in the BackendService must be set to GRPC.",
38456          "type": "string"
38457        },
38458        "validateForProxyless": {
38459          "description": "If true, indicates that the BackendServices referenced by the urlMap may be accessed by gRPC applications without using a sidecar proxy. This will enable configuration checks on urlMap and its referenced BackendServices to not allow unsupported features. A gRPC application must use \"xds:///\" scheme in the target URI of the service it is connecting to. If false, indicates that the BackendServices referenced by the urlMap will be accessed by gRPC applications via a sidecar proxy. In this case, a gRPC application must not use \"xds:///\" scheme in the target URI of the service it is connecting to",
38460          "type": "boolean"
38461        },
38462        "fingerprint": {
38463          "description": "Fingerprint of this resource. A hash of the contents stored in this object. This field is used in optimistic locking. This field will be ignored when inserting a TargetGrpcProxy. An up-to-date fingerprint must be provided in order to patch/update the TargetGrpcProxy; otherwise, the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve the TargetGrpcProxy.",
38464          "type": "string",
38465          "format": "byte"
38466        }
38467      }
38468    },
38469    "TargetHttpProxyList": {
38470      "id": "TargetHttpProxyList",
38471      "description": "A list of TargetHttpProxy resources.",
38472      "type": "object",
38473      "properties": {
38474        "kind": {
38475          "description": "Type of resource. Always compute#targetHttpProxyList for lists of target HTTP proxies.",
38476          "default": "compute#targetHttpProxyList",
38477          "type": "string"
38478        },
38479        "id": {
38480          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
38481          "type": "string"
38482        },
38483        "items": {
38484          "description": "A list of TargetHttpProxy resources.",
38485          "type": "array",
38486          "items": {
38487            "$ref": "TargetHttpProxy"
38488          }
38489        },
38490        "nextPageToken": {
38491          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
38492          "type": "string"
38493        },
38494        "selfLink": {
38495          "description": "[Output Only] Server-defined URL for this resource.",
38496          "type": "string"
38497        },
38498        "warning": {
38499          "description": "[Output Only] Informational warning message.",
38500          "type": "object",
38501          "properties": {
38502            "code": {
38503              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
38504              "type": "string",
38505              "enumDescriptions": [
38506                "Warning about failed cleanup of transient changes made by a failed operation.",
38507                "A link to a deprecated resource was created.",
38508                "When deploying and at least one of the resources has a type marked as deprecated",
38509                "The user created a boot disk that is larger than image size.",
38510                "When deploying and at least one of the resources has a type marked as experimental",
38511                "Warning that is present in an external api call",
38512                "Warning that value of a field has been overridden. Deprecated unused field.",
38513                "The operation involved use of an injected kernel, which is deprecated.",
38514                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
38515                "When deploying a deployment with a exceedingly large number of resources",
38516                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
38517                "A resource depends on a missing type",
38518                "The route's nextHopIp address is not assigned to an instance on the network.",
38519                "The route's next hop instance cannot ip forward.",
38520                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
38521                "The route's nextHopInstance URL refers to an instance that does not exist.",
38522                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
38523                "The route's next hop instance does not have a status of RUNNING.",
38524                "Error which is not critical. We decided to continue the process despite the mentioned error.",
38525                "No results are present on a particular list page.",
38526                "Success is reported, but some results may be missing due to errors",
38527                "The user attempted to use a resource that requires a TOS they have not accepted.",
38528                "Warning that a resource is in use.",
38529                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
38530                "When a resource schema validation is ignored.",
38531                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
38532                "When undeclared properties in the schema are present",
38533                "A given scope cannot be reached."
38534              ],
38535              "enumDeprecated": [
38536                false,
38537                false,
38538                false,
38539                false,
38540                false,
38541                false,
38542                true,
38543                false,
38544                false,
38545                false,
38546                false,
38547                false,
38548                false,
38549                false,
38550                false,
38551                false,
38552                false,
38553                false,
38554                false,
38555                false,
38556                false,
38557                false,
38558                false,
38559                false,
38560                false,
38561                false,
38562                false,
38563                false
38564              ],
38565              "enum": [
38566                "CLEANUP_FAILED",
38567                "DEPRECATED_RESOURCE_USED",
38568                "DEPRECATED_TYPE_USED",
38569                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
38570                "EXPERIMENTAL_TYPE_USED",
38571                "EXTERNAL_API_WARNING",
38572                "FIELD_VALUE_OVERRIDEN",
38573                "INJECTED_KERNELS_DEPRECATED",
38574                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
38575                "LARGE_DEPLOYMENT_WARNING",
38576                "LIST_OVERHEAD_QUOTA_EXCEED",
38577                "MISSING_TYPE_DEPENDENCY",
38578                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
38579                "NEXT_HOP_CANNOT_IP_FORWARD",
38580                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
38581                "NEXT_HOP_INSTANCE_NOT_FOUND",
38582                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
38583                "NEXT_HOP_NOT_RUNNING",
38584                "NOT_CRITICAL_ERROR",
38585                "NO_RESULTS_ON_PAGE",
38586                "PARTIAL_SUCCESS",
38587                "REQUIRED_TOS_AGREEMENT",
38588                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
38589                "RESOURCE_NOT_DELETED",
38590                "SCHEMA_VALIDATION_IGNORED",
38591                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
38592                "UNDECLARED_PROPERTIES",
38593                "UNREACHABLE"
38594              ]
38595            },
38596            "message": {
38597              "description": "[Output Only] A human-readable description of the warning code.",
38598              "type": "string"
38599            },
38600            "data": {
38601              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
38602              "type": "array",
38603              "items": {
38604                "type": "object",
38605                "properties": {
38606                  "key": {
38607                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
38608                    "type": "string"
38609                  },
38610                  "value": {
38611                    "description": "[Output Only] A warning data value corresponding to the key.",
38612                    "type": "string"
38613                  }
38614                }
38615              }
38616            }
38617          }
38618        }
38619      }
38620    },
38621    "TargetHttpProxy": {
38622      "id": "TargetHttpProxy",
38623      "description": "Represents a Target HTTP Proxy resource. Google Compute Engine has two Target HTTP Proxy resources: * [Global](/compute/docs/reference/rest/v1/targetHttpProxies) * [Regional](/compute/docs/reference/rest/v1/regionTargetHttpProxies) A target HTTP proxy is a component of Google Cloud HTTP load balancers. * targetHttpProxies are used by global external Application Load Balancers, classic Application Load Balancers, cross-region internal Application Load Balancers, and Traffic Director. * regionTargetHttpProxies are used by regional internal Application Load Balancers and regional external Application Load Balancers. Forwarding rules reference a target HTTP proxy, and the target proxy then references a URL map. For more information, read Using Target Proxies and Forwarding rule concepts.",
38624      "type": "object",
38625      "properties": {
38626        "kind": {
38627          "description": "[Output Only] Type of resource. Always compute#targetHttpProxy for target HTTP proxies.",
38628          "default": "compute#targetHttpProxy",
38629          "type": "string"
38630        },
38631        "id": {
38632          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
38633          "type": "string",
38634          "format": "uint64"
38635        },
38636        "creationTimestamp": {
38637          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
38638          "type": "string"
38639        },
38640        "name": {
38641          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
38642          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
38643          "type": "string"
38644        },
38645        "description": {
38646          "description": "An optional description of this resource. Provide this property when you create the resource.",
38647          "type": "string"
38648        },
38649        "selfLink": {
38650          "description": "[Output Only] Server-defined URL for the resource.",
38651          "type": "string"
38652        },
38653        "urlMap": {
38654          "description": "URL to the UrlMap resource that defines the mapping from URL to the BackendService.",
38655          "type": "string"
38656        },
38657        "region": {
38658          "description": "[Output Only] URL of the region where the regional Target HTTP Proxy resides. This field is not applicable to global Target HTTP Proxies.",
38659          "type": "string"
38660        },
38661        "proxyBind": {
38662          "description": "This field only applies when the forwarding rule that references this target proxy has a loadBalancingScheme set to INTERNAL_SELF_MANAGED. When this field is set to true, Envoy proxies set up inbound traffic interception and bind to the IP address and port specified in the forwarding rule. This is generally useful when using Traffic Director to configure Envoy as a gateway or middle proxy (in other words, not a sidecar proxy). The Envoy proxy listens for inbound requests and handles requests when it receives them. The default is false.",
38663          "type": "boolean"
38664        },
38665        "fingerprint": {
38666          "description": "Fingerprint of this resource. A hash of the contents stored in this object. This field is used in optimistic locking. This field will be ignored when inserting a TargetHttpProxy. An up-to-date fingerprint must be provided in order to patch/update the TargetHttpProxy; otherwise, the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve the TargetHttpProxy.",
38667          "type": "string",
38668          "format": "byte"
38669        },
38670        "httpKeepAliveTimeoutSec": {
38671          "description": "Specifies how long to keep a connection open, after completing a response, while there is no matching traffic (in seconds). If an HTTP keep-alive is not specified, a default value (610 seconds) will be used. For global external Application Load Balancers, the minimum allowed value is 5 seconds and the maximum allowed value is 1200 seconds. For classic Application Load Balancers, this option is not supported.",
38672          "type": "integer",
38673          "format": "int32"
38674        }
38675      }
38676    },
38677    "UrlMapReference": {
38678      "id": "UrlMapReference",
38679      "type": "object",
38680      "properties": {
38681        "urlMap": {
38682          "type": "string"
38683        }
38684      }
38685    },
38686    "TargetHttpProxyAggregatedList": {
38687      "id": "TargetHttpProxyAggregatedList",
38688      "type": "object",
38689      "properties": {
38690        "kind": {
38691          "description": "[Output Only] Type of resource. Always compute#targetHttpProxyAggregatedList for lists of Target HTTP Proxies.",
38692          "default": "compute#targetHttpProxyAggregatedList",
38693          "type": "string"
38694        },
38695        "id": {
38696          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
38697          "type": "string"
38698        },
38699        "items": {
38700          "description": "A list of TargetHttpProxiesScopedList resources.",
38701          "type": "object",
38702          "additionalProperties": {
38703            "description": "Name of the scope containing this set of TargetHttpProxies.",
38704            "$ref": "TargetHttpProxiesScopedList"
38705          }
38706        },
38707        "nextPageToken": {
38708          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
38709          "type": "string"
38710        },
38711        "selfLink": {
38712          "description": "[Output Only] Server-defined URL for this resource.",
38713          "type": "string"
38714        },
38715        "unreachables": {
38716          "description": "[Output Only] Unreachable resources.",
38717          "type": "array",
38718          "items": {
38719            "type": "string"
38720          }
38721        }
38722      }
38723    },
38724    "TargetHttpProxiesScopedList": {
38725      "id": "TargetHttpProxiesScopedList",
38726      "type": "object",
38727      "properties": {
38728        "targetHttpProxies": {
38729          "description": "A list of TargetHttpProxies contained in this scope.",
38730          "type": "array",
38731          "items": {
38732            "$ref": "TargetHttpProxy"
38733          }
38734        },
38735        "warning": {
38736          "description": "Informational warning which replaces the list of backend services when the list is empty.",
38737          "type": "object",
38738          "properties": {
38739            "code": {
38740              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
38741              "type": "string",
38742              "enumDescriptions": [
38743                "Warning about failed cleanup of transient changes made by a failed operation.",
38744                "A link to a deprecated resource was created.",
38745                "When deploying and at least one of the resources has a type marked as deprecated",
38746                "The user created a boot disk that is larger than image size.",
38747                "When deploying and at least one of the resources has a type marked as experimental",
38748                "Warning that is present in an external api call",
38749                "Warning that value of a field has been overridden. Deprecated unused field.",
38750                "The operation involved use of an injected kernel, which is deprecated.",
38751                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
38752                "When deploying a deployment with a exceedingly large number of resources",
38753                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
38754                "A resource depends on a missing type",
38755                "The route's nextHopIp address is not assigned to an instance on the network.",
38756                "The route's next hop instance cannot ip forward.",
38757                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
38758                "The route's nextHopInstance URL refers to an instance that does not exist.",
38759                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
38760                "The route's next hop instance does not have a status of RUNNING.",
38761                "Error which is not critical. We decided to continue the process despite the mentioned error.",
38762                "No results are present on a particular list page.",
38763                "Success is reported, but some results may be missing due to errors",
38764                "The user attempted to use a resource that requires a TOS they have not accepted.",
38765                "Warning that a resource is in use.",
38766                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
38767                "When a resource schema validation is ignored.",
38768                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
38769                "When undeclared properties in the schema are present",
38770                "A given scope cannot be reached."
38771              ],
38772              "enumDeprecated": [
38773                false,
38774                false,
38775                false,
38776                false,
38777                false,
38778                false,
38779                true,
38780                false,
38781                false,
38782                false,
38783                false,
38784                false,
38785                false,
38786                false,
38787                false,
38788                false,
38789                false,
38790                false,
38791                false,
38792                false,
38793                false,
38794                false,
38795                false,
38796                false,
38797                false,
38798                false,
38799                false,
38800                false
38801              ],
38802              "enum": [
38803                "CLEANUP_FAILED",
38804                "DEPRECATED_RESOURCE_USED",
38805                "DEPRECATED_TYPE_USED",
38806                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
38807                "EXPERIMENTAL_TYPE_USED",
38808                "EXTERNAL_API_WARNING",
38809                "FIELD_VALUE_OVERRIDEN",
38810                "INJECTED_KERNELS_DEPRECATED",
38811                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
38812                "LARGE_DEPLOYMENT_WARNING",
38813                "LIST_OVERHEAD_QUOTA_EXCEED",
38814                "MISSING_TYPE_DEPENDENCY",
38815                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
38816                "NEXT_HOP_CANNOT_IP_FORWARD",
38817                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
38818                "NEXT_HOP_INSTANCE_NOT_FOUND",
38819                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
38820                "NEXT_HOP_NOT_RUNNING",
38821                "NOT_CRITICAL_ERROR",
38822                "NO_RESULTS_ON_PAGE",
38823                "PARTIAL_SUCCESS",
38824                "REQUIRED_TOS_AGREEMENT",
38825                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
38826                "RESOURCE_NOT_DELETED",
38827                "SCHEMA_VALIDATION_IGNORED",
38828                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
38829                "UNDECLARED_PROPERTIES",
38830                "UNREACHABLE"
38831              ]
38832            },
38833            "message": {
38834              "description": "[Output Only] A human-readable description of the warning code.",
38835              "type": "string"
38836            },
38837            "data": {
38838              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
38839              "type": "array",
38840              "items": {
38841                "type": "object",
38842                "properties": {
38843                  "key": {
38844                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
38845                    "type": "string"
38846                  },
38847                  "value": {
38848                    "description": "[Output Only] A warning data value corresponding to the key.",
38849                    "type": "string"
38850                  }
38851                }
38852              }
38853            }
38854          }
38855        }
38856      }
38857    },
38858    "TargetHttpsProxyList": {
38859      "id": "TargetHttpsProxyList",
38860      "description": "Contains a list of TargetHttpsProxy resources.",
38861      "type": "object",
38862      "properties": {
38863        "kind": {
38864          "description": "Type of resource. Always compute#targetHttpsProxyList for lists of target HTTPS proxies.",
38865          "default": "compute#targetHttpsProxyList",
38866          "type": "string"
38867        },
38868        "id": {
38869          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
38870          "type": "string"
38871        },
38872        "items": {
38873          "description": "A list of TargetHttpsProxy resources.",
38874          "type": "array",
38875          "items": {
38876            "$ref": "TargetHttpsProxy"
38877          }
38878        },
38879        "nextPageToken": {
38880          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
38881          "type": "string"
38882        },
38883        "selfLink": {
38884          "description": "[Output Only] Server-defined URL for this resource.",
38885          "type": "string"
38886        },
38887        "warning": {
38888          "description": "[Output Only] Informational warning message.",
38889          "type": "object",
38890          "properties": {
38891            "code": {
38892              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
38893              "type": "string",
38894              "enumDescriptions": [
38895                "Warning about failed cleanup of transient changes made by a failed operation.",
38896                "A link to a deprecated resource was created.",
38897                "When deploying and at least one of the resources has a type marked as deprecated",
38898                "The user created a boot disk that is larger than image size.",
38899                "When deploying and at least one of the resources has a type marked as experimental",
38900                "Warning that is present in an external api call",
38901                "Warning that value of a field has been overridden. Deprecated unused field.",
38902                "The operation involved use of an injected kernel, which is deprecated.",
38903                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
38904                "When deploying a deployment with a exceedingly large number of resources",
38905                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
38906                "A resource depends on a missing type",
38907                "The route's nextHopIp address is not assigned to an instance on the network.",
38908                "The route's next hop instance cannot ip forward.",
38909                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
38910                "The route's nextHopInstance URL refers to an instance that does not exist.",
38911                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
38912                "The route's next hop instance does not have a status of RUNNING.",
38913                "Error which is not critical. We decided to continue the process despite the mentioned error.",
38914                "No results are present on a particular list page.",
38915                "Success is reported, but some results may be missing due to errors",
38916                "The user attempted to use a resource that requires a TOS they have not accepted.",
38917                "Warning that a resource is in use.",
38918                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
38919                "When a resource schema validation is ignored.",
38920                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
38921                "When undeclared properties in the schema are present",
38922                "A given scope cannot be reached."
38923              ],
38924              "enumDeprecated": [
38925                false,
38926                false,
38927                false,
38928                false,
38929                false,
38930                false,
38931                true,
38932                false,
38933                false,
38934                false,
38935                false,
38936                false,
38937                false,
38938                false,
38939                false,
38940                false,
38941                false,
38942                false,
38943                false,
38944                false,
38945                false,
38946                false,
38947                false,
38948                false,
38949                false,
38950                false,
38951                false,
38952                false
38953              ],
38954              "enum": [
38955                "CLEANUP_FAILED",
38956                "DEPRECATED_RESOURCE_USED",
38957                "DEPRECATED_TYPE_USED",
38958                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
38959                "EXPERIMENTAL_TYPE_USED",
38960                "EXTERNAL_API_WARNING",
38961                "FIELD_VALUE_OVERRIDEN",
38962                "INJECTED_KERNELS_DEPRECATED",
38963                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
38964                "LARGE_DEPLOYMENT_WARNING",
38965                "LIST_OVERHEAD_QUOTA_EXCEED",
38966                "MISSING_TYPE_DEPENDENCY",
38967                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
38968                "NEXT_HOP_CANNOT_IP_FORWARD",
38969                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
38970                "NEXT_HOP_INSTANCE_NOT_FOUND",
38971                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
38972                "NEXT_HOP_NOT_RUNNING",
38973                "NOT_CRITICAL_ERROR",
38974                "NO_RESULTS_ON_PAGE",
38975                "PARTIAL_SUCCESS",
38976                "REQUIRED_TOS_AGREEMENT",
38977                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
38978                "RESOURCE_NOT_DELETED",
38979                "SCHEMA_VALIDATION_IGNORED",
38980                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
38981                "UNDECLARED_PROPERTIES",
38982                "UNREACHABLE"
38983              ]
38984            },
38985            "message": {
38986              "description": "[Output Only] A human-readable description of the warning code.",
38987              "type": "string"
38988            },
38989            "data": {
38990              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
38991              "type": "array",
38992              "items": {
38993                "type": "object",
38994                "properties": {
38995                  "key": {
38996                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
38997                    "type": "string"
38998                  },
38999                  "value": {
39000                    "description": "[Output Only] A warning data value corresponding to the key.",
39001                    "type": "string"
39002                  }
39003                }
39004              }
39005            }
39006          }
39007        }
39008      }
39009    },
39010    "TargetHttpsProxy": {
39011      "id": "TargetHttpsProxy",
39012      "description": "Represents a Target HTTPS Proxy resource. Google Compute Engine has two Target HTTPS Proxy resources: * [Global](/compute/docs/reference/rest/v1/targetHttpsProxies) * [Regional](/compute/docs/reference/rest/v1/regionTargetHttpsProxies) A target HTTPS proxy is a component of GCP HTTPS load balancers. * targetHttpProxies are used by global external Application Load Balancers, classic Application Load Balancers, cross-region internal Application Load Balancers, and Traffic Director. * regionTargetHttpProxies are used by regional internal Application Load Balancers and regional external Application Load Balancers. Forwarding rules reference a target HTTPS proxy, and the target proxy then references a URL map. For more information, read Using Target Proxies and Forwarding rule concepts.",
39013      "type": "object",
39014      "properties": {
39015        "kind": {
39016          "description": "[Output Only] Type of resource. Always compute#targetHttpsProxy for target HTTPS proxies.",
39017          "default": "compute#targetHttpsProxy",
39018          "type": "string"
39019        },
39020        "id": {
39021          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
39022          "type": "string",
39023          "format": "uint64"
39024        },
39025        "creationTimestamp": {
39026          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
39027          "type": "string"
39028        },
39029        "name": {
39030          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
39031          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
39032          "type": "string"
39033        },
39034        "description": {
39035          "description": "An optional description of this resource. Provide this property when you create the resource.",
39036          "type": "string"
39037        },
39038        "selfLink": {
39039          "description": "[Output Only] Server-defined URL for the resource.",
39040          "type": "string"
39041        },
39042        "urlMap": {
39043          "description": "A fully-qualified or valid partial URL to the UrlMap resource that defines the mapping from URL to the BackendService. For example, the following are all valid URLs for specifying a URL map: - https://www.googleapis.compute/v1/projects/project/global/urlMaps/ url-map - projects/project/global/urlMaps/url-map - global/urlMaps/url-map ",
39044          "type": "string"
39045        },
39046        "sslCertificates": {
39047          "description": "URLs to SslCertificate resources that are used to authenticate connections between users and the load balancer. At least one SSL certificate must be specified. Currently, you may specify up to 15 SSL certificates. sslCertificates do not apply when the load balancing scheme is set to INTERNAL_SELF_MANAGED.",
39048          "type": "array",
39049          "items": {
39050            "type": "string"
39051          }
39052        },
39053        "certificateMap": {
39054          "description": "URL of a certificate map that identifies a certificate map associated with the given target proxy. This field can only be set for global target proxies. If set, sslCertificates will be ignored. Accepted format is //certificatemanager.googleapis.com/projects/{project }/locations/{location}/certificateMaps/{resourceName}.",
39055          "type": "string"
39056        },
39057        "quicOverride": {
39058          "description": "Specifies the QUIC override policy for this TargetHttpsProxy resource. This setting determines whether the load balancer attempts to negotiate QUIC with clients. You can specify NONE, ENABLE, or DISABLE. - When quic-override is set to NONE, Google manages whether QUIC is used. - When quic-override is set to ENABLE, the load balancer uses QUIC when possible. - When quic-override is set to DISABLE, the load balancer doesn't use QUIC. - If the quic-override flag is not specified, NONE is implied. ",
39059          "type": "string",
39060          "enumDescriptions": [
39061            "The load balancer will not attempt to negotiate QUIC with clients.",
39062            "The load balancer will attempt to negotiate QUIC with clients.",
39063            "No overrides to the default QUIC policy. This option is implicit if no QUIC override has been specified in the request."
39064          ],
39065          "enum": [
39066            "DISABLE",
39067            "ENABLE",
39068            "NONE"
39069          ]
39070        },
39071        "sslPolicy": {
39072          "description": "URL of SslPolicy resource that will be associated with the TargetHttpsProxy resource. If not set, the TargetHttpsProxy resource has no SSL policy configured.",
39073          "type": "string"
39074        },
39075        "region": {
39076          "description": "[Output Only] URL of the region where the regional TargetHttpsProxy resides. This field is not applicable to global TargetHttpsProxies.",
39077          "type": "string"
39078        },
39079        "proxyBind": {
39080          "description": "This field only applies when the forwarding rule that references this target proxy has a loadBalancingScheme set to INTERNAL_SELF_MANAGED. When this field is set to true, Envoy proxies set up inbound traffic interception and bind to the IP address and port specified in the forwarding rule. This is generally useful when using Traffic Director to configure Envoy as a gateway or middle proxy (in other words, not a sidecar proxy). The Envoy proxy listens for inbound requests and handles requests when it receives them. The default is false.",
39081          "type": "boolean"
39082        },
39083        "serverTlsPolicy": {
39084          "description": "Optional. A URL referring to a networksecurity.ServerTlsPolicy resource that describes how the proxy should authenticate inbound traffic. serverTlsPolicy only applies to a global TargetHttpsProxy attached to globalForwardingRules with the loadBalancingScheme set to INTERNAL_SELF_MANAGED or EXTERNAL or EXTERNAL_MANAGED. For details which ServerTlsPolicy resources are accepted with INTERNAL_SELF_MANAGED and which with EXTERNAL, EXTERNAL_MANAGED loadBalancingScheme consult ServerTlsPolicy documentation. If left blank, communications are not encrypted.",
39085          "type": "string"
39086        },
39087        "authorizationPolicy": {
39088          "description": "Optional. A URL referring to a networksecurity.AuthorizationPolicy resource that describes how the proxy should authorize inbound traffic. If left blank, access will not be restricted by an authorization policy. Refer to the AuthorizationPolicy resource for additional details. authorizationPolicy only applies to a global TargetHttpsProxy attached to globalForwardingRules with the loadBalancingScheme set to INTERNAL_SELF_MANAGED. Note: This field currently has no impact.",
39089          "type": "string"
39090        },
39091        "fingerprint": {
39092          "description": "Fingerprint of this resource. A hash of the contents stored in this object. This field is used in optimistic locking. This field will be ignored when inserting a TargetHttpsProxy. An up-to-date fingerprint must be provided in order to patch the TargetHttpsProxy; otherwise, the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve the TargetHttpsProxy.",
39093          "type": "string",
39094          "format": "byte"
39095        },
39096        "httpKeepAliveTimeoutSec": {
39097          "description": "Specifies how long to keep a connection open, after completing a response, while there is no matching traffic (in seconds). If an HTTP keep-alive is not specified, a default value (610 seconds) will be used. For global external Application Load Balancers, the minimum allowed value is 5 seconds and the maximum allowed value is 1200 seconds. For classic Application Load Balancers, this option is not supported.",
39098          "type": "integer",
39099          "format": "int32"
39100        }
39101      }
39102    },
39103    "TargetHttpsProxyAggregatedList": {
39104      "id": "TargetHttpsProxyAggregatedList",
39105      "type": "object",
39106      "properties": {
39107        "kind": {
39108          "description": "[Output Only] Type of resource. Always compute#targetHttpsProxyAggregatedList for lists of Target HTTP Proxies.",
39109          "default": "compute#targetHttpsProxyAggregatedList",
39110          "type": "string"
39111        },
39112        "id": {
39113          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
39114          "type": "string"
39115        },
39116        "items": {
39117          "description": "A list of TargetHttpsProxiesScopedList resources.",
39118          "type": "object",
39119          "additionalProperties": {
39120            "description": "Name of the scope containing this set of TargetHttpsProxies.",
39121            "$ref": "TargetHttpsProxiesScopedList"
39122          }
39123        },
39124        "nextPageToken": {
39125          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
39126          "type": "string"
39127        },
39128        "selfLink": {
39129          "description": "[Output Only] Server-defined URL for this resource.",
39130          "type": "string"
39131        },
39132        "warning": {
39133          "description": "[Output Only] Informational warning message.",
39134          "type": "object",
39135          "properties": {
39136            "code": {
39137              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
39138              "type": "string",
39139              "enumDescriptions": [
39140                "Warning about failed cleanup of transient changes made by a failed operation.",
39141                "A link to a deprecated resource was created.",
39142                "When deploying and at least one of the resources has a type marked as deprecated",
39143                "The user created a boot disk that is larger than image size.",
39144                "When deploying and at least one of the resources has a type marked as experimental",
39145                "Warning that is present in an external api call",
39146                "Warning that value of a field has been overridden. Deprecated unused field.",
39147                "The operation involved use of an injected kernel, which is deprecated.",
39148                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
39149                "When deploying a deployment with a exceedingly large number of resources",
39150                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
39151                "A resource depends on a missing type",
39152                "The route's nextHopIp address is not assigned to an instance on the network.",
39153                "The route's next hop instance cannot ip forward.",
39154                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
39155                "The route's nextHopInstance URL refers to an instance that does not exist.",
39156                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
39157                "The route's next hop instance does not have a status of RUNNING.",
39158                "Error which is not critical. We decided to continue the process despite the mentioned error.",
39159                "No results are present on a particular list page.",
39160                "Success is reported, but some results may be missing due to errors",
39161                "The user attempted to use a resource that requires a TOS they have not accepted.",
39162                "Warning that a resource is in use.",
39163                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
39164                "When a resource schema validation is ignored.",
39165                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
39166                "When undeclared properties in the schema are present",
39167                "A given scope cannot be reached."
39168              ],
39169              "enumDeprecated": [
39170                false,
39171                false,
39172                false,
39173                false,
39174                false,
39175                false,
39176                true,
39177                false,
39178                false,
39179                false,
39180                false,
39181                false,
39182                false,
39183                false,
39184                false,
39185                false,
39186                false,
39187                false,
39188                false,
39189                false,
39190                false,
39191                false,
39192                false,
39193                false,
39194                false,
39195                false,
39196                false,
39197                false
39198              ],
39199              "enum": [
39200                "CLEANUP_FAILED",
39201                "DEPRECATED_RESOURCE_USED",
39202                "DEPRECATED_TYPE_USED",
39203                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
39204                "EXPERIMENTAL_TYPE_USED",
39205                "EXTERNAL_API_WARNING",
39206                "FIELD_VALUE_OVERRIDEN",
39207                "INJECTED_KERNELS_DEPRECATED",
39208                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
39209                "LARGE_DEPLOYMENT_WARNING",
39210                "LIST_OVERHEAD_QUOTA_EXCEED",
39211                "MISSING_TYPE_DEPENDENCY",
39212                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
39213                "NEXT_HOP_CANNOT_IP_FORWARD",
39214                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
39215                "NEXT_HOP_INSTANCE_NOT_FOUND",
39216                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
39217                "NEXT_HOP_NOT_RUNNING",
39218                "NOT_CRITICAL_ERROR",
39219                "NO_RESULTS_ON_PAGE",
39220                "PARTIAL_SUCCESS",
39221                "REQUIRED_TOS_AGREEMENT",
39222                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
39223                "RESOURCE_NOT_DELETED",
39224                "SCHEMA_VALIDATION_IGNORED",
39225                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
39226                "UNDECLARED_PROPERTIES",
39227                "UNREACHABLE"
39228              ]
39229            },
39230            "message": {
39231              "description": "[Output Only] A human-readable description of the warning code.",
39232              "type": "string"
39233            },
39234            "data": {
39235              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
39236              "type": "array",
39237              "items": {
39238                "type": "object",
39239                "properties": {
39240                  "key": {
39241                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
39242                    "type": "string"
39243                  },
39244                  "value": {
39245                    "description": "[Output Only] A warning data value corresponding to the key.",
39246                    "type": "string"
39247                  }
39248                }
39249              }
39250            }
39251          }
39252        },
39253        "unreachables": {
39254          "description": "[Output Only] Unreachable resources.",
39255          "type": "array",
39256          "items": {
39257            "type": "string"
39258          }
39259        }
39260      }
39261    },
39262    "TargetHttpsProxiesScopedList": {
39263      "id": "TargetHttpsProxiesScopedList",
39264      "type": "object",
39265      "properties": {
39266        "targetHttpsProxies": {
39267          "description": "A list of TargetHttpsProxies contained in this scope.",
39268          "type": "array",
39269          "items": {
39270            "$ref": "TargetHttpsProxy"
39271          }
39272        },
39273        "warning": {
39274          "description": "Informational warning which replaces the list of backend services when the list is empty.",
39275          "type": "object",
39276          "properties": {
39277            "code": {
39278              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
39279              "type": "string",
39280              "enumDescriptions": [
39281                "Warning about failed cleanup of transient changes made by a failed operation.",
39282                "A link to a deprecated resource was created.",
39283                "When deploying and at least one of the resources has a type marked as deprecated",
39284                "The user created a boot disk that is larger than image size.",
39285                "When deploying and at least one of the resources has a type marked as experimental",
39286                "Warning that is present in an external api call",
39287                "Warning that value of a field has been overridden. Deprecated unused field.",
39288                "The operation involved use of an injected kernel, which is deprecated.",
39289                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
39290                "When deploying a deployment with a exceedingly large number of resources",
39291                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
39292                "A resource depends on a missing type",
39293                "The route's nextHopIp address is not assigned to an instance on the network.",
39294                "The route's next hop instance cannot ip forward.",
39295                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
39296                "The route's nextHopInstance URL refers to an instance that does not exist.",
39297                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
39298                "The route's next hop instance does not have a status of RUNNING.",
39299                "Error which is not critical. We decided to continue the process despite the mentioned error.",
39300                "No results are present on a particular list page.",
39301                "Success is reported, but some results may be missing due to errors",
39302                "The user attempted to use a resource that requires a TOS they have not accepted.",
39303                "Warning that a resource is in use.",
39304                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
39305                "When a resource schema validation is ignored.",
39306                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
39307                "When undeclared properties in the schema are present",
39308                "A given scope cannot be reached."
39309              ],
39310              "enumDeprecated": [
39311                false,
39312                false,
39313                false,
39314                false,
39315                false,
39316                false,
39317                true,
39318                false,
39319                false,
39320                false,
39321                false,
39322                false,
39323                false,
39324                false,
39325                false,
39326                false,
39327                false,
39328                false,
39329                false,
39330                false,
39331                false,
39332                false,
39333                false,
39334                false,
39335                false,
39336                false,
39337                false,
39338                false
39339              ],
39340              "enum": [
39341                "CLEANUP_FAILED",
39342                "DEPRECATED_RESOURCE_USED",
39343                "DEPRECATED_TYPE_USED",
39344                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
39345                "EXPERIMENTAL_TYPE_USED",
39346                "EXTERNAL_API_WARNING",
39347                "FIELD_VALUE_OVERRIDEN",
39348                "INJECTED_KERNELS_DEPRECATED",
39349                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
39350                "LARGE_DEPLOYMENT_WARNING",
39351                "LIST_OVERHEAD_QUOTA_EXCEED",
39352                "MISSING_TYPE_DEPENDENCY",
39353                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
39354                "NEXT_HOP_CANNOT_IP_FORWARD",
39355                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
39356                "NEXT_HOP_INSTANCE_NOT_FOUND",
39357                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
39358                "NEXT_HOP_NOT_RUNNING",
39359                "NOT_CRITICAL_ERROR",
39360                "NO_RESULTS_ON_PAGE",
39361                "PARTIAL_SUCCESS",
39362                "REQUIRED_TOS_AGREEMENT",
39363                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
39364                "RESOURCE_NOT_DELETED",
39365                "SCHEMA_VALIDATION_IGNORED",
39366                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
39367                "UNDECLARED_PROPERTIES",
39368                "UNREACHABLE"
39369              ]
39370            },
39371            "message": {
39372              "description": "[Output Only] A human-readable description of the warning code.",
39373              "type": "string"
39374            },
39375            "data": {
39376              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
39377              "type": "array",
39378              "items": {
39379                "type": "object",
39380                "properties": {
39381                  "key": {
39382                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
39383                    "type": "string"
39384                  },
39385                  "value": {
39386                    "description": "[Output Only] A warning data value corresponding to the key.",
39387                    "type": "string"
39388                  }
39389                }
39390              }
39391            }
39392          }
39393        }
39394      }
39395    },
39396    "TargetHttpsProxiesSetSslCertificatesRequest": {
39397      "id": "TargetHttpsProxiesSetSslCertificatesRequest",
39398      "type": "object",
39399      "properties": {
39400        "sslCertificates": {
39401          "description": "New set of SslCertificate resources to associate with this TargetHttpsProxy resource. At least one SSL certificate must be specified. Currently, you may specify up to 15 SSL certificates.",
39402          "type": "array",
39403          "items": {
39404            "type": "string"
39405          }
39406        }
39407      }
39408    },
39409    "TargetHttpsProxiesSetCertificateMapRequest": {
39410      "id": "TargetHttpsProxiesSetCertificateMapRequest",
39411      "type": "object",
39412      "properties": {
39413        "certificateMap": {
39414          "description": "URL of the Certificate Map to associate with this TargetHttpsProxy. Accepted format is //certificatemanager.googleapis.com/projects/{project }/locations/{location}/certificateMaps/{resourceName}.",
39415          "type": "string"
39416        }
39417      }
39418    },
39419    "SslPolicyReference": {
39420      "id": "SslPolicyReference",
39421      "type": "object",
39422      "properties": {
39423        "sslPolicy": {
39424          "description": "URL of the SSL policy resource. Set this to empty string to clear any existing SSL policy associated with the target proxy resource.",
39425          "type": "string"
39426        }
39427      }
39428    },
39429    "TargetHttpsProxiesSetQuicOverrideRequest": {
39430      "id": "TargetHttpsProxiesSetQuicOverrideRequest",
39431      "type": "object",
39432      "properties": {
39433        "quicOverride": {
39434          "description": "QUIC policy for the TargetHttpsProxy resource.",
39435          "type": "string",
39436          "enumDescriptions": [
39437            "The load balancer will not attempt to negotiate QUIC with clients.",
39438            "The load balancer will attempt to negotiate QUIC with clients.",
39439            "No overrides to the default QUIC policy. This option is implicit if no QUIC override has been specified in the request."
39440          ],
39441          "enum": [
39442            "DISABLE",
39443            "ENABLE",
39444            "NONE"
39445          ]
39446        }
39447      }
39448    },
39449    "RegionTargetHttpsProxiesSetSslCertificatesRequest": {
39450      "id": "RegionTargetHttpsProxiesSetSslCertificatesRequest",
39451      "type": "object",
39452      "properties": {
39453        "sslCertificates": {
39454          "description": "New set of SslCertificate resources to associate with this TargetHttpsProxy resource.",
39455          "type": "array",
39456          "items": {
39457            "type": "string"
39458          }
39459        }
39460      }
39461    },
39462    "TargetInstanceList": {
39463      "id": "TargetInstanceList",
39464      "description": "Contains a list of TargetInstance resources.",
39465      "type": "object",
39466      "properties": {
39467        "kind": {
39468          "description": "Type of resource.",
39469          "default": "compute#targetInstanceList",
39470          "type": "string"
39471        },
39472        "id": {
39473          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
39474          "type": "string"
39475        },
39476        "items": {
39477          "description": "A list of TargetInstance resources.",
39478          "type": "array",
39479          "items": {
39480            "$ref": "TargetInstance"
39481          }
39482        },
39483        "nextPageToken": {
39484          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
39485          "type": "string"
39486        },
39487        "selfLink": {
39488          "description": "[Output Only] Server-defined URL for this resource.",
39489          "type": "string"
39490        },
39491        "warning": {
39492          "description": "[Output Only] Informational warning message.",
39493          "type": "object",
39494          "properties": {
39495            "code": {
39496              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
39497              "type": "string",
39498              "enumDescriptions": [
39499                "Warning about failed cleanup of transient changes made by a failed operation.",
39500                "A link to a deprecated resource was created.",
39501                "When deploying and at least one of the resources has a type marked as deprecated",
39502                "The user created a boot disk that is larger than image size.",
39503                "When deploying and at least one of the resources has a type marked as experimental",
39504                "Warning that is present in an external api call",
39505                "Warning that value of a field has been overridden. Deprecated unused field.",
39506                "The operation involved use of an injected kernel, which is deprecated.",
39507                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
39508                "When deploying a deployment with a exceedingly large number of resources",
39509                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
39510                "A resource depends on a missing type",
39511                "The route's nextHopIp address is not assigned to an instance on the network.",
39512                "The route's next hop instance cannot ip forward.",
39513                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
39514                "The route's nextHopInstance URL refers to an instance that does not exist.",
39515                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
39516                "The route's next hop instance does not have a status of RUNNING.",
39517                "Error which is not critical. We decided to continue the process despite the mentioned error.",
39518                "No results are present on a particular list page.",
39519                "Success is reported, but some results may be missing due to errors",
39520                "The user attempted to use a resource that requires a TOS they have not accepted.",
39521                "Warning that a resource is in use.",
39522                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
39523                "When a resource schema validation is ignored.",
39524                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
39525                "When undeclared properties in the schema are present",
39526                "A given scope cannot be reached."
39527              ],
39528              "enumDeprecated": [
39529                false,
39530                false,
39531                false,
39532                false,
39533                false,
39534                false,
39535                true,
39536                false,
39537                false,
39538                false,
39539                false,
39540                false,
39541                false,
39542                false,
39543                false,
39544                false,
39545                false,
39546                false,
39547                false,
39548                false,
39549                false,
39550                false,
39551                false,
39552                false,
39553                false,
39554                false,
39555                false,
39556                false
39557              ],
39558              "enum": [
39559                "CLEANUP_FAILED",
39560                "DEPRECATED_RESOURCE_USED",
39561                "DEPRECATED_TYPE_USED",
39562                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
39563                "EXPERIMENTAL_TYPE_USED",
39564                "EXTERNAL_API_WARNING",
39565                "FIELD_VALUE_OVERRIDEN",
39566                "INJECTED_KERNELS_DEPRECATED",
39567                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
39568                "LARGE_DEPLOYMENT_WARNING",
39569                "LIST_OVERHEAD_QUOTA_EXCEED",
39570                "MISSING_TYPE_DEPENDENCY",
39571                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
39572                "NEXT_HOP_CANNOT_IP_FORWARD",
39573                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
39574                "NEXT_HOP_INSTANCE_NOT_FOUND",
39575                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
39576                "NEXT_HOP_NOT_RUNNING",
39577                "NOT_CRITICAL_ERROR",
39578                "NO_RESULTS_ON_PAGE",
39579                "PARTIAL_SUCCESS",
39580                "REQUIRED_TOS_AGREEMENT",
39581                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
39582                "RESOURCE_NOT_DELETED",
39583                "SCHEMA_VALIDATION_IGNORED",
39584                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
39585                "UNDECLARED_PROPERTIES",
39586                "UNREACHABLE"
39587              ]
39588            },
39589            "message": {
39590              "description": "[Output Only] A human-readable description of the warning code.",
39591              "type": "string"
39592            },
39593            "data": {
39594              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
39595              "type": "array",
39596              "items": {
39597                "type": "object",
39598                "properties": {
39599                  "key": {
39600                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
39601                    "type": "string"
39602                  },
39603                  "value": {
39604                    "description": "[Output Only] A warning data value corresponding to the key.",
39605                    "type": "string"
39606                  }
39607                }
39608              }
39609            }
39610          }
39611        }
39612      }
39613    },
39614    "TargetInstance": {
39615      "id": "TargetInstance",
39616      "description": "Represents a Target Instance resource. You can use a target instance to handle traffic for one or more forwarding rules, which is ideal for forwarding protocol traffic that is managed by a single source. For example, ESP, AH, TCP, or UDP. For more information, read Target instances.",
39617      "type": "object",
39618      "properties": {
39619        "kind": {
39620          "description": "[Output Only] The type of the resource. Always compute#targetInstance for target instances.",
39621          "default": "compute#targetInstance",
39622          "type": "string"
39623        },
39624        "id": {
39625          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
39626          "type": "string",
39627          "format": "uint64"
39628        },
39629        "creationTimestamp": {
39630          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
39631          "type": "string"
39632        },
39633        "name": {
39634          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
39635          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
39636          "type": "string"
39637        },
39638        "description": {
39639          "description": "An optional description of this resource. Provide this property when you create the resource.",
39640          "type": "string"
39641        },
39642        "zone": {
39643          "description": "[Output Only] URL of the zone where the target instance resides. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
39644          "type": "string"
39645        },
39646        "natPolicy": {
39647          "description": "Must have a value of NO_NAT. Protocol forwarding delivers packets while preserving the destination IP address of the forwarding rule referencing the target instance.",
39648          "type": "string",
39649          "enumDescriptions": [
39650            "No NAT performed."
39651          ],
39652          "enum": [
39653            "NO_NAT"
39654          ]
39655        },
39656        "instance": {
39657          "description": "A URL to the virtual machine instance that handles traffic for this target instance. When creating a target instance, you can provide the fully-qualified URL or a valid partial URL to the desired virtual machine. For example, the following are all valid URLs: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /instances/instance - projects/project/zones/zone/instances/instance - zones/zone/instances/instance ",
39658          "type": "string"
39659        },
39660        "selfLink": {
39661          "description": "[Output Only] Server-defined URL for the resource.",
39662          "type": "string"
39663        },
39664        "network": {
39665          "description": "The URL of the network this target instance uses to forward traffic. If not specified, the traffic will be forwarded to the network that the default network interface belongs to.",
39666          "type": "string"
39667        },
39668        "securityPolicy": {
39669          "description": "[Output Only] The resource URL for the security policy associated with this target instance.",
39670          "type": "string"
39671        }
39672      }
39673    },
39674    "TargetInstanceAggregatedList": {
39675      "id": "TargetInstanceAggregatedList",
39676      "type": "object",
39677      "properties": {
39678        "kind": {
39679          "description": "Type of resource.",
39680          "default": "compute#targetInstanceAggregatedList",
39681          "type": "string"
39682        },
39683        "id": {
39684          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
39685          "type": "string"
39686        },
39687        "items": {
39688          "description": "A list of TargetInstance resources.",
39689          "type": "object",
39690          "additionalProperties": {
39691            "description": "Name of the scope containing this set of target instances.",
39692            "$ref": "TargetInstancesScopedList"
39693          }
39694        },
39695        "nextPageToken": {
39696          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
39697          "type": "string"
39698        },
39699        "selfLink": {
39700          "description": "[Output Only] Server-defined URL for this resource.",
39701          "type": "string"
39702        },
39703        "warning": {
39704          "description": "[Output Only] Informational warning message.",
39705          "type": "object",
39706          "properties": {
39707            "code": {
39708              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
39709              "type": "string",
39710              "enumDescriptions": [
39711                "Warning about failed cleanup of transient changes made by a failed operation.",
39712                "A link to a deprecated resource was created.",
39713                "When deploying and at least one of the resources has a type marked as deprecated",
39714                "The user created a boot disk that is larger than image size.",
39715                "When deploying and at least one of the resources has a type marked as experimental",
39716                "Warning that is present in an external api call",
39717                "Warning that value of a field has been overridden. Deprecated unused field.",
39718                "The operation involved use of an injected kernel, which is deprecated.",
39719                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
39720                "When deploying a deployment with a exceedingly large number of resources",
39721                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
39722                "A resource depends on a missing type",
39723                "The route's nextHopIp address is not assigned to an instance on the network.",
39724                "The route's next hop instance cannot ip forward.",
39725                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
39726                "The route's nextHopInstance URL refers to an instance that does not exist.",
39727                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
39728                "The route's next hop instance does not have a status of RUNNING.",
39729                "Error which is not critical. We decided to continue the process despite the mentioned error.",
39730                "No results are present on a particular list page.",
39731                "Success is reported, but some results may be missing due to errors",
39732                "The user attempted to use a resource that requires a TOS they have not accepted.",
39733                "Warning that a resource is in use.",
39734                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
39735                "When a resource schema validation is ignored.",
39736                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
39737                "When undeclared properties in the schema are present",
39738                "A given scope cannot be reached."
39739              ],
39740              "enumDeprecated": [
39741                false,
39742                false,
39743                false,
39744                false,
39745                false,
39746                false,
39747                true,
39748                false,
39749                false,
39750                false,
39751                false,
39752                false,
39753                false,
39754                false,
39755                false,
39756                false,
39757                false,
39758                false,
39759                false,
39760                false,
39761                false,
39762                false,
39763                false,
39764                false,
39765                false,
39766                false,
39767                false,
39768                false
39769              ],
39770              "enum": [
39771                "CLEANUP_FAILED",
39772                "DEPRECATED_RESOURCE_USED",
39773                "DEPRECATED_TYPE_USED",
39774                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
39775                "EXPERIMENTAL_TYPE_USED",
39776                "EXTERNAL_API_WARNING",
39777                "FIELD_VALUE_OVERRIDEN",
39778                "INJECTED_KERNELS_DEPRECATED",
39779                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
39780                "LARGE_DEPLOYMENT_WARNING",
39781                "LIST_OVERHEAD_QUOTA_EXCEED",
39782                "MISSING_TYPE_DEPENDENCY",
39783                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
39784                "NEXT_HOP_CANNOT_IP_FORWARD",
39785                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
39786                "NEXT_HOP_INSTANCE_NOT_FOUND",
39787                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
39788                "NEXT_HOP_NOT_RUNNING",
39789                "NOT_CRITICAL_ERROR",
39790                "NO_RESULTS_ON_PAGE",
39791                "PARTIAL_SUCCESS",
39792                "REQUIRED_TOS_AGREEMENT",
39793                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
39794                "RESOURCE_NOT_DELETED",
39795                "SCHEMA_VALIDATION_IGNORED",
39796                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
39797                "UNDECLARED_PROPERTIES",
39798                "UNREACHABLE"
39799              ]
39800            },
39801            "message": {
39802              "description": "[Output Only] A human-readable description of the warning code.",
39803              "type": "string"
39804            },
39805            "data": {
39806              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
39807              "type": "array",
39808              "items": {
39809                "type": "object",
39810                "properties": {
39811                  "key": {
39812                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
39813                    "type": "string"
39814                  },
39815                  "value": {
39816                    "description": "[Output Only] A warning data value corresponding to the key.",
39817                    "type": "string"
39818                  }
39819                }
39820              }
39821            }
39822          }
39823        },
39824        "unreachables": {
39825          "description": "[Output Only] Unreachable resources.",
39826          "type": "array",
39827          "items": {
39828            "type": "string"
39829          }
39830        }
39831      }
39832    },
39833    "TargetInstancesScopedList": {
39834      "id": "TargetInstancesScopedList",
39835      "type": "object",
39836      "properties": {
39837        "targetInstances": {
39838          "description": "A list of target instances contained in this scope.",
39839          "type": "array",
39840          "items": {
39841            "$ref": "TargetInstance"
39842          }
39843        },
39844        "warning": {
39845          "description": "Informational warning which replaces the list of addresses when the list is empty.",
39846          "type": "object",
39847          "properties": {
39848            "code": {
39849              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
39850              "type": "string",
39851              "enumDescriptions": [
39852                "Warning about failed cleanup of transient changes made by a failed operation.",
39853                "A link to a deprecated resource was created.",
39854                "When deploying and at least one of the resources has a type marked as deprecated",
39855                "The user created a boot disk that is larger than image size.",
39856                "When deploying and at least one of the resources has a type marked as experimental",
39857                "Warning that is present in an external api call",
39858                "Warning that value of a field has been overridden. Deprecated unused field.",
39859                "The operation involved use of an injected kernel, which is deprecated.",
39860                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
39861                "When deploying a deployment with a exceedingly large number of resources",
39862                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
39863                "A resource depends on a missing type",
39864                "The route's nextHopIp address is not assigned to an instance on the network.",
39865                "The route's next hop instance cannot ip forward.",
39866                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
39867                "The route's nextHopInstance URL refers to an instance that does not exist.",
39868                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
39869                "The route's next hop instance does not have a status of RUNNING.",
39870                "Error which is not critical. We decided to continue the process despite the mentioned error.",
39871                "No results are present on a particular list page.",
39872                "Success is reported, but some results may be missing due to errors",
39873                "The user attempted to use a resource that requires a TOS they have not accepted.",
39874                "Warning that a resource is in use.",
39875                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
39876                "When a resource schema validation is ignored.",
39877                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
39878                "When undeclared properties in the schema are present",
39879                "A given scope cannot be reached."
39880              ],
39881              "enumDeprecated": [
39882                false,
39883                false,
39884                false,
39885                false,
39886                false,
39887                false,
39888                true,
39889                false,
39890                false,
39891                false,
39892                false,
39893                false,
39894                false,
39895                false,
39896                false,
39897                false,
39898                false,
39899                false,
39900                false,
39901                false,
39902                false,
39903                false,
39904                false,
39905                false,
39906                false,
39907                false,
39908                false,
39909                false
39910              ],
39911              "enum": [
39912                "CLEANUP_FAILED",
39913                "DEPRECATED_RESOURCE_USED",
39914                "DEPRECATED_TYPE_USED",
39915                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
39916                "EXPERIMENTAL_TYPE_USED",
39917                "EXTERNAL_API_WARNING",
39918                "FIELD_VALUE_OVERRIDEN",
39919                "INJECTED_KERNELS_DEPRECATED",
39920                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
39921                "LARGE_DEPLOYMENT_WARNING",
39922                "LIST_OVERHEAD_QUOTA_EXCEED",
39923                "MISSING_TYPE_DEPENDENCY",
39924                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
39925                "NEXT_HOP_CANNOT_IP_FORWARD",
39926                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
39927                "NEXT_HOP_INSTANCE_NOT_FOUND",
39928                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
39929                "NEXT_HOP_NOT_RUNNING",
39930                "NOT_CRITICAL_ERROR",
39931                "NO_RESULTS_ON_PAGE",
39932                "PARTIAL_SUCCESS",
39933                "REQUIRED_TOS_AGREEMENT",
39934                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
39935                "RESOURCE_NOT_DELETED",
39936                "SCHEMA_VALIDATION_IGNORED",
39937                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
39938                "UNDECLARED_PROPERTIES",
39939                "UNREACHABLE"
39940              ]
39941            },
39942            "message": {
39943              "description": "[Output Only] A human-readable description of the warning code.",
39944              "type": "string"
39945            },
39946            "data": {
39947              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
39948              "type": "array",
39949              "items": {
39950                "type": "object",
39951                "properties": {
39952                  "key": {
39953                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
39954                    "type": "string"
39955                  },
39956                  "value": {
39957                    "description": "[Output Only] A warning data value corresponding to the key.",
39958                    "type": "string"
39959                  }
39960                }
39961              }
39962            }
39963          }
39964        }
39965      }
39966    },
39967    "TargetPoolList": {
39968      "id": "TargetPoolList",
39969      "description": "Contains a list of TargetPool resources.",
39970      "type": "object",
39971      "properties": {
39972        "kind": {
39973          "description": "[Output Only] Type of resource. Always compute#targetPoolList for lists of target pools.",
39974          "default": "compute#targetPoolList",
39975          "type": "string"
39976        },
39977        "id": {
39978          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
39979          "type": "string"
39980        },
39981        "items": {
39982          "description": "A list of TargetPool resources.",
39983          "type": "array",
39984          "items": {
39985            "$ref": "TargetPool"
39986          }
39987        },
39988        "nextPageToken": {
39989          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
39990          "type": "string"
39991        },
39992        "selfLink": {
39993          "description": "[Output Only] Server-defined URL for this resource.",
39994          "type": "string"
39995        },
39996        "warning": {
39997          "description": "[Output Only] Informational warning message.",
39998          "type": "object",
39999          "properties": {
40000            "code": {
40001              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
40002              "type": "string",
40003              "enumDescriptions": [
40004                "Warning about failed cleanup of transient changes made by a failed operation.",
40005                "A link to a deprecated resource was created.",
40006                "When deploying and at least one of the resources has a type marked as deprecated",
40007                "The user created a boot disk that is larger than image size.",
40008                "When deploying and at least one of the resources has a type marked as experimental",
40009                "Warning that is present in an external api call",
40010                "Warning that value of a field has been overridden. Deprecated unused field.",
40011                "The operation involved use of an injected kernel, which is deprecated.",
40012                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
40013                "When deploying a deployment with a exceedingly large number of resources",
40014                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
40015                "A resource depends on a missing type",
40016                "The route's nextHopIp address is not assigned to an instance on the network.",
40017                "The route's next hop instance cannot ip forward.",
40018                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
40019                "The route's nextHopInstance URL refers to an instance that does not exist.",
40020                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
40021                "The route's next hop instance does not have a status of RUNNING.",
40022                "Error which is not critical. We decided to continue the process despite the mentioned error.",
40023                "No results are present on a particular list page.",
40024                "Success is reported, but some results may be missing due to errors",
40025                "The user attempted to use a resource that requires a TOS they have not accepted.",
40026                "Warning that a resource is in use.",
40027                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
40028                "When a resource schema validation is ignored.",
40029                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
40030                "When undeclared properties in the schema are present",
40031                "A given scope cannot be reached."
40032              ],
40033              "enumDeprecated": [
40034                false,
40035                false,
40036                false,
40037                false,
40038                false,
40039                false,
40040                true,
40041                false,
40042                false,
40043                false,
40044                false,
40045                false,
40046                false,
40047                false,
40048                false,
40049                false,
40050                false,
40051                false,
40052                false,
40053                false,
40054                false,
40055                false,
40056                false,
40057                false,
40058                false,
40059                false,
40060                false,
40061                false
40062              ],
40063              "enum": [
40064                "CLEANUP_FAILED",
40065                "DEPRECATED_RESOURCE_USED",
40066                "DEPRECATED_TYPE_USED",
40067                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
40068                "EXPERIMENTAL_TYPE_USED",
40069                "EXTERNAL_API_WARNING",
40070                "FIELD_VALUE_OVERRIDEN",
40071                "INJECTED_KERNELS_DEPRECATED",
40072                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
40073                "LARGE_DEPLOYMENT_WARNING",
40074                "LIST_OVERHEAD_QUOTA_EXCEED",
40075                "MISSING_TYPE_DEPENDENCY",
40076                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
40077                "NEXT_HOP_CANNOT_IP_FORWARD",
40078                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
40079                "NEXT_HOP_INSTANCE_NOT_FOUND",
40080                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
40081                "NEXT_HOP_NOT_RUNNING",
40082                "NOT_CRITICAL_ERROR",
40083                "NO_RESULTS_ON_PAGE",
40084                "PARTIAL_SUCCESS",
40085                "REQUIRED_TOS_AGREEMENT",
40086                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
40087                "RESOURCE_NOT_DELETED",
40088                "SCHEMA_VALIDATION_IGNORED",
40089                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
40090                "UNDECLARED_PROPERTIES",
40091                "UNREACHABLE"
40092              ]
40093            },
40094            "message": {
40095              "description": "[Output Only] A human-readable description of the warning code.",
40096              "type": "string"
40097            },
40098            "data": {
40099              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
40100              "type": "array",
40101              "items": {
40102                "type": "object",
40103                "properties": {
40104                  "key": {
40105                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
40106                    "type": "string"
40107                  },
40108                  "value": {
40109                    "description": "[Output Only] A warning data value corresponding to the key.",
40110                    "type": "string"
40111                  }
40112                }
40113              }
40114            }
40115          }
40116        }
40117      }
40118    },
40119    "TargetPool": {
40120      "id": "TargetPool",
40121      "description": "Represents a Target Pool resource. Target pools are used with external passthrough Network Load Balancers. A target pool references member instances, an associated legacy HttpHealthCheck resource, and, optionally, a backup target pool. For more information, read Using target pools.",
40122      "type": "object",
40123      "properties": {
40124        "kind": {
40125          "description": "[Output Only] Type of the resource. Always compute#targetPool for target pools.",
40126          "default": "compute#targetPool",
40127          "type": "string"
40128        },
40129        "id": {
40130          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
40131          "type": "string",
40132          "format": "uint64"
40133        },
40134        "creationTimestamp": {
40135          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
40136          "type": "string"
40137        },
40138        "name": {
40139          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
40140          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
40141          "type": "string"
40142        },
40143        "description": {
40144          "description": "An optional description of this resource. Provide this property when you create the resource.",
40145          "type": "string"
40146        },
40147        "region": {
40148          "description": "[Output Only] URL of the region where the target pool resides.",
40149          "type": "string"
40150        },
40151        "healthChecks": {
40152          "description": "The URL of the HttpHealthCheck resource. A member instance in this pool is considered healthy if and only if the health checks pass. Only legacy HttpHealthChecks are supported. Only one health check may be specified.",
40153          "type": "array",
40154          "items": {
40155            "type": "string"
40156          }
40157        },
40158        "instances": {
40159          "description": "A list of resource URLs to the virtual machine instances serving this pool. They must live in zones contained in the same region as this pool.",
40160          "type": "array",
40161          "items": {
40162            "type": "string"
40163          }
40164        },
40165        "sessionAffinity": {
40166          "description": "Session affinity option, must be one of the following values: NONE: Connections from the same client IP may go to any instance in the pool. CLIENT_IP: Connections from the same client IP will go to the same instance in the pool while that instance remains healthy. CLIENT_IP_PROTO: Connections from the same client IP with the same IP protocol will go to the same instance in the pool while that instance remains healthy.",
40167          "type": "string",
40168          "enumDescriptions": [
40169            "2-tuple hash on packet's source and destination IP addresses. Connections from the same source IP address to the same destination IP address will be served by the same backend VM while that VM remains healthy.",
40170            "1-tuple hash only on packet's source IP address. Connections from the same source IP address will be served by the same backend VM while that VM remains healthy. This option can only be used for Internal TCP/UDP Load Balancing.",
40171            "5-tuple hash on packet's source and destination IP addresses, IP protocol, and source and destination ports. Connections for the same IP protocol from the same source IP address and port to the same destination IP address and port will be served by the same backend VM while that VM remains healthy. This option cannot be used for HTTP(S) load balancing.",
40172            "3-tuple hash on packet's source and destination IP addresses, and IP protocol. Connections for the same IP protocol from the same source IP address to the same destination IP address will be served by the same backend VM while that VM remains healthy. This option cannot be used for HTTP(S) load balancing.",
40173            "Hash based on a cookie generated by the L7 loadbalancer. Only valid for HTTP(S) load balancing.",
40174            "The hash is based on a user specified header field.",
40175            "The hash is based on a user provided cookie.",
40176            "No session affinity. Connections from the same client IP may go to any instance in the pool."
40177          ],
40178          "enum": [
40179            "CLIENT_IP",
40180            "CLIENT_IP_NO_DESTINATION",
40181            "CLIENT_IP_PORT_PROTO",
40182            "CLIENT_IP_PROTO",
40183            "GENERATED_COOKIE",
40184            "HEADER_FIELD",
40185            "HTTP_COOKIE",
40186            "NONE"
40187          ]
40188        },
40189        "failoverRatio": {
40190          "description": "This field is applicable only when the containing target pool is serving a forwarding rule as the primary pool (i.e., not as a backup pool to some other target pool). The value of the field must be in [0, 1]. If set, backupPool must also be set. They together define the fallback behavior of the primary target pool: if the ratio of the healthy instances in the primary pool is at or below this number, traffic arriving at the load-balanced IP will be directed to the backup pool. In case where failoverRatio is not set or all the instances in the backup pool are unhealthy, the traffic will be directed back to the primary pool in the \"force\" mode, where traffic will be spread to the healthy instances with the best effort, or to all instances when no instance is healthy.",
40191          "type": "number",
40192          "format": "float"
40193        },
40194        "backupPool": {
40195          "description": "The server-defined URL for the resource. This field is applicable only when the containing target pool is serving a forwarding rule as the primary pool, and its failoverRatio field is properly set to a value between [0, 1]. backupPool and failoverRatio together define the fallback behavior of the primary target pool: if the ratio of the healthy instances in the primary pool is at or below failoverRatio, traffic arriving at the load-balanced IP will be directed to the backup pool. In case where failoverRatio and backupPool are not set, or all the instances in the backup pool are unhealthy, the traffic will be directed back to the primary pool in the \"force\" mode, where traffic will be spread to the healthy instances with the best effort, or to all instances when no instance is healthy.",
40196          "type": "string"
40197        },
40198        "selfLink": {
40199          "description": "[Output Only] Server-defined URL for the resource.",
40200          "type": "string"
40201        },
40202        "securityPolicy": {
40203          "description": "[Output Only] The resource URL for the security policy associated with this target pool.",
40204          "type": "string"
40205        }
40206      }
40207    },
40208    "TargetPoolAggregatedList": {
40209      "id": "TargetPoolAggregatedList",
40210      "type": "object",
40211      "properties": {
40212        "kind": {
40213          "description": "[Output Only] Type of resource. Always compute#targetPoolAggregatedList for aggregated lists of target pools.",
40214          "default": "compute#targetPoolAggregatedList",
40215          "type": "string"
40216        },
40217        "id": {
40218          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
40219          "type": "string"
40220        },
40221        "items": {
40222          "description": "A list of TargetPool resources.",
40223          "type": "object",
40224          "additionalProperties": {
40225            "description": "Name of the scope containing this set of target pools.",
40226            "$ref": "TargetPoolsScopedList"
40227          }
40228        },
40229        "nextPageToken": {
40230          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
40231          "type": "string"
40232        },
40233        "selfLink": {
40234          "description": "[Output Only] Server-defined URL for this resource.",
40235          "type": "string"
40236        },
40237        "warning": {
40238          "description": "[Output Only] Informational warning message.",
40239          "type": "object",
40240          "properties": {
40241            "code": {
40242              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
40243              "type": "string",
40244              "enumDescriptions": [
40245                "Warning about failed cleanup of transient changes made by a failed operation.",
40246                "A link to a deprecated resource was created.",
40247                "When deploying and at least one of the resources has a type marked as deprecated",
40248                "The user created a boot disk that is larger than image size.",
40249                "When deploying and at least one of the resources has a type marked as experimental",
40250                "Warning that is present in an external api call",
40251                "Warning that value of a field has been overridden. Deprecated unused field.",
40252                "The operation involved use of an injected kernel, which is deprecated.",
40253                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
40254                "When deploying a deployment with a exceedingly large number of resources",
40255                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
40256                "A resource depends on a missing type",
40257                "The route's nextHopIp address is not assigned to an instance on the network.",
40258                "The route's next hop instance cannot ip forward.",
40259                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
40260                "The route's nextHopInstance URL refers to an instance that does not exist.",
40261                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
40262                "The route's next hop instance does not have a status of RUNNING.",
40263                "Error which is not critical. We decided to continue the process despite the mentioned error.",
40264                "No results are present on a particular list page.",
40265                "Success is reported, but some results may be missing due to errors",
40266                "The user attempted to use a resource that requires a TOS they have not accepted.",
40267                "Warning that a resource is in use.",
40268                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
40269                "When a resource schema validation is ignored.",
40270                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
40271                "When undeclared properties in the schema are present",
40272                "A given scope cannot be reached."
40273              ],
40274              "enumDeprecated": [
40275                false,
40276                false,
40277                false,
40278                false,
40279                false,
40280                false,
40281                true,
40282                false,
40283                false,
40284                false,
40285                false,
40286                false,
40287                false,
40288                false,
40289                false,
40290                false,
40291                false,
40292                false,
40293                false,
40294                false,
40295                false,
40296                false,
40297                false,
40298                false,
40299                false,
40300                false,
40301                false,
40302                false
40303              ],
40304              "enum": [
40305                "CLEANUP_FAILED",
40306                "DEPRECATED_RESOURCE_USED",
40307                "DEPRECATED_TYPE_USED",
40308                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
40309                "EXPERIMENTAL_TYPE_USED",
40310                "EXTERNAL_API_WARNING",
40311                "FIELD_VALUE_OVERRIDEN",
40312                "INJECTED_KERNELS_DEPRECATED",
40313                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
40314                "LARGE_DEPLOYMENT_WARNING",
40315                "LIST_OVERHEAD_QUOTA_EXCEED",
40316                "MISSING_TYPE_DEPENDENCY",
40317                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
40318                "NEXT_HOP_CANNOT_IP_FORWARD",
40319                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
40320                "NEXT_HOP_INSTANCE_NOT_FOUND",
40321                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
40322                "NEXT_HOP_NOT_RUNNING",
40323                "NOT_CRITICAL_ERROR",
40324                "NO_RESULTS_ON_PAGE",
40325                "PARTIAL_SUCCESS",
40326                "REQUIRED_TOS_AGREEMENT",
40327                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
40328                "RESOURCE_NOT_DELETED",
40329                "SCHEMA_VALIDATION_IGNORED",
40330                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
40331                "UNDECLARED_PROPERTIES",
40332                "UNREACHABLE"
40333              ]
40334            },
40335            "message": {
40336              "description": "[Output Only] A human-readable description of the warning code.",
40337              "type": "string"
40338            },
40339            "data": {
40340              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
40341              "type": "array",
40342              "items": {
40343                "type": "object",
40344                "properties": {
40345                  "key": {
40346                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
40347                    "type": "string"
40348                  },
40349                  "value": {
40350                    "description": "[Output Only] A warning data value corresponding to the key.",
40351                    "type": "string"
40352                  }
40353                }
40354              }
40355            }
40356          }
40357        },
40358        "unreachables": {
40359          "description": "[Output Only] Unreachable resources.",
40360          "type": "array",
40361          "items": {
40362            "type": "string"
40363          }
40364        }
40365      }
40366    },
40367    "TargetPoolsScopedList": {
40368      "id": "TargetPoolsScopedList",
40369      "type": "object",
40370      "properties": {
40371        "targetPools": {
40372          "description": "A list of target pools contained in this scope.",
40373          "type": "array",
40374          "items": {
40375            "$ref": "TargetPool"
40376          }
40377        },
40378        "warning": {
40379          "description": "Informational warning which replaces the list of addresses when the list is empty.",
40380          "type": "object",
40381          "properties": {
40382            "code": {
40383              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
40384              "type": "string",
40385              "enumDescriptions": [
40386                "Warning about failed cleanup of transient changes made by a failed operation.",
40387                "A link to a deprecated resource was created.",
40388                "When deploying and at least one of the resources has a type marked as deprecated",
40389                "The user created a boot disk that is larger than image size.",
40390                "When deploying and at least one of the resources has a type marked as experimental",
40391                "Warning that is present in an external api call",
40392                "Warning that value of a field has been overridden. Deprecated unused field.",
40393                "The operation involved use of an injected kernel, which is deprecated.",
40394                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
40395                "When deploying a deployment with a exceedingly large number of resources",
40396                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
40397                "A resource depends on a missing type",
40398                "The route's nextHopIp address is not assigned to an instance on the network.",
40399                "The route's next hop instance cannot ip forward.",
40400                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
40401                "The route's nextHopInstance URL refers to an instance that does not exist.",
40402                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
40403                "The route's next hop instance does not have a status of RUNNING.",
40404                "Error which is not critical. We decided to continue the process despite the mentioned error.",
40405                "No results are present on a particular list page.",
40406                "Success is reported, but some results may be missing due to errors",
40407                "The user attempted to use a resource that requires a TOS they have not accepted.",
40408                "Warning that a resource is in use.",
40409                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
40410                "When a resource schema validation is ignored.",
40411                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
40412                "When undeclared properties in the schema are present",
40413                "A given scope cannot be reached."
40414              ],
40415              "enumDeprecated": [
40416                false,
40417                false,
40418                false,
40419                false,
40420                false,
40421                false,
40422                true,
40423                false,
40424                false,
40425                false,
40426                false,
40427                false,
40428                false,
40429                false,
40430                false,
40431                false,
40432                false,
40433                false,
40434                false,
40435                false,
40436                false,
40437                false,
40438                false,
40439                false,
40440                false,
40441                false,
40442                false,
40443                false
40444              ],
40445              "enum": [
40446                "CLEANUP_FAILED",
40447                "DEPRECATED_RESOURCE_USED",
40448                "DEPRECATED_TYPE_USED",
40449                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
40450                "EXPERIMENTAL_TYPE_USED",
40451                "EXTERNAL_API_WARNING",
40452                "FIELD_VALUE_OVERRIDEN",
40453                "INJECTED_KERNELS_DEPRECATED",
40454                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
40455                "LARGE_DEPLOYMENT_WARNING",
40456                "LIST_OVERHEAD_QUOTA_EXCEED",
40457                "MISSING_TYPE_DEPENDENCY",
40458                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
40459                "NEXT_HOP_CANNOT_IP_FORWARD",
40460                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
40461                "NEXT_HOP_INSTANCE_NOT_FOUND",
40462                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
40463                "NEXT_HOP_NOT_RUNNING",
40464                "NOT_CRITICAL_ERROR",
40465                "NO_RESULTS_ON_PAGE",
40466                "PARTIAL_SUCCESS",
40467                "REQUIRED_TOS_AGREEMENT",
40468                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
40469                "RESOURCE_NOT_DELETED",
40470                "SCHEMA_VALIDATION_IGNORED",
40471                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
40472                "UNDECLARED_PROPERTIES",
40473                "UNREACHABLE"
40474              ]
40475            },
40476            "message": {
40477              "description": "[Output Only] A human-readable description of the warning code.",
40478              "type": "string"
40479            },
40480            "data": {
40481              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
40482              "type": "array",
40483              "items": {
40484                "type": "object",
40485                "properties": {
40486                  "key": {
40487                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
40488                    "type": "string"
40489                  },
40490                  "value": {
40491                    "description": "[Output Only] A warning data value corresponding to the key.",
40492                    "type": "string"
40493                  }
40494                }
40495              }
40496            }
40497          }
40498        }
40499      }
40500    },
40501    "TargetPoolInstanceHealth": {
40502      "id": "TargetPoolInstanceHealth",
40503      "type": "object",
40504      "properties": {
40505        "kind": {
40506          "description": "[Output Only] Type of resource. Always compute#targetPoolInstanceHealth when checking the health of an instance.",
40507          "default": "compute#targetPoolInstanceHealth",
40508          "type": "string"
40509        },
40510        "healthStatus": {
40511          "type": "array",
40512          "items": {
40513            "$ref": "HealthStatus"
40514          }
40515        }
40516      }
40517    },
40518    "TargetPoolsAddHealthCheckRequest": {
40519      "id": "TargetPoolsAddHealthCheckRequest",
40520      "type": "object",
40521      "properties": {
40522        "healthChecks": {
40523          "description": "The HttpHealthCheck to add to the target pool.",
40524          "type": "array",
40525          "items": {
40526            "$ref": "HealthCheckReference"
40527          }
40528        }
40529      }
40530    },
40531    "TargetPoolsRemoveHealthCheckRequest": {
40532      "id": "TargetPoolsRemoveHealthCheckRequest",
40533      "type": "object",
40534      "properties": {
40535        "healthChecks": {
40536          "description": "Health check URL to be removed. This can be a full or valid partial URL. For example, the following are valid URLs: - https://www.googleapis.com/compute/beta/projects/project /global/httpHealthChecks/health-check - projects/project/global/httpHealthChecks/health-check - global/httpHealthChecks/health-check ",
40537          "type": "array",
40538          "items": {
40539            "$ref": "HealthCheckReference"
40540          }
40541        }
40542      }
40543    },
40544    "TargetPoolsAddInstanceRequest": {
40545      "id": "TargetPoolsAddInstanceRequest",
40546      "type": "object",
40547      "properties": {
40548        "instances": {
40549          "description": "A full or partial URL to an instance to add to this target pool. This can be a full or partial URL. For example, the following are valid URLs: - https://www.googleapis.com/compute/v1/projects/project-id/zones/zone /instances/instance-name - projects/project-id/zones/zone/instances/instance-name - zones/zone/instances/instance-name ",
40550          "type": "array",
40551          "items": {
40552            "$ref": "InstanceReference"
40553          }
40554        }
40555      }
40556    },
40557    "TargetPoolsRemoveInstanceRequest": {
40558      "id": "TargetPoolsRemoveInstanceRequest",
40559      "type": "object",
40560      "properties": {
40561        "instances": {
40562          "description": "URLs of the instances to be removed from target pool.",
40563          "type": "array",
40564          "items": {
40565            "$ref": "InstanceReference"
40566          }
40567        }
40568      }
40569    },
40570    "TargetSslProxyList": {
40571      "id": "TargetSslProxyList",
40572      "description": "Contains a list of TargetSslProxy resources.",
40573      "type": "object",
40574      "properties": {
40575        "kind": {
40576          "description": "Type of resource.",
40577          "default": "compute#targetSslProxyList",
40578          "type": "string"
40579        },
40580        "id": {
40581          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
40582          "type": "string"
40583        },
40584        "items": {
40585          "description": "A list of TargetSslProxy resources.",
40586          "type": "array",
40587          "items": {
40588            "$ref": "TargetSslProxy"
40589          }
40590        },
40591        "nextPageToken": {
40592          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
40593          "type": "string"
40594        },
40595        "selfLink": {
40596          "description": "[Output Only] Server-defined URL for this resource.",
40597          "type": "string"
40598        },
40599        "warning": {
40600          "description": "[Output Only] Informational warning message.",
40601          "type": "object",
40602          "properties": {
40603            "code": {
40604              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
40605              "type": "string",
40606              "enumDescriptions": [
40607                "Warning about failed cleanup of transient changes made by a failed operation.",
40608                "A link to a deprecated resource was created.",
40609                "When deploying and at least one of the resources has a type marked as deprecated",
40610                "The user created a boot disk that is larger than image size.",
40611                "When deploying and at least one of the resources has a type marked as experimental",
40612                "Warning that is present in an external api call",
40613                "Warning that value of a field has been overridden. Deprecated unused field.",
40614                "The operation involved use of an injected kernel, which is deprecated.",
40615                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
40616                "When deploying a deployment with a exceedingly large number of resources",
40617                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
40618                "A resource depends on a missing type",
40619                "The route's nextHopIp address is not assigned to an instance on the network.",
40620                "The route's next hop instance cannot ip forward.",
40621                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
40622                "The route's nextHopInstance URL refers to an instance that does not exist.",
40623                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
40624                "The route's next hop instance does not have a status of RUNNING.",
40625                "Error which is not critical. We decided to continue the process despite the mentioned error.",
40626                "No results are present on a particular list page.",
40627                "Success is reported, but some results may be missing due to errors",
40628                "The user attempted to use a resource that requires a TOS they have not accepted.",
40629                "Warning that a resource is in use.",
40630                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
40631                "When a resource schema validation is ignored.",
40632                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
40633                "When undeclared properties in the schema are present",
40634                "A given scope cannot be reached."
40635              ],
40636              "enumDeprecated": [
40637                false,
40638                false,
40639                false,
40640                false,
40641                false,
40642                false,
40643                true,
40644                false,
40645                false,
40646                false,
40647                false,
40648                false,
40649                false,
40650                false,
40651                false,
40652                false,
40653                false,
40654                false,
40655                false,
40656                false,
40657                false,
40658                false,
40659                false,
40660                false,
40661                false,
40662                false,
40663                false,
40664                false
40665              ],
40666              "enum": [
40667                "CLEANUP_FAILED",
40668                "DEPRECATED_RESOURCE_USED",
40669                "DEPRECATED_TYPE_USED",
40670                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
40671                "EXPERIMENTAL_TYPE_USED",
40672                "EXTERNAL_API_WARNING",
40673                "FIELD_VALUE_OVERRIDEN",
40674                "INJECTED_KERNELS_DEPRECATED",
40675                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
40676                "LARGE_DEPLOYMENT_WARNING",
40677                "LIST_OVERHEAD_QUOTA_EXCEED",
40678                "MISSING_TYPE_DEPENDENCY",
40679                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
40680                "NEXT_HOP_CANNOT_IP_FORWARD",
40681                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
40682                "NEXT_HOP_INSTANCE_NOT_FOUND",
40683                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
40684                "NEXT_HOP_NOT_RUNNING",
40685                "NOT_CRITICAL_ERROR",
40686                "NO_RESULTS_ON_PAGE",
40687                "PARTIAL_SUCCESS",
40688                "REQUIRED_TOS_AGREEMENT",
40689                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
40690                "RESOURCE_NOT_DELETED",
40691                "SCHEMA_VALIDATION_IGNORED",
40692                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
40693                "UNDECLARED_PROPERTIES",
40694                "UNREACHABLE"
40695              ]
40696            },
40697            "message": {
40698              "description": "[Output Only] A human-readable description of the warning code.",
40699              "type": "string"
40700            },
40701            "data": {
40702              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
40703              "type": "array",
40704              "items": {
40705                "type": "object",
40706                "properties": {
40707                  "key": {
40708                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
40709                    "type": "string"
40710                  },
40711                  "value": {
40712                    "description": "[Output Only] A warning data value corresponding to the key.",
40713                    "type": "string"
40714                  }
40715                }
40716              }
40717            }
40718          }
40719        }
40720      }
40721    },
40722    "TargetSslProxy": {
40723      "id": "TargetSslProxy",
40724      "description": "Represents a Target SSL Proxy resource. A target SSL proxy is a component of a Proxy Network Load Balancer. The forwarding rule references the target SSL proxy, and the target proxy then references a backend service. For more information, read Proxy Network Load Balancer overview.",
40725      "type": "object",
40726      "properties": {
40727        "kind": {
40728          "description": "[Output Only] Type of the resource. Always compute#targetSslProxy for target SSL proxies.",
40729          "default": "compute#targetSslProxy",
40730          "type": "string"
40731        },
40732        "id": {
40733          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
40734          "type": "string",
40735          "format": "uint64"
40736        },
40737        "creationTimestamp": {
40738          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
40739          "type": "string"
40740        },
40741        "name": {
40742          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
40743          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
40744          "type": "string"
40745        },
40746        "description": {
40747          "description": "An optional description of this resource. Provide this property when you create the resource.",
40748          "type": "string"
40749        },
40750        "selfLink": {
40751          "description": "[Output Only] Server-defined URL for the resource.",
40752          "type": "string"
40753        },
40754        "service": {
40755          "description": "URL to the BackendService resource.",
40756          "type": "string"
40757        },
40758        "sslCertificates": {
40759          "description": "URLs to SslCertificate resources that are used to authenticate connections to Backends. At least one SSL certificate must be specified. Currently, you may specify up to 15 SSL certificates. sslCertificates do not apply when the load balancing scheme is set to INTERNAL_SELF_MANAGED.",
40760          "type": "array",
40761          "items": {
40762            "type": "string"
40763          }
40764        },
40765        "certificateMap": {
40766          "description": "URL of a certificate map that identifies a certificate map associated with the given target proxy. This field can only be set for global target proxies. If set, sslCertificates will be ignored. Accepted format is //certificatemanager.googleapis.com/projects/{project }/locations/{location}/certificateMaps/{resourceName}.",
40767          "type": "string"
40768        },
40769        "proxyHeader": {
40770          "description": "Specifies the type of proxy header to append before sending data to the backend, either NONE or PROXY_V1. The default is NONE.",
40771          "type": "string",
40772          "enumDescriptions": [
40773            "",
40774            ""
40775          ],
40776          "enum": [
40777            "NONE",
40778            "PROXY_V1"
40779          ]
40780        },
40781        "sslPolicy": {
40782          "description": "URL of SslPolicy resource that will be associated with the TargetSslProxy resource. If not set, the TargetSslProxy resource will not have any SSL policy configured.",
40783          "type": "string"
40784        }
40785      }
40786    },
40787    "TargetSslProxiesSetBackendServiceRequest": {
40788      "id": "TargetSslProxiesSetBackendServiceRequest",
40789      "type": "object",
40790      "properties": {
40791        "service": {
40792          "description": "The URL of the new BackendService resource for the targetSslProxy.",
40793          "type": "string"
40794        }
40795      }
40796    },
40797    "TargetSslProxiesSetSslCertificatesRequest": {
40798      "id": "TargetSslProxiesSetSslCertificatesRequest",
40799      "type": "object",
40800      "properties": {
40801        "sslCertificates": {
40802          "description": "New set of URLs to SslCertificate resources to associate with this TargetSslProxy. At least one SSL certificate must be specified. Currently, you may specify up to 15 SSL certificates.",
40803          "type": "array",
40804          "items": {
40805            "type": "string"
40806          }
40807        }
40808      }
40809    },
40810    "TargetSslProxiesSetCertificateMapRequest": {
40811      "id": "TargetSslProxiesSetCertificateMapRequest",
40812      "type": "object",
40813      "properties": {
40814        "certificateMap": {
40815          "description": "URL of the Certificate Map to associate with this TargetSslProxy. Accepted format is //certificatemanager.googleapis.com/projects/{project }/locations/{location}/certificateMaps/{resourceName}.",
40816          "type": "string"
40817        }
40818      }
40819    },
40820    "TargetSslProxiesSetProxyHeaderRequest": {
40821      "id": "TargetSslProxiesSetProxyHeaderRequest",
40822      "type": "object",
40823      "properties": {
40824        "proxyHeader": {
40825          "description": "The new type of proxy header to append before sending data to the backend. NONE or PROXY_V1 are allowed.",
40826          "type": "string",
40827          "enumDescriptions": [
40828            "",
40829            ""
40830          ],
40831          "enum": [
40832            "NONE",
40833            "PROXY_V1"
40834          ]
40835        }
40836      }
40837    },
40838    "TargetTcpProxyList": {
40839      "id": "TargetTcpProxyList",
40840      "description": "Contains a list of TargetTcpProxy resources.",
40841      "type": "object",
40842      "properties": {
40843        "kind": {
40844          "description": "Type of resource.",
40845          "default": "compute#targetTcpProxyList",
40846          "type": "string"
40847        },
40848        "id": {
40849          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
40850          "type": "string"
40851        },
40852        "items": {
40853          "description": "A list of TargetTcpProxy resources.",
40854          "type": "array",
40855          "items": {
40856            "$ref": "TargetTcpProxy"
40857          }
40858        },
40859        "nextPageToken": {
40860          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
40861          "type": "string"
40862        },
40863        "selfLink": {
40864          "description": "[Output Only] Server-defined URL for this resource.",
40865          "type": "string"
40866        },
40867        "warning": {
40868          "description": "[Output Only] Informational warning message.",
40869          "type": "object",
40870          "properties": {
40871            "code": {
40872              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
40873              "type": "string",
40874              "enumDescriptions": [
40875                "Warning about failed cleanup of transient changes made by a failed operation.",
40876                "A link to a deprecated resource was created.",
40877                "When deploying and at least one of the resources has a type marked as deprecated",
40878                "The user created a boot disk that is larger than image size.",
40879                "When deploying and at least one of the resources has a type marked as experimental",
40880                "Warning that is present in an external api call",
40881                "Warning that value of a field has been overridden. Deprecated unused field.",
40882                "The operation involved use of an injected kernel, which is deprecated.",
40883                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
40884                "When deploying a deployment with a exceedingly large number of resources",
40885                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
40886                "A resource depends on a missing type",
40887                "The route's nextHopIp address is not assigned to an instance on the network.",
40888                "The route's next hop instance cannot ip forward.",
40889                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
40890                "The route's nextHopInstance URL refers to an instance that does not exist.",
40891                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
40892                "The route's next hop instance does not have a status of RUNNING.",
40893                "Error which is not critical. We decided to continue the process despite the mentioned error.",
40894                "No results are present on a particular list page.",
40895                "Success is reported, but some results may be missing due to errors",
40896                "The user attempted to use a resource that requires a TOS they have not accepted.",
40897                "Warning that a resource is in use.",
40898                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
40899                "When a resource schema validation is ignored.",
40900                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
40901                "When undeclared properties in the schema are present",
40902                "A given scope cannot be reached."
40903              ],
40904              "enumDeprecated": [
40905                false,
40906                false,
40907                false,
40908                false,
40909                false,
40910                false,
40911                true,
40912                false,
40913                false,
40914                false,
40915                false,
40916                false,
40917                false,
40918                false,
40919                false,
40920                false,
40921                false,
40922                false,
40923                false,
40924                false,
40925                false,
40926                false,
40927                false,
40928                false,
40929                false,
40930                false,
40931                false,
40932                false
40933              ],
40934              "enum": [
40935                "CLEANUP_FAILED",
40936                "DEPRECATED_RESOURCE_USED",
40937                "DEPRECATED_TYPE_USED",
40938                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
40939                "EXPERIMENTAL_TYPE_USED",
40940                "EXTERNAL_API_WARNING",
40941                "FIELD_VALUE_OVERRIDEN",
40942                "INJECTED_KERNELS_DEPRECATED",
40943                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
40944                "LARGE_DEPLOYMENT_WARNING",
40945                "LIST_OVERHEAD_QUOTA_EXCEED",
40946                "MISSING_TYPE_DEPENDENCY",
40947                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
40948                "NEXT_HOP_CANNOT_IP_FORWARD",
40949                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
40950                "NEXT_HOP_INSTANCE_NOT_FOUND",
40951                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
40952                "NEXT_HOP_NOT_RUNNING",
40953                "NOT_CRITICAL_ERROR",
40954                "NO_RESULTS_ON_PAGE",
40955                "PARTIAL_SUCCESS",
40956                "REQUIRED_TOS_AGREEMENT",
40957                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
40958                "RESOURCE_NOT_DELETED",
40959                "SCHEMA_VALIDATION_IGNORED",
40960                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
40961                "UNDECLARED_PROPERTIES",
40962                "UNREACHABLE"
40963              ]
40964            },
40965            "message": {
40966              "description": "[Output Only] A human-readable description of the warning code.",
40967              "type": "string"
40968            },
40969            "data": {
40970              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
40971              "type": "array",
40972              "items": {
40973                "type": "object",
40974                "properties": {
40975                  "key": {
40976                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
40977                    "type": "string"
40978                  },
40979                  "value": {
40980                    "description": "[Output Only] A warning data value corresponding to the key.",
40981                    "type": "string"
40982                  }
40983                }
40984              }
40985            }
40986          }
40987        }
40988      }
40989    },
40990    "TargetTcpProxy": {
40991      "id": "TargetTcpProxy",
40992      "description": "Represents a Target TCP Proxy resource. A target TCP proxy is a component of a Proxy Network Load Balancer. The forwarding rule references the target TCP proxy, and the target proxy then references a backend service. For more information, read Proxy Network Load Balancer overview.",
40993      "type": "object",
40994      "properties": {
40995        "kind": {
40996          "description": "[Output Only] Type of the resource. Always compute#targetTcpProxy for target TCP proxies.",
40997          "default": "compute#targetTcpProxy",
40998          "type": "string"
40999        },
41000        "id": {
41001          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
41002          "type": "string",
41003          "format": "uint64"
41004        },
41005        "creationTimestamp": {
41006          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
41007          "type": "string"
41008        },
41009        "name": {
41010          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
41011          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
41012          "type": "string"
41013        },
41014        "description": {
41015          "description": "An optional description of this resource. Provide this property when you create the resource.",
41016          "type": "string"
41017        },
41018        "selfLink": {
41019          "description": "[Output Only] Server-defined URL for the resource.",
41020          "type": "string"
41021        },
41022        "service": {
41023          "description": "URL to the BackendService resource.",
41024          "type": "string"
41025        },
41026        "proxyHeader": {
41027          "description": "Specifies the type of proxy header to append before sending data to the backend, either NONE or PROXY_V1. The default is NONE.",
41028          "type": "string",
41029          "enumDescriptions": [
41030            "",
41031            ""
41032          ],
41033          "enum": [
41034            "NONE",
41035            "PROXY_V1"
41036          ]
41037        },
41038        "proxyBind": {
41039          "description": "This field only applies when the forwarding rule that references this target proxy has a loadBalancingScheme set to INTERNAL_SELF_MANAGED. When this field is set to true, Envoy proxies set up inbound traffic interception and bind to the IP address and port specified in the forwarding rule. This is generally useful when using Traffic Director to configure Envoy as a gateway or middle proxy (in other words, not a sidecar proxy). The Envoy proxy listens for inbound requests and handles requests when it receives them. The default is false.",
41040          "type": "boolean"
41041        },
41042        "region": {
41043          "description": "[Output Only] URL of the region where the regional TCP proxy resides. This field is not applicable to global TCP proxy.",
41044          "type": "string"
41045        }
41046      }
41047    },
41048    "TargetTcpProxyAggregatedList": {
41049      "id": "TargetTcpProxyAggregatedList",
41050      "type": "object",
41051      "properties": {
41052        "kind": {
41053          "description": "[Output Only] Type of resource. Always compute#targetTcpProxyAggregatedList for lists of Target TCP Proxies.",
41054          "default": "compute#targetTcpProxyAggregatedList",
41055          "type": "string"
41056        },
41057        "id": {
41058          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
41059          "type": "string"
41060        },
41061        "items": {
41062          "description": "A list of TargetTcpProxiesScopedList resources.",
41063          "type": "object",
41064          "additionalProperties": {
41065            "description": "Name of the scope containing this set of TargetTcpProxies.",
41066            "$ref": "TargetTcpProxiesScopedList"
41067          }
41068        },
41069        "nextPageToken": {
41070          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
41071          "type": "string"
41072        },
41073        "selfLink": {
41074          "description": "[Output Only] Server-defined URL for this resource.",
41075          "type": "string"
41076        },
41077        "warning": {
41078          "description": "[Output Only] Informational warning message.",
41079          "type": "object",
41080          "properties": {
41081            "code": {
41082              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
41083              "type": "string",
41084              "enumDescriptions": [
41085                "Warning about failed cleanup of transient changes made by a failed operation.",
41086                "A link to a deprecated resource was created.",
41087                "When deploying and at least one of the resources has a type marked as deprecated",
41088                "The user created a boot disk that is larger than image size.",
41089                "When deploying and at least one of the resources has a type marked as experimental",
41090                "Warning that is present in an external api call",
41091                "Warning that value of a field has been overridden. Deprecated unused field.",
41092                "The operation involved use of an injected kernel, which is deprecated.",
41093                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
41094                "When deploying a deployment with a exceedingly large number of resources",
41095                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
41096                "A resource depends on a missing type",
41097                "The route's nextHopIp address is not assigned to an instance on the network.",
41098                "The route's next hop instance cannot ip forward.",
41099                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
41100                "The route's nextHopInstance URL refers to an instance that does not exist.",
41101                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
41102                "The route's next hop instance does not have a status of RUNNING.",
41103                "Error which is not critical. We decided to continue the process despite the mentioned error.",
41104                "No results are present on a particular list page.",
41105                "Success is reported, but some results may be missing due to errors",
41106                "The user attempted to use a resource that requires a TOS they have not accepted.",
41107                "Warning that a resource is in use.",
41108                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
41109                "When a resource schema validation is ignored.",
41110                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
41111                "When undeclared properties in the schema are present",
41112                "A given scope cannot be reached."
41113              ],
41114              "enumDeprecated": [
41115                false,
41116                false,
41117                false,
41118                false,
41119                false,
41120                false,
41121                true,
41122                false,
41123                false,
41124                false,
41125                false,
41126                false,
41127                false,
41128                false,
41129                false,
41130                false,
41131                false,
41132                false,
41133                false,
41134                false,
41135                false,
41136                false,
41137                false,
41138                false,
41139                false,
41140                false,
41141                false,
41142                false
41143              ],
41144              "enum": [
41145                "CLEANUP_FAILED",
41146                "DEPRECATED_RESOURCE_USED",
41147                "DEPRECATED_TYPE_USED",
41148                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
41149                "EXPERIMENTAL_TYPE_USED",
41150                "EXTERNAL_API_WARNING",
41151                "FIELD_VALUE_OVERRIDEN",
41152                "INJECTED_KERNELS_DEPRECATED",
41153                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
41154                "LARGE_DEPLOYMENT_WARNING",
41155                "LIST_OVERHEAD_QUOTA_EXCEED",
41156                "MISSING_TYPE_DEPENDENCY",
41157                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
41158                "NEXT_HOP_CANNOT_IP_FORWARD",
41159                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
41160                "NEXT_HOP_INSTANCE_NOT_FOUND",
41161                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
41162                "NEXT_HOP_NOT_RUNNING",
41163                "NOT_CRITICAL_ERROR",
41164                "NO_RESULTS_ON_PAGE",
41165                "PARTIAL_SUCCESS",
41166                "REQUIRED_TOS_AGREEMENT",
41167                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
41168                "RESOURCE_NOT_DELETED",
41169                "SCHEMA_VALIDATION_IGNORED",
41170                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
41171                "UNDECLARED_PROPERTIES",
41172                "UNREACHABLE"
41173              ]
41174            },
41175            "message": {
41176              "description": "[Output Only] A human-readable description of the warning code.",
41177              "type": "string"
41178            },
41179            "data": {
41180              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
41181              "type": "array",
41182              "items": {
41183                "type": "object",
41184                "properties": {
41185                  "key": {
41186                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
41187                    "type": "string"
41188                  },
41189                  "value": {
41190                    "description": "[Output Only] A warning data value corresponding to the key.",
41191                    "type": "string"
41192                  }
41193                }
41194              }
41195            }
41196          }
41197        },
41198        "unreachables": {
41199          "description": "[Output Only] Unreachable resources.",
41200          "type": "array",
41201          "items": {
41202            "type": "string"
41203          }
41204        }
41205      }
41206    },
41207    "TargetTcpProxiesScopedList": {
41208      "id": "TargetTcpProxiesScopedList",
41209      "type": "object",
41210      "properties": {
41211        "targetTcpProxies": {
41212          "description": "A list of TargetTcpProxies contained in this scope.",
41213          "type": "array",
41214          "items": {
41215            "$ref": "TargetTcpProxy"
41216          }
41217        },
41218        "warning": {
41219          "description": "Informational warning which replaces the list of backend services when the list is empty.",
41220          "type": "object",
41221          "properties": {
41222            "code": {
41223              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
41224              "type": "string",
41225              "enumDescriptions": [
41226                "Warning about failed cleanup of transient changes made by a failed operation.",
41227                "A link to a deprecated resource was created.",
41228                "When deploying and at least one of the resources has a type marked as deprecated",
41229                "The user created a boot disk that is larger than image size.",
41230                "When deploying and at least one of the resources has a type marked as experimental",
41231                "Warning that is present in an external api call",
41232                "Warning that value of a field has been overridden. Deprecated unused field.",
41233                "The operation involved use of an injected kernel, which is deprecated.",
41234                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
41235                "When deploying a deployment with a exceedingly large number of resources",
41236                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
41237                "A resource depends on a missing type",
41238                "The route's nextHopIp address is not assigned to an instance on the network.",
41239                "The route's next hop instance cannot ip forward.",
41240                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
41241                "The route's nextHopInstance URL refers to an instance that does not exist.",
41242                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
41243                "The route's next hop instance does not have a status of RUNNING.",
41244                "Error which is not critical. We decided to continue the process despite the mentioned error.",
41245                "No results are present on a particular list page.",
41246                "Success is reported, but some results may be missing due to errors",
41247                "The user attempted to use a resource that requires a TOS they have not accepted.",
41248                "Warning that a resource is in use.",
41249                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
41250                "When a resource schema validation is ignored.",
41251                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
41252                "When undeclared properties in the schema are present",
41253                "A given scope cannot be reached."
41254              ],
41255              "enumDeprecated": [
41256                false,
41257                false,
41258                false,
41259                false,
41260                false,
41261                false,
41262                true,
41263                false,
41264                false,
41265                false,
41266                false,
41267                false,
41268                false,
41269                false,
41270                false,
41271                false,
41272                false,
41273                false,
41274                false,
41275                false,
41276                false,
41277                false,
41278                false,
41279                false,
41280                false,
41281                false,
41282                false,
41283                false
41284              ],
41285              "enum": [
41286                "CLEANUP_FAILED",
41287                "DEPRECATED_RESOURCE_USED",
41288                "DEPRECATED_TYPE_USED",
41289                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
41290                "EXPERIMENTAL_TYPE_USED",
41291                "EXTERNAL_API_WARNING",
41292                "FIELD_VALUE_OVERRIDEN",
41293                "INJECTED_KERNELS_DEPRECATED",
41294                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
41295                "LARGE_DEPLOYMENT_WARNING",
41296                "LIST_OVERHEAD_QUOTA_EXCEED",
41297                "MISSING_TYPE_DEPENDENCY",
41298                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
41299                "NEXT_HOP_CANNOT_IP_FORWARD",
41300                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
41301                "NEXT_HOP_INSTANCE_NOT_FOUND",
41302                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
41303                "NEXT_HOP_NOT_RUNNING",
41304                "NOT_CRITICAL_ERROR",
41305                "NO_RESULTS_ON_PAGE",
41306                "PARTIAL_SUCCESS",
41307                "REQUIRED_TOS_AGREEMENT",
41308                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
41309                "RESOURCE_NOT_DELETED",
41310                "SCHEMA_VALIDATION_IGNORED",
41311                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
41312                "UNDECLARED_PROPERTIES",
41313                "UNREACHABLE"
41314              ]
41315            },
41316            "message": {
41317              "description": "[Output Only] A human-readable description of the warning code.",
41318              "type": "string"
41319            },
41320            "data": {
41321              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
41322              "type": "array",
41323              "items": {
41324                "type": "object",
41325                "properties": {
41326                  "key": {
41327                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
41328                    "type": "string"
41329                  },
41330                  "value": {
41331                    "description": "[Output Only] A warning data value corresponding to the key.",
41332                    "type": "string"
41333                  }
41334                }
41335              }
41336            }
41337          }
41338        }
41339      }
41340    },
41341    "TargetTcpProxiesSetBackendServiceRequest": {
41342      "id": "TargetTcpProxiesSetBackendServiceRequest",
41343      "type": "object",
41344      "properties": {
41345        "service": {
41346          "description": "The URL of the new BackendService resource for the targetTcpProxy.",
41347          "type": "string"
41348        }
41349      }
41350    },
41351    "TargetTcpProxiesSetProxyHeaderRequest": {
41352      "id": "TargetTcpProxiesSetProxyHeaderRequest",
41353      "type": "object",
41354      "properties": {
41355        "proxyHeader": {
41356          "description": "The new type of proxy header to append before sending data to the backend. NONE or PROXY_V1 are allowed.",
41357          "type": "string",
41358          "enumDescriptions": [
41359            "",
41360            ""
41361          ],
41362          "enum": [
41363            "NONE",
41364            "PROXY_V1"
41365          ]
41366        }
41367      }
41368    },
41369    "TargetVpnGatewayList": {
41370      "id": "TargetVpnGatewayList",
41371      "description": "Contains a list of TargetVpnGateway resources.",
41372      "type": "object",
41373      "properties": {
41374        "kind": {
41375          "description": "[Output Only] Type of resource. Always compute#targetVpnGateway for target VPN gateways.",
41376          "default": "compute#targetVpnGatewayList",
41377          "type": "string"
41378        },
41379        "id": {
41380          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
41381          "type": "string"
41382        },
41383        "items": {
41384          "description": "A list of TargetVpnGateway resources.",
41385          "type": "array",
41386          "items": {
41387            "$ref": "TargetVpnGateway"
41388          }
41389        },
41390        "nextPageToken": {
41391          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
41392          "type": "string"
41393        },
41394        "selfLink": {
41395          "description": "[Output Only] Server-defined URL for this resource.",
41396          "type": "string"
41397        },
41398        "warning": {
41399          "description": "[Output Only] Informational warning message.",
41400          "type": "object",
41401          "properties": {
41402            "code": {
41403              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
41404              "type": "string",
41405              "enumDescriptions": [
41406                "Warning about failed cleanup of transient changes made by a failed operation.",
41407                "A link to a deprecated resource was created.",
41408                "When deploying and at least one of the resources has a type marked as deprecated",
41409                "The user created a boot disk that is larger than image size.",
41410                "When deploying and at least one of the resources has a type marked as experimental",
41411                "Warning that is present in an external api call",
41412                "Warning that value of a field has been overridden. Deprecated unused field.",
41413                "The operation involved use of an injected kernel, which is deprecated.",
41414                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
41415                "When deploying a deployment with a exceedingly large number of resources",
41416                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
41417                "A resource depends on a missing type",
41418                "The route's nextHopIp address is not assigned to an instance on the network.",
41419                "The route's next hop instance cannot ip forward.",
41420                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
41421                "The route's nextHopInstance URL refers to an instance that does not exist.",
41422                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
41423                "The route's next hop instance does not have a status of RUNNING.",
41424                "Error which is not critical. We decided to continue the process despite the mentioned error.",
41425                "No results are present on a particular list page.",
41426                "Success is reported, but some results may be missing due to errors",
41427                "The user attempted to use a resource that requires a TOS they have not accepted.",
41428                "Warning that a resource is in use.",
41429                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
41430                "When a resource schema validation is ignored.",
41431                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
41432                "When undeclared properties in the schema are present",
41433                "A given scope cannot be reached."
41434              ],
41435              "enumDeprecated": [
41436                false,
41437                false,
41438                false,
41439                false,
41440                false,
41441                false,
41442                true,
41443                false,
41444                false,
41445                false,
41446                false,
41447                false,
41448                false,
41449                false,
41450                false,
41451                false,
41452                false,
41453                false,
41454                false,
41455                false,
41456                false,
41457                false,
41458                false,
41459                false,
41460                false,
41461                false,
41462                false,
41463                false
41464              ],
41465              "enum": [
41466                "CLEANUP_FAILED",
41467                "DEPRECATED_RESOURCE_USED",
41468                "DEPRECATED_TYPE_USED",
41469                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
41470                "EXPERIMENTAL_TYPE_USED",
41471                "EXTERNAL_API_WARNING",
41472                "FIELD_VALUE_OVERRIDEN",
41473                "INJECTED_KERNELS_DEPRECATED",
41474                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
41475                "LARGE_DEPLOYMENT_WARNING",
41476                "LIST_OVERHEAD_QUOTA_EXCEED",
41477                "MISSING_TYPE_DEPENDENCY",
41478                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
41479                "NEXT_HOP_CANNOT_IP_FORWARD",
41480                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
41481                "NEXT_HOP_INSTANCE_NOT_FOUND",
41482                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
41483                "NEXT_HOP_NOT_RUNNING",
41484                "NOT_CRITICAL_ERROR",
41485                "NO_RESULTS_ON_PAGE",
41486                "PARTIAL_SUCCESS",
41487                "REQUIRED_TOS_AGREEMENT",
41488                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
41489                "RESOURCE_NOT_DELETED",
41490                "SCHEMA_VALIDATION_IGNORED",
41491                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
41492                "UNDECLARED_PROPERTIES",
41493                "UNREACHABLE"
41494              ]
41495            },
41496            "message": {
41497              "description": "[Output Only] A human-readable description of the warning code.",
41498              "type": "string"
41499            },
41500            "data": {
41501              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
41502              "type": "array",
41503              "items": {
41504                "type": "object",
41505                "properties": {
41506                  "key": {
41507                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
41508                    "type": "string"
41509                  },
41510                  "value": {
41511                    "description": "[Output Only] A warning data value corresponding to the key.",
41512                    "type": "string"
41513                  }
41514                }
41515              }
41516            }
41517          }
41518        }
41519      }
41520    },
41521    "TargetVpnGateway": {
41522      "id": "TargetVpnGateway",
41523      "description": "Represents a Target VPN Gateway resource. The target VPN gateway resource represents a Classic Cloud VPN gateway. For more information, read the the Cloud VPN Overview.",
41524      "type": "object",
41525      "properties": {
41526        "kind": {
41527          "description": "[Output Only] Type of resource. Always compute#targetVpnGateway for target VPN gateways.",
41528          "default": "compute#targetVpnGateway",
41529          "type": "string"
41530        },
41531        "id": {
41532          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
41533          "type": "string",
41534          "format": "uint64"
41535        },
41536        "creationTimestamp": {
41537          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
41538          "type": "string"
41539        },
41540        "name": {
41541          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
41542          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
41543          "annotations": {
41544            "required": [
41545              "compute.targetVpnGateways.insert"
41546            ]
41547          },
41548          "type": "string"
41549        },
41550        "description": {
41551          "description": "An optional description of this resource. Provide this property when you create the resource.",
41552          "type": "string"
41553        },
41554        "region": {
41555          "description": "[Output Only] URL of the region where the target VPN gateway resides. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
41556          "type": "string"
41557        },
41558        "network": {
41559          "description": "URL of the network to which this VPN gateway is attached. Provided by the client when the VPN gateway is created.",
41560          "annotations": {
41561            "required": [
41562              "compute.targetVpnGateways.insert"
41563            ]
41564          },
41565          "type": "string"
41566        },
41567        "tunnels": {
41568          "description": "[Output Only] A list of URLs to VpnTunnel resources. VpnTunnels are created using the compute.vpntunnels.insert method and associated with a VPN gateway.",
41569          "type": "array",
41570          "items": {
41571            "type": "string"
41572          }
41573        },
41574        "status": {
41575          "description": "[Output Only] The status of the VPN gateway, which can be one of the following: CREATING, READY, FAILED, or DELETING.",
41576          "type": "string",
41577          "enumDescriptions": [
41578            "",
41579            "",
41580            "",
41581            ""
41582          ],
41583          "enum": [
41584            "CREATING",
41585            "DELETING",
41586            "FAILED",
41587            "READY"
41588          ]
41589        },
41590        "selfLink": {
41591          "description": "[Output Only] Server-defined URL for the resource.",
41592          "type": "string"
41593        },
41594        "forwardingRules": {
41595          "description": "[Output Only] A list of URLs to the ForwardingRule resources. ForwardingRules are created using compute.forwardingRules.insert and associated with a VPN gateway.",
41596          "type": "array",
41597          "items": {
41598            "type": "string"
41599          }
41600        },
41601        "labels": {
41602          "description": "Labels for this resource. These can only be added or modified by the setLabels method. Each label key/value pair must comply with RFC1035. Label values may be empty.",
41603          "type": "object",
41604          "additionalProperties": {
41605            "type": "string"
41606          }
41607        },
41608        "labelFingerprint": {
41609          "description": "A fingerprint for the labels being applied to this TargetVpnGateway, which is essentially a hash of the labels set used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve a TargetVpnGateway.",
41610          "type": "string",
41611          "format": "byte"
41612        }
41613      }
41614    },
41615    "TargetVpnGatewayAggregatedList": {
41616      "id": "TargetVpnGatewayAggregatedList",
41617      "type": "object",
41618      "properties": {
41619        "kind": {
41620          "description": "[Output Only] Type of resource. Always compute#targetVpnGateway for target VPN gateways.",
41621          "default": "compute#targetVpnGatewayAggregatedList",
41622          "type": "string"
41623        },
41624        "id": {
41625          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
41626          "type": "string"
41627        },
41628        "items": {
41629          "description": "A list of TargetVpnGateway resources.",
41630          "type": "object",
41631          "additionalProperties": {
41632            "description": "[Output Only] Name of the scope containing this set of target VPN gateways.",
41633            "$ref": "TargetVpnGatewaysScopedList"
41634          }
41635        },
41636        "nextPageToken": {
41637          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
41638          "type": "string"
41639        },
41640        "selfLink": {
41641          "description": "[Output Only] Server-defined URL for this resource.",
41642          "type": "string"
41643        },
41644        "warning": {
41645          "description": "[Output Only] Informational warning message.",
41646          "type": "object",
41647          "properties": {
41648            "code": {
41649              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
41650              "type": "string",
41651              "enumDescriptions": [
41652                "Warning about failed cleanup of transient changes made by a failed operation.",
41653                "A link to a deprecated resource was created.",
41654                "When deploying and at least one of the resources has a type marked as deprecated",
41655                "The user created a boot disk that is larger than image size.",
41656                "When deploying and at least one of the resources has a type marked as experimental",
41657                "Warning that is present in an external api call",
41658                "Warning that value of a field has been overridden. Deprecated unused field.",
41659                "The operation involved use of an injected kernel, which is deprecated.",
41660                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
41661                "When deploying a deployment with a exceedingly large number of resources",
41662                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
41663                "A resource depends on a missing type",
41664                "The route's nextHopIp address is not assigned to an instance on the network.",
41665                "The route's next hop instance cannot ip forward.",
41666                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
41667                "The route's nextHopInstance URL refers to an instance that does not exist.",
41668                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
41669                "The route's next hop instance does not have a status of RUNNING.",
41670                "Error which is not critical. We decided to continue the process despite the mentioned error.",
41671                "No results are present on a particular list page.",
41672                "Success is reported, but some results may be missing due to errors",
41673                "The user attempted to use a resource that requires a TOS they have not accepted.",
41674                "Warning that a resource is in use.",
41675                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
41676                "When a resource schema validation is ignored.",
41677                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
41678                "When undeclared properties in the schema are present",
41679                "A given scope cannot be reached."
41680              ],
41681              "enumDeprecated": [
41682                false,
41683                false,
41684                false,
41685                false,
41686                false,
41687                false,
41688                true,
41689                false,
41690                false,
41691                false,
41692                false,
41693                false,
41694                false,
41695                false,
41696                false,
41697                false,
41698                false,
41699                false,
41700                false,
41701                false,
41702                false,
41703                false,
41704                false,
41705                false,
41706                false,
41707                false,
41708                false,
41709                false
41710              ],
41711              "enum": [
41712                "CLEANUP_FAILED",
41713                "DEPRECATED_RESOURCE_USED",
41714                "DEPRECATED_TYPE_USED",
41715                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
41716                "EXPERIMENTAL_TYPE_USED",
41717                "EXTERNAL_API_WARNING",
41718                "FIELD_VALUE_OVERRIDEN",
41719                "INJECTED_KERNELS_DEPRECATED",
41720                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
41721                "LARGE_DEPLOYMENT_WARNING",
41722                "LIST_OVERHEAD_QUOTA_EXCEED",
41723                "MISSING_TYPE_DEPENDENCY",
41724                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
41725                "NEXT_HOP_CANNOT_IP_FORWARD",
41726                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
41727                "NEXT_HOP_INSTANCE_NOT_FOUND",
41728                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
41729                "NEXT_HOP_NOT_RUNNING",
41730                "NOT_CRITICAL_ERROR",
41731                "NO_RESULTS_ON_PAGE",
41732                "PARTIAL_SUCCESS",
41733                "REQUIRED_TOS_AGREEMENT",
41734                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
41735                "RESOURCE_NOT_DELETED",
41736                "SCHEMA_VALIDATION_IGNORED",
41737                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
41738                "UNDECLARED_PROPERTIES",
41739                "UNREACHABLE"
41740              ]
41741            },
41742            "message": {
41743              "description": "[Output Only] A human-readable description of the warning code.",
41744              "type": "string"
41745            },
41746            "data": {
41747              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
41748              "type": "array",
41749              "items": {
41750                "type": "object",
41751                "properties": {
41752                  "key": {
41753                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
41754                    "type": "string"
41755                  },
41756                  "value": {
41757                    "description": "[Output Only] A warning data value corresponding to the key.",
41758                    "type": "string"
41759                  }
41760                }
41761              }
41762            }
41763          }
41764        },
41765        "unreachables": {
41766          "description": "[Output Only] Unreachable resources.",
41767          "type": "array",
41768          "items": {
41769            "type": "string"
41770          }
41771        }
41772      }
41773    },
41774    "TargetVpnGatewaysScopedList": {
41775      "id": "TargetVpnGatewaysScopedList",
41776      "type": "object",
41777      "properties": {
41778        "targetVpnGateways": {
41779          "description": "[Output Only] A list of target VPN gateways contained in this scope.",
41780          "type": "array",
41781          "items": {
41782            "$ref": "TargetVpnGateway"
41783          }
41784        },
41785        "warning": {
41786          "description": "[Output Only] Informational warning which replaces the list of addresses when the list is empty.",
41787          "type": "object",
41788          "properties": {
41789            "code": {
41790              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
41791              "type": "string",
41792              "enumDescriptions": [
41793                "Warning about failed cleanup of transient changes made by a failed operation.",
41794                "A link to a deprecated resource was created.",
41795                "When deploying and at least one of the resources has a type marked as deprecated",
41796                "The user created a boot disk that is larger than image size.",
41797                "When deploying and at least one of the resources has a type marked as experimental",
41798                "Warning that is present in an external api call",
41799                "Warning that value of a field has been overridden. Deprecated unused field.",
41800                "The operation involved use of an injected kernel, which is deprecated.",
41801                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
41802                "When deploying a deployment with a exceedingly large number of resources",
41803                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
41804                "A resource depends on a missing type",
41805                "The route's nextHopIp address is not assigned to an instance on the network.",
41806                "The route's next hop instance cannot ip forward.",
41807                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
41808                "The route's nextHopInstance URL refers to an instance that does not exist.",
41809                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
41810                "The route's next hop instance does not have a status of RUNNING.",
41811                "Error which is not critical. We decided to continue the process despite the mentioned error.",
41812                "No results are present on a particular list page.",
41813                "Success is reported, but some results may be missing due to errors",
41814                "The user attempted to use a resource that requires a TOS they have not accepted.",
41815                "Warning that a resource is in use.",
41816                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
41817                "When a resource schema validation is ignored.",
41818                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
41819                "When undeclared properties in the schema are present",
41820                "A given scope cannot be reached."
41821              ],
41822              "enumDeprecated": [
41823                false,
41824                false,
41825                false,
41826                false,
41827                false,
41828                false,
41829                true,
41830                false,
41831                false,
41832                false,
41833                false,
41834                false,
41835                false,
41836                false,
41837                false,
41838                false,
41839                false,
41840                false,
41841                false,
41842                false,
41843                false,
41844                false,
41845                false,
41846                false,
41847                false,
41848                false,
41849                false,
41850                false
41851              ],
41852              "enum": [
41853                "CLEANUP_FAILED",
41854                "DEPRECATED_RESOURCE_USED",
41855                "DEPRECATED_TYPE_USED",
41856                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
41857                "EXPERIMENTAL_TYPE_USED",
41858                "EXTERNAL_API_WARNING",
41859                "FIELD_VALUE_OVERRIDEN",
41860                "INJECTED_KERNELS_DEPRECATED",
41861                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
41862                "LARGE_DEPLOYMENT_WARNING",
41863                "LIST_OVERHEAD_QUOTA_EXCEED",
41864                "MISSING_TYPE_DEPENDENCY",
41865                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
41866                "NEXT_HOP_CANNOT_IP_FORWARD",
41867                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
41868                "NEXT_HOP_INSTANCE_NOT_FOUND",
41869                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
41870                "NEXT_HOP_NOT_RUNNING",
41871                "NOT_CRITICAL_ERROR",
41872                "NO_RESULTS_ON_PAGE",
41873                "PARTIAL_SUCCESS",
41874                "REQUIRED_TOS_AGREEMENT",
41875                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
41876                "RESOURCE_NOT_DELETED",
41877                "SCHEMA_VALIDATION_IGNORED",
41878                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
41879                "UNDECLARED_PROPERTIES",
41880                "UNREACHABLE"
41881              ]
41882            },
41883            "message": {
41884              "description": "[Output Only] A human-readable description of the warning code.",
41885              "type": "string"
41886            },
41887            "data": {
41888              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
41889              "type": "array",
41890              "items": {
41891                "type": "object",
41892                "properties": {
41893                  "key": {
41894                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
41895                    "type": "string"
41896                  },
41897                  "value": {
41898                    "description": "[Output Only] A warning data value corresponding to the key.",
41899                    "type": "string"
41900                  }
41901                }
41902              }
41903            }
41904          }
41905        }
41906      }
41907    },
41908    "UrlMapList": {
41909      "id": "UrlMapList",
41910      "description": "Contains a list of UrlMap resources.",
41911      "type": "object",
41912      "properties": {
41913        "kind": {
41914          "description": "Type of resource.",
41915          "default": "compute#urlMapList",
41916          "type": "string"
41917        },
41918        "id": {
41919          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
41920          "type": "string"
41921        },
41922        "items": {
41923          "description": "A list of UrlMap resources.",
41924          "type": "array",
41925          "items": {
41926            "$ref": "UrlMap"
41927          }
41928        },
41929        "nextPageToken": {
41930          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
41931          "type": "string"
41932        },
41933        "selfLink": {
41934          "description": "[Output Only] Server-defined URL for this resource.",
41935          "type": "string"
41936        },
41937        "warning": {
41938          "description": "[Output Only] Informational warning message.",
41939          "type": "object",
41940          "properties": {
41941            "code": {
41942              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
41943              "type": "string",
41944              "enumDescriptions": [
41945                "Warning about failed cleanup of transient changes made by a failed operation.",
41946                "A link to a deprecated resource was created.",
41947                "When deploying and at least one of the resources has a type marked as deprecated",
41948                "The user created a boot disk that is larger than image size.",
41949                "When deploying and at least one of the resources has a type marked as experimental",
41950                "Warning that is present in an external api call",
41951                "Warning that value of a field has been overridden. Deprecated unused field.",
41952                "The operation involved use of an injected kernel, which is deprecated.",
41953                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
41954                "When deploying a deployment with a exceedingly large number of resources",
41955                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
41956                "A resource depends on a missing type",
41957                "The route's nextHopIp address is not assigned to an instance on the network.",
41958                "The route's next hop instance cannot ip forward.",
41959                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
41960                "The route's nextHopInstance URL refers to an instance that does not exist.",
41961                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
41962                "The route's next hop instance does not have a status of RUNNING.",
41963                "Error which is not critical. We decided to continue the process despite the mentioned error.",
41964                "No results are present on a particular list page.",
41965                "Success is reported, but some results may be missing due to errors",
41966                "The user attempted to use a resource that requires a TOS they have not accepted.",
41967                "Warning that a resource is in use.",
41968                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
41969                "When a resource schema validation is ignored.",
41970                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
41971                "When undeclared properties in the schema are present",
41972                "A given scope cannot be reached."
41973              ],
41974              "enumDeprecated": [
41975                false,
41976                false,
41977                false,
41978                false,
41979                false,
41980                false,
41981                true,
41982                false,
41983                false,
41984                false,
41985                false,
41986                false,
41987                false,
41988                false,
41989                false,
41990                false,
41991                false,
41992                false,
41993                false,
41994                false,
41995                false,
41996                false,
41997                false,
41998                false,
41999                false,
42000                false,
42001                false,
42002                false
42003              ],
42004              "enum": [
42005                "CLEANUP_FAILED",
42006                "DEPRECATED_RESOURCE_USED",
42007                "DEPRECATED_TYPE_USED",
42008                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
42009                "EXPERIMENTAL_TYPE_USED",
42010                "EXTERNAL_API_WARNING",
42011                "FIELD_VALUE_OVERRIDEN",
42012                "INJECTED_KERNELS_DEPRECATED",
42013                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
42014                "LARGE_DEPLOYMENT_WARNING",
42015                "LIST_OVERHEAD_QUOTA_EXCEED",
42016                "MISSING_TYPE_DEPENDENCY",
42017                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
42018                "NEXT_HOP_CANNOT_IP_FORWARD",
42019                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
42020                "NEXT_HOP_INSTANCE_NOT_FOUND",
42021                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
42022                "NEXT_HOP_NOT_RUNNING",
42023                "NOT_CRITICAL_ERROR",
42024                "NO_RESULTS_ON_PAGE",
42025                "PARTIAL_SUCCESS",
42026                "REQUIRED_TOS_AGREEMENT",
42027                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
42028                "RESOURCE_NOT_DELETED",
42029                "SCHEMA_VALIDATION_IGNORED",
42030                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
42031                "UNDECLARED_PROPERTIES",
42032                "UNREACHABLE"
42033              ]
42034            },
42035            "message": {
42036              "description": "[Output Only] A human-readable description of the warning code.",
42037              "type": "string"
42038            },
42039            "data": {
42040              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
42041              "type": "array",
42042              "items": {
42043                "type": "object",
42044                "properties": {
42045                  "key": {
42046                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
42047                    "type": "string"
42048                  },
42049                  "value": {
42050                    "description": "[Output Only] A warning data value corresponding to the key.",
42051                    "type": "string"
42052                  }
42053                }
42054              }
42055            }
42056          }
42057        }
42058      }
42059    },
42060    "UrlMap": {
42061      "id": "UrlMap",
42062      "description": "Represents a URL Map resource. Compute Engine has two URL Map resources: * [Global](/compute/docs/reference/rest/v1/urlMaps) * [Regional](/compute/docs/reference/rest/v1/regionUrlMaps) A URL map resource is a component of certain types of cloud load balancers and Traffic Director: * urlMaps are used by global external Application Load Balancers, classic Application Load Balancers, and cross-region internal Application Load Balancers. * regionUrlMaps are used by internal Application Load Balancers, regional external Application Load Balancers and regional internal Application Load Balancers. For a list of supported URL map features by the load balancer type, see the Load balancing features: Routing and traffic management table. For a list of supported URL map features for Traffic Director, see the Traffic Director features: Routing and traffic management table. This resource defines mappings from hostnames and URL paths to either a backend service or a backend bucket. To use the global urlMaps resource, the backend service must have a loadBalancingScheme of either EXTERNAL or INTERNAL_SELF_MANAGED. To use the regionUrlMaps resource, the backend service must have a loadBalancingScheme of INTERNAL_MANAGED. For more information, read URL Map Concepts.",
42063      "type": "object",
42064      "properties": {
42065        "kind": {
42066          "description": "[Output Only] Type of the resource. Always compute#urlMaps for url maps.",
42067          "default": "compute#urlMap",
42068          "type": "string"
42069        },
42070        "id": {
42071          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
42072          "type": "string",
42073          "format": "uint64"
42074        },
42075        "creationTimestamp": {
42076          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
42077          "type": "string"
42078        },
42079        "name": {
42080          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
42081          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
42082          "type": "string"
42083        },
42084        "description": {
42085          "description": "An optional description of this resource. Provide this property when you create the resource.",
42086          "type": "string"
42087        },
42088        "selfLink": {
42089          "description": "[Output Only] Server-defined URL for the resource.",
42090          "type": "string"
42091        },
42092        "hostRules": {
42093          "description": "The list of host rules to use against the URL.",
42094          "type": "array",
42095          "items": {
42096            "$ref": "HostRule"
42097          }
42098        },
42099        "pathMatchers": {
42100          "description": "The list of named PathMatchers to use against the URL.",
42101          "type": "array",
42102          "items": {
42103            "$ref": "PathMatcher"
42104          }
42105        },
42106        "tests": {
42107          "description": "The list of expected URL mapping tests. Request to update the UrlMap succeeds only if all test cases pass. You can specify a maximum of 100 tests per UrlMap. Not supported when the URL map is bound to a target gRPC proxy that has validateForProxyless field set to true.",
42108          "type": "array",
42109          "items": {
42110            "$ref": "UrlMapTest"
42111          }
42112        },
42113        "defaultService": {
42114          "description": "The full or partial URL of the defaultService resource to which traffic is directed if none of the hostRules match. If defaultRouteAction is also specified, advanced routing actions, such as URL rewrites, take effect before sending the request to the backend. However, if defaultService is specified, defaultRouteAction cannot contain any weightedBackendServices. Conversely, if routeAction specifies any weightedBackendServices, service must not be specified. Only one of defaultService, defaultUrlRedirect , or defaultRouteAction.weightedBackendService must be set. defaultService has no effect when the URL map is bound to a target gRPC proxy that has the validateForProxyless field set to true.",
42115          "type": "string"
42116        },
42117        "defaultRouteAction": {
42118          "description": "defaultRouteAction takes effect when none of the hostRules match. The load balancer performs advanced routing actions, such as URL rewrites and header transformations, before forwarding the request to the selected backend. If defaultRouteAction specifies any weightedBackendServices, defaultService must not be set. Conversely if defaultService is set, defaultRouteAction cannot contain any weightedBackendServices. Only one of defaultRouteAction or defaultUrlRedirect must be set. URL maps for classic Application Load Balancers only support the urlRewrite action within defaultRouteAction. defaultRouteAction has no effect when the URL map is bound to a target gRPC proxy that has the validateForProxyless field set to true.",
42119          "$ref": "HttpRouteAction"
42120        },
42121        "defaultUrlRedirect": {
42122          "description": "When none of the specified hostRules match, the request is redirected to a URL specified by defaultUrlRedirect. If defaultUrlRedirect is specified, defaultService or defaultRouteAction must not be set. Not supported when the URL map is bound to a target gRPC proxy.",
42123          "$ref": "HttpRedirectAction"
42124        },
42125        "headerAction": {
42126          "description": "Specifies changes to request and response headers that need to take effect for the selected backendService. The headerAction specified here take effect after headerAction specified under pathMatcher. headerAction is not supported for load balancers that have their loadBalancingScheme set to EXTERNAL. Not supported when the URL map is bound to a target gRPC proxy that has validateForProxyless field set to true.",
42127          "$ref": "HttpHeaderAction"
42128        },
42129        "fingerprint": {
42130          "description": "Fingerprint of this resource. A hash of the contents stored in this object. This field is used in optimistic locking. This field is ignored when inserting a UrlMap. An up-to-date fingerprint must be provided in order to update the UrlMap, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve a UrlMap.",
42131          "type": "string",
42132          "format": "byte"
42133        },
42134        "region": {
42135          "description": "[Output Only] URL of the region where the regional URL map resides. This field is not applicable to global URL maps. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
42136          "type": "string"
42137        }
42138      }
42139    },
42140    "HostRule": {
42141      "id": "HostRule",
42142      "description": "UrlMaps A host-matching rule for a URL. If matched, will use the named PathMatcher to select the BackendService.",
42143      "type": "object",
42144      "properties": {
42145        "description": {
42146          "description": "An optional description of this resource. Provide this property when you create the resource.",
42147          "type": "string"
42148        },
42149        "hosts": {
42150          "description": "The list of host patterns to match. They must be valid hostnames with optional port numbers in the format host:port. * matches any string of ([a-z0-9-.]*). In that case, * must be the first character, and if followed by anything, the immediate following character must be either - or .. * based matching is not supported when the URL map is bound to a target gRPC proxy that has the validateForProxyless field set to true.",
42151          "type": "array",
42152          "items": {
42153            "type": "string"
42154          }
42155        },
42156        "pathMatcher": {
42157          "description": "The name of the PathMatcher to use to match the path portion of the URL if the hostRule matches the URL's host portion.",
42158          "type": "string"
42159        }
42160      }
42161    },
42162    "PathMatcher": {
42163      "id": "PathMatcher",
42164      "description": "A matcher for the path portion of the URL. The BackendService from the longest-matched rule will serve the URL. If no rule was matched, the default service is used.",
42165      "type": "object",
42166      "properties": {
42167        "name": {
42168          "description": "The name to which this PathMatcher is referred by the HostRule.",
42169          "type": "string"
42170        },
42171        "description": {
42172          "description": "An optional description of this resource. Provide this property when you create the resource.",
42173          "type": "string"
42174        },
42175        "defaultService": {
42176          "description": "The full or partial URL to the BackendService resource. This URL is used if none of the pathRules or routeRules defined by this PathMatcher are matched. For example, the following are all valid URLs to a BackendService resource: - https://www.googleapis.com/compute/v1/projects/project /global/backendServices/backendService - compute/v1/projects/project/global/backendServices/backendService - global/backendServices/backendService If defaultRouteAction is also specified, advanced routing actions, such as URL rewrites, take effect before sending the request to the backend. However, if defaultService is specified, defaultRouteAction cannot contain any weightedBackendServices. Conversely, if defaultRouteAction specifies any weightedBackendServices, defaultService must not be specified. Only one of defaultService, defaultUrlRedirect , or defaultRouteAction.weightedBackendService must be set. Authorization requires one or more of the following Google IAM permissions on the specified resource default_service: - compute.backendBuckets.use - compute.backendServices.use ",
42177          "type": "string"
42178        },
42179        "defaultRouteAction": {
42180          "description": "defaultRouteAction takes effect when none of the pathRules or routeRules match. The load balancer performs advanced routing actions, such as URL rewrites and header transformations, before forwarding the request to the selected backend. If defaultRouteAction specifies any weightedBackendServices, defaultService must not be set. Conversely if defaultService is set, defaultRouteAction cannot contain any weightedBackendServices. Only one of defaultRouteAction or defaultUrlRedirect must be set. URL maps for classic Application Load Balancers only support the urlRewrite action within a path matcher's defaultRouteAction.",
42181          "$ref": "HttpRouteAction"
42182        },
42183        "defaultUrlRedirect": {
42184          "description": "When none of the specified pathRules or routeRules match, the request is redirected to a URL specified by defaultUrlRedirect. If defaultUrlRedirect is specified, defaultService or defaultRouteAction must not be set. Not supported when the URL map is bound to a target gRPC proxy.",
42185          "$ref": "HttpRedirectAction"
42186        },
42187        "pathRules": {
42188          "description": "The list of path rules. Use this list instead of routeRules when routing based on simple path matching is all that's required. The order by which path rules are specified does not matter. Matches are always done on the longest-path-first basis. For example: a pathRule with a path /a/b/c/* will match before /a/b/* irrespective of the order in which those paths appear in this list. Within a given pathMatcher, only one of pathRules or routeRules must be set.",
42189          "type": "array",
42190          "items": {
42191            "$ref": "PathRule"
42192          }
42193        },
42194        "routeRules": {
42195          "description": "The list of HTTP route rules. Use this list instead of pathRules when advanced route matching and routing actions are desired. routeRules are evaluated in order of priority, from the lowest to highest number. Within a given pathMatcher, you can set only one of pathRules or routeRules.",
42196          "type": "array",
42197          "items": {
42198            "$ref": "HttpRouteRule"
42199          }
42200        },
42201        "headerAction": {
42202          "description": "Specifies changes to request and response headers that need to take effect for the selected backend service. HeaderAction specified here are applied after the matching HttpRouteRule HeaderAction and before the HeaderAction in the UrlMap HeaderAction is not supported for load balancers that have their loadBalancingScheme set to EXTERNAL. Not supported when the URL map is bound to a target gRPC proxy that has validateForProxyless field set to true.",
42203          "$ref": "HttpHeaderAction"
42204        }
42205      }
42206    },
42207    "HttpRouteAction": {
42208      "id": "HttpRouteAction",
42209      "type": "object",
42210      "properties": {
42211        "weightedBackendServices": {
42212          "description": "A list of weighted backend services to send traffic to when a route match occurs. The weights determine the fraction of traffic that flows to their corresponding backend service. If all traffic needs to go to a single backend service, there must be one weightedBackendService with weight set to a non-zero number. After a backend service is identified and before forwarding the request to the backend service, advanced routing actions such as URL rewrites and header transformations are applied depending on additional settings specified in this HttpRouteAction.",
42213          "type": "array",
42214          "items": {
42215            "$ref": "WeightedBackendService"
42216          }
42217        },
42218        "urlRewrite": {
42219          "description": "The spec to modify the URL of the request, before forwarding the request to the matched service. urlRewrite is the only action supported in UrlMaps for classic Application Load Balancers. Not supported when the URL map is bound to a target gRPC proxy that has the validateForProxyless field set to true.",
42220          "$ref": "UrlRewrite"
42221        },
42222        "timeout": {
42223          "description": "Specifies the timeout for the selected route. Timeout is computed from the time the request has been fully processed (known as *end-of-stream*) up until the response has been processed. Timeout includes all retries. If not specified, this field uses the largest timeout among all backend services associated with the route. Not supported when the URL map is bound to a target gRPC proxy that has validateForProxyless field set to true.",
42224          "$ref": "Duration"
42225        },
42226        "retryPolicy": {
42227          "description": "Specifies the retry policy associated with this route.",
42228          "$ref": "HttpRetryPolicy"
42229        },
42230        "requestMirrorPolicy": {
42231          "description": "Specifies the policy on how requests intended for the route's backends are shadowed to a separate mirrored backend service. The load balancer does not wait for responses from the shadow service. Before sending traffic to the shadow service, the host / authority header is suffixed with -shadow. Not supported when the URL map is bound to a target gRPC proxy that has the validateForProxyless field set to true.",
42232          "$ref": "RequestMirrorPolicy"
42233        },
42234        "corsPolicy": {
42235          "description": "The specification for allowing client-side cross-origin requests. For more information about the W3C recommendation for cross-origin resource sharing (CORS), see Fetch API Living Standard. Not supported when the URL map is bound to a target gRPC proxy.",
42236          "$ref": "CorsPolicy"
42237        },
42238        "faultInjectionPolicy": {
42239          "description": "The specification for fault injection introduced into traffic to test the resiliency of clients to backend service failure. As part of fault injection, when clients send requests to a backend service, delays can be introduced by a load balancer on a percentage of requests before sending those requests to the backend service. Similarly requests from clients can be aborted by the load balancer for a percentage of requests. timeout and retry_policy is ignored by clients that are configured with a fault_injection_policy if: 1. The traffic is generated by fault injection AND 2. The fault injection is not a delay fault injection. Fault injection is not supported with the classic Application Load Balancer . To see which load balancers support fault injection, see Load balancing: Routing and traffic management features.",
42240          "$ref": "HttpFaultInjection"
42241        },
42242        "maxStreamDuration": {
42243          "description": "Specifies the maximum duration (timeout) for streams on the selected route. Unlike the timeout field where the timeout duration starts from the time the request has been fully processed (known as *end-of-stream*), the duration in this field is computed from the beginning of the stream until the response has been processed, including all retries. A stream that does not complete in this duration is closed. If not specified, this field uses the maximum maxStreamDuration value among all backend services associated with the route. This field is only allowed if the Url map is used with backend services with loadBalancingScheme set to INTERNAL_SELF_MANAGED.",
42244          "$ref": "Duration"
42245        }
42246      }
42247    },
42248    "WeightedBackendService": {
42249      "id": "WeightedBackendService",
42250      "description": "In contrast to a single BackendService in HttpRouteAction to which all matching traffic is directed to, WeightedBackendService allows traffic to be split across multiple backend services. The volume of traffic for each backend service is proportional to the weight specified in each WeightedBackendService",
42251      "type": "object",
42252      "properties": {
42253        "backendService": {
42254          "description": "The full or partial URL to the default BackendService resource. Before forwarding the request to backendService, the load balancer applies any relevant headerActions specified as part of this backendServiceWeight.",
42255          "type": "string"
42256        },
42257        "weight": {
42258          "description": "Specifies the fraction of traffic sent to a backend service, computed as weight / (sum of all weightedBackendService weights in routeAction) . The selection of a backend service is determined only for new traffic. Once a user's request has been directed to a backend service, subsequent requests are sent to the same backend service as determined by the backend service's session affinity policy. The value must be from 0 to 1000.",
42259          "type": "integer",
42260          "format": "uint32"
42261        },
42262        "headerAction": {
42263          "description": "Specifies changes to request and response headers that need to take effect for the selected backendService. headerAction specified here take effect before headerAction in the enclosing HttpRouteRule, PathMatcher and UrlMap. headerAction is not supported for load balancers that have their loadBalancingScheme set to EXTERNAL. Not supported when the URL map is bound to a target gRPC proxy that has validateForProxyless field set to true.",
42264          "$ref": "HttpHeaderAction"
42265        }
42266      }
42267    },
42268    "HttpHeaderAction": {
42269      "id": "HttpHeaderAction",
42270      "description": "The request and response header transformations that take effect before the request is passed along to the selected backendService.",
42271      "type": "object",
42272      "properties": {
42273        "requestHeadersToRemove": {
42274          "description": "A list of header names for headers that need to be removed from the request before forwarding the request to the backendService.",
42275          "type": "array",
42276          "items": {
42277            "type": "string"
42278          }
42279        },
42280        "requestHeadersToAdd": {
42281          "description": "Headers to add to a matching request before forwarding the request to the backendService.",
42282          "type": "array",
42283          "items": {
42284            "$ref": "HttpHeaderOption"
42285          }
42286        },
42287        "responseHeadersToRemove": {
42288          "description": "A list of header names for headers that need to be removed from the response before sending the response back to the client.",
42289          "type": "array",
42290          "items": {
42291            "type": "string"
42292          }
42293        },
42294        "responseHeadersToAdd": {
42295          "description": "Headers to add the response before sending the response back to the client.",
42296          "type": "array",
42297          "items": {
42298            "$ref": "HttpHeaderOption"
42299          }
42300        }
42301      }
42302    },
42303    "HttpHeaderOption": {
42304      "id": "HttpHeaderOption",
42305      "description": "Specification determining how headers are added to requests or responses.",
42306      "type": "object",
42307      "properties": {
42308        "headerName": {
42309          "description": "The name of the header.",
42310          "type": "string"
42311        },
42312        "headerValue": {
42313          "description": "The value of the header to add.",
42314          "type": "string"
42315        },
42316        "replace": {
42317          "description": "If false, headerValue is appended to any values that already exist for the header. If true, headerValue is set for the header, discarding any values that were set for that header. The default value is false. ",
42318          "type": "boolean"
42319        }
42320      }
42321    },
42322    "UrlRewrite": {
42323      "id": "UrlRewrite",
42324      "description": "The spec for modifying the path before sending the request to the matched backend service.",
42325      "type": "object",
42326      "properties": {
42327        "pathPrefixRewrite": {
42328          "description": "Before forwarding the request to the selected backend service, the matching portion of the request's path is replaced by pathPrefixRewrite. The value must be from 1 to 1024 characters.",
42329          "type": "string"
42330        },
42331        "hostRewrite": {
42332          "description": "Before forwarding the request to the selected service, the request's host header is replaced with contents of hostRewrite. The value must be from 1 to 255 characters.",
42333          "type": "string"
42334        },
42335        "pathTemplateRewrite": {
42336          "description": " If specified, the pattern rewrites the URL path (based on the :path header) using the HTTP template syntax. A corresponding path_template_match must be specified. Any template variables must exist in the path_template_match field. - -At least one variable must be specified in the path_template_match field - You can omit variables from the rewritten URL - The * and ** operators cannot be matched unless they have a corresponding variable name - e.g. {format=*} or {var=**}. For example, a path_template_match of /static/{format=**} could be rewritten as /static/content/{format} to prefix /content to the URL. Variables can also be re-ordered in a rewrite, so that /{country}/{format}/{suffix=**} can be rewritten as /content/{format}/{country}/{suffix}. At least one non-empty routeRules[].matchRules[].path_template_match is required. Only one of path_prefix_rewrite or path_template_rewrite may be specified.",
42337          "type": "string"
42338        }
42339      }
42340    },
42341    "HttpRetryPolicy": {
42342      "id": "HttpRetryPolicy",
42343      "description": "The retry policy associates with HttpRouteRule",
42344      "type": "object",
42345      "properties": {
42346        "retryConditions": {
42347          "description": "Specifies one or more conditions when this retry policy applies. Valid values are: - 5xx: retry is attempted if the instance or endpoint responds with any 5xx response code, or if the instance or endpoint does not respond at all. For example, disconnects, reset, read timeout, connection failure, and refused streams. - gateway-error: Similar to 5xx, but only applies to response codes 502, 503 or 504. - connect-failure: a retry is attempted on failures connecting to the instance or endpoint. For example, connection timeouts. - retriable-4xx: a retry is attempted if the instance or endpoint responds with a 4xx response code. The only error that you can retry is error code 409. - refused-stream: a retry is attempted if the instance or endpoint resets the stream with a REFUSED_STREAM error code. This reset type indicates that it is safe to retry. - cancelled: a retry is attempted if the gRPC status code in the response header is set to cancelled. - deadline-exceeded: a retry is attempted if the gRPC status code in the response header is set to deadline-exceeded. - internal: a retry is attempted if the gRPC status code in the response header is set to internal. - resource-exhausted: a retry is attempted if the gRPC status code in the response header is set to resource-exhausted. - unavailable: a retry is attempted if the gRPC status code in the response header is set to unavailable. Only the following codes are supported when the URL map is bound to target gRPC proxy that has validateForProxyless field set to true. - cancelled - deadline-exceeded - internal - resource-exhausted - unavailable ",
42348          "type": "array",
42349          "items": {
42350            "type": "string"
42351          }
42352        },
42353        "numRetries": {
42354          "description": "Specifies the allowed number retries. This number must be \u003e 0. If not specified, defaults to 1.",
42355          "type": "integer",
42356          "format": "uint32"
42357        },
42358        "perTryTimeout": {
42359          "description": "Specifies a non-zero timeout per retry attempt. If not specified, will use the timeout set in the HttpRouteAction field. If timeout in the HttpRouteAction field is not set, this field uses the largest timeout among all backend services associated with the route. Not supported when the URL map is bound to a target gRPC proxy that has the validateForProxyless field set to true.",
42360          "$ref": "Duration"
42361        }
42362      }
42363    },
42364    "RequestMirrorPolicy": {
42365      "id": "RequestMirrorPolicy",
42366      "description": "A policy that specifies how requests intended for the route's backends are shadowed to a separate mirrored backend service. The load balancer doesn't wait for responses from the shadow service. Before sending traffic to the shadow service, the host or authority header is suffixed with -shadow.",
42367      "type": "object",
42368      "properties": {
42369        "backendService": {
42370          "description": "The full or partial URL to the BackendService resource being mirrored to. The backend service configured for a mirroring policy must reference backends that are of the same type as the original backend service matched in the URL map. Serverless NEG backends are not currently supported as a mirrored backend service. ",
42371          "type": "string"
42372        }
42373      }
42374    },
42375    "CorsPolicy": {
42376      "id": "CorsPolicy",
42377      "description": "The specification for allowing client-side cross-origin requests. For more information about the W3C recommendation for cross-origin resource sharing (CORS), see Fetch API Living Standard.",
42378      "type": "object",
42379      "properties": {
42380        "allowOrigins": {
42381          "description": "Specifies the list of origins that is allowed to do CORS requests. An origin is allowed if it matches either an item in allowOrigins or an item in allowOriginRegexes.",
42382          "type": "array",
42383          "items": {
42384            "type": "string"
42385          }
42386        },
42387        "allowOriginRegexes": {
42388          "description": "Specifies a regular expression that matches allowed origins. For more information about the regular expression syntax, see Syntax. An origin is allowed if it matches either an item in allowOrigins or an item in allowOriginRegexes. Regular expressions can only be used when the loadBalancingScheme is set to INTERNAL_SELF_MANAGED.",
42389          "type": "array",
42390          "items": {
42391            "type": "string"
42392          }
42393        },
42394        "allowMethods": {
42395          "description": "Specifies the content for the Access-Control-Allow-Methods header.",
42396          "type": "array",
42397          "items": {
42398            "type": "string"
42399          }
42400        },
42401        "allowHeaders": {
42402          "description": "Specifies the content for the Access-Control-Allow-Headers header.",
42403          "type": "array",
42404          "items": {
42405            "type": "string"
42406          }
42407        },
42408        "exposeHeaders": {
42409          "description": "Specifies the content for the Access-Control-Expose-Headers header.",
42410          "type": "array",
42411          "items": {
42412            "type": "string"
42413          }
42414        },
42415        "maxAge": {
42416          "description": "Specifies how long results of a preflight request can be cached in seconds. This field translates to the Access-Control-Max-Age header.",
42417          "type": "integer",
42418          "format": "int32"
42419        },
42420        "allowCredentials": {
42421          "description": "In response to a preflight request, setting this to true indicates that the actual request can include user credentials. This field translates to the Access-Control-Allow-Credentials header. Default is false.",
42422          "type": "boolean"
42423        },
42424        "disabled": {
42425          "description": "If true, the setting specifies the CORS policy is disabled. The default value of false, which indicates that the CORS policy is in effect.",
42426          "type": "boolean"
42427        }
42428      }
42429    },
42430    "HttpFaultInjection": {
42431      "id": "HttpFaultInjection",
42432      "description": "The specification for fault injection introduced into traffic to test the resiliency of clients to backend service failure. As part of fault injection, when clients send requests to a backend service, delays can be introduced by the load balancer on a percentage of requests before sending those request to the backend service. Similarly requests from clients can be aborted by the load balancer for a percentage of requests.",
42433      "type": "object",
42434      "properties": {
42435        "delay": {
42436          "description": "The specification for how client requests are delayed as part of fault injection, before being sent to a backend service.",
42437          "$ref": "HttpFaultDelay"
42438        },
42439        "abort": {
42440          "description": "The specification for how client requests are aborted as part of fault injection.",
42441          "$ref": "HttpFaultAbort"
42442        }
42443      }
42444    },
42445    "HttpFaultDelay": {
42446      "id": "HttpFaultDelay",
42447      "description": "Specifies the delay introduced by the load balancer before forwarding the request to the backend service as part of fault injection.",
42448      "type": "object",
42449      "properties": {
42450        "fixedDelay": {
42451          "description": "Specifies the value of the fixed delay interval.",
42452          "$ref": "Duration"
42453        },
42454        "percentage": {
42455          "description": "The percentage of traffic for connections, operations, or requests for which a delay is introduced as part of fault injection. The value must be from 0.0 to 100.0 inclusive.",
42456          "type": "number",
42457          "format": "double"
42458        }
42459      }
42460    },
42461    "HttpFaultAbort": {
42462      "id": "HttpFaultAbort",
42463      "description": "Specification for how requests are aborted as part of fault injection.",
42464      "type": "object",
42465      "properties": {
42466        "httpStatus": {
42467          "description": "The HTTP status code used to abort the request. The value must be from 200 to 599 inclusive. For gRPC protocol, the gRPC status code is mapped to HTTP status code according to this mapping table. HTTP status 200 is mapped to gRPC status UNKNOWN. Injecting an OK status is currently not supported by Traffic Director.",
42468          "type": "integer",
42469          "format": "uint32"
42470        },
42471        "percentage": {
42472          "description": "The percentage of traffic for connections, operations, or requests that is aborted as part of fault injection. The value must be from 0.0 to 100.0 inclusive.",
42473          "type": "number",
42474          "format": "double"
42475        }
42476      }
42477    },
42478    "HttpRedirectAction": {
42479      "id": "HttpRedirectAction",
42480      "description": "Specifies settings for an HTTP redirect.",
42481      "type": "object",
42482      "properties": {
42483        "hostRedirect": {
42484          "description": "The host that is used in the redirect response instead of the one that was supplied in the request. The value must be from 1 to 255 characters.",
42485          "type": "string"
42486        },
42487        "pathRedirect": {
42488          "description": "The path that is used in the redirect response instead of the one that was supplied in the request. pathRedirect cannot be supplied together with prefixRedirect. Supply one alone or neither. If neither is supplied, the path of the original request is used for the redirect. The value must be from 1 to 1024 characters.",
42489          "type": "string"
42490        },
42491        "prefixRedirect": {
42492          "description": "The prefix that replaces the prefixMatch specified in the HttpRouteRuleMatch, retaining the remaining portion of the URL before redirecting the request. prefixRedirect cannot be supplied together with pathRedirect. Supply one alone or neither. If neither is supplied, the path of the original request is used for the redirect. The value must be from 1 to 1024 characters.",
42493          "type": "string"
42494        },
42495        "redirectResponseCode": {
42496          "description": "The HTTP Status code to use for this RedirectAction. Supported values are: - MOVED_PERMANENTLY_DEFAULT, which is the default value and corresponds to 301. - FOUND, which corresponds to 302. - SEE_OTHER which corresponds to 303. - TEMPORARY_REDIRECT, which corresponds to 307. In this case, the request method is retained. - PERMANENT_REDIRECT, which corresponds to 308. In this case, the request method is retained. ",
42497          "type": "string",
42498          "enumDescriptions": [
42499            "Http Status Code 302 - Found.",
42500            "Http Status Code 301 - Moved Permanently.",
42501            "Http Status Code 308 - Permanent Redirect maintaining HTTP method.",
42502            "Http Status Code 303 - See Other.",
42503            "Http Status Code 307 - Temporary Redirect maintaining HTTP method."
42504          ],
42505          "enum": [
42506            "FOUND",
42507            "MOVED_PERMANENTLY_DEFAULT",
42508            "PERMANENT_REDIRECT",
42509            "SEE_OTHER",
42510            "TEMPORARY_REDIRECT"
42511          ]
42512        },
42513        "httpsRedirect": {
42514          "description": "If set to true, the URL scheme in the redirected request is set to HTTPS. If set to false, the URL scheme of the redirected request remains the same as that of the request. This must only be set for URL maps used in TargetHttpProxys. Setting this true for TargetHttpsProxy is not permitted. The default is set to false.",
42515          "type": "boolean"
42516        },
42517        "stripQuery": {
42518          "description": "If set to true, any accompanying query portion of the original URL is removed before redirecting the request. If set to false, the query portion of the original URL is retained. The default is set to false. ",
42519          "type": "boolean"
42520        }
42521      }
42522    },
42523    "PathRule": {
42524      "id": "PathRule",
42525      "description": "A path-matching rule for a URL. If matched, will use the specified BackendService to handle the traffic arriving at this URL.",
42526      "type": "object",
42527      "properties": {
42528        "service": {
42529          "description": "The full or partial URL of the backend service resource to which traffic is directed if this rule is matched. If routeAction is also specified, advanced routing actions, such as URL rewrites, take effect before sending the request to the backend. However, if service is specified, routeAction cannot contain any weightedBackendServices. Conversely, if routeAction specifies any weightedBackendServices, service must not be specified. Only one of urlRedirect, service or routeAction.weightedBackendService must be set.",
42530          "type": "string"
42531        },
42532        "routeAction": {
42533          "description": "In response to a matching path, the load balancer performs advanced routing actions, such as URL rewrites and header transformations, before forwarding the request to the selected backend. If routeAction specifies any weightedBackendServices, service must not be set. Conversely if service is set, routeAction cannot contain any weightedBackendServices. Only one of routeAction or urlRedirect must be set. URL maps for classic Application Load Balancers only support the urlRewrite action within a path rule's routeAction.",
42534          "$ref": "HttpRouteAction"
42535        },
42536        "urlRedirect": {
42537          "description": "When a path pattern is matched, the request is redirected to a URL specified by urlRedirect. If urlRedirect is specified, service or routeAction must not be set. Not supported when the URL map is bound to a target gRPC proxy.",
42538          "$ref": "HttpRedirectAction"
42539        },
42540        "paths": {
42541          "description": "The list of path patterns to match. Each must start with / and the only place a * is allowed is at the end following a /. The string fed to the path matcher does not include any text after the first ? or #, and those chars are not allowed here.",
42542          "type": "array",
42543          "items": {
42544            "type": "string"
42545          }
42546        }
42547      }
42548    },
42549    "HttpRouteRule": {
42550      "id": "HttpRouteRule",
42551      "description": "The HttpRouteRule setting specifies how to match an HTTP request and the corresponding routing action that load balancing proxies perform.",
42552      "type": "object",
42553      "properties": {
42554        "priority": {
42555          "description": "For routeRules within a given pathMatcher, priority determines the order in which a load balancer interprets routeRules. RouteRules are evaluated in order of priority, from the lowest to highest number. The priority of a rule decreases as its number increases (1, 2, 3, N+1). The first rule that matches the request is applied. You cannot configure two or more routeRules with the same priority. Priority for each rule must be set to a number from 0 to 2147483647 inclusive. Priority numbers can have gaps, which enable you to add or remove rules in the future without affecting the rest of the rules. For example, 1, 2, 3, 4, 5, 9, 12, 16 is a valid series of priority numbers to which you could add rules numbered from 6 to 8, 10 to 11, and 13 to 15 in the future without any impact on existing rules.",
42556          "type": "integer",
42557          "format": "int32"
42558        },
42559        "description": {
42560          "description": "The short description conveying the intent of this routeRule. The description can have a maximum length of 1024 characters.",
42561          "type": "string"
42562        },
42563        "matchRules": {
42564          "description": "The list of criteria for matching attributes of a request to this routeRule. This list has OR semantics: the request matches this routeRule when any of the matchRules are satisfied. However predicates within a given matchRule have AND semantics. All predicates within a matchRule must match for the request to match the rule.",
42565          "type": "array",
42566          "items": {
42567            "$ref": "HttpRouteRuleMatch"
42568          }
42569        },
42570        "service": {
42571          "description": "The full or partial URL of the backend service resource to which traffic is directed if this rule is matched. If routeAction is also specified, advanced routing actions, such as URL rewrites, take effect before sending the request to the backend. However, if service is specified, routeAction cannot contain any weightedBackendServices. Conversely, if routeAction specifies any weightedBackendServices, service must not be specified. Only one of urlRedirect, service or routeAction.weightedBackendService must be set.",
42572          "type": "string"
42573        },
42574        "routeAction": {
42575          "description": "In response to a matching matchRule, the load balancer performs advanced routing actions, such as URL rewrites and header transformations, before forwarding the request to the selected backend. If routeAction specifies any weightedBackendServices, service must not be set. Conversely if service is set, routeAction cannot contain any weightedBackendServices. Only one of urlRedirect, service or routeAction.weightedBackendService must be set. URL maps for classic Application Load Balancers only support the urlRewrite action within a route rule's routeAction.",
42576          "$ref": "HttpRouteAction"
42577        },
42578        "urlRedirect": {
42579          "description": "When this rule is matched, the request is redirected to a URL specified by urlRedirect. If urlRedirect is specified, service or routeAction must not be set. Not supported when the URL map is bound to a target gRPC proxy.",
42580          "$ref": "HttpRedirectAction"
42581        },
42582        "headerAction": {
42583          "description": "Specifies changes to request and response headers that need to take effect for the selected backendService. The headerAction value specified here is applied before the matching pathMatchers[].headerAction and after pathMatchers[].routeRules[].routeAction.weightedBackendService.backendServiceWeightAction[].headerAction HeaderAction is not supported for load balancers that have their loadBalancingScheme set to EXTERNAL. Not supported when the URL map is bound to a target gRPC proxy that has validateForProxyless field set to true.",
42584          "$ref": "HttpHeaderAction"
42585        }
42586      }
42587    },
42588    "HttpRouteRuleMatch": {
42589      "id": "HttpRouteRuleMatch",
42590      "description": "HttpRouteRuleMatch specifies a set of criteria for matching requests to an HttpRouteRule. All specified criteria must be satisfied for a match to occur.",
42591      "type": "object",
42592      "properties": {
42593        "prefixMatch": {
42594          "description": "For satisfying the matchRule condition, the request's path must begin with the specified prefixMatch. prefixMatch must begin with a /. The value must be from 1 to 1024 characters. Only one of prefixMatch, fullPathMatch or regexMatch must be specified.",
42595          "type": "string"
42596        },
42597        "fullPathMatch": {
42598          "description": "For satisfying the matchRule condition, the path of the request must exactly match the value specified in fullPathMatch after removing any query parameters and anchor that may be part of the original URL. fullPathMatch must be from 1 to 1024 characters. Only one of prefixMatch, fullPathMatch or regexMatch must be specified.",
42599          "type": "string"
42600        },
42601        "regexMatch": {
42602          "description": "For satisfying the matchRule condition, the path of the request must satisfy the regular expression specified in regexMatch after removing any query parameters and anchor supplied with the original URL. For more information about regular expression syntax, see Syntax. Only one of prefixMatch, fullPathMatch or regexMatch must be specified. Regular expressions can only be used when the loadBalancingScheme is set to INTERNAL_SELF_MANAGED.",
42603          "type": "string"
42604        },
42605        "ignoreCase": {
42606          "description": "Specifies that prefixMatch and fullPathMatch matches are case sensitive. The default value is false. ignoreCase must not be used with regexMatch. Not supported when the URL map is bound to a target gRPC proxy.",
42607          "type": "boolean"
42608        },
42609        "headerMatches": {
42610          "description": "Specifies a list of header match criteria, all of which must match corresponding headers in the request.",
42611          "type": "array",
42612          "items": {
42613            "$ref": "HttpHeaderMatch"
42614          }
42615        },
42616        "queryParameterMatches": {
42617          "description": "Specifies a list of query parameter match criteria, all of which must match corresponding query parameters in the request. Not supported when the URL map is bound to a target gRPC proxy.",
42618          "type": "array",
42619          "items": {
42620            "$ref": "HttpQueryParameterMatch"
42621          }
42622        },
42623        "metadataFilters": {
42624          "description": "Opaque filter criteria used by the load balancer to restrict routing configuration to a limited set of xDS compliant clients. In their xDS requests to the load balancer, xDS clients present node metadata. When there is a match, the relevant routing configuration is made available to those proxies. For each metadataFilter in this list, if its filterMatchCriteria is set to MATCH_ANY, at least one of the filterLabels must match the corresponding label provided in the metadata. If its filterMatchCriteria is set to MATCH_ALL, then all of its filterLabels must match with corresponding labels provided in the metadata. If multiple metadata filters are specified, all of them need to be satisfied in order to be considered a match. metadataFilters specified here is applied after those specified in ForwardingRule that refers to the UrlMap this HttpRouteRuleMatch belongs to. metadataFilters only applies to load balancers that have loadBalancingScheme set to INTERNAL_SELF_MANAGED. Not supported when the URL map is bound to a target gRPC proxy that has validateForProxyless field set to true.",
42625          "type": "array",
42626          "items": {
42627            "$ref": "MetadataFilter"
42628          }
42629        },
42630        "pathTemplateMatch": {
42631          "description": "If specified, the route is a pattern match expression that must match the :path header once the query string is removed. A pattern match allows you to match - The value must be between 1 and 1024 characters - The pattern must start with a leading slash (\"/\") - There may be no more than 5 operators in pattern Precisely one of prefix_match, full_path_match, regex_match or path_template_match must be set.",
42632          "type": "string"
42633        }
42634      }
42635    },
42636    "HttpHeaderMatch": {
42637      "id": "HttpHeaderMatch",
42638      "description": "matchRule criteria for request header matches.",
42639      "type": "object",
42640      "properties": {
42641        "headerName": {
42642          "description": "The name of the HTTP header to match. For matching against the HTTP request's authority, use a headerMatch with the header name \":authority\". For matching a request's method, use the headerName \":method\". When the URL map is bound to a target gRPC proxy that has the validateForProxyless field set to true, only non-binary user-specified custom metadata and the `content-type` header are supported. The following transport-level headers cannot be used in header matching rules: `:authority`, `:method`, `:path`, `:scheme`, `user-agent`, `accept-encoding`, `content-encoding`, `grpc-accept-encoding`, `grpc-encoding`, `grpc-previous-rpc-attempts`, `grpc-tags-bin`, `grpc-timeout` and `grpc-trace-bin`.",
42643          "type": "string"
42644        },
42645        "exactMatch": {
42646          "description": "The value should exactly match contents of exactMatch. Only one of exactMatch, prefixMatch, suffixMatch, regexMatch, presentMatch or rangeMatch must be set.",
42647          "type": "string"
42648        },
42649        "regexMatch": {
42650          "description": "The value of the header must match the regular expression specified in regexMatch. For more information about regular expression syntax, see Syntax. For matching against a port specified in the HTTP request, use a headerMatch with headerName set to PORT and a regular expression that satisfies the RFC2616 Host header's port specifier. Only one of exactMatch, prefixMatch, suffixMatch, regexMatch, presentMatch or rangeMatch must be set. Regular expressions can only be used when the loadBalancingScheme is set to INTERNAL_SELF_MANAGED.",
42651          "type": "string"
42652        },
42653        "rangeMatch": {
42654          "description": "The header value must be an integer and its value must be in the range specified in rangeMatch. If the header does not contain an integer, number or is empty, the match fails. For example for a range [-5, 0] - -3 will match. - 0 will not match. - 0.25 will not match. - -3someString will not match. Only one of exactMatch, prefixMatch, suffixMatch, regexMatch, presentMatch or rangeMatch must be set. rangeMatch is not supported for load balancers that have loadBalancingScheme set to EXTERNAL.",
42655          "$ref": "Int64RangeMatch"
42656        },
42657        "presentMatch": {
42658          "description": "A header with the contents of headerName must exist. The match takes place whether or not the request's header has a value. Only one of exactMatch, prefixMatch, suffixMatch, regexMatch, presentMatch or rangeMatch must be set.",
42659          "type": "boolean"
42660        },
42661        "prefixMatch": {
42662          "description": "The value of the header must start with the contents of prefixMatch. Only one of exactMatch, prefixMatch, suffixMatch, regexMatch, presentMatch or rangeMatch must be set.",
42663          "type": "string"
42664        },
42665        "suffixMatch": {
42666          "description": "The value of the header must end with the contents of suffixMatch. Only one of exactMatch, prefixMatch, suffixMatch, regexMatch, presentMatch or rangeMatch must be set.",
42667          "type": "string"
42668        },
42669        "invertMatch": {
42670          "description": "If set to false, the headerMatch is considered a match if the preceding match criteria are met. If set to true, the headerMatch is considered a match if the preceding match criteria are NOT met. The default setting is false. ",
42671          "type": "boolean"
42672        }
42673      }
42674    },
42675    "Int64RangeMatch": {
42676      "id": "Int64RangeMatch",
42677      "description": "HttpRouteRuleMatch criteria for field values that must stay within the specified integer range.",
42678      "type": "object",
42679      "properties": {
42680        "rangeStart": {
42681          "description": "The start of the range (inclusive) in signed long integer format.",
42682          "type": "string",
42683          "format": "int64"
42684        },
42685        "rangeEnd": {
42686          "description": "The end of the range (exclusive) in signed long integer format.",
42687          "type": "string",
42688          "format": "int64"
42689        }
42690      }
42691    },
42692    "HttpQueryParameterMatch": {
42693      "id": "HttpQueryParameterMatch",
42694      "description": "HttpRouteRuleMatch criteria for a request's query parameter.",
42695      "type": "object",
42696      "properties": {
42697        "name": {
42698          "description": "The name of the query parameter to match. The query parameter must exist in the request, in the absence of which the request match fails.",
42699          "type": "string"
42700        },
42701        "presentMatch": {
42702          "description": "Specifies that the queryParameterMatch matches if the request contains the query parameter, irrespective of whether the parameter has a value or not. Only one of presentMatch, exactMatch, or regexMatch must be set. ",
42703          "type": "boolean"
42704        },
42705        "exactMatch": {
42706          "description": "The queryParameterMatch matches if the value of the parameter exactly matches the contents of exactMatch. Only one of presentMatch, exactMatch, or regexMatch must be set. ",
42707          "type": "string"
42708        },
42709        "regexMatch": {
42710          "description": "The queryParameterMatch matches if the value of the parameter matches the regular expression specified by regexMatch. For more information about regular expression syntax, see Syntax. Only one of presentMatch, exactMatch, or regexMatch must be set. Regular expressions can only be used when the loadBalancingScheme is set to INTERNAL_SELF_MANAGED. ",
42711          "type": "string"
42712        }
42713      }
42714    },
42715    "UrlMapTest": {
42716      "id": "UrlMapTest",
42717      "description": "Message for the expected URL mappings.",
42718      "type": "object",
42719      "properties": {
42720        "description": {
42721          "description": "Description of this test case.",
42722          "type": "string"
42723        },
42724        "host": {
42725          "description": "Host portion of the URL. If headers contains a host header, then host must also match the header value.",
42726          "type": "string"
42727        },
42728        "path": {
42729          "description": "Path portion of the URL.",
42730          "type": "string"
42731        },
42732        "headers": {
42733          "description": "HTTP headers for this request. If headers contains a host header, then host must also match the header value.",
42734          "type": "array",
42735          "items": {
42736            "$ref": "UrlMapTestHeader"
42737          }
42738        },
42739        "service": {
42740          "description": "Expected BackendService or BackendBucket resource the given URL should be mapped to. The service field cannot be set if expectedRedirectResponseCode is set.",
42741          "type": "string"
42742        },
42743        "expectedOutputUrl": {
42744          "description": "The expected output URL evaluated by the load balancer containing the scheme, host, path and query parameters. For rules that forward requests to backends, the test passes only when expectedOutputUrl matches the request forwarded by the load balancer to backends. For rules with urlRewrite, the test verifies that the forwarded request matches hostRewrite and pathPrefixRewrite in the urlRewrite action. When service is specified, expectedOutputUrl`s scheme is ignored. For rules with urlRedirect, the test passes only if expectedOutputUrl matches the URL in the load balancer's redirect response. If urlRedirect specifies https_redirect, the test passes only if the scheme in expectedOutputUrl is also set to HTTPS. If urlRedirect specifies strip_query, the test passes only if expectedOutputUrl does not contain any query parameters. expectedOutputUrl is optional when service is specified.",
42745          "type": "string"
42746        },
42747        "expectedRedirectResponseCode": {
42748          "description": "For rules with urlRedirect, the test passes only if expectedRedirectResponseCode matches the HTTP status code in load balancer's redirect response. expectedRedirectResponseCode cannot be set when service is set.",
42749          "type": "integer",
42750          "format": "int32"
42751        }
42752      }
42753    },
42754    "UrlMapTestHeader": {
42755      "id": "UrlMapTestHeader",
42756      "description": "HTTP headers used in UrlMapTests.",
42757      "type": "object",
42758      "properties": {
42759        "name": {
42760          "description": "Header name.",
42761          "type": "string"
42762        },
42763        "value": {
42764          "description": "Header value.",
42765          "type": "string"
42766        }
42767      }
42768    },
42769    "UrlMapsAggregatedList": {
42770      "id": "UrlMapsAggregatedList",
42771      "type": "object",
42772      "properties": {
42773        "kind": {
42774          "description": "Type of resource.",
42775          "default": "compute#urlMapsAggregatedList",
42776          "type": "string"
42777        },
42778        "id": {
42779          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
42780          "type": "string"
42781        },
42782        "items": {
42783          "description": "A list of UrlMapsScopedList resources.",
42784          "type": "object",
42785          "additionalProperties": {
42786            "description": "Name of the scope containing this set of UrlMaps.",
42787            "$ref": "UrlMapsScopedList"
42788          }
42789        },
42790        "nextPageToken": {
42791          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
42792          "type": "string"
42793        },
42794        "selfLink": {
42795          "description": "[Output Only] Server-defined URL for this resource.",
42796          "type": "string"
42797        },
42798        "warning": {
42799          "description": "[Output Only] Informational warning message.",
42800          "type": "object",
42801          "properties": {
42802            "code": {
42803              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
42804              "type": "string",
42805              "enumDescriptions": [
42806                "Warning about failed cleanup of transient changes made by a failed operation.",
42807                "A link to a deprecated resource was created.",
42808                "When deploying and at least one of the resources has a type marked as deprecated",
42809                "The user created a boot disk that is larger than image size.",
42810                "When deploying and at least one of the resources has a type marked as experimental",
42811                "Warning that is present in an external api call",
42812                "Warning that value of a field has been overridden. Deprecated unused field.",
42813                "The operation involved use of an injected kernel, which is deprecated.",
42814                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
42815                "When deploying a deployment with a exceedingly large number of resources",
42816                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
42817                "A resource depends on a missing type",
42818                "The route's nextHopIp address is not assigned to an instance on the network.",
42819                "The route's next hop instance cannot ip forward.",
42820                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
42821                "The route's nextHopInstance URL refers to an instance that does not exist.",
42822                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
42823                "The route's next hop instance does not have a status of RUNNING.",
42824                "Error which is not critical. We decided to continue the process despite the mentioned error.",
42825                "No results are present on a particular list page.",
42826                "Success is reported, but some results may be missing due to errors",
42827                "The user attempted to use a resource that requires a TOS they have not accepted.",
42828                "Warning that a resource is in use.",
42829                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
42830                "When a resource schema validation is ignored.",
42831                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
42832                "When undeclared properties in the schema are present",
42833                "A given scope cannot be reached."
42834              ],
42835              "enumDeprecated": [
42836                false,
42837                false,
42838                false,
42839                false,
42840                false,
42841                false,
42842                true,
42843                false,
42844                false,
42845                false,
42846                false,
42847                false,
42848                false,
42849                false,
42850                false,
42851                false,
42852                false,
42853                false,
42854                false,
42855                false,
42856                false,
42857                false,
42858                false,
42859                false,
42860                false,
42861                false,
42862                false,
42863                false
42864              ],
42865              "enum": [
42866                "CLEANUP_FAILED",
42867                "DEPRECATED_RESOURCE_USED",
42868                "DEPRECATED_TYPE_USED",
42869                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
42870                "EXPERIMENTAL_TYPE_USED",
42871                "EXTERNAL_API_WARNING",
42872                "FIELD_VALUE_OVERRIDEN",
42873                "INJECTED_KERNELS_DEPRECATED",
42874                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
42875                "LARGE_DEPLOYMENT_WARNING",
42876                "LIST_OVERHEAD_QUOTA_EXCEED",
42877                "MISSING_TYPE_DEPENDENCY",
42878                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
42879                "NEXT_HOP_CANNOT_IP_FORWARD",
42880                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
42881                "NEXT_HOP_INSTANCE_NOT_FOUND",
42882                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
42883                "NEXT_HOP_NOT_RUNNING",
42884                "NOT_CRITICAL_ERROR",
42885                "NO_RESULTS_ON_PAGE",
42886                "PARTIAL_SUCCESS",
42887                "REQUIRED_TOS_AGREEMENT",
42888                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
42889                "RESOURCE_NOT_DELETED",
42890                "SCHEMA_VALIDATION_IGNORED",
42891                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
42892                "UNDECLARED_PROPERTIES",
42893                "UNREACHABLE"
42894              ]
42895            },
42896            "message": {
42897              "description": "[Output Only] A human-readable description of the warning code.",
42898              "type": "string"
42899            },
42900            "data": {
42901              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
42902              "type": "array",
42903              "items": {
42904                "type": "object",
42905                "properties": {
42906                  "key": {
42907                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
42908                    "type": "string"
42909                  },
42910                  "value": {
42911                    "description": "[Output Only] A warning data value corresponding to the key.",
42912                    "type": "string"
42913                  }
42914                }
42915              }
42916            }
42917          }
42918        },
42919        "unreachables": {
42920          "description": "[Output Only] Unreachable resources.",
42921          "type": "array",
42922          "items": {
42923            "type": "string"
42924          }
42925        }
42926      }
42927    },
42928    "UrlMapsScopedList": {
42929      "id": "UrlMapsScopedList",
42930      "type": "object",
42931      "properties": {
42932        "urlMaps": {
42933          "description": "A list of UrlMaps contained in this scope.",
42934          "type": "array",
42935          "items": {
42936            "$ref": "UrlMap"
42937          }
42938        },
42939        "warning": {
42940          "description": "Informational warning which replaces the list of backend services when the list is empty.",
42941          "type": "object",
42942          "properties": {
42943            "code": {
42944              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
42945              "type": "string",
42946              "enumDescriptions": [
42947                "Warning about failed cleanup of transient changes made by a failed operation.",
42948                "A link to a deprecated resource was created.",
42949                "When deploying and at least one of the resources has a type marked as deprecated",
42950                "The user created a boot disk that is larger than image size.",
42951                "When deploying and at least one of the resources has a type marked as experimental",
42952                "Warning that is present in an external api call",
42953                "Warning that value of a field has been overridden. Deprecated unused field.",
42954                "The operation involved use of an injected kernel, which is deprecated.",
42955                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
42956                "When deploying a deployment with a exceedingly large number of resources",
42957                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
42958                "A resource depends on a missing type",
42959                "The route's nextHopIp address is not assigned to an instance on the network.",
42960                "The route's next hop instance cannot ip forward.",
42961                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
42962                "The route's nextHopInstance URL refers to an instance that does not exist.",
42963                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
42964                "The route's next hop instance does not have a status of RUNNING.",
42965                "Error which is not critical. We decided to continue the process despite the mentioned error.",
42966                "No results are present on a particular list page.",
42967                "Success is reported, but some results may be missing due to errors",
42968                "The user attempted to use a resource that requires a TOS they have not accepted.",
42969                "Warning that a resource is in use.",
42970                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
42971                "When a resource schema validation is ignored.",
42972                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
42973                "When undeclared properties in the schema are present",
42974                "A given scope cannot be reached."
42975              ],
42976              "enumDeprecated": [
42977                false,
42978                false,
42979                false,
42980                false,
42981                false,
42982                false,
42983                true,
42984                false,
42985                false,
42986                false,
42987                false,
42988                false,
42989                false,
42990                false,
42991                false,
42992                false,
42993                false,
42994                false,
42995                false,
42996                false,
42997                false,
42998                false,
42999                false,
43000                false,
43001                false,
43002                false,
43003                false,
43004                false
43005              ],
43006              "enum": [
43007                "CLEANUP_FAILED",
43008                "DEPRECATED_RESOURCE_USED",
43009                "DEPRECATED_TYPE_USED",
43010                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
43011                "EXPERIMENTAL_TYPE_USED",
43012                "EXTERNAL_API_WARNING",
43013                "FIELD_VALUE_OVERRIDEN",
43014                "INJECTED_KERNELS_DEPRECATED",
43015                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
43016                "LARGE_DEPLOYMENT_WARNING",
43017                "LIST_OVERHEAD_QUOTA_EXCEED",
43018                "MISSING_TYPE_DEPENDENCY",
43019                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
43020                "NEXT_HOP_CANNOT_IP_FORWARD",
43021                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
43022                "NEXT_HOP_INSTANCE_NOT_FOUND",
43023                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
43024                "NEXT_HOP_NOT_RUNNING",
43025                "NOT_CRITICAL_ERROR",
43026                "NO_RESULTS_ON_PAGE",
43027                "PARTIAL_SUCCESS",
43028                "REQUIRED_TOS_AGREEMENT",
43029                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
43030                "RESOURCE_NOT_DELETED",
43031                "SCHEMA_VALIDATION_IGNORED",
43032                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
43033                "UNDECLARED_PROPERTIES",
43034                "UNREACHABLE"
43035              ]
43036            },
43037            "message": {
43038              "description": "[Output Only] A human-readable description of the warning code.",
43039              "type": "string"
43040            },
43041            "data": {
43042              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
43043              "type": "array",
43044              "items": {
43045                "type": "object",
43046                "properties": {
43047                  "key": {
43048                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
43049                    "type": "string"
43050                  },
43051                  "value": {
43052                    "description": "[Output Only] A warning data value corresponding to the key.",
43053                    "type": "string"
43054                  }
43055                }
43056              }
43057            }
43058          }
43059        }
43060      }
43061    },
43062    "UrlMapsValidateRequest": {
43063      "id": "UrlMapsValidateRequest",
43064      "type": "object",
43065      "properties": {
43066        "resource": {
43067          "description": "Content of the UrlMap to be validated.",
43068          "$ref": "UrlMap"
43069        },
43070        "loadBalancingSchemes": {
43071          "description": "Specifies the load balancer type(s) this validation request is for. Use EXTERNAL_MANAGED for global external Application Load Balancers and regional external Application Load Balancers. Use EXTERNAL for classic Application Load Balancers. Use INTERNAL_MANAGED for internal Application Load Balancers. For more information, refer to Choosing a load balancer. If unspecified, the load balancing scheme will be inferred from the backend service resources this URL map references. If that can not be inferred (for example, this URL map only references backend buckets, or this Url map is for rewrites and redirects only and doesn't reference any backends), EXTERNAL will be used as the default type. If specified, the scheme(s) must not conflict with the load balancing scheme of the backend service resources this Url map references.",
43072          "type": "array",
43073          "items": {
43074            "type": "string",
43075            "enumDescriptions": [
43076              "Signifies that this will be used for classic Application Load Balancers.",
43077              "Signifies that this will be used for Envoy-based global external Application Load Balancers.",
43078              "If unspecified, the validation will try to infer the scheme from the backend service resources this Url map references. If the inference is not possible, EXTERNAL will be used as the default type."
43079            ],
43080            "enum": [
43081              "EXTERNAL",
43082              "EXTERNAL_MANAGED",
43083              "LOAD_BALANCING_SCHEME_UNSPECIFIED"
43084            ]
43085          }
43086        }
43087      }
43088    },
43089    "UrlMapsValidateResponse": {
43090      "id": "UrlMapsValidateResponse",
43091      "type": "object",
43092      "properties": {
43093        "result": {
43094          "$ref": "UrlMapValidationResult"
43095        }
43096      }
43097    },
43098    "UrlMapValidationResult": {
43099      "id": "UrlMapValidationResult",
43100      "description": "Message representing the validation result for a UrlMap.",
43101      "type": "object",
43102      "properties": {
43103        "loadSucceeded": {
43104          "description": "Whether the given UrlMap can be successfully loaded. If false, 'loadErrors' indicates the reasons.",
43105          "type": "boolean"
43106        },
43107        "loadErrors": {
43108          "type": "array",
43109          "items": {
43110            "type": "string"
43111          }
43112        },
43113        "testPassed": {
43114          "description": "If successfully loaded, this field indicates whether the test passed. If false, 'testFailures's indicate the reason of failure.",
43115          "type": "boolean"
43116        },
43117        "testFailures": {
43118          "type": "array",
43119          "items": {
43120            "$ref": "TestFailure"
43121          }
43122        }
43123      }
43124    },
43125    "TestFailure": {
43126      "id": "TestFailure",
43127      "type": "object",
43128      "properties": {
43129        "host": {
43130          "description": "Host portion of the URL.",
43131          "type": "string"
43132        },
43133        "path": {
43134          "description": "Path portion including query parameters in the URL.",
43135          "type": "string"
43136        },
43137        "headers": {
43138          "description": "HTTP headers of the request.",
43139          "type": "array",
43140          "items": {
43141            "$ref": "UrlMapTestHeader"
43142          }
43143        },
43144        "expectedService": {
43145          "description": "Expected BackendService or BackendBucket resource the given URL should be mapped to.",
43146          "type": "string"
43147        },
43148        "actualService": {
43149          "description": "BackendService or BackendBucket returned by load balancer.",
43150          "type": "string"
43151        },
43152        "expectedOutputUrl": {
43153          "description": "The expected output URL evaluated by a load balancer containing the scheme, host, path and query parameters.",
43154          "type": "string"
43155        },
43156        "actualOutputUrl": {
43157          "description": "The actual output URL evaluated by a load balancer containing the scheme, host, path and query parameters.",
43158          "type": "string"
43159        },
43160        "expectedRedirectResponseCode": {
43161          "description": "Expected HTTP status code for rule with `urlRedirect` calculated by load balancer",
43162          "type": "integer",
43163          "format": "int32"
43164        },
43165        "actualRedirectResponseCode": {
43166          "description": "Actual HTTP status code for rule with `urlRedirect` calculated by load balancer",
43167          "type": "integer",
43168          "format": "int32"
43169        }
43170      }
43171    },
43172    "CacheInvalidationRule": {
43173      "id": "CacheInvalidationRule",
43174      "type": "object",
43175      "properties": {
43176        "path": {
43177          "type": "string"
43178        },
43179        "host": {
43180          "description": "If set, this invalidation rule will only apply to requests with a Host header matching host.",
43181          "type": "string"
43182        }
43183      }
43184    },
43185    "RegionUrlMapsValidateRequest": {
43186      "id": "RegionUrlMapsValidateRequest",
43187      "type": "object",
43188      "properties": {
43189        "resource": {
43190          "description": "Content of the UrlMap to be validated.",
43191          "$ref": "UrlMap"
43192        }
43193      }
43194    },
43195    "VpnGatewayList": {
43196      "id": "VpnGatewayList",
43197      "description": "Contains a list of VpnGateway resources.",
43198      "type": "object",
43199      "properties": {
43200        "kind": {
43201          "description": "[Output Only] Type of resource. Always compute#vpnGateway for VPN gateways.",
43202          "default": "compute#vpnGatewayList",
43203          "type": "string"
43204        },
43205        "id": {
43206          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
43207          "type": "string"
43208        },
43209        "items": {
43210          "description": "A list of VpnGateway resources.",
43211          "type": "array",
43212          "items": {
43213            "$ref": "VpnGateway"
43214          }
43215        },
43216        "nextPageToken": {
43217          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
43218          "type": "string"
43219        },
43220        "selfLink": {
43221          "description": "[Output Only] Server-defined URL for this resource.",
43222          "type": "string"
43223        },
43224        "warning": {
43225          "description": "[Output Only] Informational warning message.",
43226          "type": "object",
43227          "properties": {
43228            "code": {
43229              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
43230              "type": "string",
43231              "enumDescriptions": [
43232                "Warning about failed cleanup of transient changes made by a failed operation.",
43233                "A link to a deprecated resource was created.",
43234                "When deploying and at least one of the resources has a type marked as deprecated",
43235                "The user created a boot disk that is larger than image size.",
43236                "When deploying and at least one of the resources has a type marked as experimental",
43237                "Warning that is present in an external api call",
43238                "Warning that value of a field has been overridden. Deprecated unused field.",
43239                "The operation involved use of an injected kernel, which is deprecated.",
43240                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
43241                "When deploying a deployment with a exceedingly large number of resources",
43242                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
43243                "A resource depends on a missing type",
43244                "The route's nextHopIp address is not assigned to an instance on the network.",
43245                "The route's next hop instance cannot ip forward.",
43246                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
43247                "The route's nextHopInstance URL refers to an instance that does not exist.",
43248                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
43249                "The route's next hop instance does not have a status of RUNNING.",
43250                "Error which is not critical. We decided to continue the process despite the mentioned error.",
43251                "No results are present on a particular list page.",
43252                "Success is reported, but some results may be missing due to errors",
43253                "The user attempted to use a resource that requires a TOS they have not accepted.",
43254                "Warning that a resource is in use.",
43255                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
43256                "When a resource schema validation is ignored.",
43257                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
43258                "When undeclared properties in the schema are present",
43259                "A given scope cannot be reached."
43260              ],
43261              "enumDeprecated": [
43262                false,
43263                false,
43264                false,
43265                false,
43266                false,
43267                false,
43268                true,
43269                false,
43270                false,
43271                false,
43272                false,
43273                false,
43274                false,
43275                false,
43276                false,
43277                false,
43278                false,
43279                false,
43280                false,
43281                false,
43282                false,
43283                false,
43284                false,
43285                false,
43286                false,
43287                false,
43288                false,
43289                false
43290              ],
43291              "enum": [
43292                "CLEANUP_FAILED",
43293                "DEPRECATED_RESOURCE_USED",
43294                "DEPRECATED_TYPE_USED",
43295                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
43296                "EXPERIMENTAL_TYPE_USED",
43297                "EXTERNAL_API_WARNING",
43298                "FIELD_VALUE_OVERRIDEN",
43299                "INJECTED_KERNELS_DEPRECATED",
43300                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
43301                "LARGE_DEPLOYMENT_WARNING",
43302                "LIST_OVERHEAD_QUOTA_EXCEED",
43303                "MISSING_TYPE_DEPENDENCY",
43304                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
43305                "NEXT_HOP_CANNOT_IP_FORWARD",
43306                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
43307                "NEXT_HOP_INSTANCE_NOT_FOUND",
43308                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
43309                "NEXT_HOP_NOT_RUNNING",
43310                "NOT_CRITICAL_ERROR",
43311                "NO_RESULTS_ON_PAGE",
43312                "PARTIAL_SUCCESS",
43313                "REQUIRED_TOS_AGREEMENT",
43314                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
43315                "RESOURCE_NOT_DELETED",
43316                "SCHEMA_VALIDATION_IGNORED",
43317                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
43318                "UNDECLARED_PROPERTIES",
43319                "UNREACHABLE"
43320              ]
43321            },
43322            "message": {
43323              "description": "[Output Only] A human-readable description of the warning code.",
43324              "type": "string"
43325            },
43326            "data": {
43327              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
43328              "type": "array",
43329              "items": {
43330                "type": "object",
43331                "properties": {
43332                  "key": {
43333                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
43334                    "type": "string"
43335                  },
43336                  "value": {
43337                    "description": "[Output Only] A warning data value corresponding to the key.",
43338                    "type": "string"
43339                  }
43340                }
43341              }
43342            }
43343          }
43344        }
43345      }
43346    },
43347    "VpnGateway": {
43348      "id": "VpnGateway",
43349      "description": "Represents a HA VPN gateway. HA VPN is a high-availability (HA) Cloud VPN solution that lets you securely connect your on-premises network to your Google Cloud Virtual Private Cloud network through an IPsec VPN connection in a single region. For more information about Cloud HA VPN solutions, see Cloud VPN topologies .",
43350      "type": "object",
43351      "properties": {
43352        "kind": {
43353          "description": "[Output Only] Type of resource. Always compute#vpnGateway for VPN gateways.",
43354          "default": "compute#vpnGateway",
43355          "type": "string"
43356        },
43357        "id": {
43358          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
43359          "type": "string",
43360          "format": "uint64"
43361        },
43362        "creationTimestamp": {
43363          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
43364          "type": "string"
43365        },
43366        "name": {
43367          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
43368          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
43369          "annotations": {
43370            "required": [
43371              "compute.vpnGateways.insert"
43372            ]
43373          },
43374          "type": "string"
43375        },
43376        "description": {
43377          "description": "An optional description of this resource. Provide this property when you create the resource.",
43378          "type": "string"
43379        },
43380        "region": {
43381          "description": "[Output Only] URL of the region where the VPN gateway resides.",
43382          "type": "string"
43383        },
43384        "network": {
43385          "description": "URL of the network to which this VPN gateway is attached. Provided by the client when the VPN gateway is created.",
43386          "annotations": {
43387            "required": [
43388              "compute.vpnGateways.insert"
43389            ]
43390          },
43391          "type": "string"
43392        },
43393        "selfLink": {
43394          "description": "[Output Only] Server-defined URL for the resource.",
43395          "type": "string"
43396        },
43397        "labels": {
43398          "description": "Labels for this resource. These can only be added or modified by the setLabels method. Each label key/value pair must comply with RFC1035. Label values may be empty.",
43399          "type": "object",
43400          "additionalProperties": {
43401            "type": "string"
43402          }
43403        },
43404        "labelFingerprint": {
43405          "description": "A fingerprint for the labels being applied to this VpnGateway, which is essentially a hash of the labels set used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve a VpnGateway.",
43406          "type": "string",
43407          "format": "byte"
43408        },
43409        "vpnInterfaces": {
43410          "description": "The list of VPN interfaces associated with this VPN gateway.",
43411          "type": "array",
43412          "items": {
43413            "$ref": "VpnGatewayVpnGatewayInterface"
43414          }
43415        },
43416        "stackType": {
43417          "description": "The stack type for this VPN gateway to identify the IP protocols that are enabled. Possible values are: IPV4_ONLY, IPV4_IPV6. If not specified, IPV4_ONLY will be used.",
43418          "type": "string",
43419          "enumDescriptions": [
43420            "Enable VPN gateway with both IPv4 and IPv6 protocols.",
43421            "Enable VPN gateway with only IPv4 protocol."
43422          ],
43423          "enum": [
43424            "IPV4_IPV6",
43425            "IPV4_ONLY"
43426          ]
43427        },
43428        "gatewayIpVersion": {
43429          "description": "The IP family of the gateway IPs for the HA-VPN gateway interfaces. If not specified, IPV4 will be used.",
43430          "type": "string",
43431          "enumDescriptions": [
43432            "Every HA-VPN gateway interface is configured with an IPv4 address.",
43433            "Every HA-VPN gateway interface is configured with an IPv6 address."
43434          ],
43435          "enum": [
43436            "IPV4",
43437            "IPV6"
43438          ]
43439        }
43440      }
43441    },
43442    "VpnGatewayVpnGatewayInterface": {
43443      "id": "VpnGatewayVpnGatewayInterface",
43444      "description": "A VPN gateway interface.",
43445      "type": "object",
43446      "properties": {
43447        "id": {
43448          "description": "[Output Only] Numeric identifier for this VPN interface associated with the VPN gateway.",
43449          "type": "integer",
43450          "format": "uint32"
43451        },
43452        "ipAddress": {
43453          "description": "[Output Only] IP address for this VPN interface associated with the VPN gateway. The IP address could be either a regional external IP address or a regional internal IP address. The two IP addresses for a VPN gateway must be all regional external or regional internal IP addresses. There cannot be a mix of regional external IP addresses and regional internal IP addresses. For HA VPN over Cloud Interconnect, the IP addresses for both interfaces could either be regional internal IP addresses or regional external IP addresses. For regular (non HA VPN over Cloud Interconnect) HA VPN tunnels, the IP address must be a regional external IP address.",
43454          "type": "string"
43455        },
43456        "ipv6Address": {
43457          "description": "[Output Only] IPv6 address for this VPN interface associated with the VPN gateway. The IPv6 address must be a regional external IPv6 address. The format is RFC 5952 format (e.g. 2001:db8::2d9:51:0:0).",
43458          "type": "string"
43459        },
43460        "interconnectAttachment": {
43461          "description": "URL of the VLAN attachment (interconnectAttachment) resource for this VPN gateway interface. When the value of this field is present, the VPN gateway is used for HA VPN over Cloud Interconnect; all egress or ingress traffic for this VPN gateway interface goes through the specified VLAN attachment resource.",
43462          "type": "string"
43463        }
43464      }
43465    },
43466    "VpnGatewayAggregatedList": {
43467      "id": "VpnGatewayAggregatedList",
43468      "type": "object",
43469      "properties": {
43470        "kind": {
43471          "description": "[Output Only] Type of resource. Always compute#vpnGateway for VPN gateways.",
43472          "default": "compute#vpnGatewayAggregatedList",
43473          "type": "string"
43474        },
43475        "id": {
43476          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
43477          "type": "string"
43478        },
43479        "items": {
43480          "description": "A list of VpnGateway resources.",
43481          "type": "object",
43482          "additionalProperties": {
43483            "description": "[Output Only] Name of the scope containing this set of VPN gateways.",
43484            "$ref": "VpnGatewaysScopedList"
43485          }
43486        },
43487        "nextPageToken": {
43488          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
43489          "type": "string"
43490        },
43491        "selfLink": {
43492          "description": "[Output Only] Server-defined URL for this resource.",
43493          "type": "string"
43494        },
43495        "warning": {
43496          "description": "[Output Only] Informational warning message.",
43497          "type": "object",
43498          "properties": {
43499            "code": {
43500              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
43501              "type": "string",
43502              "enumDescriptions": [
43503                "Warning about failed cleanup of transient changes made by a failed operation.",
43504                "A link to a deprecated resource was created.",
43505                "When deploying and at least one of the resources has a type marked as deprecated",
43506                "The user created a boot disk that is larger than image size.",
43507                "When deploying and at least one of the resources has a type marked as experimental",
43508                "Warning that is present in an external api call",
43509                "Warning that value of a field has been overridden. Deprecated unused field.",
43510                "The operation involved use of an injected kernel, which is deprecated.",
43511                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
43512                "When deploying a deployment with a exceedingly large number of resources",
43513                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
43514                "A resource depends on a missing type",
43515                "The route's nextHopIp address is not assigned to an instance on the network.",
43516                "The route's next hop instance cannot ip forward.",
43517                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
43518                "The route's nextHopInstance URL refers to an instance that does not exist.",
43519                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
43520                "The route's next hop instance does not have a status of RUNNING.",
43521                "Error which is not critical. We decided to continue the process despite the mentioned error.",
43522                "No results are present on a particular list page.",
43523                "Success is reported, but some results may be missing due to errors",
43524                "The user attempted to use a resource that requires a TOS they have not accepted.",
43525                "Warning that a resource is in use.",
43526                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
43527                "When a resource schema validation is ignored.",
43528                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
43529                "When undeclared properties in the schema are present",
43530                "A given scope cannot be reached."
43531              ],
43532              "enumDeprecated": [
43533                false,
43534                false,
43535                false,
43536                false,
43537                false,
43538                false,
43539                true,
43540                false,
43541                false,
43542                false,
43543                false,
43544                false,
43545                false,
43546                false,
43547                false,
43548                false,
43549                false,
43550                false,
43551                false,
43552                false,
43553                false,
43554                false,
43555                false,
43556                false,
43557                false,
43558                false,
43559                false,
43560                false
43561              ],
43562              "enum": [
43563                "CLEANUP_FAILED",
43564                "DEPRECATED_RESOURCE_USED",
43565                "DEPRECATED_TYPE_USED",
43566                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
43567                "EXPERIMENTAL_TYPE_USED",
43568                "EXTERNAL_API_WARNING",
43569                "FIELD_VALUE_OVERRIDEN",
43570                "INJECTED_KERNELS_DEPRECATED",
43571                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
43572                "LARGE_DEPLOYMENT_WARNING",
43573                "LIST_OVERHEAD_QUOTA_EXCEED",
43574                "MISSING_TYPE_DEPENDENCY",
43575                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
43576                "NEXT_HOP_CANNOT_IP_FORWARD",
43577                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
43578                "NEXT_HOP_INSTANCE_NOT_FOUND",
43579                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
43580                "NEXT_HOP_NOT_RUNNING",
43581                "NOT_CRITICAL_ERROR",
43582                "NO_RESULTS_ON_PAGE",
43583                "PARTIAL_SUCCESS",
43584                "REQUIRED_TOS_AGREEMENT",
43585                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
43586                "RESOURCE_NOT_DELETED",
43587                "SCHEMA_VALIDATION_IGNORED",
43588                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
43589                "UNDECLARED_PROPERTIES",
43590                "UNREACHABLE"
43591              ]
43592            },
43593            "message": {
43594              "description": "[Output Only] A human-readable description of the warning code.",
43595              "type": "string"
43596            },
43597            "data": {
43598              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
43599              "type": "array",
43600              "items": {
43601                "type": "object",
43602                "properties": {
43603                  "key": {
43604                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
43605                    "type": "string"
43606                  },
43607                  "value": {
43608                    "description": "[Output Only] A warning data value corresponding to the key.",
43609                    "type": "string"
43610                  }
43611                }
43612              }
43613            }
43614          }
43615        },
43616        "unreachables": {
43617          "description": "[Output Only] Unreachable resources.",
43618          "type": "array",
43619          "items": {
43620            "type": "string"
43621          }
43622        }
43623      }
43624    },
43625    "VpnGatewaysScopedList": {
43626      "id": "VpnGatewaysScopedList",
43627      "type": "object",
43628      "properties": {
43629        "vpnGateways": {
43630          "description": "[Output Only] A list of VPN gateways contained in this scope.",
43631          "type": "array",
43632          "items": {
43633            "$ref": "VpnGateway"
43634          }
43635        },
43636        "warning": {
43637          "description": "[Output Only] Informational warning which replaces the list of addresses when the list is empty.",
43638          "type": "object",
43639          "properties": {
43640            "code": {
43641              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
43642              "type": "string",
43643              "enumDescriptions": [
43644                "Warning about failed cleanup of transient changes made by a failed operation.",
43645                "A link to a deprecated resource was created.",
43646                "When deploying and at least one of the resources has a type marked as deprecated",
43647                "The user created a boot disk that is larger than image size.",
43648                "When deploying and at least one of the resources has a type marked as experimental",
43649                "Warning that is present in an external api call",
43650                "Warning that value of a field has been overridden. Deprecated unused field.",
43651                "The operation involved use of an injected kernel, which is deprecated.",
43652                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
43653                "When deploying a deployment with a exceedingly large number of resources",
43654                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
43655                "A resource depends on a missing type",
43656                "The route's nextHopIp address is not assigned to an instance on the network.",
43657                "The route's next hop instance cannot ip forward.",
43658                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
43659                "The route's nextHopInstance URL refers to an instance that does not exist.",
43660                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
43661                "The route's next hop instance does not have a status of RUNNING.",
43662                "Error which is not critical. We decided to continue the process despite the mentioned error.",
43663                "No results are present on a particular list page.",
43664                "Success is reported, but some results may be missing due to errors",
43665                "The user attempted to use a resource that requires a TOS they have not accepted.",
43666                "Warning that a resource is in use.",
43667                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
43668                "When a resource schema validation is ignored.",
43669                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
43670                "When undeclared properties in the schema are present",
43671                "A given scope cannot be reached."
43672              ],
43673              "enumDeprecated": [
43674                false,
43675                false,
43676                false,
43677                false,
43678                false,
43679                false,
43680                true,
43681                false,
43682                false,
43683                false,
43684                false,
43685                false,
43686                false,
43687                false,
43688                false,
43689                false,
43690                false,
43691                false,
43692                false,
43693                false,
43694                false,
43695                false,
43696                false,
43697                false,
43698                false,
43699                false,
43700                false,
43701                false
43702              ],
43703              "enum": [
43704                "CLEANUP_FAILED",
43705                "DEPRECATED_RESOURCE_USED",
43706                "DEPRECATED_TYPE_USED",
43707                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
43708                "EXPERIMENTAL_TYPE_USED",
43709                "EXTERNAL_API_WARNING",
43710                "FIELD_VALUE_OVERRIDEN",
43711                "INJECTED_KERNELS_DEPRECATED",
43712                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
43713                "LARGE_DEPLOYMENT_WARNING",
43714                "LIST_OVERHEAD_QUOTA_EXCEED",
43715                "MISSING_TYPE_DEPENDENCY",
43716                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
43717                "NEXT_HOP_CANNOT_IP_FORWARD",
43718                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
43719                "NEXT_HOP_INSTANCE_NOT_FOUND",
43720                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
43721                "NEXT_HOP_NOT_RUNNING",
43722                "NOT_CRITICAL_ERROR",
43723                "NO_RESULTS_ON_PAGE",
43724                "PARTIAL_SUCCESS",
43725                "REQUIRED_TOS_AGREEMENT",
43726                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
43727                "RESOURCE_NOT_DELETED",
43728                "SCHEMA_VALIDATION_IGNORED",
43729                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
43730                "UNDECLARED_PROPERTIES",
43731                "UNREACHABLE"
43732              ]
43733            },
43734            "message": {
43735              "description": "[Output Only] A human-readable description of the warning code.",
43736              "type": "string"
43737            },
43738            "data": {
43739              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
43740              "type": "array",
43741              "items": {
43742                "type": "object",
43743                "properties": {
43744                  "key": {
43745                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
43746                    "type": "string"
43747                  },
43748                  "value": {
43749                    "description": "[Output Only] A warning data value corresponding to the key.",
43750                    "type": "string"
43751                  }
43752                }
43753              }
43754            }
43755          }
43756        }
43757      }
43758    },
43759    "VpnGatewaysGetStatusResponse": {
43760      "id": "VpnGatewaysGetStatusResponse",
43761      "type": "object",
43762      "properties": {
43763        "result": {
43764          "$ref": "VpnGatewayStatus"
43765        }
43766      }
43767    },
43768    "VpnGatewayStatus": {
43769      "id": "VpnGatewayStatus",
43770      "type": "object",
43771      "properties": {
43772        "vpnConnections": {
43773          "description": "List of VPN connection for this VpnGateway.",
43774          "type": "array",
43775          "items": {
43776            "$ref": "VpnGatewayStatusVpnConnection"
43777          }
43778        }
43779      }
43780    },
43781    "VpnGatewayStatusVpnConnection": {
43782      "id": "VpnGatewayStatusVpnConnection",
43783      "description": "A VPN connection contains all VPN tunnels connected from this VpnGateway to the same peer gateway. The peer gateway could either be an external VPN gateway or a Google Cloud VPN gateway.",
43784      "type": "object",
43785      "properties": {
43786        "peerExternalGateway": {
43787          "description": "URL reference to the peer external VPN gateways to which the VPN tunnels in this VPN connection are connected. This field is mutually exclusive with peer_gcp_gateway.",
43788          "type": "string"
43789        },
43790        "peerGcpGateway": {
43791          "description": "URL reference to the peer side VPN gateways to which the VPN tunnels in this VPN connection are connected. This field is mutually exclusive with peer_gcp_gateway.",
43792          "type": "string"
43793        },
43794        "tunnels": {
43795          "description": "List of VPN tunnels that are in this VPN connection.",
43796          "type": "array",
43797          "items": {
43798            "$ref": "VpnGatewayStatusTunnel"
43799          }
43800        },
43801        "state": {
43802          "description": "HighAvailabilityRequirementState for the VPN connection.",
43803          "$ref": "VpnGatewayStatusHighAvailabilityRequirementState"
43804        }
43805      }
43806    },
43807    "VpnGatewayStatusTunnel": {
43808      "id": "VpnGatewayStatusTunnel",
43809      "description": "Contains some information about a VPN tunnel.",
43810      "type": "object",
43811      "properties": {
43812        "localGatewayInterface": {
43813          "description": "The VPN gateway interface this VPN tunnel is associated with.",
43814          "type": "integer",
43815          "format": "uint32"
43816        },
43817        "peerGatewayInterface": {
43818          "description": "The peer gateway interface this VPN tunnel is connected to, the peer gateway could either be an external VPN gateway or a Google Cloud VPN gateway.",
43819          "type": "integer",
43820          "format": "uint32"
43821        },
43822        "tunnelUrl": {
43823          "description": "URL reference to the VPN tunnel.",
43824          "type": "string"
43825        }
43826      }
43827    },
43828    "VpnGatewayStatusHighAvailabilityRequirementState": {
43829      "id": "VpnGatewayStatusHighAvailabilityRequirementState",
43830      "description": "Describes the high availability requirement state for the VPN connection between this Cloud VPN gateway and a peer gateway.",
43831      "type": "object",
43832      "properties": {
43833        "state": {
43834          "description": "Indicates the high availability requirement state for the VPN connection. Valid values are CONNECTION_REDUNDANCY_MET, CONNECTION_REDUNDANCY_NOT_MET.",
43835          "type": "string",
43836          "enumDescriptions": [
43837            "VPN tunnels are configured with adequate redundancy from Cloud VPN gateway to the peer VPN gateway. For both GCP-to-non-GCP and GCP-to-GCP connections, the adequate redundancy is a pre-requirement for users to get 99.99% availability on GCP side; please note that for any connection, end-to-end 99.99% availability is subject to proper configuration on the peer VPN gateway.",
43838            "VPN tunnels are not configured with adequate redundancy from the Cloud VPN gateway to the peer gateway"
43839          ],
43840          "enum": [
43841            "CONNECTION_REDUNDANCY_MET",
43842            "CONNECTION_REDUNDANCY_NOT_MET"
43843          ]
43844        },
43845        "unsatisfiedReason": {
43846          "description": "Indicates the reason why the VPN connection does not meet the high availability redundancy criteria/requirement. Valid values is INCOMPLETE_TUNNELS_COVERAGE.",
43847          "type": "string",
43848          "enumDescriptions": [
43849            ""
43850          ],
43851          "enum": [
43852            "INCOMPLETE_TUNNELS_COVERAGE"
43853          ]
43854        }
43855      }
43856    },
43857    "VpnTunnelList": {
43858      "id": "VpnTunnelList",
43859      "description": "Contains a list of VpnTunnel resources.",
43860      "type": "object",
43861      "properties": {
43862        "kind": {
43863          "description": "[Output Only] Type of resource. Always compute#vpnTunnel for VPN tunnels.",
43864          "default": "compute#vpnTunnelList",
43865          "type": "string"
43866        },
43867        "id": {
43868          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
43869          "type": "string"
43870        },
43871        "items": {
43872          "description": "A list of VpnTunnel resources.",
43873          "type": "array",
43874          "items": {
43875            "$ref": "VpnTunnel"
43876          }
43877        },
43878        "nextPageToken": {
43879          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
43880          "type": "string"
43881        },
43882        "selfLink": {
43883          "description": "[Output Only] Server-defined URL for this resource.",
43884          "type": "string"
43885        },
43886        "warning": {
43887          "description": "[Output Only] Informational warning message.",
43888          "type": "object",
43889          "properties": {
43890            "code": {
43891              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
43892              "type": "string",
43893              "enumDescriptions": [
43894                "Warning about failed cleanup of transient changes made by a failed operation.",
43895                "A link to a deprecated resource was created.",
43896                "When deploying and at least one of the resources has a type marked as deprecated",
43897                "The user created a boot disk that is larger than image size.",
43898                "When deploying and at least one of the resources has a type marked as experimental",
43899                "Warning that is present in an external api call",
43900                "Warning that value of a field has been overridden. Deprecated unused field.",
43901                "The operation involved use of an injected kernel, which is deprecated.",
43902                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
43903                "When deploying a deployment with a exceedingly large number of resources",
43904                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
43905                "A resource depends on a missing type",
43906                "The route's nextHopIp address is not assigned to an instance on the network.",
43907                "The route's next hop instance cannot ip forward.",
43908                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
43909                "The route's nextHopInstance URL refers to an instance that does not exist.",
43910                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
43911                "The route's next hop instance does not have a status of RUNNING.",
43912                "Error which is not critical. We decided to continue the process despite the mentioned error.",
43913                "No results are present on a particular list page.",
43914                "Success is reported, but some results may be missing due to errors",
43915                "The user attempted to use a resource that requires a TOS they have not accepted.",
43916                "Warning that a resource is in use.",
43917                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
43918                "When a resource schema validation is ignored.",
43919                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
43920                "When undeclared properties in the schema are present",
43921                "A given scope cannot be reached."
43922              ],
43923              "enumDeprecated": [
43924                false,
43925                false,
43926                false,
43927                false,
43928                false,
43929                false,
43930                true,
43931                false,
43932                false,
43933                false,
43934                false,
43935                false,
43936                false,
43937                false,
43938                false,
43939                false,
43940                false,
43941                false,
43942                false,
43943                false,
43944                false,
43945                false,
43946                false,
43947                false,
43948                false,
43949                false,
43950                false,
43951                false
43952              ],
43953              "enum": [
43954                "CLEANUP_FAILED",
43955                "DEPRECATED_RESOURCE_USED",
43956                "DEPRECATED_TYPE_USED",
43957                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
43958                "EXPERIMENTAL_TYPE_USED",
43959                "EXTERNAL_API_WARNING",
43960                "FIELD_VALUE_OVERRIDEN",
43961                "INJECTED_KERNELS_DEPRECATED",
43962                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
43963                "LARGE_DEPLOYMENT_WARNING",
43964                "LIST_OVERHEAD_QUOTA_EXCEED",
43965                "MISSING_TYPE_DEPENDENCY",
43966                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
43967                "NEXT_HOP_CANNOT_IP_FORWARD",
43968                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
43969                "NEXT_HOP_INSTANCE_NOT_FOUND",
43970                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
43971                "NEXT_HOP_NOT_RUNNING",
43972                "NOT_CRITICAL_ERROR",
43973                "NO_RESULTS_ON_PAGE",
43974                "PARTIAL_SUCCESS",
43975                "REQUIRED_TOS_AGREEMENT",
43976                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
43977                "RESOURCE_NOT_DELETED",
43978                "SCHEMA_VALIDATION_IGNORED",
43979                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
43980                "UNDECLARED_PROPERTIES",
43981                "UNREACHABLE"
43982              ]
43983            },
43984            "message": {
43985              "description": "[Output Only] A human-readable description of the warning code.",
43986              "type": "string"
43987            },
43988            "data": {
43989              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
43990              "type": "array",
43991              "items": {
43992                "type": "object",
43993                "properties": {
43994                  "key": {
43995                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
43996                    "type": "string"
43997                  },
43998                  "value": {
43999                    "description": "[Output Only] A warning data value corresponding to the key.",
44000                    "type": "string"
44001                  }
44002                }
44003              }
44004            }
44005          }
44006        }
44007      }
44008    },
44009    "VpnTunnel": {
44010      "id": "VpnTunnel",
44011      "description": "Represents a Cloud VPN Tunnel resource. For more information about VPN, read the the Cloud VPN Overview.",
44012      "type": "object",
44013      "properties": {
44014        "kind": {
44015          "description": "[Output Only] Type of resource. Always compute#vpnTunnel for VPN tunnels.",
44016          "default": "compute#vpnTunnel",
44017          "type": "string"
44018        },
44019        "id": {
44020          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
44021          "type": "string",
44022          "format": "uint64"
44023        },
44024        "creationTimestamp": {
44025          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
44026          "type": "string"
44027        },
44028        "name": {
44029          "description": "Name of the resource. Provided by the client when the resource is created. The name must be 1-63 characters long, and comply with RFC1035. Specifically, the name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash.",
44030          "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
44031          "annotations": {
44032            "required": [
44033              "compute.vpnTunnels.insert"
44034            ]
44035          },
44036          "type": "string"
44037        },
44038        "description": {
44039          "description": "An optional description of this resource. Provide this property when you create the resource.",
44040          "type": "string"
44041        },
44042        "region": {
44043          "description": "[Output Only] URL of the region where the VPN tunnel resides. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.",
44044          "type": "string"
44045        },
44046        "targetVpnGateway": {
44047          "description": "URL of the Target VPN gateway with which this VPN tunnel is associated. Provided by the client when the VPN tunnel is created.",
44048          "type": "string"
44049        },
44050        "vpnGateway": {
44051          "description": "URL of the VPN gateway with which this VPN tunnel is associated. Provided by the client when the VPN tunnel is created. This must be used (instead of target_vpn_gateway) if a High Availability VPN gateway resource is created.",
44052          "type": "string"
44053        },
44054        "vpnGatewayInterface": {
44055          "description": "The interface ID of the VPN gateway with which this VPN tunnel is associated. Possible values are: `0`, `1`.",
44056          "type": "integer",
44057          "format": "int32"
44058        },
44059        "peerExternalGateway": {
44060          "description": "URL of the peer side external VPN gateway to which this VPN tunnel is connected. Provided by the client when the VPN tunnel is created. This field is exclusive with the field peerGcpGateway.",
44061          "type": "string"
44062        },
44063        "peerExternalGatewayInterface": {
44064          "description": "The interface ID of the external VPN gateway to which this VPN tunnel is connected. Provided by the client when the VPN tunnel is created. Possible values are: `0`, `1`, `2`, `3`. The number of IDs in use depends on the external VPN gateway redundancy type.",
44065          "type": "integer",
44066          "format": "int32"
44067        },
44068        "peerGcpGateway": {
44069          "description": "URL of the peer side HA VPN gateway to which this VPN tunnel is connected. Provided by the client when the VPN tunnel is created. This field can be used when creating highly available VPN from VPC network to VPC network, the field is exclusive with the field peerExternalGateway. If provided, the VPN tunnel will automatically use the same vpnGatewayInterface ID in the peer Google Cloud VPN gateway.",
44070          "type": "string"
44071        },
44072        "router": {
44073          "description": "URL of the router resource to be used for dynamic routing.",
44074          "type": "string"
44075        },
44076        "peerIp": {
44077          "description": "IP address of the peer VPN gateway. Only IPv4 is supported.",
44078          "type": "string"
44079        },
44080        "sharedSecret": {
44081          "description": "Shared secret used to set the secure session between the Cloud VPN gateway and the peer VPN gateway.",
44082          "type": "string"
44083        },
44084        "sharedSecretHash": {
44085          "description": "Hash of the shared secret.",
44086          "type": "string"
44087        },
44088        "status": {
44089          "description": "[Output Only] The status of the VPN tunnel, which can be one of the following: - PROVISIONING: Resource is being allocated for the VPN tunnel. - WAITING_FOR_FULL_CONFIG: Waiting to receive all VPN-related configs from the user. Network, TargetVpnGateway, VpnTunnel, ForwardingRule, and Route resources are needed to setup the VPN tunnel. - FIRST_HANDSHAKE: Successful first handshake with the peer VPN. - ESTABLISHED: Secure session is successfully established with the peer VPN. - NETWORK_ERROR: Deprecated, replaced by NO_INCOMING_PACKETS - AUTHORIZATION_ERROR: Auth error (for example, bad shared secret). - NEGOTIATION_FAILURE: Handshake failed. - DEPROVISIONING: Resources are being deallocated for the VPN tunnel. - FAILED: Tunnel creation has failed and the tunnel is not ready to be used. - NO_INCOMING_PACKETS: No incoming packets from peer. - REJECTED: Tunnel configuration was rejected, can be result of being denied access. - ALLOCATING_RESOURCES: Cloud VPN is in the process of allocating all required resources. - STOPPED: Tunnel is stopped due to its Forwarding Rules being deleted for Classic VPN tunnels or the project is in frozen state. - PEER_IDENTITY_MISMATCH: Peer identity does not match peer IP, probably behind NAT. - TS_NARROWING_NOT_ALLOWED: Traffic selector narrowing not allowed for an HA-VPN tunnel. ",
44090          "type": "string",
44091          "enumDescriptions": [
44092            "Cloud VPN is in the process of allocating all required resources (specifically, a borg task).",
44093            "Auth error (e.g. bad shared secret).",
44094            "Resources is being deallocated for the VPN tunnel.",
44095            "Secure session is successfully established with peer VPN.",
44096            "Tunnel creation has failed and the tunnel is not ready to be used.",
44097            "Successful first handshake with peer VPN.",
44098            "Handshake failed.",
44099            "Deprecated, replaced by NO_INCOMING_PACKETS",
44100            "No incoming packets from peer",
44101            "Resource is being allocated for the VPN tunnel.",
44102            "Tunnel configuration was rejected, can be result of being denylisted.",
44103            "Tunnel is stopped due to its Forwarding Rules being deleted.",
44104            "Waiting to receive all VPN-related configs from user. Network, TargetVpnGateway, VpnTunnel, ForwardingRule and Route resources are needed to setup VPN tunnel."
44105          ],
44106          "enum": [
44107            "ALLOCATING_RESOURCES",
44108            "AUTHORIZATION_ERROR",
44109            "DEPROVISIONING",
44110            "ESTABLISHED",
44111            "FAILED",
44112            "FIRST_HANDSHAKE",
44113            "NEGOTIATION_FAILURE",
44114            "NETWORK_ERROR",
44115            "NO_INCOMING_PACKETS",
44116            "PROVISIONING",
44117            "REJECTED",
44118            "STOPPED",
44119            "WAITING_FOR_FULL_CONFIG"
44120          ]
44121        },
44122        "selfLink": {
44123          "description": "[Output Only] Server-defined URL for the resource.",
44124          "type": "string"
44125        },
44126        "ikeVersion": {
44127          "description": "IKE protocol version to use when establishing the VPN tunnel with the peer VPN gateway. Acceptable IKE versions are 1 or 2. The default version is 2.",
44128          "type": "integer",
44129          "format": "int32"
44130        },
44131        "detailedStatus": {
44132          "description": "[Output Only] Detailed status message for the VPN tunnel.",
44133          "type": "string"
44134        },
44135        "localTrafficSelector": {
44136          "description": "Local traffic selector to use when establishing the VPN tunnel with the peer VPN gateway. The value should be a CIDR formatted string, for example: 192.168.0.0/16. The ranges must be disjoint. Only IPv4 is supported.",
44137          "type": "array",
44138          "items": {
44139            "type": "string"
44140          }
44141        },
44142        "remoteTrafficSelector": {
44143          "description": "Remote traffic selectors to use when establishing the VPN tunnel with the peer VPN gateway. The value should be a CIDR formatted string, for example: 192.168.0.0/16. The ranges should be disjoint. Only IPv4 is supported.",
44144          "type": "array",
44145          "items": {
44146            "type": "string"
44147          }
44148        },
44149        "labels": {
44150          "description": "Labels for this resource. These can only be added or modified by the setLabels method. Each label key/value pair must comply with RFC1035. Label values may be empty.",
44151          "type": "object",
44152          "additionalProperties": {
44153            "type": "string"
44154          }
44155        },
44156        "labelFingerprint": {
44157          "description": "A fingerprint for the labels being applied to this VpnTunnel, which is essentially a hash of the labels set used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels, otherwise the request will fail with error 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve a VpnTunnel.",
44158          "type": "string",
44159          "format": "byte"
44160        }
44161      }
44162    },
44163    "VpnTunnelAggregatedList": {
44164      "id": "VpnTunnelAggregatedList",
44165      "type": "object",
44166      "properties": {
44167        "kind": {
44168          "description": "[Output Only] Type of resource. Always compute#vpnTunnel for VPN tunnels.",
44169          "default": "compute#vpnTunnelAggregatedList",
44170          "type": "string"
44171        },
44172        "id": {
44173          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
44174          "type": "string"
44175        },
44176        "items": {
44177          "description": "A list of VpnTunnelsScopedList resources.",
44178          "type": "object",
44179          "additionalProperties": {
44180            "description": "Name of the scope containing this set of VPN tunnels.",
44181            "$ref": "VpnTunnelsScopedList"
44182          }
44183        },
44184        "nextPageToken": {
44185          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
44186          "type": "string"
44187        },
44188        "selfLink": {
44189          "description": "[Output Only] Server-defined URL for this resource.",
44190          "type": "string"
44191        },
44192        "warning": {
44193          "description": "[Output Only] Informational warning message.",
44194          "type": "object",
44195          "properties": {
44196            "code": {
44197              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
44198              "type": "string",
44199              "enumDescriptions": [
44200                "Warning about failed cleanup of transient changes made by a failed operation.",
44201                "A link to a deprecated resource was created.",
44202                "When deploying and at least one of the resources has a type marked as deprecated",
44203                "The user created a boot disk that is larger than image size.",
44204                "When deploying and at least one of the resources has a type marked as experimental",
44205                "Warning that is present in an external api call",
44206                "Warning that value of a field has been overridden. Deprecated unused field.",
44207                "The operation involved use of an injected kernel, which is deprecated.",
44208                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
44209                "When deploying a deployment with a exceedingly large number of resources",
44210                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
44211                "A resource depends on a missing type",
44212                "The route's nextHopIp address is not assigned to an instance on the network.",
44213                "The route's next hop instance cannot ip forward.",
44214                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
44215                "The route's nextHopInstance URL refers to an instance that does not exist.",
44216                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
44217                "The route's next hop instance does not have a status of RUNNING.",
44218                "Error which is not critical. We decided to continue the process despite the mentioned error.",
44219                "No results are present on a particular list page.",
44220                "Success is reported, but some results may be missing due to errors",
44221                "The user attempted to use a resource that requires a TOS they have not accepted.",
44222                "Warning that a resource is in use.",
44223                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
44224                "When a resource schema validation is ignored.",
44225                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
44226                "When undeclared properties in the schema are present",
44227                "A given scope cannot be reached."
44228              ],
44229              "enumDeprecated": [
44230                false,
44231                false,
44232                false,
44233                false,
44234                false,
44235                false,
44236                true,
44237                false,
44238                false,
44239                false,
44240                false,
44241                false,
44242                false,
44243                false,
44244                false,
44245                false,
44246                false,
44247                false,
44248                false,
44249                false,
44250                false,
44251                false,
44252                false,
44253                false,
44254                false,
44255                false,
44256                false,
44257                false
44258              ],
44259              "enum": [
44260                "CLEANUP_FAILED",
44261                "DEPRECATED_RESOURCE_USED",
44262                "DEPRECATED_TYPE_USED",
44263                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
44264                "EXPERIMENTAL_TYPE_USED",
44265                "EXTERNAL_API_WARNING",
44266                "FIELD_VALUE_OVERRIDEN",
44267                "INJECTED_KERNELS_DEPRECATED",
44268                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
44269                "LARGE_DEPLOYMENT_WARNING",
44270                "LIST_OVERHEAD_QUOTA_EXCEED",
44271                "MISSING_TYPE_DEPENDENCY",
44272                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
44273                "NEXT_HOP_CANNOT_IP_FORWARD",
44274                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
44275                "NEXT_HOP_INSTANCE_NOT_FOUND",
44276                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
44277                "NEXT_HOP_NOT_RUNNING",
44278                "NOT_CRITICAL_ERROR",
44279                "NO_RESULTS_ON_PAGE",
44280                "PARTIAL_SUCCESS",
44281                "REQUIRED_TOS_AGREEMENT",
44282                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
44283                "RESOURCE_NOT_DELETED",
44284                "SCHEMA_VALIDATION_IGNORED",
44285                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
44286                "UNDECLARED_PROPERTIES",
44287                "UNREACHABLE"
44288              ]
44289            },
44290            "message": {
44291              "description": "[Output Only] A human-readable description of the warning code.",
44292              "type": "string"
44293            },
44294            "data": {
44295              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
44296              "type": "array",
44297              "items": {
44298                "type": "object",
44299                "properties": {
44300                  "key": {
44301                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
44302                    "type": "string"
44303                  },
44304                  "value": {
44305                    "description": "[Output Only] A warning data value corresponding to the key.",
44306                    "type": "string"
44307                  }
44308                }
44309              }
44310            }
44311          }
44312        },
44313        "unreachables": {
44314          "description": "[Output Only] Unreachable resources.",
44315          "type": "array",
44316          "items": {
44317            "type": "string"
44318          }
44319        }
44320      }
44321    },
44322    "VpnTunnelsScopedList": {
44323      "id": "VpnTunnelsScopedList",
44324      "type": "object",
44325      "properties": {
44326        "vpnTunnels": {
44327          "description": "A list of VPN tunnels contained in this scope.",
44328          "type": "array",
44329          "items": {
44330            "$ref": "VpnTunnel"
44331          }
44332        },
44333        "warning": {
44334          "description": "Informational warning which replaces the list of addresses when the list is empty.",
44335          "type": "object",
44336          "properties": {
44337            "code": {
44338              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
44339              "type": "string",
44340              "enumDescriptions": [
44341                "Warning about failed cleanup of transient changes made by a failed operation.",
44342                "A link to a deprecated resource was created.",
44343                "When deploying and at least one of the resources has a type marked as deprecated",
44344                "The user created a boot disk that is larger than image size.",
44345                "When deploying and at least one of the resources has a type marked as experimental",
44346                "Warning that is present in an external api call",
44347                "Warning that value of a field has been overridden. Deprecated unused field.",
44348                "The operation involved use of an injected kernel, which is deprecated.",
44349                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
44350                "When deploying a deployment with a exceedingly large number of resources",
44351                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
44352                "A resource depends on a missing type",
44353                "The route's nextHopIp address is not assigned to an instance on the network.",
44354                "The route's next hop instance cannot ip forward.",
44355                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
44356                "The route's nextHopInstance URL refers to an instance that does not exist.",
44357                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
44358                "The route's next hop instance does not have a status of RUNNING.",
44359                "Error which is not critical. We decided to continue the process despite the mentioned error.",
44360                "No results are present on a particular list page.",
44361                "Success is reported, but some results may be missing due to errors",
44362                "The user attempted to use a resource that requires a TOS they have not accepted.",
44363                "Warning that a resource is in use.",
44364                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
44365                "When a resource schema validation is ignored.",
44366                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
44367                "When undeclared properties in the schema are present",
44368                "A given scope cannot be reached."
44369              ],
44370              "enumDeprecated": [
44371                false,
44372                false,
44373                false,
44374                false,
44375                false,
44376                false,
44377                true,
44378                false,
44379                false,
44380                false,
44381                false,
44382                false,
44383                false,
44384                false,
44385                false,
44386                false,
44387                false,
44388                false,
44389                false,
44390                false,
44391                false,
44392                false,
44393                false,
44394                false,
44395                false,
44396                false,
44397                false,
44398                false
44399              ],
44400              "enum": [
44401                "CLEANUP_FAILED",
44402                "DEPRECATED_RESOURCE_USED",
44403                "DEPRECATED_TYPE_USED",
44404                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
44405                "EXPERIMENTAL_TYPE_USED",
44406                "EXTERNAL_API_WARNING",
44407                "FIELD_VALUE_OVERRIDEN",
44408                "INJECTED_KERNELS_DEPRECATED",
44409                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
44410                "LARGE_DEPLOYMENT_WARNING",
44411                "LIST_OVERHEAD_QUOTA_EXCEED",
44412                "MISSING_TYPE_DEPENDENCY",
44413                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
44414                "NEXT_HOP_CANNOT_IP_FORWARD",
44415                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
44416                "NEXT_HOP_INSTANCE_NOT_FOUND",
44417                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
44418                "NEXT_HOP_NOT_RUNNING",
44419                "NOT_CRITICAL_ERROR",
44420                "NO_RESULTS_ON_PAGE",
44421                "PARTIAL_SUCCESS",
44422                "REQUIRED_TOS_AGREEMENT",
44423                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
44424                "RESOURCE_NOT_DELETED",
44425                "SCHEMA_VALIDATION_IGNORED",
44426                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
44427                "UNDECLARED_PROPERTIES",
44428                "UNREACHABLE"
44429              ]
44430            },
44431            "message": {
44432              "description": "[Output Only] A human-readable description of the warning code.",
44433              "type": "string"
44434            },
44435            "data": {
44436              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
44437              "type": "array",
44438              "items": {
44439                "type": "object",
44440                "properties": {
44441                  "key": {
44442                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
44443                    "type": "string"
44444                  },
44445                  "value": {
44446                    "description": "[Output Only] A warning data value corresponding to the key.",
44447                    "type": "string"
44448                  }
44449                }
44450              }
44451            }
44452          }
44453        }
44454      }
44455    },
44456    "ZoneList": {
44457      "id": "ZoneList",
44458      "description": "Contains a list of zone resources.",
44459      "type": "object",
44460      "properties": {
44461        "kind": {
44462          "description": "Type of resource.",
44463          "default": "compute#zoneList",
44464          "type": "string"
44465        },
44466        "id": {
44467          "description": "[Output Only] Unique identifier for the resource; defined by the server.",
44468          "type": "string"
44469        },
44470        "items": {
44471          "description": "A list of Zone resources.",
44472          "type": "array",
44473          "items": {
44474            "$ref": "Zone"
44475          }
44476        },
44477        "nextPageToken": {
44478          "description": "[Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than maxResults, use the nextPageToken as a value for the query parameter pageToken in the next list request. Subsequent list requests will have their own nextPageToken to continue paging through the results.",
44479          "type": "string"
44480        },
44481        "selfLink": {
44482          "description": "[Output Only] Server-defined URL for this resource.",
44483          "type": "string"
44484        },
44485        "warning": {
44486          "description": "[Output Only] Informational warning message.",
44487          "type": "object",
44488          "properties": {
44489            "code": {
44490              "description": "[Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.",
44491              "type": "string",
44492              "enumDescriptions": [
44493                "Warning about failed cleanup of transient changes made by a failed operation.",
44494                "A link to a deprecated resource was created.",
44495                "When deploying and at least one of the resources has a type marked as deprecated",
44496                "The user created a boot disk that is larger than image size.",
44497                "When deploying and at least one of the resources has a type marked as experimental",
44498                "Warning that is present in an external api call",
44499                "Warning that value of a field has been overridden. Deprecated unused field.",
44500                "The operation involved use of an injected kernel, which is deprecated.",
44501                "A WEIGHTED_MAGLEV backend service is associated with a health check that is not of type HTTP/HTTPS/HTTP2.",
44502                "When deploying a deployment with a exceedingly large number of resources",
44503                "Resource can't be retrieved due to list overhead quota exceed which captures the amount of resources filtered out by user-defined list filter.",
44504                "A resource depends on a missing type",
44505                "The route's nextHopIp address is not assigned to an instance on the network.",
44506                "The route's next hop instance cannot ip forward.",
44507                "The route's nextHopInstance URL refers to an instance that does not have an ipv6 interface on the same network as the route.",
44508                "The route's nextHopInstance URL refers to an instance that does not exist.",
44509                "The route's nextHopInstance URL refers to an instance that is not on the same network as the route.",
44510                "The route's next hop instance does not have a status of RUNNING.",
44511                "Error which is not critical. We decided to continue the process despite the mentioned error.",
44512                "No results are present on a particular list page.",
44513                "Success is reported, but some results may be missing due to errors",
44514                "The user attempted to use a resource that requires a TOS they have not accepted.",
44515                "Warning that a resource is in use.",
44516                "One or more of the resources set to auto-delete could not be deleted because they were in use.",
44517                "When a resource schema validation is ignored.",
44518                "Instance template used in instance group manager is valid as such, but its application does not make a lot of sense, because it allows only single instance in instance group.",
44519                "When undeclared properties in the schema are present",
44520                "A given scope cannot be reached."
44521              ],
44522              "enumDeprecated": [
44523                false,
44524                false,
44525                false,
44526                false,
44527                false,
44528                false,
44529                true,
44530                false,
44531                false,
44532                false,
44533                false,
44534                false,
44535                false,
44536                false,
44537                false,
44538                false,
44539                false,
44540                false,
44541                false,
44542                false,
44543                false,
44544                false,
44545                false,
44546                false,
44547                false,
44548                false,
44549                false,
44550                false
44551              ],
44552              "enum": [
44553                "CLEANUP_FAILED",
44554                "DEPRECATED_RESOURCE_USED",
44555                "DEPRECATED_TYPE_USED",
44556                "DISK_SIZE_LARGER_THAN_IMAGE_SIZE",
44557                "EXPERIMENTAL_TYPE_USED",
44558                "EXTERNAL_API_WARNING",
44559                "FIELD_VALUE_OVERRIDEN",
44560                "INJECTED_KERNELS_DEPRECATED",
44561                "INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB",
44562                "LARGE_DEPLOYMENT_WARNING",
44563                "LIST_OVERHEAD_QUOTA_EXCEED",
44564                "MISSING_TYPE_DEPENDENCY",
44565                "NEXT_HOP_ADDRESS_NOT_ASSIGNED",
44566                "NEXT_HOP_CANNOT_IP_FORWARD",
44567                "NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE",
44568                "NEXT_HOP_INSTANCE_NOT_FOUND",
44569                "NEXT_HOP_INSTANCE_NOT_ON_NETWORK",
44570                "NEXT_HOP_NOT_RUNNING",
44571                "NOT_CRITICAL_ERROR",
44572                "NO_RESULTS_ON_PAGE",
44573                "PARTIAL_SUCCESS",
44574                "REQUIRED_TOS_AGREEMENT",
44575                "RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING",
44576                "RESOURCE_NOT_DELETED",
44577                "SCHEMA_VALIDATION_IGNORED",
44578                "SINGLE_INSTANCE_PROPERTY_TEMPLATE",
44579                "UNDECLARED_PROPERTIES",
44580                "UNREACHABLE"
44581              ]
44582            },
44583            "message": {
44584              "description": "[Output Only] A human-readable description of the warning code.",
44585              "type": "string"
44586            },
44587            "data": {
44588              "description": "[Output Only] Metadata about this warning in key: value format. For example: \"data\": [ { \"key\": \"scope\", \"value\": \"zones/us-east1-d\" } ",
44589              "type": "array",
44590              "items": {
44591                "type": "object",
44592                "properties": {
44593                  "key": {
44594                    "description": "[Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be scope and the key value might be the zone name. Other examples might be a key indicating a deprecated resource and a suggested replacement, or a warning about invalid network settings (for example, if an instance attempts to perform IP forwarding but is not enabled for IP forwarding).",
44595                    "type": "string"
44596                  },
44597                  "value": {
44598                    "description": "[Output Only] A warning data value corresponding to the key.",
44599                    "type": "string"
44600                  }
44601                }
44602              }
44603            }
44604          }
44605        }
44606      }
44607    },
44608    "Zone": {
44609      "id": "Zone",
44610      "description": "Represents a Zone resource. A zone is a deployment area. These deployment areas are subsets of a region. For example the zone us-east1-a is located in the us-east1 region. For more information, read Regions and Zones.",
44611      "type": "object",
44612      "properties": {
44613        "kind": {
44614          "description": "[Output Only] Type of the resource. Always compute#zone for zones.",
44615          "default": "compute#zone",
44616          "type": "string"
44617        },
44618        "id": {
44619          "description": "[Output Only] The unique identifier for the resource. This identifier is defined by the server.",
44620          "type": "string",
44621          "format": "uint64"
44622        },
44623        "creationTimestamp": {
44624          "description": "[Output Only] Creation timestamp in RFC3339 text format.",
44625          "type": "string"
44626        },
44627        "name": {
44628          "description": "[Output Only] Name of the resource.",
44629          "type": "string"
44630        },
44631        "description": {
44632          "description": "[Output Only] Textual description of the resource.",
44633          "type": "string"
44634        },
44635        "status": {
44636          "description": "[Output Only] Status of the zone, either UP or DOWN.",
44637          "type": "string",
44638          "enumDescriptions": [
44639            "",
44640            ""
44641          ],
44642          "enum": [
44643            "DOWN",
44644            "UP"
44645          ]
44646        },
44647        "deprecated": {
44648          "description": "[Output Only] The deprecation status associated with this zone.",
44649          "$ref": "DeprecationStatus"
44650        },
44651        "region": {
44652          "description": "[Output Only] Full URL reference to the region which hosts the zone.",
44653          "type": "string"
44654        },
44655        "selfLink": {
44656          "description": "[Output Only] Server-defined URL for the resource.",
44657          "type": "string"
44658        },
44659        "availableCpuPlatforms": {
44660          "description": "[Output Only] Available cpu/platform selections for the zone.",
44661          "type": "array",
44662          "items": {
44663            "type": "string"
44664          }
44665        },
44666        "supportsPzs": {
44667          "description": "[Output Only] Reserved for future use.",
44668          "type": "boolean"
44669        }
44670      }
44671    },
44672    "AuditConfig": {
44673      "id": "AuditConfig",
44674      "description": "Specifies the audit configuration for a service. The configuration determines which permission types are logged, and what identities, if any, are exempted from logging. An AuditConfig must have one or more AuditLogConfigs. If there are AuditConfigs for both `allServices` and a specific service, the union of the two AuditConfigs is used for that service: the log_types specified in each AuditConfig are enabled, and the exempted_members in each AuditLogConfig are exempted. Example Policy with multiple AuditConfigs: { \"audit_configs\": [ { \"service\": \"allServices\", \"audit_log_configs\": [ { \"log_type\": \"DATA_READ\", \"exempted_members\": [ \"user:[email protected]\" ] }, { \"log_type\": \"DATA_WRITE\" }, { \"log_type\": \"ADMIN_READ\" } ] }, { \"service\": \"sampleservice.googleapis.com\", \"audit_log_configs\": [ { \"log_type\": \"DATA_READ\" }, { \"log_type\": \"DATA_WRITE\", \"exempted_members\": [ \"user:[email protected]\" ] } ] } ] } For sampleservice, this policy enables DATA_READ, DATA_WRITE and ADMIN_READ logging. It also exempts [email protected] from DATA_READ logging, and [email protected] from DATA_WRITE logging.",
44675      "type": "object",
44676      "properties": {
44677        "exemptedMembers": {
44678          "description": "This is deprecated and has no effect. Do not use.",
44679          "type": "array",
44680          "items": {
44681            "type": "string"
44682          }
44683        },
44684        "auditLogConfigs": {
44685          "description": "The configuration for logging of each type of permission.",
44686          "type": "array",
44687          "items": {
44688            "$ref": "AuditLogConfig"
44689          }
44690        },
44691        "service": {
44692          "description": "Specifies a service that will be enabled for audit logging. For example, `storage.googleapis.com`, `cloudsql.googleapis.com`. `allServices` is a special value that covers all services.",
44693          "type": "string"
44694        }
44695      }
44696    }
44697  },
44698  "name": "compute",
44699  "basePath": "/compute/v1/",
44700  "revision": "20240220",
44701  "protocol": "rest",
44702  "servicePath": "compute/v1/",
44703  "resources": {
44704    "acceleratorTypes": {
44705      "methods": {
44706        "list": {
44707          "id": "compute.acceleratorTypes.list",
44708          "path": "projects/{project}/zones/{zone}/acceleratorTypes",
44709          "flatPath": "projects/{project}/zones/{zone}/acceleratorTypes",
44710          "httpMethod": "GET",
44711          "parameters": {
44712            "filter": {
44713              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
44714              "location": "query",
44715              "type": "string"
44716            },
44717            "maxResults": {
44718              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
44719              "default": "500",
44720              "minimum": "0",
44721              "location": "query",
44722              "type": "integer",
44723              "format": "uint32"
44724            },
44725            "orderBy": {
44726              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
44727              "location": "query",
44728              "type": "string"
44729            },
44730            "pageToken": {
44731              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
44732              "location": "query",
44733              "type": "string"
44734            },
44735            "project": {
44736              "description": "Project ID for this request.",
44737              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
44738              "location": "path",
44739              "required": true,
44740              "type": "string"
44741            },
44742            "returnPartialSuccess": {
44743              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
44744              "location": "query",
44745              "type": "boolean"
44746            },
44747            "zone": {
44748              "description": "The name of the zone for this request.",
44749              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
44750              "location": "path",
44751              "required": true,
44752              "type": "string"
44753            }
44754          },
44755          "parameterOrder": [
44756            "project",
44757            "zone"
44758          ],
44759          "response": {
44760            "$ref": "AcceleratorTypeList"
44761          },
44762          "scopes": [
44763            "https://www.googleapis.com/auth/cloud-platform",
44764            "https://www.googleapis.com/auth/compute",
44765            "https://www.googleapis.com/auth/compute.readonly"
44766          ],
44767          "description": "Retrieves a list of accelerator types that are available to the specified project."
44768        },
44769        "aggregatedList": {
44770          "id": "compute.acceleratorTypes.aggregatedList",
44771          "path": "projects/{project}/aggregated/acceleratorTypes",
44772          "flatPath": "projects/{project}/aggregated/acceleratorTypes",
44773          "httpMethod": "GET",
44774          "parameters": {
44775            "filter": {
44776              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
44777              "location": "query",
44778              "type": "string"
44779            },
44780            "includeAllScopes": {
44781              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
44782              "location": "query",
44783              "type": "boolean"
44784            },
44785            "maxResults": {
44786              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
44787              "default": "500",
44788              "minimum": "0",
44789              "location": "query",
44790              "type": "integer",
44791              "format": "uint32"
44792            },
44793            "orderBy": {
44794              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
44795              "location": "query",
44796              "type": "string"
44797            },
44798            "pageToken": {
44799              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
44800              "location": "query",
44801              "type": "string"
44802            },
44803            "project": {
44804              "description": "Project ID for this request.",
44805              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
44806              "location": "path",
44807              "required": true,
44808              "type": "string"
44809            },
44810            "returnPartialSuccess": {
44811              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
44812              "location": "query",
44813              "type": "boolean"
44814            },
44815            "serviceProjectNumber": {
44816              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
44817              "location": "query",
44818              "type": "string",
44819              "format": "int64"
44820            }
44821          },
44822          "parameterOrder": [
44823            "project"
44824          ],
44825          "response": {
44826            "$ref": "AcceleratorTypeAggregatedList"
44827          },
44828          "scopes": [
44829            "https://www.googleapis.com/auth/cloud-platform",
44830            "https://www.googleapis.com/auth/compute",
44831            "https://www.googleapis.com/auth/compute.readonly"
44832          ],
44833          "description": "Retrieves an aggregated list of accelerator types. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
44834        },
44835        "get": {
44836          "id": "compute.acceleratorTypes.get",
44837          "path": "projects/{project}/zones/{zone}/acceleratorTypes/{acceleratorType}",
44838          "flatPath": "projects/{project}/zones/{zone}/acceleratorTypes/{acceleratorType}",
44839          "httpMethod": "GET",
44840          "parameters": {
44841            "acceleratorType": {
44842              "description": "Name of the accelerator type to return.",
44843              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
44844              "location": "path",
44845              "required": true,
44846              "type": "string"
44847            },
44848            "project": {
44849              "description": "Project ID for this request.",
44850              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
44851              "location": "path",
44852              "required": true,
44853              "type": "string"
44854            },
44855            "zone": {
44856              "description": "The name of the zone for this request.",
44857              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
44858              "location": "path",
44859              "required": true,
44860              "type": "string"
44861            }
44862          },
44863          "parameterOrder": [
44864            "project",
44865            "zone",
44866            "acceleratorType"
44867          ],
44868          "response": {
44869            "$ref": "AcceleratorType"
44870          },
44871          "scopes": [
44872            "https://www.googleapis.com/auth/cloud-platform",
44873            "https://www.googleapis.com/auth/compute",
44874            "https://www.googleapis.com/auth/compute.readonly"
44875          ],
44876          "description": "Returns the specified accelerator type."
44877        }
44878      }
44879    },
44880    "globalOperations": {
44881      "methods": {
44882        "list": {
44883          "id": "compute.globalOperations.list",
44884          "path": "projects/{project}/global/operations",
44885          "flatPath": "projects/{project}/global/operations",
44886          "httpMethod": "GET",
44887          "parameters": {
44888            "filter": {
44889              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
44890              "location": "query",
44891              "type": "string"
44892            },
44893            "maxResults": {
44894              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
44895              "default": "500",
44896              "minimum": "0",
44897              "location": "query",
44898              "type": "integer",
44899              "format": "uint32"
44900            },
44901            "orderBy": {
44902              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
44903              "location": "query",
44904              "type": "string"
44905            },
44906            "pageToken": {
44907              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
44908              "location": "query",
44909              "type": "string"
44910            },
44911            "project": {
44912              "description": "Project ID for this request.",
44913              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
44914              "location": "path",
44915              "required": true,
44916              "type": "string"
44917            },
44918            "returnPartialSuccess": {
44919              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
44920              "location": "query",
44921              "type": "boolean"
44922            }
44923          },
44924          "parameterOrder": [
44925            "project"
44926          ],
44927          "response": {
44928            "$ref": "OperationList"
44929          },
44930          "scopes": [
44931            "https://www.googleapis.com/auth/cloud-platform",
44932            "https://www.googleapis.com/auth/compute",
44933            "https://www.googleapis.com/auth/compute.readonly"
44934          ],
44935          "description": "Retrieves a list of Operation resources contained within the specified project."
44936        },
44937        "aggregatedList": {
44938          "id": "compute.globalOperations.aggregatedList",
44939          "path": "projects/{project}/aggregated/operations",
44940          "flatPath": "projects/{project}/aggregated/operations",
44941          "httpMethod": "GET",
44942          "parameters": {
44943            "filter": {
44944              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
44945              "location": "query",
44946              "type": "string"
44947            },
44948            "includeAllScopes": {
44949              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
44950              "location": "query",
44951              "type": "boolean"
44952            },
44953            "maxResults": {
44954              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
44955              "default": "500",
44956              "minimum": "0",
44957              "location": "query",
44958              "type": "integer",
44959              "format": "uint32"
44960            },
44961            "orderBy": {
44962              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
44963              "location": "query",
44964              "type": "string"
44965            },
44966            "pageToken": {
44967              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
44968              "location": "query",
44969              "type": "string"
44970            },
44971            "project": {
44972              "description": "Project ID for this request.",
44973              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
44974              "location": "path",
44975              "required": true,
44976              "type": "string"
44977            },
44978            "returnPartialSuccess": {
44979              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
44980              "location": "query",
44981              "type": "boolean"
44982            },
44983            "serviceProjectNumber": {
44984              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
44985              "location": "query",
44986              "type": "string",
44987              "format": "int64"
44988            }
44989          },
44990          "parameterOrder": [
44991            "project"
44992          ],
44993          "response": {
44994            "$ref": "OperationAggregatedList"
44995          },
44996          "scopes": [
44997            "https://www.googleapis.com/auth/cloud-platform",
44998            "https://www.googleapis.com/auth/compute",
44999            "https://www.googleapis.com/auth/compute.readonly"
45000          ],
45001          "description": "Retrieves an aggregated list of all operations. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
45002        },
45003        "get": {
45004          "id": "compute.globalOperations.get",
45005          "path": "projects/{project}/global/operations/{operation}",
45006          "flatPath": "projects/{project}/global/operations/{operation}",
45007          "httpMethod": "GET",
45008          "parameters": {
45009            "operation": {
45010              "description": "Name of the Operations resource to return.",
45011              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
45012              "location": "path",
45013              "required": true,
45014              "type": "string"
45015            },
45016            "project": {
45017              "description": "Project ID for this request.",
45018              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45019              "location": "path",
45020              "required": true,
45021              "type": "string"
45022            }
45023          },
45024          "parameterOrder": [
45025            "project",
45026            "operation"
45027          ],
45028          "response": {
45029            "$ref": "Operation"
45030          },
45031          "scopes": [
45032            "https://www.googleapis.com/auth/cloud-platform",
45033            "https://www.googleapis.com/auth/compute",
45034            "https://www.googleapis.com/auth/compute.readonly"
45035          ],
45036          "description": "Retrieves the specified Operations resource."
45037        },
45038        "wait": {
45039          "id": "compute.globalOperations.wait",
45040          "path": "projects/{project}/global/operations/{operation}/wait",
45041          "flatPath": "projects/{project}/global/operations/{operation}/wait",
45042          "httpMethod": "POST",
45043          "parameters": {
45044            "operation": {
45045              "description": "Name of the Operations resource to return.",
45046              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
45047              "location": "path",
45048              "required": true,
45049              "type": "string"
45050            },
45051            "project": {
45052              "description": "Project ID for this request.",
45053              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45054              "location": "path",
45055              "required": true,
45056              "type": "string"
45057            }
45058          },
45059          "parameterOrder": [
45060            "project",
45061            "operation"
45062          ],
45063          "response": {
45064            "$ref": "Operation"
45065          },
45066          "scopes": [
45067            "https://www.googleapis.com/auth/cloud-platform",
45068            "https://www.googleapis.com/auth/compute",
45069            "https://www.googleapis.com/auth/compute.readonly"
45070          ],
45071          "description": "Waits for the specified Operation resource to return as `DONE` or for the request to approach the 2 minute deadline, and retrieves the specified Operation resource. This method differs from the `GET` method in that it waits for no more than the default deadline (2 minutes) and then returns the current state of the operation, which might be `DONE` or still in progress. This method is called on a best-effort basis. Specifically: - In uncommon cases, when the server is overloaded, the request might return before the default deadline is reached, or might return after zero seconds. - If the default deadline is reached, there is no guarantee that the operation is actually done when the method returns. Be prepared to retry if the operation is not `DONE`. "
45072        },
45073        "delete": {
45074          "id": "compute.globalOperations.delete",
45075          "path": "projects/{project}/global/operations/{operation}",
45076          "flatPath": "projects/{project}/global/operations/{operation}",
45077          "httpMethod": "DELETE",
45078          "parameters": {
45079            "operation": {
45080              "description": "Name of the Operations resource to delete.",
45081              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
45082              "location": "path",
45083              "required": true,
45084              "type": "string"
45085            },
45086            "project": {
45087              "description": "Project ID for this request.",
45088              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45089              "location": "path",
45090              "required": true,
45091              "type": "string"
45092            }
45093          },
45094          "parameterOrder": [
45095            "project",
45096            "operation"
45097          ],
45098          "scopes": [
45099            "https://www.googleapis.com/auth/cloud-platform",
45100            "https://www.googleapis.com/auth/compute"
45101          ],
45102          "description": "Deletes the specified Operations resource."
45103        }
45104      }
45105    },
45106    "globalOrganizationOperations": {
45107      "methods": {
45108        "list": {
45109          "id": "compute.globalOrganizationOperations.list",
45110          "path": "locations/global/operations",
45111          "flatPath": "locations/global/operations",
45112          "httpMethod": "GET",
45113          "parameters": {
45114            "filter": {
45115              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
45116              "location": "query",
45117              "type": "string"
45118            },
45119            "maxResults": {
45120              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
45121              "default": "500",
45122              "minimum": "0",
45123              "location": "query",
45124              "type": "integer",
45125              "format": "uint32"
45126            },
45127            "orderBy": {
45128              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
45129              "location": "query",
45130              "type": "string"
45131            },
45132            "pageToken": {
45133              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
45134              "location": "query",
45135              "type": "string"
45136            },
45137            "parentId": {
45138              "description": "Parent ID for this request.",
45139              "location": "query",
45140              "type": "string"
45141            },
45142            "returnPartialSuccess": {
45143              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
45144              "location": "query",
45145              "type": "boolean"
45146            }
45147          },
45148          "response": {
45149            "$ref": "OperationList"
45150          },
45151          "scopes": [
45152            "https://www.googleapis.com/auth/cloud-platform",
45153            "https://www.googleapis.com/auth/compute",
45154            "https://www.googleapis.com/auth/compute.readonly"
45155          ],
45156          "description": "Retrieves a list of Operation resources contained within the specified organization."
45157        },
45158        "get": {
45159          "id": "compute.globalOrganizationOperations.get",
45160          "path": "locations/global/operations/{operation}",
45161          "flatPath": "locations/global/operations/{operation}",
45162          "httpMethod": "GET",
45163          "parameters": {
45164            "operation": {
45165              "description": "Name of the Operations resource to return.",
45166              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
45167              "location": "path",
45168              "required": true,
45169              "type": "string"
45170            },
45171            "parentId": {
45172              "description": "Parent ID for this request.",
45173              "location": "query",
45174              "type": "string"
45175            }
45176          },
45177          "parameterOrder": [
45178            "operation"
45179          ],
45180          "response": {
45181            "$ref": "Operation"
45182          },
45183          "scopes": [
45184            "https://www.googleapis.com/auth/cloud-platform",
45185            "https://www.googleapis.com/auth/compute",
45186            "https://www.googleapis.com/auth/compute.readonly"
45187          ],
45188          "description": "Retrieves the specified Operations resource. Gets a list of operations by making a `list()` request."
45189        },
45190        "delete": {
45191          "id": "compute.globalOrganizationOperations.delete",
45192          "path": "locations/global/operations/{operation}",
45193          "flatPath": "locations/global/operations/{operation}",
45194          "httpMethod": "DELETE",
45195          "parameters": {
45196            "operation": {
45197              "description": "Name of the Operations resource to delete.",
45198              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
45199              "location": "path",
45200              "required": true,
45201              "type": "string"
45202            },
45203            "parentId": {
45204              "description": "Parent ID for this request.",
45205              "location": "query",
45206              "type": "string"
45207            }
45208          },
45209          "parameterOrder": [
45210            "operation"
45211          ],
45212          "scopes": [
45213            "https://www.googleapis.com/auth/cloud-platform",
45214            "https://www.googleapis.com/auth/compute"
45215          ],
45216          "description": "Deletes the specified Operations resource."
45217        }
45218      }
45219    },
45220    "zoneOperations": {
45221      "methods": {
45222        "list": {
45223          "id": "compute.zoneOperations.list",
45224          "path": "projects/{project}/zones/{zone}/operations",
45225          "flatPath": "projects/{project}/zones/{zone}/operations",
45226          "httpMethod": "GET",
45227          "parameters": {
45228            "filter": {
45229              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
45230              "location": "query",
45231              "type": "string"
45232            },
45233            "maxResults": {
45234              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
45235              "default": "500",
45236              "minimum": "0",
45237              "location": "query",
45238              "type": "integer",
45239              "format": "uint32"
45240            },
45241            "orderBy": {
45242              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
45243              "location": "query",
45244              "type": "string"
45245            },
45246            "pageToken": {
45247              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
45248              "location": "query",
45249              "type": "string"
45250            },
45251            "project": {
45252              "description": "Project ID for this request.",
45253              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45254              "location": "path",
45255              "required": true,
45256              "type": "string"
45257            },
45258            "returnPartialSuccess": {
45259              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
45260              "location": "query",
45261              "type": "boolean"
45262            },
45263            "zone": {
45264              "description": "Name of the zone for request.",
45265              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
45266              "location": "path",
45267              "required": true,
45268              "type": "string"
45269            }
45270          },
45271          "parameterOrder": [
45272            "project",
45273            "zone"
45274          ],
45275          "response": {
45276            "$ref": "OperationList"
45277          },
45278          "scopes": [
45279            "https://www.googleapis.com/auth/cloud-platform",
45280            "https://www.googleapis.com/auth/compute",
45281            "https://www.googleapis.com/auth/compute.readonly"
45282          ],
45283          "description": "Retrieves a list of Operation resources contained within the specified zone."
45284        },
45285        "get": {
45286          "id": "compute.zoneOperations.get",
45287          "path": "projects/{project}/zones/{zone}/operations/{operation}",
45288          "flatPath": "projects/{project}/zones/{zone}/operations/{operation}",
45289          "httpMethod": "GET",
45290          "parameters": {
45291            "operation": {
45292              "description": "Name of the Operations resource to return.",
45293              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
45294              "location": "path",
45295              "required": true,
45296              "type": "string"
45297            },
45298            "project": {
45299              "description": "Project ID for this request.",
45300              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45301              "location": "path",
45302              "required": true,
45303              "type": "string"
45304            },
45305            "zone": {
45306              "description": "Name of the zone for this request.",
45307              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
45308              "location": "path",
45309              "required": true,
45310              "type": "string"
45311            }
45312          },
45313          "parameterOrder": [
45314            "project",
45315            "zone",
45316            "operation"
45317          ],
45318          "response": {
45319            "$ref": "Operation"
45320          },
45321          "scopes": [
45322            "https://www.googleapis.com/auth/cloud-platform",
45323            "https://www.googleapis.com/auth/compute",
45324            "https://www.googleapis.com/auth/compute.readonly"
45325          ],
45326          "description": "Retrieves the specified zone-specific Operations resource."
45327        },
45328        "wait": {
45329          "id": "compute.zoneOperations.wait",
45330          "path": "projects/{project}/zones/{zone}/operations/{operation}/wait",
45331          "flatPath": "projects/{project}/zones/{zone}/operations/{operation}/wait",
45332          "httpMethod": "POST",
45333          "parameters": {
45334            "operation": {
45335              "description": "Name of the Operations resource to return.",
45336              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
45337              "location": "path",
45338              "required": true,
45339              "type": "string"
45340            },
45341            "project": {
45342              "description": "Project ID for this request.",
45343              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45344              "location": "path",
45345              "required": true,
45346              "type": "string"
45347            },
45348            "zone": {
45349              "description": "Name of the zone for this request.",
45350              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
45351              "location": "path",
45352              "required": true,
45353              "type": "string"
45354            }
45355          },
45356          "parameterOrder": [
45357            "project",
45358            "zone",
45359            "operation"
45360          ],
45361          "response": {
45362            "$ref": "Operation"
45363          },
45364          "scopes": [
45365            "https://www.googleapis.com/auth/cloud-platform",
45366            "https://www.googleapis.com/auth/compute",
45367            "https://www.googleapis.com/auth/compute.readonly"
45368          ],
45369          "description": "Waits for the specified Operation resource to return as `DONE` or for the request to approach the 2 minute deadline, and retrieves the specified Operation resource. This method waits for no more than the 2 minutes and then returns the current state of the operation, which might be `DONE` or still in progress. This method is called on a best-effort basis. Specifically: - In uncommon cases, when the server is overloaded, the request might return before the default deadline is reached, or might return after zero seconds. - If the default deadline is reached, there is no guarantee that the operation is actually done when the method returns. Be prepared to retry if the operation is not `DONE`. "
45370        },
45371        "delete": {
45372          "id": "compute.zoneOperations.delete",
45373          "path": "projects/{project}/zones/{zone}/operations/{operation}",
45374          "flatPath": "projects/{project}/zones/{zone}/operations/{operation}",
45375          "httpMethod": "DELETE",
45376          "parameters": {
45377            "operation": {
45378              "description": "Name of the Operations resource to delete.",
45379              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
45380              "location": "path",
45381              "required": true,
45382              "type": "string"
45383            },
45384            "project": {
45385              "description": "Project ID for this request.",
45386              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45387              "location": "path",
45388              "required": true,
45389              "type": "string"
45390            },
45391            "zone": {
45392              "description": "Name of the zone for this request.",
45393              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
45394              "location": "path",
45395              "required": true,
45396              "type": "string"
45397            }
45398          },
45399          "parameterOrder": [
45400            "project",
45401            "zone",
45402            "operation"
45403          ],
45404          "scopes": [
45405            "https://www.googleapis.com/auth/cloud-platform",
45406            "https://www.googleapis.com/auth/compute"
45407          ],
45408          "description": "Deletes the specified zone-specific Operations resource."
45409        }
45410      }
45411    },
45412    "regionOperations": {
45413      "methods": {
45414        "list": {
45415          "id": "compute.regionOperations.list",
45416          "path": "projects/{project}/regions/{region}/operations",
45417          "flatPath": "projects/{project}/regions/{region}/operations",
45418          "httpMethod": "GET",
45419          "parameters": {
45420            "filter": {
45421              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
45422              "location": "query",
45423              "type": "string"
45424            },
45425            "maxResults": {
45426              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
45427              "default": "500",
45428              "minimum": "0",
45429              "location": "query",
45430              "type": "integer",
45431              "format": "uint32"
45432            },
45433            "orderBy": {
45434              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
45435              "location": "query",
45436              "type": "string"
45437            },
45438            "pageToken": {
45439              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
45440              "location": "query",
45441              "type": "string"
45442            },
45443            "project": {
45444              "description": "Project ID for this request.",
45445              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45446              "location": "path",
45447              "required": true,
45448              "type": "string"
45449            },
45450            "region": {
45451              "description": "Name of the region for this request.",
45452              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
45453              "location": "path",
45454              "required": true,
45455              "type": "string"
45456            },
45457            "returnPartialSuccess": {
45458              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
45459              "location": "query",
45460              "type": "boolean"
45461            }
45462          },
45463          "parameterOrder": [
45464            "project",
45465            "region"
45466          ],
45467          "response": {
45468            "$ref": "OperationList"
45469          },
45470          "scopes": [
45471            "https://www.googleapis.com/auth/cloud-platform",
45472            "https://www.googleapis.com/auth/compute",
45473            "https://www.googleapis.com/auth/compute.readonly"
45474          ],
45475          "description": "Retrieves a list of Operation resources contained within the specified region."
45476        },
45477        "get": {
45478          "id": "compute.regionOperations.get",
45479          "path": "projects/{project}/regions/{region}/operations/{operation}",
45480          "flatPath": "projects/{project}/regions/{region}/operations/{operation}",
45481          "httpMethod": "GET",
45482          "parameters": {
45483            "operation": {
45484              "description": "Name of the Operations resource to return.",
45485              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
45486              "location": "path",
45487              "required": true,
45488              "type": "string"
45489            },
45490            "project": {
45491              "description": "Project ID for this request.",
45492              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45493              "location": "path",
45494              "required": true,
45495              "type": "string"
45496            },
45497            "region": {
45498              "description": "Name of the region for this request.",
45499              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
45500              "location": "path",
45501              "required": true,
45502              "type": "string"
45503            }
45504          },
45505          "parameterOrder": [
45506            "project",
45507            "region",
45508            "operation"
45509          ],
45510          "response": {
45511            "$ref": "Operation"
45512          },
45513          "scopes": [
45514            "https://www.googleapis.com/auth/cloud-platform",
45515            "https://www.googleapis.com/auth/compute",
45516            "https://www.googleapis.com/auth/compute.readonly"
45517          ],
45518          "description": "Retrieves the specified region-specific Operations resource."
45519        },
45520        "wait": {
45521          "id": "compute.regionOperations.wait",
45522          "path": "projects/{project}/regions/{region}/operations/{operation}/wait",
45523          "flatPath": "projects/{project}/regions/{region}/operations/{operation}/wait",
45524          "httpMethod": "POST",
45525          "parameters": {
45526            "operation": {
45527              "description": "Name of the Operations resource to return.",
45528              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
45529              "location": "path",
45530              "required": true,
45531              "type": "string"
45532            },
45533            "project": {
45534              "description": "Project ID for this request.",
45535              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45536              "location": "path",
45537              "required": true,
45538              "type": "string"
45539            },
45540            "region": {
45541              "description": "Name of the region for this request.",
45542              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
45543              "location": "path",
45544              "required": true,
45545              "type": "string"
45546            }
45547          },
45548          "parameterOrder": [
45549            "project",
45550            "region",
45551            "operation"
45552          ],
45553          "response": {
45554            "$ref": "Operation"
45555          },
45556          "scopes": [
45557            "https://www.googleapis.com/auth/cloud-platform",
45558            "https://www.googleapis.com/auth/compute",
45559            "https://www.googleapis.com/auth/compute.readonly"
45560          ],
45561          "description": "Waits for the specified Operation resource to return as `DONE` or for the request to approach the 2 minute deadline, and retrieves the specified Operation resource. This method differs from the `GET` method in that it waits for no more than the default deadline (2 minutes) and then returns the current state of the operation, which might be `DONE` or still in progress. This method is called on a best-effort basis. Specifically: - In uncommon cases, when the server is overloaded, the request might return before the default deadline is reached, or might return after zero seconds. - If the default deadline is reached, there is no guarantee that the operation is actually done when the method returns. Be prepared to retry if the operation is not `DONE`. "
45562        },
45563        "delete": {
45564          "id": "compute.regionOperations.delete",
45565          "path": "projects/{project}/regions/{region}/operations/{operation}",
45566          "flatPath": "projects/{project}/regions/{region}/operations/{operation}",
45567          "httpMethod": "DELETE",
45568          "parameters": {
45569            "operation": {
45570              "description": "Name of the Operations resource to delete.",
45571              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
45572              "location": "path",
45573              "required": true,
45574              "type": "string"
45575            },
45576            "project": {
45577              "description": "Project ID for this request.",
45578              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45579              "location": "path",
45580              "required": true,
45581              "type": "string"
45582            },
45583            "region": {
45584              "description": "Name of the region for this request.",
45585              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
45586              "location": "path",
45587              "required": true,
45588              "type": "string"
45589            }
45590          },
45591          "parameterOrder": [
45592            "project",
45593            "region",
45594            "operation"
45595          ],
45596          "scopes": [
45597            "https://www.googleapis.com/auth/cloud-platform",
45598            "https://www.googleapis.com/auth/compute"
45599          ],
45600          "description": "Deletes the specified region-specific Operations resource."
45601        }
45602      }
45603    },
45604    "globalAddresses": {
45605      "methods": {
45606        "list": {
45607          "id": "compute.globalAddresses.list",
45608          "path": "projects/{project}/global/addresses",
45609          "flatPath": "projects/{project}/global/addresses",
45610          "httpMethod": "GET",
45611          "parameters": {
45612            "filter": {
45613              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
45614              "location": "query",
45615              "type": "string"
45616            },
45617            "maxResults": {
45618              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
45619              "default": "500",
45620              "minimum": "0",
45621              "location": "query",
45622              "type": "integer",
45623              "format": "uint32"
45624            },
45625            "orderBy": {
45626              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
45627              "location": "query",
45628              "type": "string"
45629            },
45630            "pageToken": {
45631              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
45632              "location": "query",
45633              "type": "string"
45634            },
45635            "project": {
45636              "description": "Project ID for this request.",
45637              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45638              "location": "path",
45639              "required": true,
45640              "type": "string"
45641            },
45642            "returnPartialSuccess": {
45643              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
45644              "location": "query",
45645              "type": "boolean"
45646            }
45647          },
45648          "parameterOrder": [
45649            "project"
45650          ],
45651          "response": {
45652            "$ref": "AddressList"
45653          },
45654          "scopes": [
45655            "https://www.googleapis.com/auth/cloud-platform",
45656            "https://www.googleapis.com/auth/compute",
45657            "https://www.googleapis.com/auth/compute.readonly"
45658          ],
45659          "description": "Retrieves a list of global addresses."
45660        },
45661        "get": {
45662          "id": "compute.globalAddresses.get",
45663          "path": "projects/{project}/global/addresses/{address}",
45664          "flatPath": "projects/{project}/global/addresses/{address}",
45665          "httpMethod": "GET",
45666          "parameters": {
45667            "address": {
45668              "description": "Name of the address resource to return.",
45669              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
45670              "location": "path",
45671              "required": true,
45672              "type": "string"
45673            },
45674            "project": {
45675              "description": "Project ID for this request.",
45676              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45677              "location": "path",
45678              "required": true,
45679              "type": "string"
45680            }
45681          },
45682          "parameterOrder": [
45683            "project",
45684            "address"
45685          ],
45686          "response": {
45687            "$ref": "Address"
45688          },
45689          "scopes": [
45690            "https://www.googleapis.com/auth/cloud-platform",
45691            "https://www.googleapis.com/auth/compute",
45692            "https://www.googleapis.com/auth/compute.readonly"
45693          ],
45694          "description": "Returns the specified address resource."
45695        },
45696        "insert": {
45697          "id": "compute.globalAddresses.insert",
45698          "path": "projects/{project}/global/addresses",
45699          "flatPath": "projects/{project}/global/addresses",
45700          "httpMethod": "POST",
45701          "parameters": {
45702            "project": {
45703              "description": "Project ID for this request.",
45704              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45705              "location": "path",
45706              "required": true,
45707              "type": "string"
45708            },
45709            "requestId": {
45710              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
45711              "location": "query",
45712              "type": "string"
45713            }
45714          },
45715          "parameterOrder": [
45716            "project"
45717          ],
45718          "request": {
45719            "$ref": "Address"
45720          },
45721          "response": {
45722            "$ref": "Operation"
45723          },
45724          "scopes": [
45725            "https://www.googleapis.com/auth/cloud-platform",
45726            "https://www.googleapis.com/auth/compute"
45727          ],
45728          "description": "Creates an address resource in the specified project by using the data included in the request."
45729        },
45730        "delete": {
45731          "id": "compute.globalAddresses.delete",
45732          "path": "projects/{project}/global/addresses/{address}",
45733          "flatPath": "projects/{project}/global/addresses/{address}",
45734          "httpMethod": "DELETE",
45735          "parameters": {
45736            "address": {
45737              "description": "Name of the address resource to delete.",
45738              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
45739              "location": "path",
45740              "required": true,
45741              "type": "string"
45742            },
45743            "project": {
45744              "description": "Project ID for this request.",
45745              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45746              "location": "path",
45747              "required": true,
45748              "type": "string"
45749            },
45750            "requestId": {
45751              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
45752              "location": "query",
45753              "type": "string"
45754            }
45755          },
45756          "parameterOrder": [
45757            "project",
45758            "address"
45759          ],
45760          "response": {
45761            "$ref": "Operation"
45762          },
45763          "scopes": [
45764            "https://www.googleapis.com/auth/cloud-platform",
45765            "https://www.googleapis.com/auth/compute"
45766          ],
45767          "description": "Deletes the specified address resource."
45768        },
45769        "move": {
45770          "id": "compute.globalAddresses.move",
45771          "path": "projects/{project}/global/addresses/{address}/move",
45772          "flatPath": "projects/{project}/global/addresses/{address}/move",
45773          "httpMethod": "POST",
45774          "parameters": {
45775            "address": {
45776              "description": "Name of the address resource to move.",
45777              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
45778              "location": "path",
45779              "required": true,
45780              "type": "string"
45781            },
45782            "project": {
45783              "description": "Source project ID which the Address is moved from.",
45784              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45785              "location": "path",
45786              "required": true,
45787              "type": "string"
45788            },
45789            "requestId": {
45790              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
45791              "location": "query",
45792              "type": "string"
45793            }
45794          },
45795          "parameterOrder": [
45796            "project",
45797            "address"
45798          ],
45799          "request": {
45800            "$ref": "GlobalAddressesMoveRequest"
45801          },
45802          "response": {
45803            "$ref": "Operation"
45804          },
45805          "scopes": [
45806            "https://www.googleapis.com/auth/cloud-platform",
45807            "https://www.googleapis.com/auth/compute"
45808          ],
45809          "description": "Moves the specified address resource from one project to another project."
45810        },
45811        "setLabels": {
45812          "id": "compute.globalAddresses.setLabels",
45813          "path": "projects/{project}/global/addresses/{resource}/setLabels",
45814          "flatPath": "projects/{project}/global/addresses/{resource}/setLabels",
45815          "httpMethod": "POST",
45816          "parameters": {
45817            "project": {
45818              "description": "Project ID for this request.",
45819              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45820              "location": "path",
45821              "required": true,
45822              "type": "string"
45823            },
45824            "resource": {
45825              "description": "Name or id of the resource for this request.",
45826              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
45827              "location": "path",
45828              "required": true,
45829              "type": "string"
45830            }
45831          },
45832          "parameterOrder": [
45833            "project",
45834            "resource"
45835          ],
45836          "request": {
45837            "$ref": "GlobalSetLabelsRequest"
45838          },
45839          "response": {
45840            "$ref": "Operation"
45841          },
45842          "scopes": [
45843            "https://www.googleapis.com/auth/cloud-platform",
45844            "https://www.googleapis.com/auth/compute"
45845          ],
45846          "description": "Sets the labels on a GlobalAddress. To learn more about labels, read the Labeling Resources documentation."
45847        }
45848      }
45849    },
45850    "addresses": {
45851      "methods": {
45852        "list": {
45853          "id": "compute.addresses.list",
45854          "path": "projects/{project}/regions/{region}/addresses",
45855          "flatPath": "projects/{project}/regions/{region}/addresses",
45856          "httpMethod": "GET",
45857          "parameters": {
45858            "filter": {
45859              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
45860              "location": "query",
45861              "type": "string"
45862            },
45863            "maxResults": {
45864              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
45865              "default": "500",
45866              "minimum": "0",
45867              "location": "query",
45868              "type": "integer",
45869              "format": "uint32"
45870            },
45871            "orderBy": {
45872              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
45873              "location": "query",
45874              "type": "string"
45875            },
45876            "pageToken": {
45877              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
45878              "location": "query",
45879              "type": "string"
45880            },
45881            "project": {
45882              "description": "Project ID for this request.",
45883              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45884              "location": "path",
45885              "required": true,
45886              "type": "string"
45887            },
45888            "region": {
45889              "description": "Name of the region for this request.",
45890              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
45891              "location": "path",
45892              "required": true,
45893              "type": "string"
45894            },
45895            "returnPartialSuccess": {
45896              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
45897              "location": "query",
45898              "type": "boolean"
45899            }
45900          },
45901          "parameterOrder": [
45902            "project",
45903            "region"
45904          ],
45905          "response": {
45906            "$ref": "AddressList"
45907          },
45908          "scopes": [
45909            "https://www.googleapis.com/auth/cloud-platform",
45910            "https://www.googleapis.com/auth/compute",
45911            "https://www.googleapis.com/auth/compute.readonly"
45912          ],
45913          "description": "Retrieves a list of addresses contained within the specified region."
45914        },
45915        "aggregatedList": {
45916          "id": "compute.addresses.aggregatedList",
45917          "path": "projects/{project}/aggregated/addresses",
45918          "flatPath": "projects/{project}/aggregated/addresses",
45919          "httpMethod": "GET",
45920          "parameters": {
45921            "filter": {
45922              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
45923              "location": "query",
45924              "type": "string"
45925            },
45926            "includeAllScopes": {
45927              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
45928              "location": "query",
45929              "type": "boolean"
45930            },
45931            "maxResults": {
45932              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
45933              "default": "500",
45934              "minimum": "0",
45935              "location": "query",
45936              "type": "integer",
45937              "format": "uint32"
45938            },
45939            "orderBy": {
45940              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
45941              "location": "query",
45942              "type": "string"
45943            },
45944            "pageToken": {
45945              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
45946              "location": "query",
45947              "type": "string"
45948            },
45949            "project": {
45950              "description": "Project ID for this request.",
45951              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45952              "location": "path",
45953              "required": true,
45954              "type": "string"
45955            },
45956            "returnPartialSuccess": {
45957              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
45958              "location": "query",
45959              "type": "boolean"
45960            },
45961            "serviceProjectNumber": {
45962              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
45963              "location": "query",
45964              "type": "string",
45965              "format": "int64"
45966            }
45967          },
45968          "parameterOrder": [
45969            "project"
45970          ],
45971          "response": {
45972            "$ref": "AddressAggregatedList"
45973          },
45974          "scopes": [
45975            "https://www.googleapis.com/auth/cloud-platform",
45976            "https://www.googleapis.com/auth/compute",
45977            "https://www.googleapis.com/auth/compute.readonly"
45978          ],
45979          "description": "Retrieves an aggregated list of addresses. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
45980        },
45981        "get": {
45982          "id": "compute.addresses.get",
45983          "path": "projects/{project}/regions/{region}/addresses/{address}",
45984          "flatPath": "projects/{project}/regions/{region}/addresses/{address}",
45985          "httpMethod": "GET",
45986          "parameters": {
45987            "address": {
45988              "description": "Name of the address resource to return.",
45989              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
45990              "location": "path",
45991              "required": true,
45992              "type": "string"
45993            },
45994            "project": {
45995              "description": "Project ID for this request.",
45996              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
45997              "location": "path",
45998              "required": true,
45999              "type": "string"
46000            },
46001            "region": {
46002              "description": "Name of the region for this request.",
46003              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
46004              "location": "path",
46005              "required": true,
46006              "type": "string"
46007            }
46008          },
46009          "parameterOrder": [
46010            "project",
46011            "region",
46012            "address"
46013          ],
46014          "response": {
46015            "$ref": "Address"
46016          },
46017          "scopes": [
46018            "https://www.googleapis.com/auth/cloud-platform",
46019            "https://www.googleapis.com/auth/compute",
46020            "https://www.googleapis.com/auth/compute.readonly"
46021          ],
46022          "description": "Returns the specified address resource."
46023        },
46024        "insert": {
46025          "id": "compute.addresses.insert",
46026          "path": "projects/{project}/regions/{region}/addresses",
46027          "flatPath": "projects/{project}/regions/{region}/addresses",
46028          "httpMethod": "POST",
46029          "parameters": {
46030            "project": {
46031              "description": "Project ID for this request.",
46032              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46033              "location": "path",
46034              "required": true,
46035              "type": "string"
46036            },
46037            "region": {
46038              "description": "Name of the region for this request.",
46039              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
46040              "location": "path",
46041              "required": true,
46042              "type": "string"
46043            },
46044            "requestId": {
46045              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
46046              "location": "query",
46047              "type": "string"
46048            }
46049          },
46050          "parameterOrder": [
46051            "project",
46052            "region"
46053          ],
46054          "request": {
46055            "$ref": "Address"
46056          },
46057          "response": {
46058            "$ref": "Operation"
46059          },
46060          "scopes": [
46061            "https://www.googleapis.com/auth/cloud-platform",
46062            "https://www.googleapis.com/auth/compute"
46063          ],
46064          "description": "Creates an address resource in the specified project by using the data included in the request."
46065        },
46066        "delete": {
46067          "id": "compute.addresses.delete",
46068          "path": "projects/{project}/regions/{region}/addresses/{address}",
46069          "flatPath": "projects/{project}/regions/{region}/addresses/{address}",
46070          "httpMethod": "DELETE",
46071          "parameters": {
46072            "address": {
46073              "description": "Name of the address resource to delete.",
46074              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46075              "location": "path",
46076              "required": true,
46077              "type": "string"
46078            },
46079            "project": {
46080              "description": "Project ID for this request.",
46081              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46082              "location": "path",
46083              "required": true,
46084              "type": "string"
46085            },
46086            "region": {
46087              "description": "Name of the region for this request.",
46088              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
46089              "location": "path",
46090              "required": true,
46091              "type": "string"
46092            },
46093            "requestId": {
46094              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
46095              "location": "query",
46096              "type": "string"
46097            }
46098          },
46099          "parameterOrder": [
46100            "project",
46101            "region",
46102            "address"
46103          ],
46104          "response": {
46105            "$ref": "Operation"
46106          },
46107          "scopes": [
46108            "https://www.googleapis.com/auth/cloud-platform",
46109            "https://www.googleapis.com/auth/compute"
46110          ],
46111          "description": "Deletes the specified address resource."
46112        },
46113        "move": {
46114          "id": "compute.addresses.move",
46115          "path": "projects/{project}/regions/{region}/addresses/{address}/move",
46116          "flatPath": "projects/{project}/regions/{region}/addresses/{address}/move",
46117          "httpMethod": "POST",
46118          "parameters": {
46119            "address": {
46120              "description": "Name of the address resource to move.",
46121              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46122              "location": "path",
46123              "required": true,
46124              "type": "string"
46125            },
46126            "project": {
46127              "description": "Source project ID which the Address is moved from.",
46128              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46129              "location": "path",
46130              "required": true,
46131              "type": "string"
46132            },
46133            "region": {
46134              "description": "Name of the region for this request.",
46135              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
46136              "location": "path",
46137              "required": true,
46138              "type": "string"
46139            },
46140            "requestId": {
46141              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
46142              "location": "query",
46143              "type": "string"
46144            }
46145          },
46146          "parameterOrder": [
46147            "project",
46148            "region",
46149            "address"
46150          ],
46151          "request": {
46152            "$ref": "RegionAddressesMoveRequest"
46153          },
46154          "response": {
46155            "$ref": "Operation"
46156          },
46157          "scopes": [
46158            "https://www.googleapis.com/auth/cloud-platform",
46159            "https://www.googleapis.com/auth/compute"
46160          ],
46161          "description": "Moves the specified address resource."
46162        },
46163        "setLabels": {
46164          "id": "compute.addresses.setLabels",
46165          "path": "projects/{project}/regions/{region}/addresses/{resource}/setLabels",
46166          "flatPath": "projects/{project}/regions/{region}/addresses/{resource}/setLabels",
46167          "httpMethod": "POST",
46168          "parameters": {
46169            "project": {
46170              "description": "Project ID for this request.",
46171              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46172              "location": "path",
46173              "required": true,
46174              "type": "string"
46175            },
46176            "region": {
46177              "description": "The region for this request.",
46178              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
46179              "location": "path",
46180              "required": true,
46181              "type": "string"
46182            },
46183            "requestId": {
46184              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
46185              "location": "query",
46186              "type": "string"
46187            },
46188            "resource": {
46189              "description": "Name or id of the resource for this request.",
46190              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46191              "location": "path",
46192              "required": true,
46193              "type": "string"
46194            }
46195          },
46196          "parameterOrder": [
46197            "project",
46198            "region",
46199            "resource"
46200          ],
46201          "request": {
46202            "$ref": "RegionSetLabelsRequest"
46203          },
46204          "response": {
46205            "$ref": "Operation"
46206          },
46207          "scopes": [
46208            "https://www.googleapis.com/auth/cloud-platform",
46209            "https://www.googleapis.com/auth/compute"
46210          ],
46211          "description": "Sets the labels on an Address. To learn more about labels, read the Labeling Resources documentation."
46212        }
46213      }
46214    },
46215    "images": {
46216      "methods": {
46217        "list": {
46218          "id": "compute.images.list",
46219          "path": "projects/{project}/global/images",
46220          "flatPath": "projects/{project}/global/images",
46221          "httpMethod": "GET",
46222          "parameters": {
46223            "filter": {
46224              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
46225              "location": "query",
46226              "type": "string"
46227            },
46228            "maxResults": {
46229              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
46230              "default": "500",
46231              "minimum": "0",
46232              "location": "query",
46233              "type": "integer",
46234              "format": "uint32"
46235            },
46236            "orderBy": {
46237              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
46238              "location": "query",
46239              "type": "string"
46240            },
46241            "pageToken": {
46242              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
46243              "location": "query",
46244              "type": "string"
46245            },
46246            "project": {
46247              "description": "Project ID for this request.",
46248              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46249              "location": "path",
46250              "required": true,
46251              "type": "string"
46252            },
46253            "returnPartialSuccess": {
46254              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
46255              "location": "query",
46256              "type": "boolean"
46257            }
46258          },
46259          "parameterOrder": [
46260            "project"
46261          ],
46262          "response": {
46263            "$ref": "ImageList"
46264          },
46265          "scopes": [
46266            "https://www.googleapis.com/auth/cloud-platform",
46267            "https://www.googleapis.com/auth/compute",
46268            "https://www.googleapis.com/auth/compute.readonly"
46269          ],
46270          "description": "Retrieves the list of custom images available to the specified project. Custom images are images you create that belong to your project. This method does not get any images that belong to other projects, including publicly-available images, like Debian 8. If you want to get a list of publicly-available images, use this method to make a request to the respective image project, such as debian-cloud or windows-cloud."
46271        },
46272        "get": {
46273          "id": "compute.images.get",
46274          "path": "projects/{project}/global/images/{image}",
46275          "flatPath": "projects/{project}/global/images/{image}",
46276          "httpMethod": "GET",
46277          "parameters": {
46278            "image": {
46279              "description": "Name of the image resource to return.",
46280              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46281              "location": "path",
46282              "required": true,
46283              "type": "string"
46284            },
46285            "project": {
46286              "description": "Project ID for this request.",
46287              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46288              "location": "path",
46289              "required": true,
46290              "type": "string"
46291            }
46292          },
46293          "parameterOrder": [
46294            "project",
46295            "image"
46296          ],
46297          "response": {
46298            "$ref": "Image"
46299          },
46300          "scopes": [
46301            "https://www.googleapis.com/auth/cloud-platform",
46302            "https://www.googleapis.com/auth/compute",
46303            "https://www.googleapis.com/auth/compute.readonly"
46304          ],
46305          "description": "Returns the specified image."
46306        },
46307        "getFromFamily": {
46308          "id": "compute.images.getFromFamily",
46309          "path": "projects/{project}/global/images/family/{family}",
46310          "flatPath": "projects/{project}/global/images/family/{family}",
46311          "httpMethod": "GET",
46312          "parameters": {
46313            "family": {
46314              "description": "Name of the image family to search for.",
46315              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46316              "location": "path",
46317              "required": true,
46318              "type": "string"
46319            },
46320            "project": {
46321              "description": "The image project that the image belongs to. For example, to get a CentOS image, specify centos-cloud as the image project.",
46322              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46323              "location": "path",
46324              "required": true,
46325              "type": "string"
46326            }
46327          },
46328          "parameterOrder": [
46329            "project",
46330            "family"
46331          ],
46332          "response": {
46333            "$ref": "Image"
46334          },
46335          "scopes": [
46336            "https://www.googleapis.com/auth/cloud-platform",
46337            "https://www.googleapis.com/auth/compute",
46338            "https://www.googleapis.com/auth/compute.readonly"
46339          ],
46340          "description": "Returns the latest image that is part of an image family and is not deprecated. For more information on image families, see Public image families documentation."
46341        },
46342        "insert": {
46343          "id": "compute.images.insert",
46344          "path": "projects/{project}/global/images",
46345          "flatPath": "projects/{project}/global/images",
46346          "httpMethod": "POST",
46347          "parameters": {
46348            "forceCreate": {
46349              "description": "Force image creation if true.",
46350              "location": "query",
46351              "type": "boolean"
46352            },
46353            "project": {
46354              "description": "Project ID for this request.",
46355              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46356              "location": "path",
46357              "required": true,
46358              "type": "string"
46359            },
46360            "requestId": {
46361              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
46362              "location": "query",
46363              "type": "string"
46364            }
46365          },
46366          "parameterOrder": [
46367            "project"
46368          ],
46369          "request": {
46370            "$ref": "Image"
46371          },
46372          "response": {
46373            "$ref": "Operation"
46374          },
46375          "scopes": [
46376            "https://www.googleapis.com/auth/cloud-platform",
46377            "https://www.googleapis.com/auth/compute",
46378            "https://www.googleapis.com/auth/devstorage.full_control",
46379            "https://www.googleapis.com/auth/devstorage.read_only",
46380            "https://www.googleapis.com/auth/devstorage.read_write"
46381          ],
46382          "description": "Creates an image in the specified project using the data included in the request."
46383        },
46384        "setLabels": {
46385          "id": "compute.images.setLabels",
46386          "path": "projects/{project}/global/images/{resource}/setLabels",
46387          "flatPath": "projects/{project}/global/images/{resource}/setLabels",
46388          "httpMethod": "POST",
46389          "parameters": {
46390            "project": {
46391              "description": "Project ID for this request.",
46392              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46393              "location": "path",
46394              "required": true,
46395              "type": "string"
46396            },
46397            "resource": {
46398              "description": "Name or id of the resource for this request.",
46399              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46400              "location": "path",
46401              "required": true,
46402              "type": "string"
46403            }
46404          },
46405          "parameterOrder": [
46406            "project",
46407            "resource"
46408          ],
46409          "request": {
46410            "$ref": "GlobalSetLabelsRequest"
46411          },
46412          "response": {
46413            "$ref": "Operation"
46414          },
46415          "scopes": [
46416            "https://www.googleapis.com/auth/cloud-platform",
46417            "https://www.googleapis.com/auth/compute"
46418          ],
46419          "description": "Sets the labels on an image. To learn more about labels, read the Labeling Resources documentation."
46420        },
46421        "delete": {
46422          "id": "compute.images.delete",
46423          "path": "projects/{project}/global/images/{image}",
46424          "flatPath": "projects/{project}/global/images/{image}",
46425          "httpMethod": "DELETE",
46426          "parameters": {
46427            "image": {
46428              "description": "Name of the image resource to delete.",
46429              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46430              "location": "path",
46431              "required": true,
46432              "type": "string"
46433            },
46434            "project": {
46435              "description": "Project ID for this request.",
46436              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46437              "location": "path",
46438              "required": true,
46439              "type": "string"
46440            },
46441            "requestId": {
46442              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
46443              "location": "query",
46444              "type": "string"
46445            }
46446          },
46447          "parameterOrder": [
46448            "project",
46449            "image"
46450          ],
46451          "response": {
46452            "$ref": "Operation"
46453          },
46454          "scopes": [
46455            "https://www.googleapis.com/auth/cloud-platform",
46456            "https://www.googleapis.com/auth/compute"
46457          ],
46458          "description": "Deletes the specified image."
46459        },
46460        "deprecate": {
46461          "id": "compute.images.deprecate",
46462          "path": "projects/{project}/global/images/{image}/deprecate",
46463          "flatPath": "projects/{project}/global/images/{image}/deprecate",
46464          "httpMethod": "POST",
46465          "parameters": {
46466            "image": {
46467              "description": "Image name.",
46468              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46469              "location": "path",
46470              "required": true,
46471              "type": "string"
46472            },
46473            "project": {
46474              "description": "Project ID for this request.",
46475              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46476              "location": "path",
46477              "required": true,
46478              "type": "string"
46479            },
46480            "requestId": {
46481              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
46482              "location": "query",
46483              "type": "string"
46484            }
46485          },
46486          "parameterOrder": [
46487            "project",
46488            "image"
46489          ],
46490          "request": {
46491            "$ref": "DeprecationStatus"
46492          },
46493          "response": {
46494            "$ref": "Operation"
46495          },
46496          "scopes": [
46497            "https://www.googleapis.com/auth/cloud-platform",
46498            "https://www.googleapis.com/auth/compute"
46499          ],
46500          "description": "Sets the deprecation status of an image. If an empty request body is given, clears the deprecation status instead."
46501        },
46502        "getIamPolicy": {
46503          "id": "compute.images.getIamPolicy",
46504          "path": "projects/{project}/global/images/{resource}/getIamPolicy",
46505          "flatPath": "projects/{project}/global/images/{resource}/getIamPolicy",
46506          "httpMethod": "GET",
46507          "parameters": {
46508            "optionsRequestedPolicyVersion": {
46509              "description": "Requested IAM Policy version.",
46510              "location": "query",
46511              "type": "integer",
46512              "format": "int32"
46513            },
46514            "project": {
46515              "description": "Project ID for this request.",
46516              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46517              "location": "path",
46518              "required": true,
46519              "type": "string"
46520            },
46521            "resource": {
46522              "description": "Name or id of the resource for this request.",
46523              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46524              "location": "path",
46525              "required": true,
46526              "type": "string"
46527            }
46528          },
46529          "parameterOrder": [
46530            "project",
46531            "resource"
46532          ],
46533          "response": {
46534            "$ref": "Policy"
46535          },
46536          "scopes": [
46537            "https://www.googleapis.com/auth/cloud-platform",
46538            "https://www.googleapis.com/auth/compute",
46539            "https://www.googleapis.com/auth/compute.readonly"
46540          ],
46541          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
46542        },
46543        "patch": {
46544          "id": "compute.images.patch",
46545          "path": "projects/{project}/global/images/{image}",
46546          "flatPath": "projects/{project}/global/images/{image}",
46547          "httpMethod": "PATCH",
46548          "parameters": {
46549            "image": {
46550              "description": "Name of the image resource to patch.",
46551              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46552              "location": "path",
46553              "required": true,
46554              "type": "string"
46555            },
46556            "project": {
46557              "description": "Project ID for this request.",
46558              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46559              "location": "path",
46560              "required": true,
46561              "type": "string"
46562            },
46563            "requestId": {
46564              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
46565              "location": "query",
46566              "type": "string"
46567            }
46568          },
46569          "parameterOrder": [
46570            "project",
46571            "image"
46572          ],
46573          "request": {
46574            "$ref": "Image"
46575          },
46576          "response": {
46577            "$ref": "Operation"
46578          },
46579          "scopes": [
46580            "https://www.googleapis.com/auth/cloud-platform",
46581            "https://www.googleapis.com/auth/compute"
46582          ],
46583          "description": "Patches the specified image with the data included in the request. Only the following fields can be modified: family, description, deprecation status."
46584        },
46585        "setIamPolicy": {
46586          "id": "compute.images.setIamPolicy",
46587          "path": "projects/{project}/global/images/{resource}/setIamPolicy",
46588          "flatPath": "projects/{project}/global/images/{resource}/setIamPolicy",
46589          "httpMethod": "POST",
46590          "parameters": {
46591            "project": {
46592              "description": "Project ID for this request.",
46593              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46594              "location": "path",
46595              "required": true,
46596              "type": "string"
46597            },
46598            "resource": {
46599              "description": "Name or id of the resource for this request.",
46600              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46601              "location": "path",
46602              "required": true,
46603              "type": "string"
46604            }
46605          },
46606          "parameterOrder": [
46607            "project",
46608            "resource"
46609          ],
46610          "request": {
46611            "$ref": "GlobalSetPolicyRequest"
46612          },
46613          "response": {
46614            "$ref": "Policy"
46615          },
46616          "scopes": [
46617            "https://www.googleapis.com/auth/cloud-platform",
46618            "https://www.googleapis.com/auth/compute"
46619          ],
46620          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
46621        },
46622        "testIamPermissions": {
46623          "id": "compute.images.testIamPermissions",
46624          "path": "projects/{project}/global/images/{resource}/testIamPermissions",
46625          "flatPath": "projects/{project}/global/images/{resource}/testIamPermissions",
46626          "httpMethod": "POST",
46627          "parameters": {
46628            "project": {
46629              "description": "Project ID for this request.",
46630              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46631              "location": "path",
46632              "required": true,
46633              "type": "string"
46634            },
46635            "resource": {
46636              "description": "Name or id of the resource for this request.",
46637              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46638              "location": "path",
46639              "required": true,
46640              "type": "string"
46641            }
46642          },
46643          "parameterOrder": [
46644            "project",
46645            "resource"
46646          ],
46647          "request": {
46648            "$ref": "TestPermissionsRequest"
46649          },
46650          "response": {
46651            "$ref": "TestPermissionsResponse"
46652          },
46653          "scopes": [
46654            "https://www.googleapis.com/auth/cloud-platform",
46655            "https://www.googleapis.com/auth/compute",
46656            "https://www.googleapis.com/auth/compute.readonly"
46657          ],
46658          "description": "Returns permissions that a caller has on the specified resource."
46659        }
46660      }
46661    },
46662    "imageFamilyViews": {
46663      "methods": {
46664        "get": {
46665          "id": "compute.imageFamilyViews.get",
46666          "path": "projects/{project}/zones/{zone}/imageFamilyViews/{family}",
46667          "flatPath": "projects/{project}/zones/{zone}/imageFamilyViews/{family}",
46668          "httpMethod": "GET",
46669          "parameters": {
46670            "family": {
46671              "description": "Name of the image family to search for.",
46672              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46673              "location": "path",
46674              "required": true,
46675              "type": "string"
46676            },
46677            "project": {
46678              "description": "Project ID for this request.",
46679              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46680              "location": "path",
46681              "required": true,
46682              "type": "string"
46683            },
46684            "zone": {
46685              "description": "The name of the zone for this request.",
46686              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
46687              "location": "path",
46688              "required": true,
46689              "type": "string"
46690            }
46691          },
46692          "parameterOrder": [
46693            "project",
46694            "zone",
46695            "family"
46696          ],
46697          "response": {
46698            "$ref": "ImageFamilyView"
46699          },
46700          "scopes": [
46701            "https://www.googleapis.com/auth/cloud-platform",
46702            "https://www.googleapis.com/auth/compute",
46703            "https://www.googleapis.com/auth/compute.readonly"
46704          ],
46705          "description": "Returns the latest image that is part of an image family, is not deprecated and is rolled out in the specified zone."
46706        }
46707      }
46708    },
46709    "snapshots": {
46710      "methods": {
46711        "list": {
46712          "id": "compute.snapshots.list",
46713          "path": "projects/{project}/global/snapshots",
46714          "flatPath": "projects/{project}/global/snapshots",
46715          "httpMethod": "GET",
46716          "parameters": {
46717            "filter": {
46718              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
46719              "location": "query",
46720              "type": "string"
46721            },
46722            "maxResults": {
46723              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
46724              "default": "500",
46725              "minimum": "0",
46726              "location": "query",
46727              "type": "integer",
46728              "format": "uint32"
46729            },
46730            "orderBy": {
46731              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
46732              "location": "query",
46733              "type": "string"
46734            },
46735            "pageToken": {
46736              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
46737              "location": "query",
46738              "type": "string"
46739            },
46740            "project": {
46741              "description": "Project ID for this request.",
46742              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46743              "location": "path",
46744              "required": true,
46745              "type": "string"
46746            },
46747            "returnPartialSuccess": {
46748              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
46749              "location": "query",
46750              "type": "boolean"
46751            }
46752          },
46753          "parameterOrder": [
46754            "project"
46755          ],
46756          "response": {
46757            "$ref": "SnapshotList"
46758          },
46759          "scopes": [
46760            "https://www.googleapis.com/auth/cloud-platform",
46761            "https://www.googleapis.com/auth/compute",
46762            "https://www.googleapis.com/auth/compute.readonly"
46763          ],
46764          "description": "Retrieves the list of Snapshot resources contained within the specified project."
46765        },
46766        "get": {
46767          "id": "compute.snapshots.get",
46768          "path": "projects/{project}/global/snapshots/{snapshot}",
46769          "flatPath": "projects/{project}/global/snapshots/{snapshot}",
46770          "httpMethod": "GET",
46771          "parameters": {
46772            "project": {
46773              "description": "Project ID for this request.",
46774              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46775              "location": "path",
46776              "required": true,
46777              "type": "string"
46778            },
46779            "snapshot": {
46780              "description": "Name of the Snapshot resource to return.",
46781              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46782              "location": "path",
46783              "required": true,
46784              "type": "string"
46785            }
46786          },
46787          "parameterOrder": [
46788            "project",
46789            "snapshot"
46790          ],
46791          "response": {
46792            "$ref": "Snapshot"
46793          },
46794          "scopes": [
46795            "https://www.googleapis.com/auth/cloud-platform",
46796            "https://www.googleapis.com/auth/compute",
46797            "https://www.googleapis.com/auth/compute.readonly"
46798          ],
46799          "description": "Returns the specified Snapshot resource."
46800        },
46801        "insert": {
46802          "id": "compute.snapshots.insert",
46803          "path": "projects/{project}/global/snapshots",
46804          "flatPath": "projects/{project}/global/snapshots",
46805          "httpMethod": "POST",
46806          "parameters": {
46807            "project": {
46808              "description": "Project ID for this request.",
46809              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46810              "location": "path",
46811              "required": true,
46812              "type": "string"
46813            },
46814            "requestId": {
46815              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
46816              "location": "query",
46817              "type": "string"
46818            }
46819          },
46820          "parameterOrder": [
46821            "project"
46822          ],
46823          "request": {
46824            "$ref": "Snapshot"
46825          },
46826          "response": {
46827            "$ref": "Operation"
46828          },
46829          "scopes": [
46830            "https://www.googleapis.com/auth/cloud-platform",
46831            "https://www.googleapis.com/auth/compute"
46832          ],
46833          "description": "Creates a snapshot in the specified project using the data included in the request. For regular snapshot creation, consider using this method instead of disks.createSnapshot, as this method supports more features, such as creating snapshots in a project different from the source disk project."
46834        },
46835        "setLabels": {
46836          "id": "compute.snapshots.setLabels",
46837          "path": "projects/{project}/global/snapshots/{resource}/setLabels",
46838          "flatPath": "projects/{project}/global/snapshots/{resource}/setLabels",
46839          "httpMethod": "POST",
46840          "parameters": {
46841            "project": {
46842              "description": "Project ID for this request.",
46843              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46844              "location": "path",
46845              "required": true,
46846              "type": "string"
46847            },
46848            "resource": {
46849              "description": "Name or id of the resource for this request.",
46850              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46851              "location": "path",
46852              "required": true,
46853              "type": "string"
46854            }
46855          },
46856          "parameterOrder": [
46857            "project",
46858            "resource"
46859          ],
46860          "request": {
46861            "$ref": "GlobalSetLabelsRequest"
46862          },
46863          "response": {
46864            "$ref": "Operation"
46865          },
46866          "scopes": [
46867            "https://www.googleapis.com/auth/cloud-platform",
46868            "https://www.googleapis.com/auth/compute"
46869          ],
46870          "description": "Sets the labels on a snapshot. To learn more about labels, read the Labeling Resources documentation."
46871        },
46872        "delete": {
46873          "id": "compute.snapshots.delete",
46874          "path": "projects/{project}/global/snapshots/{snapshot}",
46875          "flatPath": "projects/{project}/global/snapshots/{snapshot}",
46876          "httpMethod": "DELETE",
46877          "parameters": {
46878            "project": {
46879              "description": "Project ID for this request.",
46880              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46881              "location": "path",
46882              "required": true,
46883              "type": "string"
46884            },
46885            "requestId": {
46886              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
46887              "location": "query",
46888              "type": "string"
46889            },
46890            "snapshot": {
46891              "description": "Name of the Snapshot resource to delete.",
46892              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46893              "location": "path",
46894              "required": true,
46895              "type": "string"
46896            }
46897          },
46898          "parameterOrder": [
46899            "project",
46900            "snapshot"
46901          ],
46902          "response": {
46903            "$ref": "Operation"
46904          },
46905          "scopes": [
46906            "https://www.googleapis.com/auth/cloud-platform",
46907            "https://www.googleapis.com/auth/compute"
46908          ],
46909          "description": "Deletes the specified Snapshot resource. Keep in mind that deleting a single snapshot might not necessarily delete all the data on that snapshot. If any data on the snapshot that is marked for deletion is needed for subsequent snapshots, the data will be moved to the next corresponding snapshot. For more information, see Deleting snapshots."
46910        },
46911        "getIamPolicy": {
46912          "id": "compute.snapshots.getIamPolicy",
46913          "path": "projects/{project}/global/snapshots/{resource}/getIamPolicy",
46914          "flatPath": "projects/{project}/global/snapshots/{resource}/getIamPolicy",
46915          "httpMethod": "GET",
46916          "parameters": {
46917            "optionsRequestedPolicyVersion": {
46918              "description": "Requested IAM Policy version.",
46919              "location": "query",
46920              "type": "integer",
46921              "format": "int32"
46922            },
46923            "project": {
46924              "description": "Project ID for this request.",
46925              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46926              "location": "path",
46927              "required": true,
46928              "type": "string"
46929            },
46930            "resource": {
46931              "description": "Name or id of the resource for this request.",
46932              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46933              "location": "path",
46934              "required": true,
46935              "type": "string"
46936            }
46937          },
46938          "parameterOrder": [
46939            "project",
46940            "resource"
46941          ],
46942          "response": {
46943            "$ref": "Policy"
46944          },
46945          "scopes": [
46946            "https://www.googleapis.com/auth/cloud-platform",
46947            "https://www.googleapis.com/auth/compute",
46948            "https://www.googleapis.com/auth/compute.readonly"
46949          ],
46950          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
46951        },
46952        "setIamPolicy": {
46953          "id": "compute.snapshots.setIamPolicy",
46954          "path": "projects/{project}/global/snapshots/{resource}/setIamPolicy",
46955          "flatPath": "projects/{project}/global/snapshots/{resource}/setIamPolicy",
46956          "httpMethod": "POST",
46957          "parameters": {
46958            "project": {
46959              "description": "Project ID for this request.",
46960              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46961              "location": "path",
46962              "required": true,
46963              "type": "string"
46964            },
46965            "resource": {
46966              "description": "Name or id of the resource for this request.",
46967              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
46968              "location": "path",
46969              "required": true,
46970              "type": "string"
46971            }
46972          },
46973          "parameterOrder": [
46974            "project",
46975            "resource"
46976          ],
46977          "request": {
46978            "$ref": "GlobalSetPolicyRequest"
46979          },
46980          "response": {
46981            "$ref": "Policy"
46982          },
46983          "scopes": [
46984            "https://www.googleapis.com/auth/cloud-platform",
46985            "https://www.googleapis.com/auth/compute"
46986          ],
46987          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
46988        },
46989        "testIamPermissions": {
46990          "id": "compute.snapshots.testIamPermissions",
46991          "path": "projects/{project}/global/snapshots/{resource}/testIamPermissions",
46992          "flatPath": "projects/{project}/global/snapshots/{resource}/testIamPermissions",
46993          "httpMethod": "POST",
46994          "parameters": {
46995            "project": {
46996              "description": "Project ID for this request.",
46997              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
46998              "location": "path",
46999              "required": true,
47000              "type": "string"
47001            },
47002            "resource": {
47003              "description": "Name or id of the resource for this request.",
47004              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
47005              "location": "path",
47006              "required": true,
47007              "type": "string"
47008            }
47009          },
47010          "parameterOrder": [
47011            "project",
47012            "resource"
47013          ],
47014          "request": {
47015            "$ref": "TestPermissionsRequest"
47016          },
47017          "response": {
47018            "$ref": "TestPermissionsResponse"
47019          },
47020          "scopes": [
47021            "https://www.googleapis.com/auth/cloud-platform",
47022            "https://www.googleapis.com/auth/compute",
47023            "https://www.googleapis.com/auth/compute.readonly"
47024          ],
47025          "description": "Returns permissions that a caller has on the specified resource."
47026        }
47027      }
47028    },
47029    "disks": {
47030      "methods": {
47031        "list": {
47032          "id": "compute.disks.list",
47033          "path": "projects/{project}/zones/{zone}/disks",
47034          "flatPath": "projects/{project}/zones/{zone}/disks",
47035          "httpMethod": "GET",
47036          "parameters": {
47037            "filter": {
47038              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
47039              "location": "query",
47040              "type": "string"
47041            },
47042            "maxResults": {
47043              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
47044              "default": "500",
47045              "minimum": "0",
47046              "location": "query",
47047              "type": "integer",
47048              "format": "uint32"
47049            },
47050            "orderBy": {
47051              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
47052              "location": "query",
47053              "type": "string"
47054            },
47055            "pageToken": {
47056              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
47057              "location": "query",
47058              "type": "string"
47059            },
47060            "project": {
47061              "description": "Project ID for this request.",
47062              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47063              "location": "path",
47064              "required": true,
47065              "type": "string"
47066            },
47067            "returnPartialSuccess": {
47068              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
47069              "location": "query",
47070              "type": "boolean"
47071            },
47072            "zone": {
47073              "description": "The name of the zone for this request.",
47074              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47075              "location": "path",
47076              "required": true,
47077              "type": "string"
47078            }
47079          },
47080          "parameterOrder": [
47081            "project",
47082            "zone"
47083          ],
47084          "response": {
47085            "$ref": "DiskList"
47086          },
47087          "scopes": [
47088            "https://www.googleapis.com/auth/cloud-platform",
47089            "https://www.googleapis.com/auth/compute",
47090            "https://www.googleapis.com/auth/compute.readonly"
47091          ],
47092          "description": "Retrieves a list of persistent disks contained within the specified zone."
47093        },
47094        "aggregatedList": {
47095          "id": "compute.disks.aggregatedList",
47096          "path": "projects/{project}/aggregated/disks",
47097          "flatPath": "projects/{project}/aggregated/disks",
47098          "httpMethod": "GET",
47099          "parameters": {
47100            "filter": {
47101              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
47102              "location": "query",
47103              "type": "string"
47104            },
47105            "includeAllScopes": {
47106              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
47107              "location": "query",
47108              "type": "boolean"
47109            },
47110            "maxResults": {
47111              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
47112              "default": "500",
47113              "minimum": "0",
47114              "location": "query",
47115              "type": "integer",
47116              "format": "uint32"
47117            },
47118            "orderBy": {
47119              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
47120              "location": "query",
47121              "type": "string"
47122            },
47123            "pageToken": {
47124              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
47125              "location": "query",
47126              "type": "string"
47127            },
47128            "project": {
47129              "description": "Project ID for this request.",
47130              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47131              "location": "path",
47132              "required": true,
47133              "type": "string"
47134            },
47135            "returnPartialSuccess": {
47136              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
47137              "location": "query",
47138              "type": "boolean"
47139            },
47140            "serviceProjectNumber": {
47141              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
47142              "location": "query",
47143              "type": "string",
47144              "format": "int64"
47145            }
47146          },
47147          "parameterOrder": [
47148            "project"
47149          ],
47150          "response": {
47151            "$ref": "DiskAggregatedList"
47152          },
47153          "scopes": [
47154            "https://www.googleapis.com/auth/cloud-platform",
47155            "https://www.googleapis.com/auth/compute",
47156            "https://www.googleapis.com/auth/compute.readonly"
47157          ],
47158          "description": "Retrieves an aggregated list of persistent disks. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
47159        },
47160        "get": {
47161          "id": "compute.disks.get",
47162          "path": "projects/{project}/zones/{zone}/disks/{disk}",
47163          "flatPath": "projects/{project}/zones/{zone}/disks/{disk}",
47164          "httpMethod": "GET",
47165          "parameters": {
47166            "disk": {
47167              "description": "Name of the persistent disk to return.",
47168              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
47169              "location": "path",
47170              "required": true,
47171              "type": "string"
47172            },
47173            "project": {
47174              "description": "Project ID for this request.",
47175              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47176              "location": "path",
47177              "required": true,
47178              "type": "string"
47179            },
47180            "zone": {
47181              "description": "The name of the zone for this request.",
47182              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47183              "location": "path",
47184              "required": true,
47185              "type": "string"
47186            }
47187          },
47188          "parameterOrder": [
47189            "project",
47190            "zone",
47191            "disk"
47192          ],
47193          "response": {
47194            "$ref": "Disk"
47195          },
47196          "scopes": [
47197            "https://www.googleapis.com/auth/cloud-platform",
47198            "https://www.googleapis.com/auth/compute",
47199            "https://www.googleapis.com/auth/compute.readonly"
47200          ],
47201          "description": "Returns the specified persistent disk."
47202        },
47203        "insert": {
47204          "id": "compute.disks.insert",
47205          "path": "projects/{project}/zones/{zone}/disks",
47206          "flatPath": "projects/{project}/zones/{zone}/disks",
47207          "httpMethod": "POST",
47208          "parameters": {
47209            "project": {
47210              "description": "Project ID for this request.",
47211              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47212              "location": "path",
47213              "required": true,
47214              "type": "string"
47215            },
47216            "requestId": {
47217              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
47218              "location": "query",
47219              "type": "string"
47220            },
47221            "sourceImage": {
47222              "description": "Source image to restore onto a disk. This field is optional.",
47223              "location": "query",
47224              "type": "string"
47225            },
47226            "zone": {
47227              "description": "The name of the zone for this request.",
47228              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47229              "location": "path",
47230              "required": true,
47231              "type": "string"
47232            }
47233          },
47234          "parameterOrder": [
47235            "project",
47236            "zone"
47237          ],
47238          "request": {
47239            "$ref": "Disk"
47240          },
47241          "response": {
47242            "$ref": "Operation"
47243          },
47244          "scopes": [
47245            "https://www.googleapis.com/auth/cloud-platform",
47246            "https://www.googleapis.com/auth/compute"
47247          ],
47248          "description": "Creates a persistent disk in the specified project using the data in the request. You can create a disk from a source (sourceImage, sourceSnapshot, or sourceDisk) or create an empty 500 GB data disk by omitting all properties. You can also create a disk that is larger than the default size by specifying the sizeGb property."
47249        },
47250        "setLabels": {
47251          "id": "compute.disks.setLabels",
47252          "path": "projects/{project}/zones/{zone}/disks/{resource}/setLabels",
47253          "flatPath": "projects/{project}/zones/{zone}/disks/{resource}/setLabels",
47254          "httpMethod": "POST",
47255          "parameters": {
47256            "project": {
47257              "description": "Project ID for this request.",
47258              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47259              "location": "path",
47260              "required": true,
47261              "type": "string"
47262            },
47263            "requestId": {
47264              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
47265              "location": "query",
47266              "type": "string"
47267            },
47268            "resource": {
47269              "description": "Name or id of the resource for this request.",
47270              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
47271              "location": "path",
47272              "required": true,
47273              "type": "string"
47274            },
47275            "zone": {
47276              "description": "The name of the zone for this request.",
47277              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47278              "location": "path",
47279              "required": true,
47280              "type": "string"
47281            }
47282          },
47283          "parameterOrder": [
47284            "project",
47285            "zone",
47286            "resource"
47287          ],
47288          "request": {
47289            "$ref": "ZoneSetLabelsRequest"
47290          },
47291          "response": {
47292            "$ref": "Operation"
47293          },
47294          "scopes": [
47295            "https://www.googleapis.com/auth/cloud-platform",
47296            "https://www.googleapis.com/auth/compute"
47297          ],
47298          "description": "Sets the labels on a disk. To learn more about labels, read the Labeling Resources documentation."
47299        },
47300        "delete": {
47301          "id": "compute.disks.delete",
47302          "path": "projects/{project}/zones/{zone}/disks/{disk}",
47303          "flatPath": "projects/{project}/zones/{zone}/disks/{disk}",
47304          "httpMethod": "DELETE",
47305          "parameters": {
47306            "disk": {
47307              "description": "Name of the persistent disk to delete.",
47308              "location": "path",
47309              "required": true,
47310              "type": "string"
47311            },
47312            "project": {
47313              "description": "Project ID for this request.",
47314              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47315              "location": "path",
47316              "required": true,
47317              "type": "string"
47318            },
47319            "requestId": {
47320              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
47321              "location": "query",
47322              "type": "string"
47323            },
47324            "zone": {
47325              "description": "The name of the zone for this request.",
47326              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47327              "location": "path",
47328              "required": true,
47329              "type": "string"
47330            }
47331          },
47332          "parameterOrder": [
47333            "project",
47334            "zone",
47335            "disk"
47336          ],
47337          "response": {
47338            "$ref": "Operation"
47339          },
47340          "scopes": [
47341            "https://www.googleapis.com/auth/cloud-platform",
47342            "https://www.googleapis.com/auth/compute"
47343          ],
47344          "description": "Deletes the specified persistent disk. Deleting a disk removes its data permanently and is irreversible. However, deleting a disk does not delete any snapshots previously made from the disk. You must separately delete snapshots."
47345        },
47346        "createSnapshot": {
47347          "id": "compute.disks.createSnapshot",
47348          "path": "projects/{project}/zones/{zone}/disks/{disk}/createSnapshot",
47349          "flatPath": "projects/{project}/zones/{zone}/disks/{disk}/createSnapshot",
47350          "httpMethod": "POST",
47351          "parameters": {
47352            "disk": {
47353              "description": "Name of the persistent disk to snapshot.",
47354              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
47355              "location": "path",
47356              "required": true,
47357              "type": "string"
47358            },
47359            "guestFlush": {
47360              "description": "[Input Only] Whether to attempt an application consistent snapshot by informing the OS to prepare for the snapshot process.",
47361              "location": "query",
47362              "type": "boolean"
47363            },
47364            "project": {
47365              "description": "Project ID for this request.",
47366              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47367              "location": "path",
47368              "required": true,
47369              "type": "string"
47370            },
47371            "requestId": {
47372              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
47373              "location": "query",
47374              "type": "string"
47375            },
47376            "zone": {
47377              "description": "The name of the zone for this request.",
47378              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47379              "location": "path",
47380              "required": true,
47381              "type": "string"
47382            }
47383          },
47384          "parameterOrder": [
47385            "project",
47386            "zone",
47387            "disk"
47388          ],
47389          "request": {
47390            "$ref": "Snapshot"
47391          },
47392          "response": {
47393            "$ref": "Operation"
47394          },
47395          "scopes": [
47396            "https://www.googleapis.com/auth/cloud-platform",
47397            "https://www.googleapis.com/auth/compute"
47398          ],
47399          "description": "Creates a snapshot of a specified persistent disk. For regular snapshot creation, consider using snapshots.insert instead, as that method supports more features, such as creating snapshots in a project different from the source disk project."
47400        },
47401        "resize": {
47402          "id": "compute.disks.resize",
47403          "path": "projects/{project}/zones/{zone}/disks/{disk}/resize",
47404          "flatPath": "projects/{project}/zones/{zone}/disks/{disk}/resize",
47405          "httpMethod": "POST",
47406          "parameters": {
47407            "disk": {
47408              "description": "The name of the persistent disk.",
47409              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
47410              "location": "path",
47411              "required": true,
47412              "type": "string"
47413            },
47414            "project": {
47415              "description": "Project ID for this request.",
47416              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47417              "location": "path",
47418              "required": true,
47419              "type": "string"
47420            },
47421            "requestId": {
47422              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
47423              "location": "query",
47424              "type": "string"
47425            },
47426            "zone": {
47427              "description": "The name of the zone for this request.",
47428              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47429              "location": "path",
47430              "required": true,
47431              "type": "string"
47432            }
47433          },
47434          "parameterOrder": [
47435            "project",
47436            "zone",
47437            "disk"
47438          ],
47439          "request": {
47440            "$ref": "DisksResizeRequest"
47441          },
47442          "response": {
47443            "$ref": "Operation"
47444          },
47445          "scopes": [
47446            "https://www.googleapis.com/auth/cloud-platform",
47447            "https://www.googleapis.com/auth/compute"
47448          ],
47449          "description": "Resizes the specified persistent disk. You can only increase the size of the disk."
47450        },
47451        "addResourcePolicies": {
47452          "id": "compute.disks.addResourcePolicies",
47453          "path": "projects/{project}/zones/{zone}/disks/{disk}/addResourcePolicies",
47454          "flatPath": "projects/{project}/zones/{zone}/disks/{disk}/addResourcePolicies",
47455          "httpMethod": "POST",
47456          "parameters": {
47457            "disk": {
47458              "description": "The disk name for this request.",
47459              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
47460              "location": "path",
47461              "required": true,
47462              "type": "string"
47463            },
47464            "project": {
47465              "description": "Project ID for this request.",
47466              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47467              "location": "path",
47468              "required": true,
47469              "type": "string"
47470            },
47471            "requestId": {
47472              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
47473              "location": "query",
47474              "type": "string"
47475            },
47476            "zone": {
47477              "description": "The name of the zone for this request.",
47478              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47479              "location": "path",
47480              "required": true,
47481              "type": "string"
47482            }
47483          },
47484          "parameterOrder": [
47485            "project",
47486            "zone",
47487            "disk"
47488          ],
47489          "request": {
47490            "$ref": "DisksAddResourcePoliciesRequest"
47491          },
47492          "response": {
47493            "$ref": "Operation"
47494          },
47495          "scopes": [
47496            "https://www.googleapis.com/auth/cloud-platform",
47497            "https://www.googleapis.com/auth/compute"
47498          ],
47499          "description": "Adds existing resource policies to a disk. You can only add one policy which will be applied to this disk for scheduling snapshot creation."
47500        },
47501        "removeResourcePolicies": {
47502          "id": "compute.disks.removeResourcePolicies",
47503          "path": "projects/{project}/zones/{zone}/disks/{disk}/removeResourcePolicies",
47504          "flatPath": "projects/{project}/zones/{zone}/disks/{disk}/removeResourcePolicies",
47505          "httpMethod": "POST",
47506          "parameters": {
47507            "disk": {
47508              "description": "The disk name for this request.",
47509              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
47510              "location": "path",
47511              "required": true,
47512              "type": "string"
47513            },
47514            "project": {
47515              "description": "Project ID for this request.",
47516              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47517              "location": "path",
47518              "required": true,
47519              "type": "string"
47520            },
47521            "requestId": {
47522              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
47523              "location": "query",
47524              "type": "string"
47525            },
47526            "zone": {
47527              "description": "The name of the zone for this request.",
47528              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47529              "location": "path",
47530              "required": true,
47531              "type": "string"
47532            }
47533          },
47534          "parameterOrder": [
47535            "project",
47536            "zone",
47537            "disk"
47538          ],
47539          "request": {
47540            "$ref": "DisksRemoveResourcePoliciesRequest"
47541          },
47542          "response": {
47543            "$ref": "Operation"
47544          },
47545          "scopes": [
47546            "https://www.googleapis.com/auth/cloud-platform",
47547            "https://www.googleapis.com/auth/compute"
47548          ],
47549          "description": "Removes resource policies from a disk."
47550        },
47551        "getIamPolicy": {
47552          "id": "compute.disks.getIamPolicy",
47553          "path": "projects/{project}/zones/{zone}/disks/{resource}/getIamPolicy",
47554          "flatPath": "projects/{project}/zones/{zone}/disks/{resource}/getIamPolicy",
47555          "httpMethod": "GET",
47556          "parameters": {
47557            "optionsRequestedPolicyVersion": {
47558              "description": "Requested IAM Policy version.",
47559              "location": "query",
47560              "type": "integer",
47561              "format": "int32"
47562            },
47563            "project": {
47564              "description": "Project ID for this request.",
47565              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47566              "location": "path",
47567              "required": true,
47568              "type": "string"
47569            },
47570            "resource": {
47571              "description": "Name or id of the resource for this request.",
47572              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
47573              "location": "path",
47574              "required": true,
47575              "type": "string"
47576            },
47577            "zone": {
47578              "description": "The name of the zone for this request.",
47579              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47580              "location": "path",
47581              "required": true,
47582              "type": "string"
47583            }
47584          },
47585          "parameterOrder": [
47586            "project",
47587            "zone",
47588            "resource"
47589          ],
47590          "response": {
47591            "$ref": "Policy"
47592          },
47593          "scopes": [
47594            "https://www.googleapis.com/auth/cloud-platform",
47595            "https://www.googleapis.com/auth/compute",
47596            "https://www.googleapis.com/auth/compute.readonly"
47597          ],
47598          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
47599        },
47600        "setIamPolicy": {
47601          "id": "compute.disks.setIamPolicy",
47602          "path": "projects/{project}/zones/{zone}/disks/{resource}/setIamPolicy",
47603          "flatPath": "projects/{project}/zones/{zone}/disks/{resource}/setIamPolicy",
47604          "httpMethod": "POST",
47605          "parameters": {
47606            "project": {
47607              "description": "Project ID for this request.",
47608              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47609              "location": "path",
47610              "required": true,
47611              "type": "string"
47612            },
47613            "resource": {
47614              "description": "Name or id of the resource for this request.",
47615              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
47616              "location": "path",
47617              "required": true,
47618              "type": "string"
47619            },
47620            "zone": {
47621              "description": "The name of the zone for this request.",
47622              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47623              "location": "path",
47624              "required": true,
47625              "type": "string"
47626            }
47627          },
47628          "parameterOrder": [
47629            "project",
47630            "zone",
47631            "resource"
47632          ],
47633          "request": {
47634            "$ref": "ZoneSetPolicyRequest"
47635          },
47636          "response": {
47637            "$ref": "Policy"
47638          },
47639          "scopes": [
47640            "https://www.googleapis.com/auth/cloud-platform",
47641            "https://www.googleapis.com/auth/compute"
47642          ],
47643          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
47644        },
47645        "testIamPermissions": {
47646          "id": "compute.disks.testIamPermissions",
47647          "path": "projects/{project}/zones/{zone}/disks/{resource}/testIamPermissions",
47648          "flatPath": "projects/{project}/zones/{zone}/disks/{resource}/testIamPermissions",
47649          "httpMethod": "POST",
47650          "parameters": {
47651            "project": {
47652              "description": "Project ID for this request.",
47653              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47654              "location": "path",
47655              "required": true,
47656              "type": "string"
47657            },
47658            "resource": {
47659              "description": "Name or id of the resource for this request.",
47660              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
47661              "location": "path",
47662              "required": true,
47663              "type": "string"
47664            },
47665            "zone": {
47666              "description": "The name of the zone for this request.",
47667              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47668              "location": "path",
47669              "required": true,
47670              "type": "string"
47671            }
47672          },
47673          "parameterOrder": [
47674            "project",
47675            "zone",
47676            "resource"
47677          ],
47678          "request": {
47679            "$ref": "TestPermissionsRequest"
47680          },
47681          "response": {
47682            "$ref": "TestPermissionsResponse"
47683          },
47684          "scopes": [
47685            "https://www.googleapis.com/auth/cloud-platform",
47686            "https://www.googleapis.com/auth/compute",
47687            "https://www.googleapis.com/auth/compute.readonly"
47688          ],
47689          "description": "Returns permissions that a caller has on the specified resource."
47690        },
47691        "update": {
47692          "id": "compute.disks.update",
47693          "path": "projects/{project}/zones/{zone}/disks/{disk}",
47694          "flatPath": "projects/{project}/zones/{zone}/disks/{disk}",
47695          "httpMethod": "PATCH",
47696          "parameters": {
47697            "disk": {
47698              "description": "The disk name for this request.",
47699              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
47700              "location": "path",
47701              "required": true,
47702              "type": "string"
47703            },
47704            "paths": {
47705              "location": "query",
47706              "repeated": true,
47707              "type": "string"
47708            },
47709            "project": {
47710              "description": "Project ID for this request.",
47711              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47712              "location": "path",
47713              "required": true,
47714              "type": "string"
47715            },
47716            "requestId": {
47717              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
47718              "location": "query",
47719              "type": "string"
47720            },
47721            "updateMask": {
47722              "description": "update_mask indicates fields to be updated as part of this request.",
47723              "location": "query",
47724              "type": "string",
47725              "format": "google-fieldmask"
47726            },
47727            "zone": {
47728              "description": "The name of the zone for this request.",
47729              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47730              "location": "path",
47731              "required": true,
47732              "type": "string"
47733            }
47734          },
47735          "parameterOrder": [
47736            "project",
47737            "zone",
47738            "disk"
47739          ],
47740          "request": {
47741            "$ref": "Disk"
47742          },
47743          "response": {
47744            "$ref": "Operation"
47745          },
47746          "scopes": [
47747            "https://www.googleapis.com/auth/cloud-platform",
47748            "https://www.googleapis.com/auth/compute"
47749          ],
47750          "description": "Updates the specified disk with the data included in the request. The update is performed only on selected fields included as part of update-mask. Only the following fields can be modified: user_license."
47751        },
47752        "startAsyncReplication": {
47753          "id": "compute.disks.startAsyncReplication",
47754          "path": "projects/{project}/zones/{zone}/disks/{disk}/startAsyncReplication",
47755          "flatPath": "projects/{project}/zones/{zone}/disks/{disk}/startAsyncReplication",
47756          "httpMethod": "POST",
47757          "parameters": {
47758            "disk": {
47759              "description": "The name of the persistent disk.",
47760              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
47761              "location": "path",
47762              "required": true,
47763              "type": "string"
47764            },
47765            "project": {
47766              "description": "Project ID for this request.",
47767              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47768              "location": "path",
47769              "required": true,
47770              "type": "string"
47771            },
47772            "requestId": {
47773              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
47774              "location": "query",
47775              "type": "string"
47776            },
47777            "zone": {
47778              "description": "The name of the zone for this request.",
47779              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47780              "location": "path",
47781              "required": true,
47782              "type": "string"
47783            }
47784          },
47785          "parameterOrder": [
47786            "project",
47787            "zone",
47788            "disk"
47789          ],
47790          "request": {
47791            "$ref": "DisksStartAsyncReplicationRequest"
47792          },
47793          "response": {
47794            "$ref": "Operation"
47795          },
47796          "scopes": [
47797            "https://www.googleapis.com/auth/cloud-platform",
47798            "https://www.googleapis.com/auth/compute"
47799          ],
47800          "description": "Starts asynchronous replication. Must be invoked on the primary disk."
47801        },
47802        "stopAsyncReplication": {
47803          "id": "compute.disks.stopAsyncReplication",
47804          "path": "projects/{project}/zones/{zone}/disks/{disk}/stopAsyncReplication",
47805          "flatPath": "projects/{project}/zones/{zone}/disks/{disk}/stopAsyncReplication",
47806          "httpMethod": "POST",
47807          "parameters": {
47808            "disk": {
47809              "description": "The name of the persistent disk.",
47810              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
47811              "location": "path",
47812              "required": true,
47813              "type": "string"
47814            },
47815            "project": {
47816              "description": "Project ID for this request.",
47817              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47818              "location": "path",
47819              "required": true,
47820              "type": "string"
47821            },
47822            "requestId": {
47823              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
47824              "location": "query",
47825              "type": "string"
47826            },
47827            "zone": {
47828              "description": "The name of the zone for this request.",
47829              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47830              "location": "path",
47831              "required": true,
47832              "type": "string"
47833            }
47834          },
47835          "parameterOrder": [
47836            "project",
47837            "zone",
47838            "disk"
47839          ],
47840          "response": {
47841            "$ref": "Operation"
47842          },
47843          "scopes": [
47844            "https://www.googleapis.com/auth/cloud-platform",
47845            "https://www.googleapis.com/auth/compute"
47846          ],
47847          "description": "Stops asynchronous replication. Can be invoked either on the primary or on the secondary disk."
47848        },
47849        "stopGroupAsyncReplication": {
47850          "id": "compute.disks.stopGroupAsyncReplication",
47851          "path": "projects/{project}/zones/{zone}/disks/stopGroupAsyncReplication",
47852          "flatPath": "projects/{project}/zones/{zone}/disks/stopGroupAsyncReplication",
47853          "httpMethod": "POST",
47854          "parameters": {
47855            "project": {
47856              "description": "Project ID for this request.",
47857              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47858              "location": "path",
47859              "required": true,
47860              "type": "string"
47861            },
47862            "requestId": {
47863              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
47864              "location": "query",
47865              "type": "string"
47866            },
47867            "zone": {
47868              "description": "The name of the zone for this request. This must be the zone of the primary or secondary disks in the consistency group.",
47869              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47870              "location": "path",
47871              "required": true,
47872              "type": "string"
47873            }
47874          },
47875          "parameterOrder": [
47876            "project",
47877            "zone"
47878          ],
47879          "request": {
47880            "$ref": "DisksStopGroupAsyncReplicationResource"
47881          },
47882          "response": {
47883            "$ref": "Operation"
47884          },
47885          "scopes": [
47886            "https://www.googleapis.com/auth/cloud-platform",
47887            "https://www.googleapis.com/auth/compute"
47888          ],
47889          "description": "Stops asynchronous replication for a consistency group of disks. Can be invoked either in the primary or secondary scope."
47890        },
47891        "bulkInsert": {
47892          "id": "compute.disks.bulkInsert",
47893          "path": "projects/{project}/zones/{zone}/disks/bulkInsert",
47894          "flatPath": "projects/{project}/zones/{zone}/disks/bulkInsert",
47895          "httpMethod": "POST",
47896          "parameters": {
47897            "project": {
47898              "description": "Project ID for this request.",
47899              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47900              "location": "path",
47901              "required": true,
47902              "type": "string"
47903            },
47904            "requestId": {
47905              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
47906              "location": "query",
47907              "type": "string"
47908            },
47909            "zone": {
47910              "description": "The name of the zone for this request.",
47911              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47912              "location": "path",
47913              "required": true,
47914              "type": "string"
47915            }
47916          },
47917          "parameterOrder": [
47918            "project",
47919            "zone"
47920          ],
47921          "request": {
47922            "$ref": "BulkInsertDiskResource"
47923          },
47924          "response": {
47925            "$ref": "Operation"
47926          },
47927          "scopes": [
47928            "https://www.googleapis.com/auth/cloud-platform",
47929            "https://www.googleapis.com/auth/compute"
47930          ],
47931          "description": "Bulk create a set of disks."
47932        }
47933      }
47934    },
47935    "regionDisks": {
47936      "methods": {
47937        "list": {
47938          "id": "compute.regionDisks.list",
47939          "path": "projects/{project}/regions/{region}/disks",
47940          "flatPath": "projects/{project}/regions/{region}/disks",
47941          "httpMethod": "GET",
47942          "parameters": {
47943            "filter": {
47944              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
47945              "location": "query",
47946              "type": "string"
47947            },
47948            "maxResults": {
47949              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
47950              "default": "500",
47951              "minimum": "0",
47952              "location": "query",
47953              "type": "integer",
47954              "format": "uint32"
47955            },
47956            "orderBy": {
47957              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
47958              "location": "query",
47959              "type": "string"
47960            },
47961            "pageToken": {
47962              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
47963              "location": "query",
47964              "type": "string"
47965            },
47966            "project": {
47967              "description": "Project ID for this request.",
47968              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
47969              "location": "path",
47970              "required": true,
47971              "type": "string"
47972            },
47973            "region": {
47974              "description": "Name of the region for this request.",
47975              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
47976              "location": "path",
47977              "required": true,
47978              "type": "string"
47979            },
47980            "returnPartialSuccess": {
47981              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
47982              "location": "query",
47983              "type": "boolean"
47984            }
47985          },
47986          "parameterOrder": [
47987            "project",
47988            "region"
47989          ],
47990          "response": {
47991            "$ref": "DiskList"
47992          },
47993          "scopes": [
47994            "https://www.googleapis.com/auth/cloud-platform",
47995            "https://www.googleapis.com/auth/compute",
47996            "https://www.googleapis.com/auth/compute.readonly"
47997          ],
47998          "description": "Retrieves the list of persistent disks contained within the specified region."
47999        },
48000        "get": {
48001          "id": "compute.regionDisks.get",
48002          "path": "projects/{project}/regions/{region}/disks/{disk}",
48003          "flatPath": "projects/{project}/regions/{region}/disks/{disk}",
48004          "httpMethod": "GET",
48005          "parameters": {
48006            "disk": {
48007              "description": "Name of the regional persistent disk to return.",
48008              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
48009              "location": "path",
48010              "required": true,
48011              "type": "string"
48012            },
48013            "project": {
48014              "description": "Project ID for this request.",
48015              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48016              "location": "path",
48017              "required": true,
48018              "type": "string"
48019            },
48020            "region": {
48021              "description": "Name of the region for this request.",
48022              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
48023              "location": "path",
48024              "required": true,
48025              "type": "string"
48026            }
48027          },
48028          "parameterOrder": [
48029            "project",
48030            "region",
48031            "disk"
48032          ],
48033          "response": {
48034            "$ref": "Disk"
48035          },
48036          "scopes": [
48037            "https://www.googleapis.com/auth/cloud-platform",
48038            "https://www.googleapis.com/auth/compute",
48039            "https://www.googleapis.com/auth/compute.readonly"
48040          ],
48041          "description": "Returns a specified regional persistent disk."
48042        },
48043        "insert": {
48044          "id": "compute.regionDisks.insert",
48045          "path": "projects/{project}/regions/{region}/disks",
48046          "flatPath": "projects/{project}/regions/{region}/disks",
48047          "httpMethod": "POST",
48048          "parameters": {
48049            "project": {
48050              "description": "Project ID for this request.",
48051              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48052              "location": "path",
48053              "required": true,
48054              "type": "string"
48055            },
48056            "region": {
48057              "description": "Name of the region for this request.",
48058              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
48059              "location": "path",
48060              "required": true,
48061              "type": "string"
48062            },
48063            "requestId": {
48064              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
48065              "location": "query",
48066              "type": "string"
48067            },
48068            "sourceImage": {
48069              "description": "Source image to restore onto a disk. This field is optional.",
48070              "location": "query",
48071              "type": "string"
48072            }
48073          },
48074          "parameterOrder": [
48075            "project",
48076            "region"
48077          ],
48078          "request": {
48079            "$ref": "Disk"
48080          },
48081          "response": {
48082            "$ref": "Operation"
48083          },
48084          "scopes": [
48085            "https://www.googleapis.com/auth/cloud-platform",
48086            "https://www.googleapis.com/auth/compute"
48087          ],
48088          "description": "Creates a persistent regional disk in the specified project using the data included in the request."
48089        },
48090        "setLabels": {
48091          "id": "compute.regionDisks.setLabels",
48092          "path": "projects/{project}/regions/{region}/disks/{resource}/setLabels",
48093          "flatPath": "projects/{project}/regions/{region}/disks/{resource}/setLabels",
48094          "httpMethod": "POST",
48095          "parameters": {
48096            "project": {
48097              "description": "Project ID for this request.",
48098              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48099              "location": "path",
48100              "required": true,
48101              "type": "string"
48102            },
48103            "region": {
48104              "description": "The region for this request.",
48105              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
48106              "location": "path",
48107              "required": true,
48108              "type": "string"
48109            },
48110            "requestId": {
48111              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
48112              "location": "query",
48113              "type": "string"
48114            },
48115            "resource": {
48116              "description": "Name or id of the resource for this request.",
48117              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
48118              "location": "path",
48119              "required": true,
48120              "type": "string"
48121            }
48122          },
48123          "parameterOrder": [
48124            "project",
48125            "region",
48126            "resource"
48127          ],
48128          "request": {
48129            "$ref": "RegionSetLabelsRequest"
48130          },
48131          "response": {
48132            "$ref": "Operation"
48133          },
48134          "scopes": [
48135            "https://www.googleapis.com/auth/cloud-platform",
48136            "https://www.googleapis.com/auth/compute"
48137          ],
48138          "description": "Sets the labels on the target regional disk."
48139        },
48140        "delete": {
48141          "id": "compute.regionDisks.delete",
48142          "path": "projects/{project}/regions/{region}/disks/{disk}",
48143          "flatPath": "projects/{project}/regions/{region}/disks/{disk}",
48144          "httpMethod": "DELETE",
48145          "parameters": {
48146            "disk": {
48147              "description": "Name of the regional persistent disk to delete.",
48148              "location": "path",
48149              "required": true,
48150              "type": "string"
48151            },
48152            "project": {
48153              "description": "Project ID for this request.",
48154              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48155              "location": "path",
48156              "required": true,
48157              "type": "string"
48158            },
48159            "region": {
48160              "description": "Name of the region for this request.",
48161              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
48162              "location": "path",
48163              "required": true,
48164              "type": "string"
48165            },
48166            "requestId": {
48167              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
48168              "location": "query",
48169              "type": "string"
48170            }
48171          },
48172          "parameterOrder": [
48173            "project",
48174            "region",
48175            "disk"
48176          ],
48177          "response": {
48178            "$ref": "Operation"
48179          },
48180          "scopes": [
48181            "https://www.googleapis.com/auth/cloud-platform",
48182            "https://www.googleapis.com/auth/compute"
48183          ],
48184          "description": "Deletes the specified regional persistent disk. Deleting a regional disk removes all the replicas of its data permanently and is irreversible. However, deleting a disk does not delete any snapshots previously made from the disk. You must separately delete snapshots."
48185        },
48186        "createSnapshot": {
48187          "id": "compute.regionDisks.createSnapshot",
48188          "path": "projects/{project}/regions/{region}/disks/{disk}/createSnapshot",
48189          "flatPath": "projects/{project}/regions/{region}/disks/{disk}/createSnapshot",
48190          "httpMethod": "POST",
48191          "parameters": {
48192            "disk": {
48193              "description": "Name of the regional persistent disk to snapshot.",
48194              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
48195              "location": "path",
48196              "required": true,
48197              "type": "string"
48198            },
48199            "project": {
48200              "description": "Project ID for this request.",
48201              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48202              "location": "path",
48203              "required": true,
48204              "type": "string"
48205            },
48206            "region": {
48207              "description": "Name of the region for this request.",
48208              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
48209              "location": "path",
48210              "required": true,
48211              "type": "string"
48212            },
48213            "requestId": {
48214              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
48215              "location": "query",
48216              "type": "string"
48217            }
48218          },
48219          "parameterOrder": [
48220            "project",
48221            "region",
48222            "disk"
48223          ],
48224          "request": {
48225            "$ref": "Snapshot"
48226          },
48227          "response": {
48228            "$ref": "Operation"
48229          },
48230          "scopes": [
48231            "https://www.googleapis.com/auth/cloud-platform",
48232            "https://www.googleapis.com/auth/compute"
48233          ],
48234          "description": "Creates a snapshot of a specified persistent disk. For regular snapshot creation, consider using snapshots.insert instead, as that method supports more features, such as creating snapshots in a project different from the source disk project."
48235        },
48236        "resize": {
48237          "id": "compute.regionDisks.resize",
48238          "path": "projects/{project}/regions/{region}/disks/{disk}/resize",
48239          "flatPath": "projects/{project}/regions/{region}/disks/{disk}/resize",
48240          "httpMethod": "POST",
48241          "parameters": {
48242            "disk": {
48243              "description": "Name of the regional persistent disk.",
48244              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
48245              "location": "path",
48246              "required": true,
48247              "type": "string"
48248            },
48249            "project": {
48250              "description": "The project ID for this request.",
48251              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48252              "location": "path",
48253              "required": true,
48254              "type": "string"
48255            },
48256            "region": {
48257              "description": "Name of the region for this request.",
48258              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
48259              "location": "path",
48260              "required": true,
48261              "type": "string"
48262            },
48263            "requestId": {
48264              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
48265              "location": "query",
48266              "type": "string"
48267            }
48268          },
48269          "parameterOrder": [
48270            "project",
48271            "region",
48272            "disk"
48273          ],
48274          "request": {
48275            "$ref": "RegionDisksResizeRequest"
48276          },
48277          "response": {
48278            "$ref": "Operation"
48279          },
48280          "scopes": [
48281            "https://www.googleapis.com/auth/cloud-platform",
48282            "https://www.googleapis.com/auth/compute"
48283          ],
48284          "description": "Resizes the specified regional persistent disk."
48285        },
48286        "addResourcePolicies": {
48287          "id": "compute.regionDisks.addResourcePolicies",
48288          "path": "projects/{project}/regions/{region}/disks/{disk}/addResourcePolicies",
48289          "flatPath": "projects/{project}/regions/{region}/disks/{disk}/addResourcePolicies",
48290          "httpMethod": "POST",
48291          "parameters": {
48292            "disk": {
48293              "description": "The disk name for this request.",
48294              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
48295              "location": "path",
48296              "required": true,
48297              "type": "string"
48298            },
48299            "project": {
48300              "description": "Project ID for this request.",
48301              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48302              "location": "path",
48303              "required": true,
48304              "type": "string"
48305            },
48306            "region": {
48307              "description": "The name of the region for this request.",
48308              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
48309              "location": "path",
48310              "required": true,
48311              "type": "string"
48312            },
48313            "requestId": {
48314              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
48315              "location": "query",
48316              "type": "string"
48317            }
48318          },
48319          "parameterOrder": [
48320            "project",
48321            "region",
48322            "disk"
48323          ],
48324          "request": {
48325            "$ref": "RegionDisksAddResourcePoliciesRequest"
48326          },
48327          "response": {
48328            "$ref": "Operation"
48329          },
48330          "scopes": [
48331            "https://www.googleapis.com/auth/cloud-platform",
48332            "https://www.googleapis.com/auth/compute"
48333          ],
48334          "description": "Adds existing resource policies to a regional disk. You can only add one policy which will be applied to this disk for scheduling snapshot creation."
48335        },
48336        "removeResourcePolicies": {
48337          "id": "compute.regionDisks.removeResourcePolicies",
48338          "path": "projects/{project}/regions/{region}/disks/{disk}/removeResourcePolicies",
48339          "flatPath": "projects/{project}/regions/{region}/disks/{disk}/removeResourcePolicies",
48340          "httpMethod": "POST",
48341          "parameters": {
48342            "disk": {
48343              "description": "The disk name for this request.",
48344              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
48345              "location": "path",
48346              "required": true,
48347              "type": "string"
48348            },
48349            "project": {
48350              "description": "Project ID for this request.",
48351              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48352              "location": "path",
48353              "required": true,
48354              "type": "string"
48355            },
48356            "region": {
48357              "description": "The name of the region for this request.",
48358              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
48359              "location": "path",
48360              "required": true,
48361              "type": "string"
48362            },
48363            "requestId": {
48364              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
48365              "location": "query",
48366              "type": "string"
48367            }
48368          },
48369          "parameterOrder": [
48370            "project",
48371            "region",
48372            "disk"
48373          ],
48374          "request": {
48375            "$ref": "RegionDisksRemoveResourcePoliciesRequest"
48376          },
48377          "response": {
48378            "$ref": "Operation"
48379          },
48380          "scopes": [
48381            "https://www.googleapis.com/auth/cloud-platform",
48382            "https://www.googleapis.com/auth/compute"
48383          ],
48384          "description": "Removes resource policies from a regional disk."
48385        },
48386        "getIamPolicy": {
48387          "id": "compute.regionDisks.getIamPolicy",
48388          "path": "projects/{project}/regions/{region}/disks/{resource}/getIamPolicy",
48389          "flatPath": "projects/{project}/regions/{region}/disks/{resource}/getIamPolicy",
48390          "httpMethod": "GET",
48391          "parameters": {
48392            "optionsRequestedPolicyVersion": {
48393              "description": "Requested IAM Policy version.",
48394              "location": "query",
48395              "type": "integer",
48396              "format": "int32"
48397            },
48398            "project": {
48399              "description": "Project ID for this request.",
48400              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48401              "location": "path",
48402              "required": true,
48403              "type": "string"
48404            },
48405            "region": {
48406              "description": "The name of the region for this request.",
48407              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
48408              "location": "path",
48409              "required": true,
48410              "type": "string"
48411            },
48412            "resource": {
48413              "description": "Name or id of the resource for this request.",
48414              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
48415              "location": "path",
48416              "required": true,
48417              "type": "string"
48418            }
48419          },
48420          "parameterOrder": [
48421            "project",
48422            "region",
48423            "resource"
48424          ],
48425          "response": {
48426            "$ref": "Policy"
48427          },
48428          "scopes": [
48429            "https://www.googleapis.com/auth/cloud-platform",
48430            "https://www.googleapis.com/auth/compute",
48431            "https://www.googleapis.com/auth/compute.readonly"
48432          ],
48433          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
48434        },
48435        "setIamPolicy": {
48436          "id": "compute.regionDisks.setIamPolicy",
48437          "path": "projects/{project}/regions/{region}/disks/{resource}/setIamPolicy",
48438          "flatPath": "projects/{project}/regions/{region}/disks/{resource}/setIamPolicy",
48439          "httpMethod": "POST",
48440          "parameters": {
48441            "project": {
48442              "description": "Project ID for this request.",
48443              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48444              "location": "path",
48445              "required": true,
48446              "type": "string"
48447            },
48448            "region": {
48449              "description": "The name of the region for this request.",
48450              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
48451              "location": "path",
48452              "required": true,
48453              "type": "string"
48454            },
48455            "resource": {
48456              "description": "Name or id of the resource for this request.",
48457              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
48458              "location": "path",
48459              "required": true,
48460              "type": "string"
48461            }
48462          },
48463          "parameterOrder": [
48464            "project",
48465            "region",
48466            "resource"
48467          ],
48468          "request": {
48469            "$ref": "RegionSetPolicyRequest"
48470          },
48471          "response": {
48472            "$ref": "Policy"
48473          },
48474          "scopes": [
48475            "https://www.googleapis.com/auth/cloud-platform",
48476            "https://www.googleapis.com/auth/compute"
48477          ],
48478          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
48479        },
48480        "testIamPermissions": {
48481          "id": "compute.regionDisks.testIamPermissions",
48482          "path": "projects/{project}/regions/{region}/disks/{resource}/testIamPermissions",
48483          "flatPath": "projects/{project}/regions/{region}/disks/{resource}/testIamPermissions",
48484          "httpMethod": "POST",
48485          "parameters": {
48486            "project": {
48487              "description": "Project ID for this request.",
48488              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48489              "location": "path",
48490              "required": true,
48491              "type": "string"
48492            },
48493            "region": {
48494              "description": "The name of the region for this request.",
48495              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
48496              "location": "path",
48497              "required": true,
48498              "type": "string"
48499            },
48500            "resource": {
48501              "description": "Name or id of the resource for this request.",
48502              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
48503              "location": "path",
48504              "required": true,
48505              "type": "string"
48506            }
48507          },
48508          "parameterOrder": [
48509            "project",
48510            "region",
48511            "resource"
48512          ],
48513          "request": {
48514            "$ref": "TestPermissionsRequest"
48515          },
48516          "response": {
48517            "$ref": "TestPermissionsResponse"
48518          },
48519          "scopes": [
48520            "https://www.googleapis.com/auth/cloud-platform",
48521            "https://www.googleapis.com/auth/compute",
48522            "https://www.googleapis.com/auth/compute.readonly"
48523          ],
48524          "description": "Returns permissions that a caller has on the specified resource."
48525        },
48526        "update": {
48527          "id": "compute.regionDisks.update",
48528          "path": "projects/{project}/regions/{region}/disks/{disk}",
48529          "flatPath": "projects/{project}/regions/{region}/disks/{disk}",
48530          "httpMethod": "PATCH",
48531          "parameters": {
48532            "disk": {
48533              "description": "The disk name for this request.",
48534              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
48535              "location": "path",
48536              "required": true,
48537              "type": "string"
48538            },
48539            "paths": {
48540              "location": "query",
48541              "repeated": true,
48542              "type": "string"
48543            },
48544            "project": {
48545              "description": "Project ID for this request.",
48546              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48547              "location": "path",
48548              "required": true,
48549              "type": "string"
48550            },
48551            "region": {
48552              "description": "The name of the region for this request.",
48553              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
48554              "location": "path",
48555              "required": true,
48556              "type": "string"
48557            },
48558            "requestId": {
48559              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
48560              "location": "query",
48561              "type": "string"
48562            },
48563            "updateMask": {
48564              "description": "update_mask indicates fields to be updated as part of this request.",
48565              "location": "query",
48566              "type": "string",
48567              "format": "google-fieldmask"
48568            }
48569          },
48570          "parameterOrder": [
48571            "project",
48572            "region",
48573            "disk"
48574          ],
48575          "request": {
48576            "$ref": "Disk"
48577          },
48578          "response": {
48579            "$ref": "Operation"
48580          },
48581          "scopes": [
48582            "https://www.googleapis.com/auth/cloud-platform",
48583            "https://www.googleapis.com/auth/compute"
48584          ],
48585          "description": "Update the specified disk with the data included in the request. Update is performed only on selected fields included as part of update-mask. Only the following fields can be modified: user_license."
48586        },
48587        "startAsyncReplication": {
48588          "id": "compute.regionDisks.startAsyncReplication",
48589          "path": "projects/{project}/regions/{region}/disks/{disk}/startAsyncReplication",
48590          "flatPath": "projects/{project}/regions/{region}/disks/{disk}/startAsyncReplication",
48591          "httpMethod": "POST",
48592          "parameters": {
48593            "disk": {
48594              "description": "The name of the persistent disk.",
48595              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
48596              "location": "path",
48597              "required": true,
48598              "type": "string"
48599            },
48600            "project": {
48601              "description": "Project ID for this request.",
48602              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48603              "location": "path",
48604              "required": true,
48605              "type": "string"
48606            },
48607            "region": {
48608              "description": "The name of the region for this request.",
48609              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
48610              "location": "path",
48611              "required": true,
48612              "type": "string"
48613            },
48614            "requestId": {
48615              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
48616              "location": "query",
48617              "type": "string"
48618            }
48619          },
48620          "parameterOrder": [
48621            "project",
48622            "region",
48623            "disk"
48624          ],
48625          "request": {
48626            "$ref": "RegionDisksStartAsyncReplicationRequest"
48627          },
48628          "response": {
48629            "$ref": "Operation"
48630          },
48631          "scopes": [
48632            "https://www.googleapis.com/auth/cloud-platform",
48633            "https://www.googleapis.com/auth/compute"
48634          ],
48635          "description": "Starts asynchronous replication. Must be invoked on the primary disk."
48636        },
48637        "stopAsyncReplication": {
48638          "id": "compute.regionDisks.stopAsyncReplication",
48639          "path": "projects/{project}/regions/{region}/disks/{disk}/stopAsyncReplication",
48640          "flatPath": "projects/{project}/regions/{region}/disks/{disk}/stopAsyncReplication",
48641          "httpMethod": "POST",
48642          "parameters": {
48643            "disk": {
48644              "description": "The name of the persistent disk.",
48645              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
48646              "location": "path",
48647              "required": true,
48648              "type": "string"
48649            },
48650            "project": {
48651              "description": "Project ID for this request.",
48652              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48653              "location": "path",
48654              "required": true,
48655              "type": "string"
48656            },
48657            "region": {
48658              "description": "The name of the region for this request.",
48659              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
48660              "location": "path",
48661              "required": true,
48662              "type": "string"
48663            },
48664            "requestId": {
48665              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
48666              "location": "query",
48667              "type": "string"
48668            }
48669          },
48670          "parameterOrder": [
48671            "project",
48672            "region",
48673            "disk"
48674          ],
48675          "response": {
48676            "$ref": "Operation"
48677          },
48678          "scopes": [
48679            "https://www.googleapis.com/auth/cloud-platform",
48680            "https://www.googleapis.com/auth/compute"
48681          ],
48682          "description": "Stops asynchronous replication. Can be invoked either on the primary or on the secondary disk."
48683        },
48684        "stopGroupAsyncReplication": {
48685          "id": "compute.regionDisks.stopGroupAsyncReplication",
48686          "path": "projects/{project}/regions/{region}/disks/stopGroupAsyncReplication",
48687          "flatPath": "projects/{project}/regions/{region}/disks/stopGroupAsyncReplication",
48688          "httpMethod": "POST",
48689          "parameters": {
48690            "project": {
48691              "description": "Project ID for this request.",
48692              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48693              "location": "path",
48694              "required": true,
48695              "type": "string"
48696            },
48697            "region": {
48698              "description": "The name of the region for this request. This must be the region of the primary or secondary disks in the consistency group.",
48699              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
48700              "location": "path",
48701              "required": true,
48702              "type": "string"
48703            },
48704            "requestId": {
48705              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
48706              "location": "query",
48707              "type": "string"
48708            }
48709          },
48710          "parameterOrder": [
48711            "project",
48712            "region"
48713          ],
48714          "request": {
48715            "$ref": "DisksStopGroupAsyncReplicationResource"
48716          },
48717          "response": {
48718            "$ref": "Operation"
48719          },
48720          "scopes": [
48721            "https://www.googleapis.com/auth/cloud-platform",
48722            "https://www.googleapis.com/auth/compute"
48723          ],
48724          "description": "Stops asynchronous replication for a consistency group of disks. Can be invoked either in the primary or secondary scope."
48725        },
48726        "bulkInsert": {
48727          "id": "compute.regionDisks.bulkInsert",
48728          "path": "projects/{project}/regions/{region}/disks/bulkInsert",
48729          "flatPath": "projects/{project}/regions/{region}/disks/bulkInsert",
48730          "httpMethod": "POST",
48731          "parameters": {
48732            "project": {
48733              "description": "Project ID for this request.",
48734              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48735              "location": "path",
48736              "required": true,
48737              "type": "string"
48738            },
48739            "region": {
48740              "description": "The name of the region for this request.",
48741              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
48742              "location": "path",
48743              "required": true,
48744              "type": "string"
48745            },
48746            "requestId": {
48747              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
48748              "location": "query",
48749              "type": "string"
48750            }
48751          },
48752          "parameterOrder": [
48753            "project",
48754            "region"
48755          ],
48756          "request": {
48757            "$ref": "BulkInsertDiskResource"
48758          },
48759          "response": {
48760            "$ref": "Operation"
48761          },
48762          "scopes": [
48763            "https://www.googleapis.com/auth/cloud-platform",
48764            "https://www.googleapis.com/auth/compute"
48765          ],
48766          "description": "Bulk create a set of disks."
48767        }
48768      }
48769    },
48770    "firewalls": {
48771      "methods": {
48772        "list": {
48773          "id": "compute.firewalls.list",
48774          "path": "projects/{project}/global/firewalls",
48775          "flatPath": "projects/{project}/global/firewalls",
48776          "httpMethod": "GET",
48777          "parameters": {
48778            "filter": {
48779              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
48780              "location": "query",
48781              "type": "string"
48782            },
48783            "maxResults": {
48784              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
48785              "default": "500",
48786              "minimum": "0",
48787              "location": "query",
48788              "type": "integer",
48789              "format": "uint32"
48790            },
48791            "orderBy": {
48792              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
48793              "location": "query",
48794              "type": "string"
48795            },
48796            "pageToken": {
48797              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
48798              "location": "query",
48799              "type": "string"
48800            },
48801            "project": {
48802              "description": "Project ID for this request.",
48803              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48804              "location": "path",
48805              "required": true,
48806              "type": "string"
48807            },
48808            "returnPartialSuccess": {
48809              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
48810              "location": "query",
48811              "type": "boolean"
48812            }
48813          },
48814          "parameterOrder": [
48815            "project"
48816          ],
48817          "response": {
48818            "$ref": "FirewallList"
48819          },
48820          "scopes": [
48821            "https://www.googleapis.com/auth/cloud-platform",
48822            "https://www.googleapis.com/auth/compute",
48823            "https://www.googleapis.com/auth/compute.readonly"
48824          ],
48825          "description": "Retrieves the list of firewall rules available to the specified project."
48826        },
48827        "get": {
48828          "id": "compute.firewalls.get",
48829          "path": "projects/{project}/global/firewalls/{firewall}",
48830          "flatPath": "projects/{project}/global/firewalls/{firewall}",
48831          "httpMethod": "GET",
48832          "parameters": {
48833            "firewall": {
48834              "description": "Name of the firewall rule to return.",
48835              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
48836              "location": "path",
48837              "required": true,
48838              "type": "string"
48839            },
48840            "project": {
48841              "description": "Project ID for this request.",
48842              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48843              "location": "path",
48844              "required": true,
48845              "type": "string"
48846            }
48847          },
48848          "parameterOrder": [
48849            "project",
48850            "firewall"
48851          ],
48852          "response": {
48853            "$ref": "Firewall"
48854          },
48855          "scopes": [
48856            "https://www.googleapis.com/auth/cloud-platform",
48857            "https://www.googleapis.com/auth/compute",
48858            "https://www.googleapis.com/auth/compute.readonly"
48859          ],
48860          "description": "Returns the specified firewall."
48861        },
48862        "insert": {
48863          "id": "compute.firewalls.insert",
48864          "path": "projects/{project}/global/firewalls",
48865          "flatPath": "projects/{project}/global/firewalls",
48866          "httpMethod": "POST",
48867          "parameters": {
48868            "project": {
48869              "description": "Project ID for this request.",
48870              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48871              "location": "path",
48872              "required": true,
48873              "type": "string"
48874            },
48875            "requestId": {
48876              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
48877              "location": "query",
48878              "type": "string"
48879            }
48880          },
48881          "parameterOrder": [
48882            "project"
48883          ],
48884          "request": {
48885            "$ref": "Firewall"
48886          },
48887          "response": {
48888            "$ref": "Operation"
48889          },
48890          "scopes": [
48891            "https://www.googleapis.com/auth/cloud-platform",
48892            "https://www.googleapis.com/auth/compute"
48893          ],
48894          "description": "Creates a firewall rule in the specified project using the data included in the request."
48895        },
48896        "delete": {
48897          "id": "compute.firewalls.delete",
48898          "path": "projects/{project}/global/firewalls/{firewall}",
48899          "flatPath": "projects/{project}/global/firewalls/{firewall}",
48900          "httpMethod": "DELETE",
48901          "parameters": {
48902            "firewall": {
48903              "description": "Name of the firewall rule to delete.",
48904              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
48905              "location": "path",
48906              "required": true,
48907              "type": "string"
48908            },
48909            "project": {
48910              "description": "Project ID for this request.",
48911              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48912              "location": "path",
48913              "required": true,
48914              "type": "string"
48915            },
48916            "requestId": {
48917              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
48918              "location": "query",
48919              "type": "string"
48920            }
48921          },
48922          "parameterOrder": [
48923            "project",
48924            "firewall"
48925          ],
48926          "response": {
48927            "$ref": "Operation"
48928          },
48929          "scopes": [
48930            "https://www.googleapis.com/auth/cloud-platform",
48931            "https://www.googleapis.com/auth/compute"
48932          ],
48933          "description": "Deletes the specified firewall."
48934        },
48935        "update": {
48936          "id": "compute.firewalls.update",
48937          "path": "projects/{project}/global/firewalls/{firewall}",
48938          "flatPath": "projects/{project}/global/firewalls/{firewall}",
48939          "httpMethod": "PUT",
48940          "parameters": {
48941            "firewall": {
48942              "description": "Name of the firewall rule to update.",
48943              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
48944              "location": "path",
48945              "required": true,
48946              "type": "string"
48947            },
48948            "project": {
48949              "description": "Project ID for this request.",
48950              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48951              "location": "path",
48952              "required": true,
48953              "type": "string"
48954            },
48955            "requestId": {
48956              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
48957              "location": "query",
48958              "type": "string"
48959            }
48960          },
48961          "parameterOrder": [
48962            "project",
48963            "firewall"
48964          ],
48965          "request": {
48966            "$ref": "Firewall"
48967          },
48968          "response": {
48969            "$ref": "Operation"
48970          },
48971          "scopes": [
48972            "https://www.googleapis.com/auth/cloud-platform",
48973            "https://www.googleapis.com/auth/compute"
48974          ],
48975          "description": "Updates the specified firewall rule with the data included in the request. Note that all fields will be updated if using PUT, even fields that are not specified. To update individual fields, please use PATCH instead."
48976        },
48977        "patch": {
48978          "id": "compute.firewalls.patch",
48979          "path": "projects/{project}/global/firewalls/{firewall}",
48980          "flatPath": "projects/{project}/global/firewalls/{firewall}",
48981          "httpMethod": "PATCH",
48982          "parameters": {
48983            "firewall": {
48984              "description": "Name of the firewall rule to patch.",
48985              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
48986              "location": "path",
48987              "required": true,
48988              "type": "string"
48989            },
48990            "project": {
48991              "description": "Project ID for this request.",
48992              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
48993              "location": "path",
48994              "required": true,
48995              "type": "string"
48996            },
48997            "requestId": {
48998              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
48999              "location": "query",
49000              "type": "string"
49001            }
49002          },
49003          "parameterOrder": [
49004            "project",
49005            "firewall"
49006          ],
49007          "request": {
49008            "$ref": "Firewall"
49009          },
49010          "response": {
49011            "$ref": "Operation"
49012          },
49013          "scopes": [
49014            "https://www.googleapis.com/auth/cloud-platform",
49015            "https://www.googleapis.com/auth/compute"
49016          ],
49017          "description": "Updates the specified firewall rule with the data included in the request. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
49018        }
49019      }
49020    },
49021    "firewallPolicies": {
49022      "methods": {
49023        "list": {
49024          "id": "compute.firewallPolicies.list",
49025          "path": "locations/global/firewallPolicies",
49026          "flatPath": "locations/global/firewallPolicies",
49027          "httpMethod": "GET",
49028          "parameters": {
49029            "filter": {
49030              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
49031              "location": "query",
49032              "type": "string"
49033            },
49034            "maxResults": {
49035              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
49036              "default": "500",
49037              "minimum": "0",
49038              "location": "query",
49039              "type": "integer",
49040              "format": "uint32"
49041            },
49042            "orderBy": {
49043              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
49044              "location": "query",
49045              "type": "string"
49046            },
49047            "pageToken": {
49048              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
49049              "location": "query",
49050              "type": "string"
49051            },
49052            "parentId": {
49053              "description": "Parent ID for this request. The ID can be either be \"folders/[FOLDER_ID]\" if the parent is a folder or \"organizations/[ORGANIZATION_ID]\" if the parent is an organization.",
49054              "location": "query",
49055              "type": "string"
49056            },
49057            "returnPartialSuccess": {
49058              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
49059              "location": "query",
49060              "type": "boolean"
49061            }
49062          },
49063          "response": {
49064            "$ref": "FirewallPolicyList"
49065          },
49066          "scopes": [
49067            "https://www.googleapis.com/auth/cloud-platform",
49068            "https://www.googleapis.com/auth/compute",
49069            "https://www.googleapis.com/auth/compute.readonly"
49070          ],
49071          "description": "Lists all the policies that have been configured for the specified folder or organization."
49072        },
49073        "get": {
49074          "id": "compute.firewallPolicies.get",
49075          "path": "locations/global/firewallPolicies/{firewallPolicy}",
49076          "flatPath": "locations/global/firewallPolicies/{firewallPolicy}",
49077          "httpMethod": "GET",
49078          "parameters": {
49079            "firewallPolicy": {
49080              "description": "Name of the firewall policy to get.",
49081              "pattern": "(firewallPolicies/)?[0-9]{0,20}",
49082              "location": "path",
49083              "required": true,
49084              "type": "string"
49085            }
49086          },
49087          "parameterOrder": [
49088            "firewallPolicy"
49089          ],
49090          "response": {
49091            "$ref": "FirewallPolicy"
49092          },
49093          "scopes": [
49094            "https://www.googleapis.com/auth/cloud-platform",
49095            "https://www.googleapis.com/auth/compute",
49096            "https://www.googleapis.com/auth/compute.readonly"
49097          ],
49098          "description": "Returns the specified firewall policy."
49099        },
49100        "insert": {
49101          "id": "compute.firewallPolicies.insert",
49102          "path": "locations/global/firewallPolicies",
49103          "flatPath": "locations/global/firewallPolicies",
49104          "httpMethod": "POST",
49105          "parameters": {
49106            "parentId": {
49107              "description": "Parent ID for this request. The ID can be either be \"folders/[FOLDER_ID]\" if the parent is a folder or \"organizations/[ORGANIZATION_ID]\" if the parent is an organization.",
49108              "location": "query",
49109              "type": "string"
49110            },
49111            "requestId": {
49112              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
49113              "location": "query",
49114              "type": "string"
49115            }
49116          },
49117          "request": {
49118            "$ref": "FirewallPolicy"
49119          },
49120          "response": {
49121            "$ref": "Operation"
49122          },
49123          "scopes": [
49124            "https://www.googleapis.com/auth/cloud-platform",
49125            "https://www.googleapis.com/auth/compute"
49126          ],
49127          "description": "Creates a new policy in the specified project using the data included in the request."
49128        },
49129        "delete": {
49130          "id": "compute.firewallPolicies.delete",
49131          "path": "locations/global/firewallPolicies/{firewallPolicy}",
49132          "flatPath": "locations/global/firewallPolicies/{firewallPolicy}",
49133          "httpMethod": "DELETE",
49134          "parameters": {
49135            "firewallPolicy": {
49136              "description": "Name of the firewall policy to delete.",
49137              "pattern": "(firewallPolicies/)?[0-9]{0,20}",
49138              "location": "path",
49139              "required": true,
49140              "type": "string"
49141            },
49142            "requestId": {
49143              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
49144              "location": "query",
49145              "type": "string"
49146            }
49147          },
49148          "parameterOrder": [
49149            "firewallPolicy"
49150          ],
49151          "response": {
49152            "$ref": "Operation"
49153          },
49154          "scopes": [
49155            "https://www.googleapis.com/auth/cloud-platform",
49156            "https://www.googleapis.com/auth/compute"
49157          ],
49158          "description": "Deletes the specified policy."
49159        },
49160        "patch": {
49161          "id": "compute.firewallPolicies.patch",
49162          "path": "locations/global/firewallPolicies/{firewallPolicy}",
49163          "flatPath": "locations/global/firewallPolicies/{firewallPolicy}",
49164          "httpMethod": "PATCH",
49165          "parameters": {
49166            "firewallPolicy": {
49167              "description": "Name of the firewall policy to update.",
49168              "pattern": "(firewallPolicies/)?[0-9]{0,20}",
49169              "location": "path",
49170              "required": true,
49171              "type": "string"
49172            },
49173            "requestId": {
49174              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
49175              "location": "query",
49176              "type": "string"
49177            }
49178          },
49179          "parameterOrder": [
49180            "firewallPolicy"
49181          ],
49182          "request": {
49183            "$ref": "FirewallPolicy"
49184          },
49185          "response": {
49186            "$ref": "Operation"
49187          },
49188          "scopes": [
49189            "https://www.googleapis.com/auth/cloud-platform",
49190            "https://www.googleapis.com/auth/compute"
49191          ],
49192          "description": "Patches the specified policy with the data included in the request."
49193        },
49194        "getRule": {
49195          "id": "compute.firewallPolicies.getRule",
49196          "path": "locations/global/firewallPolicies/{firewallPolicy}/getRule",
49197          "flatPath": "locations/global/firewallPolicies/{firewallPolicy}/getRule",
49198          "httpMethod": "GET",
49199          "parameters": {
49200            "firewallPolicy": {
49201              "description": "Name of the firewall policy to which the queried rule belongs.",
49202              "pattern": "(firewallPolicies/)?[0-9]{0,20}",
49203              "location": "path",
49204              "required": true,
49205              "type": "string"
49206            },
49207            "priority": {
49208              "description": "The priority of the rule to get from the firewall policy.",
49209              "location": "query",
49210              "type": "integer",
49211              "format": "int32"
49212            }
49213          },
49214          "parameterOrder": [
49215            "firewallPolicy"
49216          ],
49217          "response": {
49218            "$ref": "FirewallPolicyRule"
49219          },
49220          "scopes": [
49221            "https://www.googleapis.com/auth/cloud-platform",
49222            "https://www.googleapis.com/auth/compute",
49223            "https://www.googleapis.com/auth/compute.readonly"
49224          ],
49225          "description": "Gets a rule of the specified priority."
49226        },
49227        "addRule": {
49228          "id": "compute.firewallPolicies.addRule",
49229          "path": "locations/global/firewallPolicies/{firewallPolicy}/addRule",
49230          "flatPath": "locations/global/firewallPolicies/{firewallPolicy}/addRule",
49231          "httpMethod": "POST",
49232          "parameters": {
49233            "firewallPolicy": {
49234              "description": "Name of the firewall policy to update.",
49235              "pattern": "(firewallPolicies/)?[0-9]{0,20}",
49236              "location": "path",
49237              "required": true,
49238              "type": "string"
49239            },
49240            "requestId": {
49241              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
49242              "location": "query",
49243              "type": "string"
49244            }
49245          },
49246          "parameterOrder": [
49247            "firewallPolicy"
49248          ],
49249          "request": {
49250            "$ref": "FirewallPolicyRule"
49251          },
49252          "response": {
49253            "$ref": "Operation"
49254          },
49255          "scopes": [
49256            "https://www.googleapis.com/auth/cloud-platform",
49257            "https://www.googleapis.com/auth/compute"
49258          ],
49259          "description": "Inserts a rule into a firewall policy."
49260        },
49261        "removeRule": {
49262          "id": "compute.firewallPolicies.removeRule",
49263          "path": "locations/global/firewallPolicies/{firewallPolicy}/removeRule",
49264          "flatPath": "locations/global/firewallPolicies/{firewallPolicy}/removeRule",
49265          "httpMethod": "POST",
49266          "parameters": {
49267            "firewallPolicy": {
49268              "description": "Name of the firewall policy to update.",
49269              "pattern": "(firewallPolicies/)?[0-9]{0,20}",
49270              "location": "path",
49271              "required": true,
49272              "type": "string"
49273            },
49274            "priority": {
49275              "description": "The priority of the rule to remove from the firewall policy.",
49276              "location": "query",
49277              "type": "integer",
49278              "format": "int32"
49279            },
49280            "requestId": {
49281              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
49282              "location": "query",
49283              "type": "string"
49284            }
49285          },
49286          "parameterOrder": [
49287            "firewallPolicy"
49288          ],
49289          "response": {
49290            "$ref": "Operation"
49291          },
49292          "scopes": [
49293            "https://www.googleapis.com/auth/cloud-platform",
49294            "https://www.googleapis.com/auth/compute"
49295          ],
49296          "description": "Deletes a rule of the specified priority."
49297        },
49298        "patchRule": {
49299          "id": "compute.firewallPolicies.patchRule",
49300          "path": "locations/global/firewallPolicies/{firewallPolicy}/patchRule",
49301          "flatPath": "locations/global/firewallPolicies/{firewallPolicy}/patchRule",
49302          "httpMethod": "POST",
49303          "parameters": {
49304            "firewallPolicy": {
49305              "description": "Name of the firewall policy to update.",
49306              "pattern": "(firewallPolicies/)?[0-9]{0,20}",
49307              "location": "path",
49308              "required": true,
49309              "type": "string"
49310            },
49311            "priority": {
49312              "description": "The priority of the rule to patch.",
49313              "location": "query",
49314              "type": "integer",
49315              "format": "int32"
49316            },
49317            "requestId": {
49318              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
49319              "location": "query",
49320              "type": "string"
49321            }
49322          },
49323          "parameterOrder": [
49324            "firewallPolicy"
49325          ],
49326          "request": {
49327            "$ref": "FirewallPolicyRule"
49328          },
49329          "response": {
49330            "$ref": "Operation"
49331          },
49332          "scopes": [
49333            "https://www.googleapis.com/auth/cloud-platform",
49334            "https://www.googleapis.com/auth/compute"
49335          ],
49336          "description": "Patches a rule of the specified priority."
49337        },
49338        "addAssociation": {
49339          "id": "compute.firewallPolicies.addAssociation",
49340          "path": "locations/global/firewallPolicies/{firewallPolicy}/addAssociation",
49341          "flatPath": "locations/global/firewallPolicies/{firewallPolicy}/addAssociation",
49342          "httpMethod": "POST",
49343          "parameters": {
49344            "firewallPolicy": {
49345              "description": "Name of the firewall policy to update.",
49346              "pattern": "(firewallPolicies/)?[0-9]{0,20}",
49347              "location": "path",
49348              "required": true,
49349              "type": "string"
49350            },
49351            "replaceExistingAssociation": {
49352              "description": "Indicates whether or not to replace it if an association of the attachment already exists. This is false by default, in which case an error will be returned if an association already exists.",
49353              "location": "query",
49354              "type": "boolean"
49355            },
49356            "requestId": {
49357              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
49358              "location": "query",
49359              "type": "string"
49360            }
49361          },
49362          "parameterOrder": [
49363            "firewallPolicy"
49364          ],
49365          "request": {
49366            "$ref": "FirewallPolicyAssociation"
49367          },
49368          "response": {
49369            "$ref": "Operation"
49370          },
49371          "scopes": [
49372            "https://www.googleapis.com/auth/cloud-platform",
49373            "https://www.googleapis.com/auth/compute"
49374          ],
49375          "description": "Inserts an association for the specified firewall policy."
49376        },
49377        "removeAssociation": {
49378          "id": "compute.firewallPolicies.removeAssociation",
49379          "path": "locations/global/firewallPolicies/{firewallPolicy}/removeAssociation",
49380          "flatPath": "locations/global/firewallPolicies/{firewallPolicy}/removeAssociation",
49381          "httpMethod": "POST",
49382          "parameters": {
49383            "firewallPolicy": {
49384              "description": "Name of the firewall policy to update.",
49385              "pattern": "(firewallPolicies/)?[0-9]{0,20}",
49386              "location": "path",
49387              "required": true,
49388              "type": "string"
49389            },
49390            "name": {
49391              "description": "Name for the attachment that will be removed.",
49392              "location": "query",
49393              "type": "string"
49394            },
49395            "requestId": {
49396              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
49397              "location": "query",
49398              "type": "string"
49399            }
49400          },
49401          "parameterOrder": [
49402            "firewallPolicy"
49403          ],
49404          "response": {
49405            "$ref": "Operation"
49406          },
49407          "scopes": [
49408            "https://www.googleapis.com/auth/cloud-platform",
49409            "https://www.googleapis.com/auth/compute"
49410          ],
49411          "description": "Removes an association for the specified firewall policy."
49412        },
49413        "listAssociations": {
49414          "id": "compute.firewallPolicies.listAssociations",
49415          "path": "locations/global/firewallPolicies/listAssociations",
49416          "flatPath": "locations/global/firewallPolicies/listAssociations",
49417          "httpMethod": "GET",
49418          "parameters": {
49419            "targetResource": {
49420              "description": "The target resource to list associations. It is an organization, or a folder.",
49421              "location": "query",
49422              "type": "string"
49423            }
49424          },
49425          "response": {
49426            "$ref": "FirewallPoliciesListAssociationsResponse"
49427          },
49428          "scopes": [
49429            "https://www.googleapis.com/auth/cloud-platform",
49430            "https://www.googleapis.com/auth/compute",
49431            "https://www.googleapis.com/auth/compute.readonly"
49432          ],
49433          "description": "Lists associations of a specified target, i.e., organization or folder."
49434        },
49435        "getAssociation": {
49436          "id": "compute.firewallPolicies.getAssociation",
49437          "path": "locations/global/firewallPolicies/{firewallPolicy}/getAssociation",
49438          "flatPath": "locations/global/firewallPolicies/{firewallPolicy}/getAssociation",
49439          "httpMethod": "GET",
49440          "parameters": {
49441            "firewallPolicy": {
49442              "description": "Name of the firewall policy to which the queried rule belongs.",
49443              "pattern": "(firewallPolicies/)?[0-9]{0,20}",
49444              "location": "path",
49445              "required": true,
49446              "type": "string"
49447            },
49448            "name": {
49449              "description": "The name of the association to get from the firewall policy.",
49450              "location": "query",
49451              "type": "string"
49452            }
49453          },
49454          "parameterOrder": [
49455            "firewallPolicy"
49456          ],
49457          "response": {
49458            "$ref": "FirewallPolicyAssociation"
49459          },
49460          "scopes": [
49461            "https://www.googleapis.com/auth/cloud-platform",
49462            "https://www.googleapis.com/auth/compute",
49463            "https://www.googleapis.com/auth/compute.readonly"
49464          ],
49465          "description": "Gets an association with the specified name."
49466        },
49467        "cloneRules": {
49468          "id": "compute.firewallPolicies.cloneRules",
49469          "path": "locations/global/firewallPolicies/{firewallPolicy}/cloneRules",
49470          "flatPath": "locations/global/firewallPolicies/{firewallPolicy}/cloneRules",
49471          "httpMethod": "POST",
49472          "parameters": {
49473            "firewallPolicy": {
49474              "description": "Name of the firewall policy to update.",
49475              "pattern": "(firewallPolicies/)?[0-9]{0,20}",
49476              "location": "path",
49477              "required": true,
49478              "type": "string"
49479            },
49480            "requestId": {
49481              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
49482              "location": "query",
49483              "type": "string"
49484            },
49485            "sourceFirewallPolicy": {
49486              "description": "The firewall policy from which to copy rules.",
49487              "location": "query",
49488              "type": "string"
49489            }
49490          },
49491          "parameterOrder": [
49492            "firewallPolicy"
49493          ],
49494          "response": {
49495            "$ref": "Operation"
49496          },
49497          "scopes": [
49498            "https://www.googleapis.com/auth/cloud-platform",
49499            "https://www.googleapis.com/auth/compute"
49500          ],
49501          "description": "Copies rules to the specified firewall policy."
49502        },
49503        "move": {
49504          "id": "compute.firewallPolicies.move",
49505          "path": "locations/global/firewallPolicies/{firewallPolicy}/move",
49506          "flatPath": "locations/global/firewallPolicies/{firewallPolicy}/move",
49507          "httpMethod": "POST",
49508          "parameters": {
49509            "firewallPolicy": {
49510              "description": "Name of the firewall policy to update.",
49511              "pattern": "(firewallPolicies/)?[0-9]{0,20}",
49512              "location": "path",
49513              "required": true,
49514              "type": "string"
49515            },
49516            "parentId": {
49517              "description": "The new parent of the firewall policy. The ID can be either be \"folders/[FOLDER_ID]\" if the parent is a folder or \"organizations/[ORGANIZATION_ID]\" if the parent is an organization.",
49518              "location": "query",
49519              "type": "string"
49520            },
49521            "requestId": {
49522              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
49523              "location": "query",
49524              "type": "string"
49525            }
49526          },
49527          "parameterOrder": [
49528            "firewallPolicy"
49529          ],
49530          "response": {
49531            "$ref": "Operation"
49532          },
49533          "scopes": [
49534            "https://www.googleapis.com/auth/cloud-platform",
49535            "https://www.googleapis.com/auth/compute"
49536          ],
49537          "description": "Moves the specified firewall policy."
49538        },
49539        "getIamPolicy": {
49540          "id": "compute.firewallPolicies.getIamPolicy",
49541          "path": "locations/global/firewallPolicies/{resource}/getIamPolicy",
49542          "flatPath": "locations/global/firewallPolicies/{resource}/getIamPolicy",
49543          "httpMethod": "GET",
49544          "parameters": {
49545            "optionsRequestedPolicyVersion": {
49546              "description": "Requested IAM Policy version.",
49547              "location": "query",
49548              "type": "integer",
49549              "format": "int32"
49550            },
49551            "resource": {
49552              "description": "Name or id of the resource for this request.",
49553              "pattern": "(firewallPolicies/)?[0-9]{0,20}",
49554              "location": "path",
49555              "required": true,
49556              "type": "string"
49557            }
49558          },
49559          "parameterOrder": [
49560            "resource"
49561          ],
49562          "response": {
49563            "$ref": "Policy"
49564          },
49565          "scopes": [
49566            "https://www.googleapis.com/auth/cloud-platform",
49567            "https://www.googleapis.com/auth/compute",
49568            "https://www.googleapis.com/auth/compute.readonly"
49569          ],
49570          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
49571        },
49572        "setIamPolicy": {
49573          "id": "compute.firewallPolicies.setIamPolicy",
49574          "path": "locations/global/firewallPolicies/{resource}/setIamPolicy",
49575          "flatPath": "locations/global/firewallPolicies/{resource}/setIamPolicy",
49576          "httpMethod": "POST",
49577          "parameters": {
49578            "resource": {
49579              "description": "Name or id of the resource for this request.",
49580              "pattern": "(firewallPolicies/)?[0-9]{0,20}",
49581              "location": "path",
49582              "required": true,
49583              "type": "string"
49584            }
49585          },
49586          "parameterOrder": [
49587            "resource"
49588          ],
49589          "request": {
49590            "$ref": "GlobalOrganizationSetPolicyRequest"
49591          },
49592          "response": {
49593            "$ref": "Policy"
49594          },
49595          "scopes": [
49596            "https://www.googleapis.com/auth/cloud-platform",
49597            "https://www.googleapis.com/auth/compute"
49598          ],
49599          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
49600        },
49601        "testIamPermissions": {
49602          "id": "compute.firewallPolicies.testIamPermissions",
49603          "path": "locations/global/firewallPolicies/{resource}/testIamPermissions",
49604          "flatPath": "locations/global/firewallPolicies/{resource}/testIamPermissions",
49605          "httpMethod": "POST",
49606          "parameters": {
49607            "resource": {
49608              "description": "Name or id of the resource for this request.",
49609              "pattern": "(firewallPolicies/)?[0-9]{0,20}",
49610              "location": "path",
49611              "required": true,
49612              "type": "string"
49613            }
49614          },
49615          "parameterOrder": [
49616            "resource"
49617          ],
49618          "request": {
49619            "$ref": "TestPermissionsRequest"
49620          },
49621          "response": {
49622            "$ref": "TestPermissionsResponse"
49623          },
49624          "scopes": [
49625            "https://www.googleapis.com/auth/cloud-platform",
49626            "https://www.googleapis.com/auth/compute",
49627            "https://www.googleapis.com/auth/compute.readonly"
49628          ],
49629          "description": "Returns permissions that a caller has on the specified resource."
49630        }
49631      }
49632    },
49633    "networkFirewallPolicies": {
49634      "methods": {
49635        "list": {
49636          "id": "compute.networkFirewallPolicies.list",
49637          "path": "projects/{project}/global/firewallPolicies",
49638          "flatPath": "projects/{project}/global/firewallPolicies",
49639          "httpMethod": "GET",
49640          "parameters": {
49641            "filter": {
49642              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
49643              "location": "query",
49644              "type": "string"
49645            },
49646            "maxResults": {
49647              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
49648              "default": "500",
49649              "minimum": "0",
49650              "location": "query",
49651              "type": "integer",
49652              "format": "uint32"
49653            },
49654            "orderBy": {
49655              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
49656              "location": "query",
49657              "type": "string"
49658            },
49659            "pageToken": {
49660              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
49661              "location": "query",
49662              "type": "string"
49663            },
49664            "project": {
49665              "description": "Project ID for this request.",
49666              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
49667              "location": "path",
49668              "required": true,
49669              "type": "string"
49670            },
49671            "returnPartialSuccess": {
49672              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
49673              "location": "query",
49674              "type": "boolean"
49675            }
49676          },
49677          "parameterOrder": [
49678            "project"
49679          ],
49680          "response": {
49681            "$ref": "FirewallPolicyList"
49682          },
49683          "scopes": [
49684            "https://www.googleapis.com/auth/cloud-platform",
49685            "https://www.googleapis.com/auth/compute",
49686            "https://www.googleapis.com/auth/compute.readonly"
49687          ],
49688          "description": "Lists all the policies that have been configured for the specified project."
49689        },
49690        "get": {
49691          "id": "compute.networkFirewallPolicies.get",
49692          "path": "projects/{project}/global/firewallPolicies/{firewallPolicy}",
49693          "flatPath": "projects/{project}/global/firewallPolicies/{firewallPolicy}",
49694          "httpMethod": "GET",
49695          "parameters": {
49696            "firewallPolicy": {
49697              "description": "Name of the firewall policy to get.",
49698              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
49699              "location": "path",
49700              "required": true,
49701              "type": "string"
49702            },
49703            "project": {
49704              "description": "Project ID for this request.",
49705              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
49706              "location": "path",
49707              "required": true,
49708              "type": "string"
49709            }
49710          },
49711          "parameterOrder": [
49712            "project",
49713            "firewallPolicy"
49714          ],
49715          "response": {
49716            "$ref": "FirewallPolicy"
49717          },
49718          "scopes": [
49719            "https://www.googleapis.com/auth/cloud-platform",
49720            "https://www.googleapis.com/auth/compute",
49721            "https://www.googleapis.com/auth/compute.readonly"
49722          ],
49723          "description": "Returns the specified network firewall policy."
49724        },
49725        "insert": {
49726          "id": "compute.networkFirewallPolicies.insert",
49727          "path": "projects/{project}/global/firewallPolicies",
49728          "flatPath": "projects/{project}/global/firewallPolicies",
49729          "httpMethod": "POST",
49730          "parameters": {
49731            "project": {
49732              "description": "Project ID for this request.",
49733              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
49734              "location": "path",
49735              "required": true,
49736              "type": "string"
49737            },
49738            "requestId": {
49739              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
49740              "location": "query",
49741              "type": "string"
49742            }
49743          },
49744          "parameterOrder": [
49745            "project"
49746          ],
49747          "request": {
49748            "$ref": "FirewallPolicy"
49749          },
49750          "response": {
49751            "$ref": "Operation"
49752          },
49753          "scopes": [
49754            "https://www.googleapis.com/auth/cloud-platform",
49755            "https://www.googleapis.com/auth/compute"
49756          ],
49757          "description": "Creates a new policy in the specified project using the data included in the request."
49758        },
49759        "delete": {
49760          "id": "compute.networkFirewallPolicies.delete",
49761          "path": "projects/{project}/global/firewallPolicies/{firewallPolicy}",
49762          "flatPath": "projects/{project}/global/firewallPolicies/{firewallPolicy}",
49763          "httpMethod": "DELETE",
49764          "parameters": {
49765            "firewallPolicy": {
49766              "description": "Name of the firewall policy to delete.",
49767              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
49768              "location": "path",
49769              "required": true,
49770              "type": "string"
49771            },
49772            "project": {
49773              "description": "Project ID for this request.",
49774              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
49775              "location": "path",
49776              "required": true,
49777              "type": "string"
49778            },
49779            "requestId": {
49780              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
49781              "location": "query",
49782              "type": "string"
49783            }
49784          },
49785          "parameterOrder": [
49786            "project",
49787            "firewallPolicy"
49788          ],
49789          "response": {
49790            "$ref": "Operation"
49791          },
49792          "scopes": [
49793            "https://www.googleapis.com/auth/cloud-platform",
49794            "https://www.googleapis.com/auth/compute"
49795          ],
49796          "description": "Deletes the specified policy."
49797        },
49798        "patch": {
49799          "id": "compute.networkFirewallPolicies.patch",
49800          "path": "projects/{project}/global/firewallPolicies/{firewallPolicy}",
49801          "flatPath": "projects/{project}/global/firewallPolicies/{firewallPolicy}",
49802          "httpMethod": "PATCH",
49803          "parameters": {
49804            "firewallPolicy": {
49805              "description": "Name of the firewall policy to update.",
49806              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
49807              "location": "path",
49808              "required": true,
49809              "type": "string"
49810            },
49811            "project": {
49812              "description": "Project ID for this request.",
49813              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
49814              "location": "path",
49815              "required": true,
49816              "type": "string"
49817            },
49818            "requestId": {
49819              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
49820              "location": "query",
49821              "type": "string"
49822            }
49823          },
49824          "parameterOrder": [
49825            "project",
49826            "firewallPolicy"
49827          ],
49828          "request": {
49829            "$ref": "FirewallPolicy"
49830          },
49831          "response": {
49832            "$ref": "Operation"
49833          },
49834          "scopes": [
49835            "https://www.googleapis.com/auth/cloud-platform",
49836            "https://www.googleapis.com/auth/compute"
49837          ],
49838          "description": "Patches the specified policy with the data included in the request."
49839        },
49840        "getRule": {
49841          "id": "compute.networkFirewallPolicies.getRule",
49842          "path": "projects/{project}/global/firewallPolicies/{firewallPolicy}/getRule",
49843          "flatPath": "projects/{project}/global/firewallPolicies/{firewallPolicy}/getRule",
49844          "httpMethod": "GET",
49845          "parameters": {
49846            "firewallPolicy": {
49847              "description": "Name of the firewall policy to which the queried rule belongs.",
49848              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
49849              "location": "path",
49850              "required": true,
49851              "type": "string"
49852            },
49853            "priority": {
49854              "description": "The priority of the rule to get from the firewall policy.",
49855              "location": "query",
49856              "type": "integer",
49857              "format": "int32"
49858            },
49859            "project": {
49860              "description": "Project ID for this request.",
49861              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
49862              "location": "path",
49863              "required": true,
49864              "type": "string"
49865            }
49866          },
49867          "parameterOrder": [
49868            "project",
49869            "firewallPolicy"
49870          ],
49871          "response": {
49872            "$ref": "FirewallPolicyRule"
49873          },
49874          "scopes": [
49875            "https://www.googleapis.com/auth/cloud-platform",
49876            "https://www.googleapis.com/auth/compute",
49877            "https://www.googleapis.com/auth/compute.readonly"
49878          ],
49879          "description": "Gets a rule of the specified priority."
49880        },
49881        "addRule": {
49882          "id": "compute.networkFirewallPolicies.addRule",
49883          "path": "projects/{project}/global/firewallPolicies/{firewallPolicy}/addRule",
49884          "flatPath": "projects/{project}/global/firewallPolicies/{firewallPolicy}/addRule",
49885          "httpMethod": "POST",
49886          "parameters": {
49887            "firewallPolicy": {
49888              "description": "Name of the firewall policy to update.",
49889              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
49890              "location": "path",
49891              "required": true,
49892              "type": "string"
49893            },
49894            "maxPriority": {
49895              "description": "When rule.priority is not specified, auto choose a unused priority between minPriority and maxPriority\u003e. This field is exclusive with rule.priority.",
49896              "location": "query",
49897              "type": "integer",
49898              "format": "int32"
49899            },
49900            "minPriority": {
49901              "description": "When rule.priority is not specified, auto choose a unused priority between minPriority and maxPriority\u003e. This field is exclusive with rule.priority.",
49902              "location": "query",
49903              "type": "integer",
49904              "format": "int32"
49905            },
49906            "project": {
49907              "description": "Project ID for this request.",
49908              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
49909              "location": "path",
49910              "required": true,
49911              "type": "string"
49912            },
49913            "requestId": {
49914              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
49915              "location": "query",
49916              "type": "string"
49917            }
49918          },
49919          "parameterOrder": [
49920            "project",
49921            "firewallPolicy"
49922          ],
49923          "request": {
49924            "$ref": "FirewallPolicyRule"
49925          },
49926          "response": {
49927            "$ref": "Operation"
49928          },
49929          "scopes": [
49930            "https://www.googleapis.com/auth/cloud-platform",
49931            "https://www.googleapis.com/auth/compute"
49932          ],
49933          "description": "Inserts a rule into a firewall policy."
49934        },
49935        "removeRule": {
49936          "id": "compute.networkFirewallPolicies.removeRule",
49937          "path": "projects/{project}/global/firewallPolicies/{firewallPolicy}/removeRule",
49938          "flatPath": "projects/{project}/global/firewallPolicies/{firewallPolicy}/removeRule",
49939          "httpMethod": "POST",
49940          "parameters": {
49941            "firewallPolicy": {
49942              "description": "Name of the firewall policy to update.",
49943              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
49944              "location": "path",
49945              "required": true,
49946              "type": "string"
49947            },
49948            "priority": {
49949              "description": "The priority of the rule to remove from the firewall policy.",
49950              "location": "query",
49951              "type": "integer",
49952              "format": "int32"
49953            },
49954            "project": {
49955              "description": "Project ID for this request.",
49956              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
49957              "location": "path",
49958              "required": true,
49959              "type": "string"
49960            },
49961            "requestId": {
49962              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
49963              "location": "query",
49964              "type": "string"
49965            }
49966          },
49967          "parameterOrder": [
49968            "project",
49969            "firewallPolicy"
49970          ],
49971          "response": {
49972            "$ref": "Operation"
49973          },
49974          "scopes": [
49975            "https://www.googleapis.com/auth/cloud-platform",
49976            "https://www.googleapis.com/auth/compute"
49977          ],
49978          "description": "Deletes a rule of the specified priority."
49979        },
49980        "patchRule": {
49981          "id": "compute.networkFirewallPolicies.patchRule",
49982          "path": "projects/{project}/global/firewallPolicies/{firewallPolicy}/patchRule",
49983          "flatPath": "projects/{project}/global/firewallPolicies/{firewallPolicy}/patchRule",
49984          "httpMethod": "POST",
49985          "parameters": {
49986            "firewallPolicy": {
49987              "description": "Name of the firewall policy to update.",
49988              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
49989              "location": "path",
49990              "required": true,
49991              "type": "string"
49992            },
49993            "priority": {
49994              "description": "The priority of the rule to patch.",
49995              "location": "query",
49996              "type": "integer",
49997              "format": "int32"
49998            },
49999            "project": {
50000              "description": "Project ID for this request.",
50001              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50002              "location": "path",
50003              "required": true,
50004              "type": "string"
50005            },
50006            "requestId": {
50007              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
50008              "location": "query",
50009              "type": "string"
50010            }
50011          },
50012          "parameterOrder": [
50013            "project",
50014            "firewallPolicy"
50015          ],
50016          "request": {
50017            "$ref": "FirewallPolicyRule"
50018          },
50019          "response": {
50020            "$ref": "Operation"
50021          },
50022          "scopes": [
50023            "https://www.googleapis.com/auth/cloud-platform",
50024            "https://www.googleapis.com/auth/compute"
50025          ],
50026          "description": "Patches a rule of the specified priority."
50027        },
50028        "getIamPolicy": {
50029          "id": "compute.networkFirewallPolicies.getIamPolicy",
50030          "path": "projects/{project}/global/firewallPolicies/{resource}/getIamPolicy",
50031          "flatPath": "projects/{project}/global/firewallPolicies/{resource}/getIamPolicy",
50032          "httpMethod": "GET",
50033          "parameters": {
50034            "optionsRequestedPolicyVersion": {
50035              "description": "Requested IAM Policy version.",
50036              "location": "query",
50037              "type": "integer",
50038              "format": "int32"
50039            },
50040            "project": {
50041              "description": "Project ID for this request.",
50042              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50043              "location": "path",
50044              "required": true,
50045              "type": "string"
50046            },
50047            "resource": {
50048              "description": "Name or id of the resource for this request.",
50049              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50050              "location": "path",
50051              "required": true,
50052              "type": "string"
50053            }
50054          },
50055          "parameterOrder": [
50056            "project",
50057            "resource"
50058          ],
50059          "response": {
50060            "$ref": "Policy"
50061          },
50062          "scopes": [
50063            "https://www.googleapis.com/auth/cloud-platform",
50064            "https://www.googleapis.com/auth/compute",
50065            "https://www.googleapis.com/auth/compute.readonly"
50066          ],
50067          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
50068        },
50069        "setIamPolicy": {
50070          "id": "compute.networkFirewallPolicies.setIamPolicy",
50071          "path": "projects/{project}/global/firewallPolicies/{resource}/setIamPolicy",
50072          "flatPath": "projects/{project}/global/firewallPolicies/{resource}/setIamPolicy",
50073          "httpMethod": "POST",
50074          "parameters": {
50075            "project": {
50076              "description": "Project ID for this request.",
50077              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50078              "location": "path",
50079              "required": true,
50080              "type": "string"
50081            },
50082            "resource": {
50083              "description": "Name or id of the resource for this request.",
50084              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50085              "location": "path",
50086              "required": true,
50087              "type": "string"
50088            }
50089          },
50090          "parameterOrder": [
50091            "project",
50092            "resource"
50093          ],
50094          "request": {
50095            "$ref": "GlobalSetPolicyRequest"
50096          },
50097          "response": {
50098            "$ref": "Policy"
50099          },
50100          "scopes": [
50101            "https://www.googleapis.com/auth/cloud-platform",
50102            "https://www.googleapis.com/auth/compute"
50103          ],
50104          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
50105        },
50106        "testIamPermissions": {
50107          "id": "compute.networkFirewallPolicies.testIamPermissions",
50108          "path": "projects/{project}/global/firewallPolicies/{resource}/testIamPermissions",
50109          "flatPath": "projects/{project}/global/firewallPolicies/{resource}/testIamPermissions",
50110          "httpMethod": "POST",
50111          "parameters": {
50112            "project": {
50113              "description": "Project ID for this request.",
50114              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50115              "location": "path",
50116              "required": true,
50117              "type": "string"
50118            },
50119            "resource": {
50120              "description": "Name or id of the resource for this request.",
50121              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50122              "location": "path",
50123              "required": true,
50124              "type": "string"
50125            }
50126          },
50127          "parameterOrder": [
50128            "project",
50129            "resource"
50130          ],
50131          "request": {
50132            "$ref": "TestPermissionsRequest"
50133          },
50134          "response": {
50135            "$ref": "TestPermissionsResponse"
50136          },
50137          "scopes": [
50138            "https://www.googleapis.com/auth/cloud-platform",
50139            "https://www.googleapis.com/auth/compute",
50140            "https://www.googleapis.com/auth/compute.readonly"
50141          ],
50142          "description": "Returns permissions that a caller has on the specified resource."
50143        },
50144        "addAssociation": {
50145          "id": "compute.networkFirewallPolicies.addAssociation",
50146          "path": "projects/{project}/global/firewallPolicies/{firewallPolicy}/addAssociation",
50147          "flatPath": "projects/{project}/global/firewallPolicies/{firewallPolicy}/addAssociation",
50148          "httpMethod": "POST",
50149          "parameters": {
50150            "firewallPolicy": {
50151              "description": "Name of the firewall policy to update.",
50152              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50153              "location": "path",
50154              "required": true,
50155              "type": "string"
50156            },
50157            "project": {
50158              "description": "Project ID for this request.",
50159              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50160              "location": "path",
50161              "required": true,
50162              "type": "string"
50163            },
50164            "replaceExistingAssociation": {
50165              "description": "Indicates whether or not to replace it if an association of the attachment already exists. This is false by default, in which case an error will be returned if an association already exists.",
50166              "location": "query",
50167              "type": "boolean"
50168            },
50169            "requestId": {
50170              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
50171              "location": "query",
50172              "type": "string"
50173            }
50174          },
50175          "parameterOrder": [
50176            "project",
50177            "firewallPolicy"
50178          ],
50179          "request": {
50180            "$ref": "FirewallPolicyAssociation"
50181          },
50182          "response": {
50183            "$ref": "Operation"
50184          },
50185          "scopes": [
50186            "https://www.googleapis.com/auth/cloud-platform",
50187            "https://www.googleapis.com/auth/compute"
50188          ],
50189          "description": "Inserts an association for the specified firewall policy."
50190        },
50191        "removeAssociation": {
50192          "id": "compute.networkFirewallPolicies.removeAssociation",
50193          "path": "projects/{project}/global/firewallPolicies/{firewallPolicy}/removeAssociation",
50194          "flatPath": "projects/{project}/global/firewallPolicies/{firewallPolicy}/removeAssociation",
50195          "httpMethod": "POST",
50196          "parameters": {
50197            "firewallPolicy": {
50198              "description": "Name of the firewall policy to update.",
50199              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50200              "location": "path",
50201              "required": true,
50202              "type": "string"
50203            },
50204            "name": {
50205              "description": "Name for the attachment that will be removed.",
50206              "location": "query",
50207              "type": "string"
50208            },
50209            "project": {
50210              "description": "Project ID for this request.",
50211              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50212              "location": "path",
50213              "required": true,
50214              "type": "string"
50215            },
50216            "requestId": {
50217              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
50218              "location": "query",
50219              "type": "string"
50220            }
50221          },
50222          "parameterOrder": [
50223            "project",
50224            "firewallPolicy"
50225          ],
50226          "response": {
50227            "$ref": "Operation"
50228          },
50229          "scopes": [
50230            "https://www.googleapis.com/auth/cloud-platform",
50231            "https://www.googleapis.com/auth/compute"
50232          ],
50233          "description": "Removes an association for the specified firewall policy."
50234        },
50235        "getAssociation": {
50236          "id": "compute.networkFirewallPolicies.getAssociation",
50237          "path": "projects/{project}/global/firewallPolicies/{firewallPolicy}/getAssociation",
50238          "flatPath": "projects/{project}/global/firewallPolicies/{firewallPolicy}/getAssociation",
50239          "httpMethod": "GET",
50240          "parameters": {
50241            "firewallPolicy": {
50242              "description": "Name of the firewall policy to which the queried association belongs.",
50243              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50244              "location": "path",
50245              "required": true,
50246              "type": "string"
50247            },
50248            "name": {
50249              "description": "The name of the association to get from the firewall policy.",
50250              "location": "query",
50251              "type": "string"
50252            },
50253            "project": {
50254              "description": "Project ID for this request.",
50255              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50256              "location": "path",
50257              "required": true,
50258              "type": "string"
50259            }
50260          },
50261          "parameterOrder": [
50262            "project",
50263            "firewallPolicy"
50264          ],
50265          "response": {
50266            "$ref": "FirewallPolicyAssociation"
50267          },
50268          "scopes": [
50269            "https://www.googleapis.com/auth/cloud-platform",
50270            "https://www.googleapis.com/auth/compute",
50271            "https://www.googleapis.com/auth/compute.readonly"
50272          ],
50273          "description": "Gets an association with the specified name."
50274        },
50275        "cloneRules": {
50276          "id": "compute.networkFirewallPolicies.cloneRules",
50277          "path": "projects/{project}/global/firewallPolicies/{firewallPolicy}/cloneRules",
50278          "flatPath": "projects/{project}/global/firewallPolicies/{firewallPolicy}/cloneRules",
50279          "httpMethod": "POST",
50280          "parameters": {
50281            "firewallPolicy": {
50282              "description": "Name of the firewall policy to update.",
50283              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50284              "location": "path",
50285              "required": true,
50286              "type": "string"
50287            },
50288            "project": {
50289              "description": "Project ID for this request.",
50290              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50291              "location": "path",
50292              "required": true,
50293              "type": "string"
50294            },
50295            "requestId": {
50296              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
50297              "location": "query",
50298              "type": "string"
50299            },
50300            "sourceFirewallPolicy": {
50301              "description": "The firewall policy from which to copy rules.",
50302              "location": "query",
50303              "type": "string"
50304            }
50305          },
50306          "parameterOrder": [
50307            "project",
50308            "firewallPolicy"
50309          ],
50310          "response": {
50311            "$ref": "Operation"
50312          },
50313          "scopes": [
50314            "https://www.googleapis.com/auth/cloud-platform",
50315            "https://www.googleapis.com/auth/compute"
50316          ],
50317          "description": "Copies rules to the specified firewall policy."
50318        }
50319      }
50320    },
50321    "regionNetworkFirewallPolicies": {
50322      "methods": {
50323        "list": {
50324          "id": "compute.regionNetworkFirewallPolicies.list",
50325          "path": "projects/{project}/regions/{region}/firewallPolicies",
50326          "flatPath": "projects/{project}/regions/{region}/firewallPolicies",
50327          "httpMethod": "GET",
50328          "parameters": {
50329            "filter": {
50330              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
50331              "location": "query",
50332              "type": "string"
50333            },
50334            "maxResults": {
50335              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
50336              "default": "500",
50337              "minimum": "0",
50338              "location": "query",
50339              "type": "integer",
50340              "format": "uint32"
50341            },
50342            "orderBy": {
50343              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
50344              "location": "query",
50345              "type": "string"
50346            },
50347            "pageToken": {
50348              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
50349              "location": "query",
50350              "type": "string"
50351            },
50352            "project": {
50353              "description": "Project ID for this request.",
50354              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50355              "location": "path",
50356              "required": true,
50357              "type": "string"
50358            },
50359            "region": {
50360              "description": "Name of the region scoping this request.",
50361              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
50362              "location": "path",
50363              "required": true,
50364              "type": "string"
50365            },
50366            "returnPartialSuccess": {
50367              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
50368              "location": "query",
50369              "type": "boolean"
50370            }
50371          },
50372          "parameterOrder": [
50373            "project",
50374            "region"
50375          ],
50376          "response": {
50377            "$ref": "FirewallPolicyList"
50378          },
50379          "scopes": [
50380            "https://www.googleapis.com/auth/cloud-platform",
50381            "https://www.googleapis.com/auth/compute",
50382            "https://www.googleapis.com/auth/compute.readonly"
50383          ],
50384          "description": "Lists all the network firewall policies that have been configured for the specified project in the given region."
50385        },
50386        "get": {
50387          "id": "compute.regionNetworkFirewallPolicies.get",
50388          "path": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}",
50389          "flatPath": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}",
50390          "httpMethod": "GET",
50391          "parameters": {
50392            "firewallPolicy": {
50393              "description": "Name of the firewall policy to get.",
50394              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50395              "location": "path",
50396              "required": true,
50397              "type": "string"
50398            },
50399            "project": {
50400              "description": "Project ID for this request.",
50401              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50402              "location": "path",
50403              "required": true,
50404              "type": "string"
50405            },
50406            "region": {
50407              "description": "Name of the region scoping this request.",
50408              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
50409              "location": "path",
50410              "required": true,
50411              "type": "string"
50412            }
50413          },
50414          "parameterOrder": [
50415            "project",
50416            "region",
50417            "firewallPolicy"
50418          ],
50419          "response": {
50420            "$ref": "FirewallPolicy"
50421          },
50422          "scopes": [
50423            "https://www.googleapis.com/auth/cloud-platform",
50424            "https://www.googleapis.com/auth/compute",
50425            "https://www.googleapis.com/auth/compute.readonly"
50426          ],
50427          "description": "Returns the specified network firewall policy."
50428        },
50429        "insert": {
50430          "id": "compute.regionNetworkFirewallPolicies.insert",
50431          "path": "projects/{project}/regions/{region}/firewallPolicies",
50432          "flatPath": "projects/{project}/regions/{region}/firewallPolicies",
50433          "httpMethod": "POST",
50434          "parameters": {
50435            "project": {
50436              "description": "Project ID for this request.",
50437              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50438              "location": "path",
50439              "required": true,
50440              "type": "string"
50441            },
50442            "region": {
50443              "description": "Name of the region scoping this request.",
50444              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
50445              "location": "path",
50446              "required": true,
50447              "type": "string"
50448            },
50449            "requestId": {
50450              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
50451              "location": "query",
50452              "type": "string"
50453            }
50454          },
50455          "parameterOrder": [
50456            "project",
50457            "region"
50458          ],
50459          "request": {
50460            "$ref": "FirewallPolicy"
50461          },
50462          "response": {
50463            "$ref": "Operation"
50464          },
50465          "scopes": [
50466            "https://www.googleapis.com/auth/cloud-platform",
50467            "https://www.googleapis.com/auth/compute"
50468          ],
50469          "description": "Creates a new network firewall policy in the specified project and region."
50470        },
50471        "delete": {
50472          "id": "compute.regionNetworkFirewallPolicies.delete",
50473          "path": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}",
50474          "flatPath": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}",
50475          "httpMethod": "DELETE",
50476          "parameters": {
50477            "firewallPolicy": {
50478              "description": "Name of the firewall policy to delete.",
50479              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50480              "location": "path",
50481              "required": true,
50482              "type": "string"
50483            },
50484            "project": {
50485              "description": "Project ID for this request.",
50486              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50487              "location": "path",
50488              "required": true,
50489              "type": "string"
50490            },
50491            "region": {
50492              "description": "Name of the region scoping this request.",
50493              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
50494              "location": "path",
50495              "required": true,
50496              "type": "string"
50497            },
50498            "requestId": {
50499              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
50500              "location": "query",
50501              "type": "string"
50502            }
50503          },
50504          "parameterOrder": [
50505            "project",
50506            "region",
50507            "firewallPolicy"
50508          ],
50509          "response": {
50510            "$ref": "Operation"
50511          },
50512          "scopes": [
50513            "https://www.googleapis.com/auth/cloud-platform",
50514            "https://www.googleapis.com/auth/compute"
50515          ],
50516          "description": "Deletes the specified network firewall policy."
50517        },
50518        "patch": {
50519          "id": "compute.regionNetworkFirewallPolicies.patch",
50520          "path": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}",
50521          "flatPath": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}",
50522          "httpMethod": "PATCH",
50523          "parameters": {
50524            "firewallPolicy": {
50525              "description": "Name of the firewall policy to update.",
50526              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50527              "location": "path",
50528              "required": true,
50529              "type": "string"
50530            },
50531            "project": {
50532              "description": "Project ID for this request.",
50533              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50534              "location": "path",
50535              "required": true,
50536              "type": "string"
50537            },
50538            "region": {
50539              "description": "Name of the region scoping this request.",
50540              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
50541              "location": "path",
50542              "required": true,
50543              "type": "string"
50544            },
50545            "requestId": {
50546              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
50547              "location": "query",
50548              "type": "string"
50549            }
50550          },
50551          "parameterOrder": [
50552            "project",
50553            "region",
50554            "firewallPolicy"
50555          ],
50556          "request": {
50557            "$ref": "FirewallPolicy"
50558          },
50559          "response": {
50560            "$ref": "Operation"
50561          },
50562          "scopes": [
50563            "https://www.googleapis.com/auth/cloud-platform",
50564            "https://www.googleapis.com/auth/compute"
50565          ],
50566          "description": "Patches the specified network firewall policy."
50567        },
50568        "getRule": {
50569          "id": "compute.regionNetworkFirewallPolicies.getRule",
50570          "path": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}/getRule",
50571          "flatPath": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}/getRule",
50572          "httpMethod": "GET",
50573          "parameters": {
50574            "firewallPolicy": {
50575              "description": "Name of the firewall policy to which the queried rule belongs.",
50576              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50577              "location": "path",
50578              "required": true,
50579              "type": "string"
50580            },
50581            "priority": {
50582              "description": "The priority of the rule to get from the firewall policy.",
50583              "location": "query",
50584              "type": "integer",
50585              "format": "int32"
50586            },
50587            "project": {
50588              "description": "Project ID for this request.",
50589              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50590              "location": "path",
50591              "required": true,
50592              "type": "string"
50593            },
50594            "region": {
50595              "description": "Name of the region scoping this request.",
50596              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
50597              "location": "path",
50598              "required": true,
50599              "type": "string"
50600            }
50601          },
50602          "parameterOrder": [
50603            "project",
50604            "region",
50605            "firewallPolicy"
50606          ],
50607          "response": {
50608            "$ref": "FirewallPolicyRule"
50609          },
50610          "scopes": [
50611            "https://www.googleapis.com/auth/cloud-platform",
50612            "https://www.googleapis.com/auth/compute",
50613            "https://www.googleapis.com/auth/compute.readonly"
50614          ],
50615          "description": "Gets a rule of the specified priority."
50616        },
50617        "addRule": {
50618          "id": "compute.regionNetworkFirewallPolicies.addRule",
50619          "path": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}/addRule",
50620          "flatPath": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}/addRule",
50621          "httpMethod": "POST",
50622          "parameters": {
50623            "firewallPolicy": {
50624              "description": "Name of the firewall policy to update.",
50625              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50626              "location": "path",
50627              "required": true,
50628              "type": "string"
50629            },
50630            "maxPriority": {
50631              "description": "When rule.priority is not specified, auto choose a unused priority between minPriority and maxPriority\u003e. This field is exclusive with rule.priority.",
50632              "location": "query",
50633              "type": "integer",
50634              "format": "int32"
50635            },
50636            "minPriority": {
50637              "description": "When rule.priority is not specified, auto choose a unused priority between minPriority and maxPriority\u003e. This field is exclusive with rule.priority.",
50638              "location": "query",
50639              "type": "integer",
50640              "format": "int32"
50641            },
50642            "project": {
50643              "description": "Project ID for this request.",
50644              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50645              "location": "path",
50646              "required": true,
50647              "type": "string"
50648            },
50649            "region": {
50650              "description": "Name of the region scoping this request.",
50651              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
50652              "location": "path",
50653              "required": true,
50654              "type": "string"
50655            },
50656            "requestId": {
50657              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
50658              "location": "query",
50659              "type": "string"
50660            }
50661          },
50662          "parameterOrder": [
50663            "project",
50664            "region",
50665            "firewallPolicy"
50666          ],
50667          "request": {
50668            "$ref": "FirewallPolicyRule"
50669          },
50670          "response": {
50671            "$ref": "Operation"
50672          },
50673          "scopes": [
50674            "https://www.googleapis.com/auth/cloud-platform",
50675            "https://www.googleapis.com/auth/compute"
50676          ],
50677          "description": "Inserts a rule into a network firewall policy."
50678        },
50679        "removeRule": {
50680          "id": "compute.regionNetworkFirewallPolicies.removeRule",
50681          "path": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}/removeRule",
50682          "flatPath": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}/removeRule",
50683          "httpMethod": "POST",
50684          "parameters": {
50685            "firewallPolicy": {
50686              "description": "Name of the firewall policy to update.",
50687              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50688              "location": "path",
50689              "required": true,
50690              "type": "string"
50691            },
50692            "priority": {
50693              "description": "The priority of the rule to remove from the firewall policy.",
50694              "location": "query",
50695              "type": "integer",
50696              "format": "int32"
50697            },
50698            "project": {
50699              "description": "Project ID for this request.",
50700              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50701              "location": "path",
50702              "required": true,
50703              "type": "string"
50704            },
50705            "region": {
50706              "description": "Name of the region scoping this request.",
50707              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
50708              "location": "path",
50709              "required": true,
50710              "type": "string"
50711            },
50712            "requestId": {
50713              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
50714              "location": "query",
50715              "type": "string"
50716            }
50717          },
50718          "parameterOrder": [
50719            "project",
50720            "region",
50721            "firewallPolicy"
50722          ],
50723          "response": {
50724            "$ref": "Operation"
50725          },
50726          "scopes": [
50727            "https://www.googleapis.com/auth/cloud-platform",
50728            "https://www.googleapis.com/auth/compute"
50729          ],
50730          "description": "Deletes a rule of the specified priority."
50731        },
50732        "patchRule": {
50733          "id": "compute.regionNetworkFirewallPolicies.patchRule",
50734          "path": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}/patchRule",
50735          "flatPath": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}/patchRule",
50736          "httpMethod": "POST",
50737          "parameters": {
50738            "firewallPolicy": {
50739              "description": "Name of the firewall policy to update.",
50740              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50741              "location": "path",
50742              "required": true,
50743              "type": "string"
50744            },
50745            "priority": {
50746              "description": "The priority of the rule to patch.",
50747              "location": "query",
50748              "type": "integer",
50749              "format": "int32"
50750            },
50751            "project": {
50752              "description": "Project ID for this request.",
50753              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50754              "location": "path",
50755              "required": true,
50756              "type": "string"
50757            },
50758            "region": {
50759              "description": "Name of the region scoping this request.",
50760              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
50761              "location": "path",
50762              "required": true,
50763              "type": "string"
50764            },
50765            "requestId": {
50766              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
50767              "location": "query",
50768              "type": "string"
50769            }
50770          },
50771          "parameterOrder": [
50772            "project",
50773            "region",
50774            "firewallPolicy"
50775          ],
50776          "request": {
50777            "$ref": "FirewallPolicyRule"
50778          },
50779          "response": {
50780            "$ref": "Operation"
50781          },
50782          "scopes": [
50783            "https://www.googleapis.com/auth/cloud-platform",
50784            "https://www.googleapis.com/auth/compute"
50785          ],
50786          "description": "Patches a rule of the specified priority."
50787        },
50788        "cloneRules": {
50789          "id": "compute.regionNetworkFirewallPolicies.cloneRules",
50790          "path": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}/cloneRules",
50791          "flatPath": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}/cloneRules",
50792          "httpMethod": "POST",
50793          "parameters": {
50794            "firewallPolicy": {
50795              "description": "Name of the firewall policy to update.",
50796              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50797              "location": "path",
50798              "required": true,
50799              "type": "string"
50800            },
50801            "project": {
50802              "description": "Project ID for this request.",
50803              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50804              "location": "path",
50805              "required": true,
50806              "type": "string"
50807            },
50808            "region": {
50809              "description": "Name of the region scoping this request.",
50810              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
50811              "location": "path",
50812              "required": true,
50813              "type": "string"
50814            },
50815            "requestId": {
50816              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
50817              "location": "query",
50818              "type": "string"
50819            },
50820            "sourceFirewallPolicy": {
50821              "description": "The firewall policy from which to copy rules.",
50822              "location": "query",
50823              "type": "string"
50824            }
50825          },
50826          "parameterOrder": [
50827            "project",
50828            "region",
50829            "firewallPolicy"
50830          ],
50831          "response": {
50832            "$ref": "Operation"
50833          },
50834          "scopes": [
50835            "https://www.googleapis.com/auth/cloud-platform",
50836            "https://www.googleapis.com/auth/compute"
50837          ],
50838          "description": "Copies rules to the specified network firewall policy."
50839        },
50840        "getAssociation": {
50841          "id": "compute.regionNetworkFirewallPolicies.getAssociation",
50842          "path": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}/getAssociation",
50843          "flatPath": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}/getAssociation",
50844          "httpMethod": "GET",
50845          "parameters": {
50846            "firewallPolicy": {
50847              "description": "Name of the firewall policy to which the queried association belongs.",
50848              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50849              "location": "path",
50850              "required": true,
50851              "type": "string"
50852            },
50853            "name": {
50854              "description": "The name of the association to get from the firewall policy.",
50855              "location": "query",
50856              "type": "string"
50857            },
50858            "project": {
50859              "description": "Project ID for this request.",
50860              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50861              "location": "path",
50862              "required": true,
50863              "type": "string"
50864            },
50865            "region": {
50866              "description": "Name of the region scoping this request.",
50867              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
50868              "location": "path",
50869              "required": true,
50870              "type": "string"
50871            }
50872          },
50873          "parameterOrder": [
50874            "project",
50875            "region",
50876            "firewallPolicy"
50877          ],
50878          "response": {
50879            "$ref": "FirewallPolicyAssociation"
50880          },
50881          "scopes": [
50882            "https://www.googleapis.com/auth/cloud-platform",
50883            "https://www.googleapis.com/auth/compute",
50884            "https://www.googleapis.com/auth/compute.readonly"
50885          ],
50886          "description": "Gets an association with the specified name."
50887        },
50888        "addAssociation": {
50889          "id": "compute.regionNetworkFirewallPolicies.addAssociation",
50890          "path": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}/addAssociation",
50891          "flatPath": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}/addAssociation",
50892          "httpMethod": "POST",
50893          "parameters": {
50894            "firewallPolicy": {
50895              "description": "Name of the firewall policy to update.",
50896              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50897              "location": "path",
50898              "required": true,
50899              "type": "string"
50900            },
50901            "project": {
50902              "description": "Project ID for this request.",
50903              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50904              "location": "path",
50905              "required": true,
50906              "type": "string"
50907            },
50908            "region": {
50909              "description": "Name of the region scoping this request.",
50910              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
50911              "location": "path",
50912              "required": true,
50913              "type": "string"
50914            },
50915            "replaceExistingAssociation": {
50916              "description": "Indicates whether or not to replace it if an association already exists. This is false by default, in which case an error will be returned if an association already exists.",
50917              "location": "query",
50918              "type": "boolean"
50919            },
50920            "requestId": {
50921              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
50922              "location": "query",
50923              "type": "string"
50924            }
50925          },
50926          "parameterOrder": [
50927            "project",
50928            "region",
50929            "firewallPolicy"
50930          ],
50931          "request": {
50932            "$ref": "FirewallPolicyAssociation"
50933          },
50934          "response": {
50935            "$ref": "Operation"
50936          },
50937          "scopes": [
50938            "https://www.googleapis.com/auth/cloud-platform",
50939            "https://www.googleapis.com/auth/compute"
50940          ],
50941          "description": "Inserts an association for the specified network firewall policy."
50942        },
50943        "removeAssociation": {
50944          "id": "compute.regionNetworkFirewallPolicies.removeAssociation",
50945          "path": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}/removeAssociation",
50946          "flatPath": "projects/{project}/regions/{region}/firewallPolicies/{firewallPolicy}/removeAssociation",
50947          "httpMethod": "POST",
50948          "parameters": {
50949            "firewallPolicy": {
50950              "description": "Name of the firewall policy to update.",
50951              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
50952              "location": "path",
50953              "required": true,
50954              "type": "string"
50955            },
50956            "name": {
50957              "description": "Name for the association that will be removed.",
50958              "location": "query",
50959              "type": "string"
50960            },
50961            "project": {
50962              "description": "Project ID for this request.",
50963              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
50964              "location": "path",
50965              "required": true,
50966              "type": "string"
50967            },
50968            "region": {
50969              "description": "Name of the region scoping this request.",
50970              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
50971              "location": "path",
50972              "required": true,
50973              "type": "string"
50974            },
50975            "requestId": {
50976              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
50977              "location": "query",
50978              "type": "string"
50979            }
50980          },
50981          "parameterOrder": [
50982            "project",
50983            "region",
50984            "firewallPolicy"
50985          ],
50986          "response": {
50987            "$ref": "Operation"
50988          },
50989          "scopes": [
50990            "https://www.googleapis.com/auth/cloud-platform",
50991            "https://www.googleapis.com/auth/compute"
50992          ],
50993          "description": "Removes an association for the specified network firewall policy."
50994        },
50995        "getEffectiveFirewalls": {
50996          "id": "compute.regionNetworkFirewallPolicies.getEffectiveFirewalls",
50997          "path": "projects/{project}/regions/{region}/firewallPolicies/getEffectiveFirewalls",
50998          "flatPath": "projects/{project}/regions/{region}/firewallPolicies/getEffectiveFirewalls",
50999          "httpMethod": "GET",
51000          "parameters": {
51001            "network": {
51002              "description": "Network reference",
51003              "location": "query",
51004              "required": true,
51005              "type": "string"
51006            },
51007            "project": {
51008              "description": "Project ID for this request.",
51009              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51010              "location": "path",
51011              "required": true,
51012              "type": "string"
51013            },
51014            "region": {
51015              "description": "Name of the region scoping this request.",
51016              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
51017              "location": "path",
51018              "required": true,
51019              "type": "string"
51020            }
51021          },
51022          "parameterOrder": [
51023            "project",
51024            "region",
51025            "network"
51026          ],
51027          "response": {
51028            "$ref": "RegionNetworkFirewallPoliciesGetEffectiveFirewallsResponse"
51029          },
51030          "scopes": [
51031            "https://www.googleapis.com/auth/cloud-platform",
51032            "https://www.googleapis.com/auth/compute",
51033            "https://www.googleapis.com/auth/compute.readonly"
51034          ],
51035          "description": "Returns the effective firewalls on a given network."
51036        },
51037        "getIamPolicy": {
51038          "id": "compute.regionNetworkFirewallPolicies.getIamPolicy",
51039          "path": "projects/{project}/regions/{region}/firewallPolicies/{resource}/getIamPolicy",
51040          "flatPath": "projects/{project}/regions/{region}/firewallPolicies/{resource}/getIamPolicy",
51041          "httpMethod": "GET",
51042          "parameters": {
51043            "optionsRequestedPolicyVersion": {
51044              "description": "Requested IAM Policy version.",
51045              "location": "query",
51046              "type": "integer",
51047              "format": "int32"
51048            },
51049            "project": {
51050              "description": "Project ID for this request.",
51051              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51052              "location": "path",
51053              "required": true,
51054              "type": "string"
51055            },
51056            "region": {
51057              "description": "The name of the region for this request.",
51058              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
51059              "location": "path",
51060              "required": true,
51061              "type": "string"
51062            },
51063            "resource": {
51064              "description": "Name or id of the resource for this request.",
51065              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
51066              "location": "path",
51067              "required": true,
51068              "type": "string"
51069            }
51070          },
51071          "parameterOrder": [
51072            "project",
51073            "region",
51074            "resource"
51075          ],
51076          "response": {
51077            "$ref": "Policy"
51078          },
51079          "scopes": [
51080            "https://www.googleapis.com/auth/cloud-platform",
51081            "https://www.googleapis.com/auth/compute",
51082            "https://www.googleapis.com/auth/compute.readonly"
51083          ],
51084          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
51085        },
51086        "setIamPolicy": {
51087          "id": "compute.regionNetworkFirewallPolicies.setIamPolicy",
51088          "path": "projects/{project}/regions/{region}/firewallPolicies/{resource}/setIamPolicy",
51089          "flatPath": "projects/{project}/regions/{region}/firewallPolicies/{resource}/setIamPolicy",
51090          "httpMethod": "POST",
51091          "parameters": {
51092            "project": {
51093              "description": "Project ID for this request.",
51094              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51095              "location": "path",
51096              "required": true,
51097              "type": "string"
51098            },
51099            "region": {
51100              "description": "The name of the region for this request.",
51101              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
51102              "location": "path",
51103              "required": true,
51104              "type": "string"
51105            },
51106            "resource": {
51107              "description": "Name or id of the resource for this request.",
51108              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
51109              "location": "path",
51110              "required": true,
51111              "type": "string"
51112            }
51113          },
51114          "parameterOrder": [
51115            "project",
51116            "region",
51117            "resource"
51118          ],
51119          "request": {
51120            "$ref": "RegionSetPolicyRequest"
51121          },
51122          "response": {
51123            "$ref": "Policy"
51124          },
51125          "scopes": [
51126            "https://www.googleapis.com/auth/cloud-platform",
51127            "https://www.googleapis.com/auth/compute"
51128          ],
51129          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
51130        },
51131        "testIamPermissions": {
51132          "id": "compute.regionNetworkFirewallPolicies.testIamPermissions",
51133          "path": "projects/{project}/regions/{region}/firewallPolicies/{resource}/testIamPermissions",
51134          "flatPath": "projects/{project}/regions/{region}/firewallPolicies/{resource}/testIamPermissions",
51135          "httpMethod": "POST",
51136          "parameters": {
51137            "project": {
51138              "description": "Project ID for this request.",
51139              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51140              "location": "path",
51141              "required": true,
51142              "type": "string"
51143            },
51144            "region": {
51145              "description": "The name of the region for this request.",
51146              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
51147              "location": "path",
51148              "required": true,
51149              "type": "string"
51150            },
51151            "resource": {
51152              "description": "Name or id of the resource for this request.",
51153              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
51154              "location": "path",
51155              "required": true,
51156              "type": "string"
51157            }
51158          },
51159          "parameterOrder": [
51160            "project",
51161            "region",
51162            "resource"
51163          ],
51164          "request": {
51165            "$ref": "TestPermissionsRequest"
51166          },
51167          "response": {
51168            "$ref": "TestPermissionsResponse"
51169          },
51170          "scopes": [
51171            "https://www.googleapis.com/auth/cloud-platform",
51172            "https://www.googleapis.com/auth/compute",
51173            "https://www.googleapis.com/auth/compute.readonly"
51174          ],
51175          "description": "Returns permissions that a caller has on the specified resource."
51176        }
51177      }
51178    },
51179    "securityPolicies": {
51180      "methods": {
51181        "list": {
51182          "id": "compute.securityPolicies.list",
51183          "path": "projects/{project}/global/securityPolicies",
51184          "flatPath": "projects/{project}/global/securityPolicies",
51185          "httpMethod": "GET",
51186          "parameters": {
51187            "filter": {
51188              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
51189              "location": "query",
51190              "type": "string"
51191            },
51192            "maxResults": {
51193              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
51194              "default": "500",
51195              "minimum": "0",
51196              "location": "query",
51197              "type": "integer",
51198              "format": "uint32"
51199            },
51200            "orderBy": {
51201              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
51202              "location": "query",
51203              "type": "string"
51204            },
51205            "pageToken": {
51206              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
51207              "location": "query",
51208              "type": "string"
51209            },
51210            "project": {
51211              "description": "Project ID for this request.",
51212              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51213              "location": "path",
51214              "required": true,
51215              "type": "string"
51216            },
51217            "returnPartialSuccess": {
51218              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
51219              "location": "query",
51220              "type": "boolean"
51221            }
51222          },
51223          "parameterOrder": [
51224            "project"
51225          ],
51226          "response": {
51227            "$ref": "SecurityPolicyList"
51228          },
51229          "scopes": [
51230            "https://www.googleapis.com/auth/cloud-platform",
51231            "https://www.googleapis.com/auth/compute",
51232            "https://www.googleapis.com/auth/compute.readonly"
51233          ],
51234          "description": "List all the policies that have been configured for the specified project."
51235        },
51236        "get": {
51237          "id": "compute.securityPolicies.get",
51238          "path": "projects/{project}/global/securityPolicies/{securityPolicy}",
51239          "flatPath": "projects/{project}/global/securityPolicies/{securityPolicy}",
51240          "httpMethod": "GET",
51241          "parameters": {
51242            "project": {
51243              "description": "Project ID for this request.",
51244              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51245              "location": "path",
51246              "required": true,
51247              "type": "string"
51248            },
51249            "securityPolicy": {
51250              "description": "Name of the security policy to get.",
51251              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
51252              "location": "path",
51253              "required": true,
51254              "type": "string"
51255            }
51256          },
51257          "parameterOrder": [
51258            "project",
51259            "securityPolicy"
51260          ],
51261          "response": {
51262            "$ref": "SecurityPolicy"
51263          },
51264          "scopes": [
51265            "https://www.googleapis.com/auth/cloud-platform",
51266            "https://www.googleapis.com/auth/compute",
51267            "https://www.googleapis.com/auth/compute.readonly"
51268          ],
51269          "description": "List all of the ordered rules present in a single specified policy."
51270        },
51271        "insert": {
51272          "id": "compute.securityPolicies.insert",
51273          "path": "projects/{project}/global/securityPolicies",
51274          "flatPath": "projects/{project}/global/securityPolicies",
51275          "httpMethod": "POST",
51276          "parameters": {
51277            "project": {
51278              "description": "Project ID for this request.",
51279              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51280              "location": "path",
51281              "required": true,
51282              "type": "string"
51283            },
51284            "requestId": {
51285              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
51286              "location": "query",
51287              "type": "string"
51288            },
51289            "validateOnly": {
51290              "description": "If true, the request will not be committed.",
51291              "location": "query",
51292              "type": "boolean"
51293            }
51294          },
51295          "parameterOrder": [
51296            "project"
51297          ],
51298          "request": {
51299            "$ref": "SecurityPolicy"
51300          },
51301          "response": {
51302            "$ref": "Operation"
51303          },
51304          "scopes": [
51305            "https://www.googleapis.com/auth/cloud-platform",
51306            "https://www.googleapis.com/auth/compute"
51307          ],
51308          "description": "Creates a new policy in the specified project using the data included in the request."
51309        },
51310        "delete": {
51311          "id": "compute.securityPolicies.delete",
51312          "path": "projects/{project}/global/securityPolicies/{securityPolicy}",
51313          "flatPath": "projects/{project}/global/securityPolicies/{securityPolicy}",
51314          "httpMethod": "DELETE",
51315          "parameters": {
51316            "project": {
51317              "description": "Project ID for this request.",
51318              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51319              "location": "path",
51320              "required": true,
51321              "type": "string"
51322            },
51323            "requestId": {
51324              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
51325              "location": "query",
51326              "type": "string"
51327            },
51328            "securityPolicy": {
51329              "description": "Name of the security policy to delete.",
51330              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
51331              "location": "path",
51332              "required": true,
51333              "type": "string"
51334            }
51335          },
51336          "parameterOrder": [
51337            "project",
51338            "securityPolicy"
51339          ],
51340          "response": {
51341            "$ref": "Operation"
51342          },
51343          "scopes": [
51344            "https://www.googleapis.com/auth/cloud-platform",
51345            "https://www.googleapis.com/auth/compute"
51346          ],
51347          "description": "Deletes the specified policy."
51348        },
51349        "patch": {
51350          "id": "compute.securityPolicies.patch",
51351          "path": "projects/{project}/global/securityPolicies/{securityPolicy}",
51352          "flatPath": "projects/{project}/global/securityPolicies/{securityPolicy}",
51353          "httpMethod": "PATCH",
51354          "parameters": {
51355            "project": {
51356              "description": "Project ID for this request.",
51357              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51358              "location": "path",
51359              "required": true,
51360              "type": "string"
51361            },
51362            "requestId": {
51363              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
51364              "location": "query",
51365              "type": "string"
51366            },
51367            "securityPolicy": {
51368              "description": "Name of the security policy to update.",
51369              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
51370              "location": "path",
51371              "required": true,
51372              "type": "string"
51373            },
51374            "updateMask": {
51375              "description": "Indicates fields to be cleared as part of this request.",
51376              "location": "query",
51377              "type": "string",
51378              "format": "google-fieldmask"
51379            }
51380          },
51381          "parameterOrder": [
51382            "project",
51383            "securityPolicy"
51384          ],
51385          "request": {
51386            "$ref": "SecurityPolicy"
51387          },
51388          "response": {
51389            "$ref": "Operation"
51390          },
51391          "scopes": [
51392            "https://www.googleapis.com/auth/cloud-platform",
51393            "https://www.googleapis.com/auth/compute"
51394          ],
51395          "description": "Patches the specified policy with the data included in the request. To clear fields in the policy, leave the fields empty and specify them in the updateMask. This cannot be used to be update the rules in the policy. Please use the per rule methods like addRule, patchRule, and removeRule instead."
51396        },
51397        "getRule": {
51398          "id": "compute.securityPolicies.getRule",
51399          "path": "projects/{project}/global/securityPolicies/{securityPolicy}/getRule",
51400          "flatPath": "projects/{project}/global/securityPolicies/{securityPolicy}/getRule",
51401          "httpMethod": "GET",
51402          "parameters": {
51403            "priority": {
51404              "description": "The priority of the rule to get from the security policy.",
51405              "location": "query",
51406              "type": "integer",
51407              "format": "int32"
51408            },
51409            "project": {
51410              "description": "Project ID for this request.",
51411              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51412              "location": "path",
51413              "required": true,
51414              "type": "string"
51415            },
51416            "securityPolicy": {
51417              "description": "Name of the security policy to which the queried rule belongs.",
51418              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
51419              "location": "path",
51420              "required": true,
51421              "type": "string"
51422            }
51423          },
51424          "parameterOrder": [
51425            "project",
51426            "securityPolicy"
51427          ],
51428          "response": {
51429            "$ref": "SecurityPolicyRule"
51430          },
51431          "scopes": [
51432            "https://www.googleapis.com/auth/cloud-platform",
51433            "https://www.googleapis.com/auth/compute",
51434            "https://www.googleapis.com/auth/compute.readonly"
51435          ],
51436          "description": "Gets a rule at the specified priority."
51437        },
51438        "addRule": {
51439          "id": "compute.securityPolicies.addRule",
51440          "path": "projects/{project}/global/securityPolicies/{securityPolicy}/addRule",
51441          "flatPath": "projects/{project}/global/securityPolicies/{securityPolicy}/addRule",
51442          "httpMethod": "POST",
51443          "parameters": {
51444            "project": {
51445              "description": "Project ID for this request.",
51446              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51447              "location": "path",
51448              "required": true,
51449              "type": "string"
51450            },
51451            "securityPolicy": {
51452              "description": "Name of the security policy to update.",
51453              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
51454              "location": "path",
51455              "required": true,
51456              "type": "string"
51457            },
51458            "validateOnly": {
51459              "description": "If true, the request will not be committed.",
51460              "location": "query",
51461              "type": "boolean"
51462            }
51463          },
51464          "parameterOrder": [
51465            "project",
51466            "securityPolicy"
51467          ],
51468          "request": {
51469            "$ref": "SecurityPolicyRule"
51470          },
51471          "response": {
51472            "$ref": "Operation"
51473          },
51474          "scopes": [
51475            "https://www.googleapis.com/auth/cloud-platform",
51476            "https://www.googleapis.com/auth/compute"
51477          ],
51478          "description": "Inserts a rule into a security policy."
51479        },
51480        "removeRule": {
51481          "id": "compute.securityPolicies.removeRule",
51482          "path": "projects/{project}/global/securityPolicies/{securityPolicy}/removeRule",
51483          "flatPath": "projects/{project}/global/securityPolicies/{securityPolicy}/removeRule",
51484          "httpMethod": "POST",
51485          "parameters": {
51486            "priority": {
51487              "description": "The priority of the rule to remove from the security policy.",
51488              "location": "query",
51489              "type": "integer",
51490              "format": "int32"
51491            },
51492            "project": {
51493              "description": "Project ID for this request.",
51494              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51495              "location": "path",
51496              "required": true,
51497              "type": "string"
51498            },
51499            "securityPolicy": {
51500              "description": "Name of the security policy to update.",
51501              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
51502              "location": "path",
51503              "required": true,
51504              "type": "string"
51505            }
51506          },
51507          "parameterOrder": [
51508            "project",
51509            "securityPolicy"
51510          ],
51511          "response": {
51512            "$ref": "Operation"
51513          },
51514          "scopes": [
51515            "https://www.googleapis.com/auth/cloud-platform",
51516            "https://www.googleapis.com/auth/compute"
51517          ],
51518          "description": "Deletes a rule at the specified priority."
51519        },
51520        "patchRule": {
51521          "id": "compute.securityPolicies.patchRule",
51522          "path": "projects/{project}/global/securityPolicies/{securityPolicy}/patchRule",
51523          "flatPath": "projects/{project}/global/securityPolicies/{securityPolicy}/patchRule",
51524          "httpMethod": "POST",
51525          "parameters": {
51526            "priority": {
51527              "description": "The priority of the rule to patch.",
51528              "location": "query",
51529              "type": "integer",
51530              "format": "int32"
51531            },
51532            "project": {
51533              "description": "Project ID for this request.",
51534              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51535              "location": "path",
51536              "required": true,
51537              "type": "string"
51538            },
51539            "securityPolicy": {
51540              "description": "Name of the security policy to update.",
51541              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
51542              "location": "path",
51543              "required": true,
51544              "type": "string"
51545            },
51546            "updateMask": {
51547              "description": "Indicates fields to be cleared as part of this request.",
51548              "location": "query",
51549              "type": "string",
51550              "format": "google-fieldmask"
51551            },
51552            "validateOnly": {
51553              "description": "If true, the request will not be committed.",
51554              "location": "query",
51555              "type": "boolean"
51556            }
51557          },
51558          "parameterOrder": [
51559            "project",
51560            "securityPolicy"
51561          ],
51562          "request": {
51563            "$ref": "SecurityPolicyRule"
51564          },
51565          "response": {
51566            "$ref": "Operation"
51567          },
51568          "scopes": [
51569            "https://www.googleapis.com/auth/cloud-platform",
51570            "https://www.googleapis.com/auth/compute"
51571          ],
51572          "description": "Patches a rule at the specified priority. To clear fields in the rule, leave the fields empty and specify them in the updateMask."
51573        },
51574        "listPreconfiguredExpressionSets": {
51575          "id": "compute.securityPolicies.listPreconfiguredExpressionSets",
51576          "path": "projects/{project}/global/securityPolicies/listPreconfiguredExpressionSets",
51577          "flatPath": "projects/{project}/global/securityPolicies/listPreconfiguredExpressionSets",
51578          "httpMethod": "GET",
51579          "parameters": {
51580            "filter": {
51581              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
51582              "location": "query",
51583              "type": "string"
51584            },
51585            "maxResults": {
51586              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
51587              "default": "500",
51588              "minimum": "0",
51589              "location": "query",
51590              "type": "integer",
51591              "format": "uint32"
51592            },
51593            "orderBy": {
51594              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
51595              "location": "query",
51596              "type": "string"
51597            },
51598            "pageToken": {
51599              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
51600              "location": "query",
51601              "type": "string"
51602            },
51603            "project": {
51604              "description": "Project ID for this request.",
51605              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51606              "location": "path",
51607              "required": true,
51608              "type": "string"
51609            },
51610            "returnPartialSuccess": {
51611              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
51612              "location": "query",
51613              "type": "boolean"
51614            }
51615          },
51616          "parameterOrder": [
51617            "project"
51618          ],
51619          "response": {
51620            "$ref": "SecurityPoliciesListPreconfiguredExpressionSetsResponse"
51621          },
51622          "scopes": [
51623            "https://www.googleapis.com/auth/cloud-platform",
51624            "https://www.googleapis.com/auth/compute",
51625            "https://www.googleapis.com/auth/compute.readonly"
51626          ],
51627          "description": "Gets the current list of preconfigured Web Application Firewall (WAF) expressions."
51628        },
51629        "setLabels": {
51630          "id": "compute.securityPolicies.setLabels",
51631          "path": "projects/{project}/global/securityPolicies/{resource}/setLabels",
51632          "flatPath": "projects/{project}/global/securityPolicies/{resource}/setLabels",
51633          "httpMethod": "POST",
51634          "parameters": {
51635            "project": {
51636              "description": "Project ID for this request.",
51637              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51638              "location": "path",
51639              "required": true,
51640              "type": "string"
51641            },
51642            "resource": {
51643              "description": "Name or id of the resource for this request.",
51644              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
51645              "location": "path",
51646              "required": true,
51647              "type": "string"
51648            }
51649          },
51650          "parameterOrder": [
51651            "project",
51652            "resource"
51653          ],
51654          "request": {
51655            "$ref": "GlobalSetLabelsRequest"
51656          },
51657          "response": {
51658            "$ref": "Operation"
51659          },
51660          "scopes": [
51661            "https://www.googleapis.com/auth/cloud-platform",
51662            "https://www.googleapis.com/auth/compute"
51663          ],
51664          "description": "Sets the labels on a security policy. To learn more about labels, read the Labeling Resources documentation."
51665        },
51666        "aggregatedList": {
51667          "id": "compute.securityPolicies.aggregatedList",
51668          "path": "projects/{project}/aggregated/securityPolicies",
51669          "flatPath": "projects/{project}/aggregated/securityPolicies",
51670          "httpMethod": "GET",
51671          "parameters": {
51672            "filter": {
51673              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
51674              "location": "query",
51675              "type": "string"
51676            },
51677            "includeAllScopes": {
51678              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
51679              "location": "query",
51680              "type": "boolean"
51681            },
51682            "maxResults": {
51683              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
51684              "default": "500",
51685              "minimum": "0",
51686              "location": "query",
51687              "type": "integer",
51688              "format": "uint32"
51689            },
51690            "orderBy": {
51691              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
51692              "location": "query",
51693              "type": "string"
51694            },
51695            "pageToken": {
51696              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
51697              "location": "query",
51698              "type": "string"
51699            },
51700            "project": {
51701              "description": "Name of the project scoping this request.",
51702              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51703              "location": "path",
51704              "required": true,
51705              "type": "string"
51706            },
51707            "returnPartialSuccess": {
51708              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
51709              "location": "query",
51710              "type": "boolean"
51711            },
51712            "serviceProjectNumber": {
51713              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
51714              "location": "query",
51715              "type": "string",
51716              "format": "int64"
51717            }
51718          },
51719          "parameterOrder": [
51720            "project"
51721          ],
51722          "response": {
51723            "$ref": "SecurityPoliciesAggregatedList"
51724          },
51725          "scopes": [
51726            "https://www.googleapis.com/auth/cloud-platform",
51727            "https://www.googleapis.com/auth/compute",
51728            "https://www.googleapis.com/auth/compute.readonly"
51729          ],
51730          "description": "Retrieves the list of all SecurityPolicy resources, regional and global, available to the specified project. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
51731        }
51732      }
51733    },
51734    "regionSecurityPolicies": {
51735      "methods": {
51736        "list": {
51737          "id": "compute.regionSecurityPolicies.list",
51738          "path": "projects/{project}/regions/{region}/securityPolicies",
51739          "flatPath": "projects/{project}/regions/{region}/securityPolicies",
51740          "httpMethod": "GET",
51741          "parameters": {
51742            "filter": {
51743              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
51744              "location": "query",
51745              "type": "string"
51746            },
51747            "maxResults": {
51748              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
51749              "default": "500",
51750              "minimum": "0",
51751              "location": "query",
51752              "type": "integer",
51753              "format": "uint32"
51754            },
51755            "orderBy": {
51756              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
51757              "location": "query",
51758              "type": "string"
51759            },
51760            "pageToken": {
51761              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
51762              "location": "query",
51763              "type": "string"
51764            },
51765            "project": {
51766              "description": "Project ID for this request.",
51767              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51768              "location": "path",
51769              "required": true,
51770              "type": "string"
51771            },
51772            "region": {
51773              "description": "Name of the region scoping this request.",
51774              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
51775              "location": "path",
51776              "required": true,
51777              "type": "string"
51778            },
51779            "returnPartialSuccess": {
51780              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
51781              "location": "query",
51782              "type": "boolean"
51783            }
51784          },
51785          "parameterOrder": [
51786            "project",
51787            "region"
51788          ],
51789          "response": {
51790            "$ref": "SecurityPolicyList"
51791          },
51792          "scopes": [
51793            "https://www.googleapis.com/auth/cloud-platform",
51794            "https://www.googleapis.com/auth/compute",
51795            "https://www.googleapis.com/auth/compute.readonly"
51796          ],
51797          "description": "List all the policies that have been configured for the specified project and region."
51798        },
51799        "get": {
51800          "id": "compute.regionSecurityPolicies.get",
51801          "path": "projects/{project}/regions/{region}/securityPolicies/{securityPolicy}",
51802          "flatPath": "projects/{project}/regions/{region}/securityPolicies/{securityPolicy}",
51803          "httpMethod": "GET",
51804          "parameters": {
51805            "project": {
51806              "description": "Project ID for this request.",
51807              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51808              "location": "path",
51809              "required": true,
51810              "type": "string"
51811            },
51812            "region": {
51813              "description": "Name of the region scoping this request.",
51814              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
51815              "location": "path",
51816              "required": true,
51817              "type": "string"
51818            },
51819            "securityPolicy": {
51820              "description": "Name of the security policy to get.",
51821              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
51822              "location": "path",
51823              "required": true,
51824              "type": "string"
51825            }
51826          },
51827          "parameterOrder": [
51828            "project",
51829            "region",
51830            "securityPolicy"
51831          ],
51832          "response": {
51833            "$ref": "SecurityPolicy"
51834          },
51835          "scopes": [
51836            "https://www.googleapis.com/auth/cloud-platform",
51837            "https://www.googleapis.com/auth/compute",
51838            "https://www.googleapis.com/auth/compute.readonly"
51839          ],
51840          "description": "List all of the ordered rules present in a single specified policy."
51841        },
51842        "insert": {
51843          "id": "compute.regionSecurityPolicies.insert",
51844          "path": "projects/{project}/regions/{region}/securityPolicies",
51845          "flatPath": "projects/{project}/regions/{region}/securityPolicies",
51846          "httpMethod": "POST",
51847          "parameters": {
51848            "project": {
51849              "description": "Project ID for this request.",
51850              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51851              "location": "path",
51852              "required": true,
51853              "type": "string"
51854            },
51855            "region": {
51856              "description": "Name of the region scoping this request.",
51857              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
51858              "location": "path",
51859              "required": true,
51860              "type": "string"
51861            },
51862            "requestId": {
51863              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
51864              "location": "query",
51865              "type": "string"
51866            },
51867            "validateOnly": {
51868              "description": "If true, the request will not be committed.",
51869              "location": "query",
51870              "type": "boolean"
51871            }
51872          },
51873          "parameterOrder": [
51874            "project",
51875            "region"
51876          ],
51877          "request": {
51878            "$ref": "SecurityPolicy"
51879          },
51880          "response": {
51881            "$ref": "Operation"
51882          },
51883          "scopes": [
51884            "https://www.googleapis.com/auth/cloud-platform",
51885            "https://www.googleapis.com/auth/compute"
51886          ],
51887          "description": "Creates a new policy in the specified project using the data included in the request."
51888        },
51889        "delete": {
51890          "id": "compute.regionSecurityPolicies.delete",
51891          "path": "projects/{project}/regions/{region}/securityPolicies/{securityPolicy}",
51892          "flatPath": "projects/{project}/regions/{region}/securityPolicies/{securityPolicy}",
51893          "httpMethod": "DELETE",
51894          "parameters": {
51895            "project": {
51896              "description": "Project ID for this request.",
51897              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51898              "location": "path",
51899              "required": true,
51900              "type": "string"
51901            },
51902            "region": {
51903              "description": "Name of the region scoping this request.",
51904              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
51905              "location": "path",
51906              "required": true,
51907              "type": "string"
51908            },
51909            "requestId": {
51910              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
51911              "location": "query",
51912              "type": "string"
51913            },
51914            "securityPolicy": {
51915              "description": "Name of the security policy to delete.",
51916              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
51917              "location": "path",
51918              "required": true,
51919              "type": "string"
51920            }
51921          },
51922          "parameterOrder": [
51923            "project",
51924            "region",
51925            "securityPolicy"
51926          ],
51927          "response": {
51928            "$ref": "Operation"
51929          },
51930          "scopes": [
51931            "https://www.googleapis.com/auth/cloud-platform",
51932            "https://www.googleapis.com/auth/compute"
51933          ],
51934          "description": "Deletes the specified policy."
51935        },
51936        "patch": {
51937          "id": "compute.regionSecurityPolicies.patch",
51938          "path": "projects/{project}/regions/{region}/securityPolicies/{securityPolicy}",
51939          "flatPath": "projects/{project}/regions/{region}/securityPolicies/{securityPolicy}",
51940          "httpMethod": "PATCH",
51941          "parameters": {
51942            "project": {
51943              "description": "Project ID for this request.",
51944              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
51945              "location": "path",
51946              "required": true,
51947              "type": "string"
51948            },
51949            "region": {
51950              "description": "Name of the region scoping this request.",
51951              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
51952              "location": "path",
51953              "required": true,
51954              "type": "string"
51955            },
51956            "requestId": {
51957              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
51958              "location": "query",
51959              "type": "string"
51960            },
51961            "securityPolicy": {
51962              "description": "Name of the security policy to update.",
51963              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
51964              "location": "path",
51965              "required": true,
51966              "type": "string"
51967            },
51968            "updateMask": {
51969              "description": "Indicates fields to be cleared as part of this request.",
51970              "location": "query",
51971              "type": "string",
51972              "format": "google-fieldmask"
51973            }
51974          },
51975          "parameterOrder": [
51976            "project",
51977            "region",
51978            "securityPolicy"
51979          ],
51980          "request": {
51981            "$ref": "SecurityPolicy"
51982          },
51983          "response": {
51984            "$ref": "Operation"
51985          },
51986          "scopes": [
51987            "https://www.googleapis.com/auth/cloud-platform",
51988            "https://www.googleapis.com/auth/compute"
51989          ],
51990          "description": "Patches the specified policy with the data included in the request. To clear fields in the policy, leave the fields empty and specify them in the updateMask. This cannot be used to be update the rules in the policy. Please use the per rule methods like addRule, patchRule, and removeRule instead."
51991        },
51992        "getRule": {
51993          "id": "compute.regionSecurityPolicies.getRule",
51994          "path": "projects/{project}/regions/{region}/securityPolicies/{securityPolicy}/getRule",
51995          "flatPath": "projects/{project}/regions/{region}/securityPolicies/{securityPolicy}/getRule",
51996          "httpMethod": "GET",
51997          "parameters": {
51998            "priority": {
51999              "description": "The priority of the rule to get from the security policy.",
52000              "location": "query",
52001              "type": "integer",
52002              "format": "int32"
52003            },
52004            "project": {
52005              "description": "Project ID for this request.",
52006              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52007              "location": "path",
52008              "required": true,
52009              "type": "string"
52010            },
52011            "region": {
52012              "description": "Name of the region scoping this request.",
52013              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52014              "location": "path",
52015              "required": true,
52016              "type": "string"
52017            },
52018            "securityPolicy": {
52019              "description": "Name of the security policy to which the queried rule belongs.",
52020              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
52021              "location": "path",
52022              "required": true,
52023              "type": "string"
52024            }
52025          },
52026          "parameterOrder": [
52027            "project",
52028            "region",
52029            "securityPolicy"
52030          ],
52031          "response": {
52032            "$ref": "SecurityPolicyRule"
52033          },
52034          "scopes": [
52035            "https://www.googleapis.com/auth/cloud-platform",
52036            "https://www.googleapis.com/auth/compute",
52037            "https://www.googleapis.com/auth/compute.readonly"
52038          ],
52039          "description": "Gets a rule at the specified priority."
52040        },
52041        "addRule": {
52042          "id": "compute.regionSecurityPolicies.addRule",
52043          "path": "projects/{project}/regions/{region}/securityPolicies/{securityPolicy}/addRule",
52044          "flatPath": "projects/{project}/regions/{region}/securityPolicies/{securityPolicy}/addRule",
52045          "httpMethod": "POST",
52046          "parameters": {
52047            "project": {
52048              "description": "Project ID for this request.",
52049              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52050              "location": "path",
52051              "required": true,
52052              "type": "string"
52053            },
52054            "region": {
52055              "description": "Name of the region scoping this request.",
52056              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52057              "location": "path",
52058              "required": true,
52059              "type": "string"
52060            },
52061            "securityPolicy": {
52062              "description": "Name of the security policy to update.",
52063              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
52064              "location": "path",
52065              "required": true,
52066              "type": "string"
52067            },
52068            "validateOnly": {
52069              "description": "If true, the request will not be committed.",
52070              "location": "query",
52071              "type": "boolean"
52072            }
52073          },
52074          "parameterOrder": [
52075            "project",
52076            "region",
52077            "securityPolicy"
52078          ],
52079          "request": {
52080            "$ref": "SecurityPolicyRule"
52081          },
52082          "response": {
52083            "$ref": "Operation"
52084          },
52085          "scopes": [
52086            "https://www.googleapis.com/auth/cloud-platform",
52087            "https://www.googleapis.com/auth/compute"
52088          ],
52089          "description": "Inserts a rule into a security policy."
52090        },
52091        "removeRule": {
52092          "id": "compute.regionSecurityPolicies.removeRule",
52093          "path": "projects/{project}/regions/{region}/securityPolicies/{securityPolicy}/removeRule",
52094          "flatPath": "projects/{project}/regions/{region}/securityPolicies/{securityPolicy}/removeRule",
52095          "httpMethod": "POST",
52096          "parameters": {
52097            "priority": {
52098              "description": "The priority of the rule to remove from the security policy.",
52099              "location": "query",
52100              "type": "integer",
52101              "format": "int32"
52102            },
52103            "project": {
52104              "description": "Project ID for this request.",
52105              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52106              "location": "path",
52107              "required": true,
52108              "type": "string"
52109            },
52110            "region": {
52111              "description": "Name of the region scoping this request.",
52112              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52113              "location": "path",
52114              "required": true,
52115              "type": "string"
52116            },
52117            "securityPolicy": {
52118              "description": "Name of the security policy to update.",
52119              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
52120              "location": "path",
52121              "required": true,
52122              "type": "string"
52123            }
52124          },
52125          "parameterOrder": [
52126            "project",
52127            "region",
52128            "securityPolicy"
52129          ],
52130          "response": {
52131            "$ref": "Operation"
52132          },
52133          "scopes": [
52134            "https://www.googleapis.com/auth/cloud-platform",
52135            "https://www.googleapis.com/auth/compute"
52136          ],
52137          "description": "Deletes a rule at the specified priority."
52138        },
52139        "patchRule": {
52140          "id": "compute.regionSecurityPolicies.patchRule",
52141          "path": "projects/{project}/regions/{region}/securityPolicies/{securityPolicy}/patchRule",
52142          "flatPath": "projects/{project}/regions/{region}/securityPolicies/{securityPolicy}/patchRule",
52143          "httpMethod": "POST",
52144          "parameters": {
52145            "priority": {
52146              "description": "The priority of the rule to patch.",
52147              "location": "query",
52148              "type": "integer",
52149              "format": "int32"
52150            },
52151            "project": {
52152              "description": "Project ID for this request.",
52153              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52154              "location": "path",
52155              "required": true,
52156              "type": "string"
52157            },
52158            "region": {
52159              "description": "Name of the region scoping this request.",
52160              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52161              "location": "path",
52162              "required": true,
52163              "type": "string"
52164            },
52165            "securityPolicy": {
52166              "description": "Name of the security policy to update.",
52167              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
52168              "location": "path",
52169              "required": true,
52170              "type": "string"
52171            },
52172            "updateMask": {
52173              "description": "Indicates fields to be cleared as part of this request.",
52174              "location": "query",
52175              "type": "string",
52176              "format": "google-fieldmask"
52177            },
52178            "validateOnly": {
52179              "description": "If true, the request will not be committed.",
52180              "location": "query",
52181              "type": "boolean"
52182            }
52183          },
52184          "parameterOrder": [
52185            "project",
52186            "region",
52187            "securityPolicy"
52188          ],
52189          "request": {
52190            "$ref": "SecurityPolicyRule"
52191          },
52192          "response": {
52193            "$ref": "Operation"
52194          },
52195          "scopes": [
52196            "https://www.googleapis.com/auth/cloud-platform",
52197            "https://www.googleapis.com/auth/compute"
52198          ],
52199          "description": "Patches a rule at the specified priority. To clear fields in the rule, leave the fields empty and specify them in the updateMask."
52200        }
52201      }
52202    },
52203    "instances": {
52204      "methods": {
52205        "list": {
52206          "id": "compute.instances.list",
52207          "path": "projects/{project}/zones/{zone}/instances",
52208          "flatPath": "projects/{project}/zones/{zone}/instances",
52209          "httpMethod": "GET",
52210          "parameters": {
52211            "filter": {
52212              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
52213              "location": "query",
52214              "type": "string"
52215            },
52216            "maxResults": {
52217              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
52218              "default": "500",
52219              "minimum": "0",
52220              "location": "query",
52221              "type": "integer",
52222              "format": "uint32"
52223            },
52224            "orderBy": {
52225              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
52226              "location": "query",
52227              "type": "string"
52228            },
52229            "pageToken": {
52230              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
52231              "location": "query",
52232              "type": "string"
52233            },
52234            "project": {
52235              "description": "Project ID for this request.",
52236              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52237              "location": "path",
52238              "required": true,
52239              "type": "string"
52240            },
52241            "returnPartialSuccess": {
52242              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
52243              "location": "query",
52244              "type": "boolean"
52245            },
52246            "zone": {
52247              "description": "The name of the zone for this request.",
52248              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52249              "location": "path",
52250              "required": true,
52251              "type": "string"
52252            }
52253          },
52254          "parameterOrder": [
52255            "project",
52256            "zone"
52257          ],
52258          "response": {
52259            "$ref": "InstanceList"
52260          },
52261          "scopes": [
52262            "https://www.googleapis.com/auth/cloud-platform",
52263            "https://www.googleapis.com/auth/compute",
52264            "https://www.googleapis.com/auth/compute.readonly"
52265          ],
52266          "description": "Retrieves the list of instances contained within the specified zone."
52267        },
52268        "aggregatedList": {
52269          "id": "compute.instances.aggregatedList",
52270          "path": "projects/{project}/aggregated/instances",
52271          "flatPath": "projects/{project}/aggregated/instances",
52272          "httpMethod": "GET",
52273          "parameters": {
52274            "filter": {
52275              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
52276              "location": "query",
52277              "type": "string"
52278            },
52279            "includeAllScopes": {
52280              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
52281              "location": "query",
52282              "type": "boolean"
52283            },
52284            "maxResults": {
52285              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
52286              "default": "500",
52287              "minimum": "0",
52288              "location": "query",
52289              "type": "integer",
52290              "format": "uint32"
52291            },
52292            "orderBy": {
52293              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
52294              "location": "query",
52295              "type": "string"
52296            },
52297            "pageToken": {
52298              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
52299              "location": "query",
52300              "type": "string"
52301            },
52302            "project": {
52303              "description": "Project ID for this request.",
52304              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52305              "location": "path",
52306              "required": true,
52307              "type": "string"
52308            },
52309            "returnPartialSuccess": {
52310              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
52311              "location": "query",
52312              "type": "boolean"
52313            },
52314            "serviceProjectNumber": {
52315              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
52316              "location": "query",
52317              "type": "string",
52318              "format": "int64"
52319            }
52320          },
52321          "parameterOrder": [
52322            "project"
52323          ],
52324          "response": {
52325            "$ref": "InstanceAggregatedList"
52326          },
52327          "scopes": [
52328            "https://www.googleapis.com/auth/cloud-platform",
52329            "https://www.googleapis.com/auth/compute",
52330            "https://www.googleapis.com/auth/compute.readonly"
52331          ],
52332          "description": "Retrieves an aggregated list of all of the instances in your project across all regions and zones. The performance of this method degrades when a filter is specified on a project that has a very large number of instances. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
52333        },
52334        "listReferrers": {
52335          "id": "compute.instances.listReferrers",
52336          "path": "projects/{project}/zones/{zone}/instances/{instance}/referrers",
52337          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/referrers",
52338          "httpMethod": "GET",
52339          "parameters": {
52340            "filter": {
52341              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
52342              "location": "query",
52343              "type": "string"
52344            },
52345            "instance": {
52346              "description": "Name of the target instance scoping this request, or '-' if the request should span over all instances in the container.",
52347              "pattern": "-|[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
52348              "location": "path",
52349              "required": true,
52350              "type": "string"
52351            },
52352            "maxResults": {
52353              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
52354              "default": "500",
52355              "minimum": "0",
52356              "location": "query",
52357              "type": "integer",
52358              "format": "uint32"
52359            },
52360            "orderBy": {
52361              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
52362              "location": "query",
52363              "type": "string"
52364            },
52365            "pageToken": {
52366              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
52367              "location": "query",
52368              "type": "string"
52369            },
52370            "project": {
52371              "description": "Project ID for this request.",
52372              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52373              "location": "path",
52374              "required": true,
52375              "type": "string"
52376            },
52377            "returnPartialSuccess": {
52378              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
52379              "location": "query",
52380              "type": "boolean"
52381            },
52382            "zone": {
52383              "description": "The name of the zone for this request.",
52384              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52385              "location": "path",
52386              "required": true,
52387              "type": "string"
52388            }
52389          },
52390          "parameterOrder": [
52391            "project",
52392            "zone",
52393            "instance"
52394          ],
52395          "response": {
52396            "$ref": "InstanceListReferrers"
52397          },
52398          "scopes": [
52399            "https://www.googleapis.com/auth/cloud-platform",
52400            "https://www.googleapis.com/auth/compute",
52401            "https://www.googleapis.com/auth/compute.readonly"
52402          ],
52403          "description": "Retrieves a list of resources that refer to the VM instance specified in the request. For example, if the VM instance is part of a managed or unmanaged instance group, the referrers list includes the instance group. For more information, read Viewing referrers to VM instances."
52404        },
52405        "get": {
52406          "id": "compute.instances.get",
52407          "path": "projects/{project}/zones/{zone}/instances/{instance}",
52408          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}",
52409          "httpMethod": "GET",
52410          "parameters": {
52411            "instance": {
52412              "description": "Name of the instance resource to return.",
52413              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
52414              "location": "path",
52415              "required": true,
52416              "type": "string"
52417            },
52418            "project": {
52419              "description": "Project ID for this request.",
52420              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52421              "location": "path",
52422              "required": true,
52423              "type": "string"
52424            },
52425            "zone": {
52426              "description": "The name of the zone for this request.",
52427              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52428              "location": "path",
52429              "required": true,
52430              "type": "string"
52431            }
52432          },
52433          "parameterOrder": [
52434            "project",
52435            "zone",
52436            "instance"
52437          ],
52438          "response": {
52439            "$ref": "Instance"
52440          },
52441          "scopes": [
52442            "https://www.googleapis.com/auth/cloud-platform",
52443            "https://www.googleapis.com/auth/compute",
52444            "https://www.googleapis.com/auth/compute.readonly"
52445          ],
52446          "description": "Returns the specified Instance resource."
52447        },
52448        "insert": {
52449          "id": "compute.instances.insert",
52450          "path": "projects/{project}/zones/{zone}/instances",
52451          "flatPath": "projects/{project}/zones/{zone}/instances",
52452          "httpMethod": "POST",
52453          "parameters": {
52454            "project": {
52455              "description": "Project ID for this request.",
52456              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52457              "location": "path",
52458              "required": true,
52459              "type": "string"
52460            },
52461            "requestId": {
52462              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
52463              "location": "query",
52464              "type": "string"
52465            },
52466            "sourceInstanceTemplate": {
52467              "description": "Specifies instance template to create the instance. This field is optional. It can be a full or partial URL. For example, the following are all valid URLs to an instance template: - https://www.googleapis.com/compute/v1/projects/project /global/instanceTemplates/instanceTemplate - projects/project/global/instanceTemplates/instanceTemplate - global/instanceTemplates/instanceTemplate ",
52468              "location": "query",
52469              "type": "string"
52470            },
52471            "sourceMachineImage": {
52472              "description": "Specifies the machine image to use to create the instance. This field is optional. It can be a full or partial URL. For example, the following are all valid URLs to a machine image: - https://www.googleapis.com/compute/v1/projects/project/global/global /machineImages/machineImage - projects/project/global/global/machineImages/machineImage - global/machineImages/machineImage ",
52473              "location": "query",
52474              "type": "string"
52475            },
52476            "zone": {
52477              "description": "The name of the zone for this request.",
52478              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52479              "location": "path",
52480              "required": true,
52481              "type": "string"
52482            }
52483          },
52484          "parameterOrder": [
52485            "project",
52486            "zone"
52487          ],
52488          "request": {
52489            "$ref": "Instance"
52490          },
52491          "response": {
52492            "$ref": "Operation"
52493          },
52494          "scopes": [
52495            "https://www.googleapis.com/auth/cloud-platform",
52496            "https://www.googleapis.com/auth/compute"
52497          ],
52498          "description": "Creates an instance resource in the specified project using the data included in the request."
52499        },
52500        "delete": {
52501          "id": "compute.instances.delete",
52502          "path": "projects/{project}/zones/{zone}/instances/{instance}",
52503          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}",
52504          "httpMethod": "DELETE",
52505          "parameters": {
52506            "instance": {
52507              "description": "Name of the instance resource to delete.",
52508              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
52509              "location": "path",
52510              "required": true,
52511              "type": "string"
52512            },
52513            "project": {
52514              "description": "Project ID for this request.",
52515              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52516              "location": "path",
52517              "required": true,
52518              "type": "string"
52519            },
52520            "requestId": {
52521              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
52522              "location": "query",
52523              "type": "string"
52524            },
52525            "zone": {
52526              "description": "The name of the zone for this request.",
52527              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52528              "location": "path",
52529              "required": true,
52530              "type": "string"
52531            }
52532          },
52533          "parameterOrder": [
52534            "project",
52535            "zone",
52536            "instance"
52537          ],
52538          "response": {
52539            "$ref": "Operation"
52540          },
52541          "scopes": [
52542            "https://www.googleapis.com/auth/cloud-platform",
52543            "https://www.googleapis.com/auth/compute"
52544          ],
52545          "description": "Deletes the specified Instance resource. For more information, see Deleting an instance."
52546        },
52547        "reset": {
52548          "id": "compute.instances.reset",
52549          "path": "projects/{project}/zones/{zone}/instances/{instance}/reset",
52550          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/reset",
52551          "httpMethod": "POST",
52552          "parameters": {
52553            "instance": {
52554              "description": "Name of the instance scoping this request.",
52555              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
52556              "location": "path",
52557              "required": true,
52558              "type": "string"
52559            },
52560            "project": {
52561              "description": "Project ID for this request.",
52562              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52563              "location": "path",
52564              "required": true,
52565              "type": "string"
52566            },
52567            "requestId": {
52568              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
52569              "location": "query",
52570              "type": "string"
52571            },
52572            "zone": {
52573              "description": "The name of the zone for this request.",
52574              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52575              "location": "path",
52576              "required": true,
52577              "type": "string"
52578            }
52579          },
52580          "parameterOrder": [
52581            "project",
52582            "zone",
52583            "instance"
52584          ],
52585          "response": {
52586            "$ref": "Operation"
52587          },
52588          "scopes": [
52589            "https://www.googleapis.com/auth/cloud-platform",
52590            "https://www.googleapis.com/auth/compute"
52591          ],
52592          "description": "Performs a reset on the instance. This is a hard reset. The VM does not do a graceful shutdown. For more information, see Resetting an instance."
52593        },
52594        "simulateMaintenanceEvent": {
52595          "id": "compute.instances.simulateMaintenanceEvent",
52596          "path": "projects/{project}/zones/{zone}/instances/{instance}/simulateMaintenanceEvent",
52597          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/simulateMaintenanceEvent",
52598          "httpMethod": "POST",
52599          "parameters": {
52600            "instance": {
52601              "description": "Name of the instance scoping this request.",
52602              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
52603              "location": "path",
52604              "required": true,
52605              "type": "string"
52606            },
52607            "project": {
52608              "description": "Project ID for this request.",
52609              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52610              "location": "path",
52611              "required": true,
52612              "type": "string"
52613            },
52614            "requestId": {
52615              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
52616              "location": "query",
52617              "type": "string"
52618            },
52619            "withExtendedNotifications": {
52620              "description": "Determines whether the customers receive notifications before migration. Only applicable to SF vms.",
52621              "location": "query",
52622              "type": "boolean"
52623            },
52624            "zone": {
52625              "description": "The name of the zone for this request.",
52626              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52627              "location": "path",
52628              "required": true,
52629              "type": "string"
52630            }
52631          },
52632          "parameterOrder": [
52633            "project",
52634            "zone",
52635            "instance"
52636          ],
52637          "response": {
52638            "$ref": "Operation"
52639          },
52640          "scopes": [
52641            "https://www.googleapis.com/auth/cloud-platform",
52642            "https://www.googleapis.com/auth/compute"
52643          ],
52644          "description": "Simulates a host maintenance event on a VM. For more information, see Simulate a host maintenance event."
52645        },
52646        "performMaintenance": {
52647          "id": "compute.instances.performMaintenance",
52648          "path": "projects/{project}/zones/{zone}/instances/{instance}/performMaintenance",
52649          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/performMaintenance",
52650          "httpMethod": "POST",
52651          "parameters": {
52652            "instance": {
52653              "description": "Name of the instance scoping this request.",
52654              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
52655              "location": "path",
52656              "required": true,
52657              "type": "string"
52658            },
52659            "project": {
52660              "description": "Project ID for this request.",
52661              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52662              "location": "path",
52663              "required": true,
52664              "type": "string"
52665            },
52666            "requestId": {
52667              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
52668              "location": "query",
52669              "type": "string"
52670            },
52671            "zone": {
52672              "description": "The name of the zone for this request.",
52673              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52674              "location": "path",
52675              "required": true,
52676              "type": "string"
52677            }
52678          },
52679          "parameterOrder": [
52680            "project",
52681            "zone",
52682            "instance"
52683          ],
52684          "response": {
52685            "$ref": "Operation"
52686          },
52687          "scopes": [
52688            "https://www.googleapis.com/auth/cloud-platform",
52689            "https://www.googleapis.com/auth/compute"
52690          ],
52691          "description": "Perform a manual maintenance on the instance."
52692        },
52693        "addAccessConfig": {
52694          "id": "compute.instances.addAccessConfig",
52695          "path": "projects/{project}/zones/{zone}/instances/{instance}/addAccessConfig",
52696          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/addAccessConfig",
52697          "httpMethod": "POST",
52698          "parameters": {
52699            "instance": {
52700              "description": "The instance name for this request.",
52701              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
52702              "location": "path",
52703              "required": true,
52704              "type": "string"
52705            },
52706            "networkInterface": {
52707              "description": "The name of the network interface to add to this instance.",
52708              "location": "query",
52709              "required": true,
52710              "type": "string"
52711            },
52712            "project": {
52713              "description": "Project ID for this request.",
52714              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52715              "location": "path",
52716              "required": true,
52717              "type": "string"
52718            },
52719            "requestId": {
52720              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
52721              "location": "query",
52722              "type": "string"
52723            },
52724            "zone": {
52725              "description": "The name of the zone for this request.",
52726              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52727              "location": "path",
52728              "required": true,
52729              "type": "string"
52730            }
52731          },
52732          "parameterOrder": [
52733            "project",
52734            "zone",
52735            "instance",
52736            "networkInterface"
52737          ],
52738          "request": {
52739            "$ref": "AccessConfig"
52740          },
52741          "response": {
52742            "$ref": "Operation"
52743          },
52744          "scopes": [
52745            "https://www.googleapis.com/auth/cloud-platform",
52746            "https://www.googleapis.com/auth/compute"
52747          ],
52748          "description": "Adds an access config to an instance's network interface."
52749        },
52750        "deleteAccessConfig": {
52751          "id": "compute.instances.deleteAccessConfig",
52752          "path": "projects/{project}/zones/{zone}/instances/{instance}/deleteAccessConfig",
52753          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/deleteAccessConfig",
52754          "httpMethod": "POST",
52755          "parameters": {
52756            "accessConfig": {
52757              "description": "The name of the access config to delete.",
52758              "location": "query",
52759              "required": true,
52760              "type": "string"
52761            },
52762            "instance": {
52763              "description": "The instance name for this request.",
52764              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
52765              "location": "path",
52766              "required": true,
52767              "type": "string"
52768            },
52769            "networkInterface": {
52770              "description": "The name of the network interface.",
52771              "location": "query",
52772              "required": true,
52773              "type": "string"
52774            },
52775            "project": {
52776              "description": "Project ID for this request.",
52777              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52778              "location": "path",
52779              "required": true,
52780              "type": "string"
52781            },
52782            "requestId": {
52783              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
52784              "location": "query",
52785              "type": "string"
52786            },
52787            "zone": {
52788              "description": "The name of the zone for this request.",
52789              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52790              "location": "path",
52791              "required": true,
52792              "type": "string"
52793            }
52794          },
52795          "parameterOrder": [
52796            "project",
52797            "zone",
52798            "instance",
52799            "accessConfig",
52800            "networkInterface"
52801          ],
52802          "response": {
52803            "$ref": "Operation"
52804          },
52805          "scopes": [
52806            "https://www.googleapis.com/auth/cloud-platform",
52807            "https://www.googleapis.com/auth/compute"
52808          ],
52809          "description": "Deletes an access config from an instance's network interface."
52810        },
52811        "updateAccessConfig": {
52812          "id": "compute.instances.updateAccessConfig",
52813          "path": "projects/{project}/zones/{zone}/instances/{instance}/updateAccessConfig",
52814          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/updateAccessConfig",
52815          "httpMethod": "POST",
52816          "parameters": {
52817            "instance": {
52818              "description": "The instance name for this request.",
52819              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
52820              "location": "path",
52821              "required": true,
52822              "type": "string"
52823            },
52824            "networkInterface": {
52825              "description": "The name of the network interface where the access config is attached.",
52826              "location": "query",
52827              "required": true,
52828              "type": "string"
52829            },
52830            "project": {
52831              "description": "Project ID for this request.",
52832              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52833              "location": "path",
52834              "required": true,
52835              "type": "string"
52836            },
52837            "requestId": {
52838              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
52839              "location": "query",
52840              "type": "string"
52841            },
52842            "zone": {
52843              "description": "The name of the zone for this request.",
52844              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52845              "location": "path",
52846              "required": true,
52847              "type": "string"
52848            }
52849          },
52850          "parameterOrder": [
52851            "project",
52852            "zone",
52853            "instance",
52854            "networkInterface"
52855          ],
52856          "request": {
52857            "$ref": "AccessConfig"
52858          },
52859          "response": {
52860            "$ref": "Operation"
52861          },
52862          "scopes": [
52863            "https://www.googleapis.com/auth/cloud-platform",
52864            "https://www.googleapis.com/auth/compute"
52865          ],
52866          "description": "Updates the specified access config from an instance's network interface with the data included in the request. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
52867        },
52868        "updateNetworkInterface": {
52869          "id": "compute.instances.updateNetworkInterface",
52870          "path": "projects/{project}/zones/{zone}/instances/{instance}/updateNetworkInterface",
52871          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/updateNetworkInterface",
52872          "httpMethod": "PATCH",
52873          "parameters": {
52874            "instance": {
52875              "description": "The instance name for this request.",
52876              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
52877              "location": "path",
52878              "required": true,
52879              "type": "string"
52880            },
52881            "networkInterface": {
52882              "description": "The name of the network interface to update.",
52883              "location": "query",
52884              "required": true,
52885              "type": "string"
52886            },
52887            "project": {
52888              "description": "Project ID for this request.",
52889              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52890              "location": "path",
52891              "required": true,
52892              "type": "string"
52893            },
52894            "requestId": {
52895              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
52896              "location": "query",
52897              "type": "string"
52898            },
52899            "zone": {
52900              "description": "The name of the zone for this request.",
52901              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52902              "location": "path",
52903              "required": true,
52904              "type": "string"
52905            }
52906          },
52907          "parameterOrder": [
52908            "project",
52909            "zone",
52910            "instance",
52911            "networkInterface"
52912          ],
52913          "request": {
52914            "$ref": "NetworkInterface"
52915          },
52916          "response": {
52917            "$ref": "Operation"
52918          },
52919          "scopes": [
52920            "https://www.googleapis.com/auth/cloud-platform",
52921            "https://www.googleapis.com/auth/compute"
52922          ],
52923          "description": "Updates an instance's network interface. This method can only update an interface's alias IP range and attached network. See Modifying alias IP ranges for an existing instance for instructions on changing alias IP ranges. See Migrating a VM between networks for instructions on migrating an interface. This method follows PATCH semantics."
52924        },
52925        "setScheduling": {
52926          "id": "compute.instances.setScheduling",
52927          "path": "projects/{project}/zones/{zone}/instances/{instance}/setScheduling",
52928          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/setScheduling",
52929          "httpMethod": "POST",
52930          "parameters": {
52931            "instance": {
52932              "description": "Instance name for this request.",
52933              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
52934              "location": "path",
52935              "required": true,
52936              "type": "string"
52937            },
52938            "project": {
52939              "description": "Project ID for this request.",
52940              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
52941              "location": "path",
52942              "required": true,
52943              "type": "string"
52944            },
52945            "requestId": {
52946              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
52947              "location": "query",
52948              "type": "string"
52949            },
52950            "zone": {
52951              "description": "The name of the zone for this request.",
52952              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
52953              "location": "path",
52954              "required": true,
52955              "type": "string"
52956            }
52957          },
52958          "parameterOrder": [
52959            "project",
52960            "zone",
52961            "instance"
52962          ],
52963          "request": {
52964            "$ref": "Scheduling"
52965          },
52966          "response": {
52967            "$ref": "Operation"
52968          },
52969          "scopes": [
52970            "https://www.googleapis.com/auth/cloud-platform",
52971            "https://www.googleapis.com/auth/compute"
52972          ],
52973          "description": "Sets an instance's scheduling options. You can only call this method on a stopped instance, that is, a VM instance that is in a `TERMINATED` state. See Instance Life Cycle for more information on the possible instance states. For more information about setting scheduling options for a VM, see Set VM host maintenance policy."
52974        },
52975        "getSerialPortOutput": {
52976          "id": "compute.instances.getSerialPortOutput",
52977          "path": "projects/{project}/zones/{zone}/instances/{instance}/serialPort",
52978          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/serialPort",
52979          "httpMethod": "GET",
52980          "parameters": {
52981            "instance": {
52982              "description": "Name of the instance for this request.",
52983              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
52984              "location": "path",
52985              "required": true,
52986              "type": "string"
52987            },
52988            "port": {
52989              "description": "Specifies which COM or serial port to retrieve data from.",
52990              "default": "1",
52991              "minimum": "1",
52992              "maximum": "4",
52993              "location": "query",
52994              "type": "integer",
52995              "format": "int32"
52996            },
52997            "project": {
52998              "description": "Project ID for this request.",
52999              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53000              "location": "path",
53001              "required": true,
53002              "type": "string"
53003            },
53004            "start": {
53005              "description": "Specifies the starting byte position of the output to return. To start with the first byte of output to the specified port, omit this field or set it to `0`. If the output for that byte position is available, this field matches the `start` parameter sent with the request. If the amount of serial console output exceeds the size of the buffer (1 MB), the oldest output is discarded and is no longer available. If the requested start position refers to discarded output, the start position is adjusted to the oldest output still available, and the adjusted start position is returned as the `start` property value. You can also provide a negative start position, which translates to the most recent number of bytes written to the serial port. For example, -3 is interpreted as the most recent 3 bytes written to the serial console.",
53006              "location": "query",
53007              "type": "string",
53008              "format": "int64"
53009            },
53010            "zone": {
53011              "description": "The name of the zone for this request.",
53012              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53013              "location": "path",
53014              "required": true,
53015              "type": "string"
53016            }
53017          },
53018          "parameterOrder": [
53019            "project",
53020            "zone",
53021            "instance"
53022          ],
53023          "response": {
53024            "$ref": "SerialPortOutput"
53025          },
53026          "scopes": [
53027            "https://www.googleapis.com/auth/cloud-platform",
53028            "https://www.googleapis.com/auth/compute",
53029            "https://www.googleapis.com/auth/compute.readonly"
53030          ],
53031          "description": "Returns the last 1 MB of serial port output from the specified instance."
53032        },
53033        "getScreenshot": {
53034          "id": "compute.instances.getScreenshot",
53035          "path": "projects/{project}/zones/{zone}/instances/{instance}/screenshot",
53036          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/screenshot",
53037          "httpMethod": "GET",
53038          "parameters": {
53039            "instance": {
53040              "description": "Name of the instance scoping this request.",
53041              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53042              "location": "path",
53043              "required": true,
53044              "type": "string"
53045            },
53046            "project": {
53047              "description": "Project ID for this request.",
53048              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53049              "location": "path",
53050              "required": true,
53051              "type": "string"
53052            },
53053            "zone": {
53054              "description": "The name of the zone for this request.",
53055              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53056              "location": "path",
53057              "required": true,
53058              "type": "string"
53059            }
53060          },
53061          "parameterOrder": [
53062            "project",
53063            "zone",
53064            "instance"
53065          ],
53066          "response": {
53067            "$ref": "Screenshot"
53068          },
53069          "scopes": [
53070            "https://www.googleapis.com/auth/cloud-platform",
53071            "https://www.googleapis.com/auth/compute",
53072            "https://www.googleapis.com/auth/compute.readonly"
53073          ],
53074          "description": "Returns the screenshot from the specified instance."
53075        },
53076        "sendDiagnosticInterrupt": {
53077          "id": "compute.instances.sendDiagnosticInterrupt",
53078          "path": "projects/{project}/zones/{zone}/instances/{instance}/sendDiagnosticInterrupt",
53079          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/sendDiagnosticInterrupt",
53080          "httpMethod": "POST",
53081          "parameters": {
53082            "instance": {
53083              "description": "Name of the instance scoping this request.",
53084              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53085              "location": "path",
53086              "required": true,
53087              "type": "string"
53088            },
53089            "project": {
53090              "description": "Project ID for this request.",
53091              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53092              "location": "path",
53093              "required": true,
53094              "type": "string"
53095            },
53096            "zone": {
53097              "description": "The name of the zone for this request.",
53098              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53099              "location": "path",
53100              "required": true,
53101              "type": "string"
53102            }
53103          },
53104          "parameterOrder": [
53105            "project",
53106            "zone",
53107            "instance"
53108          ],
53109          "scopes": [
53110            "https://www.googleapis.com/auth/cloud-platform",
53111            "https://www.googleapis.com/auth/compute"
53112          ],
53113          "description": "Sends diagnostic interrupt to the instance."
53114        },
53115        "getGuestAttributes": {
53116          "id": "compute.instances.getGuestAttributes",
53117          "path": "projects/{project}/zones/{zone}/instances/{instance}/getGuestAttributes",
53118          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/getGuestAttributes",
53119          "httpMethod": "GET",
53120          "parameters": {
53121            "instance": {
53122              "description": "Name of the instance scoping this request.",
53123              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53124              "location": "path",
53125              "required": true,
53126              "type": "string"
53127            },
53128            "project": {
53129              "description": "Project ID for this request.",
53130              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53131              "location": "path",
53132              "required": true,
53133              "type": "string"
53134            },
53135            "queryPath": {
53136              "description": "Specifies the guest attributes path to be queried.",
53137              "location": "query",
53138              "type": "string"
53139            },
53140            "variableKey": {
53141              "description": "Specifies the key for the guest attributes entry.",
53142              "location": "query",
53143              "type": "string"
53144            },
53145            "zone": {
53146              "description": "The name of the zone for this request.",
53147              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53148              "location": "path",
53149              "required": true,
53150              "type": "string"
53151            }
53152          },
53153          "parameterOrder": [
53154            "project",
53155            "zone",
53156            "instance"
53157          ],
53158          "response": {
53159            "$ref": "GuestAttributes"
53160          },
53161          "scopes": [
53162            "https://www.googleapis.com/auth/cloud-platform",
53163            "https://www.googleapis.com/auth/compute",
53164            "https://www.googleapis.com/auth/compute.readonly"
53165          ],
53166          "description": "Returns the specified guest attributes entry."
53167        },
53168        "attachDisk": {
53169          "id": "compute.instances.attachDisk",
53170          "path": "projects/{project}/zones/{zone}/instances/{instance}/attachDisk",
53171          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/attachDisk",
53172          "httpMethod": "POST",
53173          "parameters": {
53174            "forceAttach": {
53175              "description": "Whether to force attach the regional disk even if it's currently attached to another instance. If you try to force attach a zonal disk to an instance, you will receive an error.",
53176              "location": "query",
53177              "type": "boolean"
53178            },
53179            "instance": {
53180              "description": "The instance name for this request.",
53181              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53182              "location": "path",
53183              "required": true,
53184              "type": "string"
53185            },
53186            "project": {
53187              "description": "Project ID for this request.",
53188              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53189              "location": "path",
53190              "required": true,
53191              "type": "string"
53192            },
53193            "requestId": {
53194              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
53195              "location": "query",
53196              "type": "string"
53197            },
53198            "zone": {
53199              "description": "The name of the zone for this request.",
53200              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53201              "location": "path",
53202              "required": true,
53203              "type": "string"
53204            }
53205          },
53206          "parameterOrder": [
53207            "project",
53208            "zone",
53209            "instance"
53210          ],
53211          "request": {
53212            "$ref": "AttachedDisk"
53213          },
53214          "response": {
53215            "$ref": "Operation"
53216          },
53217          "scopes": [
53218            "https://www.googleapis.com/auth/cloud-platform",
53219            "https://www.googleapis.com/auth/compute"
53220          ],
53221          "description": "Attaches an existing Disk resource to an instance. You must first create the disk before you can attach it. It is not possible to create and attach a disk at the same time. For more information, read Adding a persistent disk to your instance."
53222        },
53223        "detachDisk": {
53224          "id": "compute.instances.detachDisk",
53225          "path": "projects/{project}/zones/{zone}/instances/{instance}/detachDisk",
53226          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/detachDisk",
53227          "httpMethod": "POST",
53228          "parameters": {
53229            "deviceName": {
53230              "description": "The device name of the disk to detach. Make a get() request on the instance to view currently attached disks and device names.",
53231              "location": "query",
53232              "required": true,
53233              "type": "string"
53234            },
53235            "instance": {
53236              "description": "Instance name for this request.",
53237              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53238              "location": "path",
53239              "required": true,
53240              "type": "string"
53241            },
53242            "project": {
53243              "description": "Project ID for this request.",
53244              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53245              "location": "path",
53246              "required": true,
53247              "type": "string"
53248            },
53249            "requestId": {
53250              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
53251              "location": "query",
53252              "type": "string"
53253            },
53254            "zone": {
53255              "description": "The name of the zone for this request.",
53256              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53257              "location": "path",
53258              "required": true,
53259              "type": "string"
53260            }
53261          },
53262          "parameterOrder": [
53263            "project",
53264            "zone",
53265            "instance",
53266            "deviceName"
53267          ],
53268          "response": {
53269            "$ref": "Operation"
53270          },
53271          "scopes": [
53272            "https://www.googleapis.com/auth/cloud-platform",
53273            "https://www.googleapis.com/auth/compute"
53274          ],
53275          "description": "Detaches a disk from an instance."
53276        },
53277        "setMachineResources": {
53278          "id": "compute.instances.setMachineResources",
53279          "path": "projects/{project}/zones/{zone}/instances/{instance}/setMachineResources",
53280          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/setMachineResources",
53281          "httpMethod": "POST",
53282          "parameters": {
53283            "instance": {
53284              "description": "Name of the instance scoping this request.",
53285              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53286              "location": "path",
53287              "required": true,
53288              "type": "string"
53289            },
53290            "project": {
53291              "description": "Project ID for this request.",
53292              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53293              "location": "path",
53294              "required": true,
53295              "type": "string"
53296            },
53297            "requestId": {
53298              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
53299              "location": "query",
53300              "type": "string"
53301            },
53302            "zone": {
53303              "description": "The name of the zone for this request.",
53304              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53305              "location": "path",
53306              "required": true,
53307              "type": "string"
53308            }
53309          },
53310          "parameterOrder": [
53311            "project",
53312            "zone",
53313            "instance"
53314          ],
53315          "request": {
53316            "$ref": "InstancesSetMachineResourcesRequest"
53317          },
53318          "response": {
53319            "$ref": "Operation"
53320          },
53321          "scopes": [
53322            "https://www.googleapis.com/auth/cloud-platform",
53323            "https://www.googleapis.com/auth/compute"
53324          ],
53325          "description": "Changes the number and/or type of accelerator for a stopped instance to the values specified in the request."
53326        },
53327        "setMachineType": {
53328          "id": "compute.instances.setMachineType",
53329          "path": "projects/{project}/zones/{zone}/instances/{instance}/setMachineType",
53330          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/setMachineType",
53331          "httpMethod": "POST",
53332          "parameters": {
53333            "instance": {
53334              "description": "Name of the instance scoping this request.",
53335              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53336              "location": "path",
53337              "required": true,
53338              "type": "string"
53339            },
53340            "project": {
53341              "description": "Project ID for this request.",
53342              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53343              "location": "path",
53344              "required": true,
53345              "type": "string"
53346            },
53347            "requestId": {
53348              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
53349              "location": "query",
53350              "type": "string"
53351            },
53352            "zone": {
53353              "description": "The name of the zone for this request.",
53354              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53355              "location": "path",
53356              "required": true,
53357              "type": "string"
53358            }
53359          },
53360          "parameterOrder": [
53361            "project",
53362            "zone",
53363            "instance"
53364          ],
53365          "request": {
53366            "$ref": "InstancesSetMachineTypeRequest"
53367          },
53368          "response": {
53369            "$ref": "Operation"
53370          },
53371          "scopes": [
53372            "https://www.googleapis.com/auth/cloud-platform",
53373            "https://www.googleapis.com/auth/compute"
53374          ],
53375          "description": "Changes the machine type for a stopped instance to the machine type specified in the request."
53376        },
53377        "setMetadata": {
53378          "id": "compute.instances.setMetadata",
53379          "path": "projects/{project}/zones/{zone}/instances/{instance}/setMetadata",
53380          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/setMetadata",
53381          "httpMethod": "POST",
53382          "parameters": {
53383            "instance": {
53384              "description": "Name of the instance scoping this request.",
53385              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53386              "location": "path",
53387              "required": true,
53388              "type": "string"
53389            },
53390            "project": {
53391              "description": "Project ID for this request.",
53392              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53393              "location": "path",
53394              "required": true,
53395              "type": "string"
53396            },
53397            "requestId": {
53398              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
53399              "location": "query",
53400              "type": "string"
53401            },
53402            "zone": {
53403              "description": "The name of the zone for this request.",
53404              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53405              "location": "path",
53406              "required": true,
53407              "type": "string"
53408            }
53409          },
53410          "parameterOrder": [
53411            "project",
53412            "zone",
53413            "instance"
53414          ],
53415          "request": {
53416            "$ref": "Metadata"
53417          },
53418          "response": {
53419            "$ref": "Operation"
53420          },
53421          "scopes": [
53422            "https://www.googleapis.com/auth/cloud-platform",
53423            "https://www.googleapis.com/auth/compute"
53424          ],
53425          "description": "Sets metadata for the specified instance to the data included in the request."
53426        },
53427        "setMinCpuPlatform": {
53428          "id": "compute.instances.setMinCpuPlatform",
53429          "path": "projects/{project}/zones/{zone}/instances/{instance}/setMinCpuPlatform",
53430          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/setMinCpuPlatform",
53431          "httpMethod": "POST",
53432          "parameters": {
53433            "instance": {
53434              "description": "Name of the instance scoping this request.",
53435              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53436              "location": "path",
53437              "required": true,
53438              "type": "string"
53439            },
53440            "project": {
53441              "description": "Project ID for this request.",
53442              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53443              "location": "path",
53444              "required": true,
53445              "type": "string"
53446            },
53447            "requestId": {
53448              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
53449              "location": "query",
53450              "type": "string"
53451            },
53452            "zone": {
53453              "description": "The name of the zone for this request.",
53454              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53455              "location": "path",
53456              "required": true,
53457              "type": "string"
53458            }
53459          },
53460          "parameterOrder": [
53461            "project",
53462            "zone",
53463            "instance"
53464          ],
53465          "request": {
53466            "$ref": "InstancesSetMinCpuPlatformRequest"
53467          },
53468          "response": {
53469            "$ref": "Operation"
53470          },
53471          "scopes": [
53472            "https://www.googleapis.com/auth/cloud-platform",
53473            "https://www.googleapis.com/auth/compute"
53474          ],
53475          "description": "Changes the minimum CPU platform that this instance should use. This method can only be called on a stopped instance. For more information, read Specifying a Minimum CPU Platform."
53476        },
53477        "setTags": {
53478          "id": "compute.instances.setTags",
53479          "path": "projects/{project}/zones/{zone}/instances/{instance}/setTags",
53480          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/setTags",
53481          "httpMethod": "POST",
53482          "parameters": {
53483            "instance": {
53484              "description": "Name of the instance scoping this request.",
53485              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53486              "location": "path",
53487              "required": true,
53488              "type": "string"
53489            },
53490            "project": {
53491              "description": "Project ID for this request.",
53492              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53493              "location": "path",
53494              "required": true,
53495              "type": "string"
53496            },
53497            "requestId": {
53498              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
53499              "location": "query",
53500              "type": "string"
53501            },
53502            "zone": {
53503              "description": "The name of the zone for this request.",
53504              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53505              "location": "path",
53506              "required": true,
53507              "type": "string"
53508            }
53509          },
53510          "parameterOrder": [
53511            "project",
53512            "zone",
53513            "instance"
53514          ],
53515          "request": {
53516            "$ref": "Tags"
53517          },
53518          "response": {
53519            "$ref": "Operation"
53520          },
53521          "scopes": [
53522            "https://www.googleapis.com/auth/cloud-platform",
53523            "https://www.googleapis.com/auth/compute"
53524          ],
53525          "description": "Sets network tags for the specified instance to the data included in the request."
53526        },
53527        "setLabels": {
53528          "id": "compute.instances.setLabels",
53529          "path": "projects/{project}/zones/{zone}/instances/{instance}/setLabels",
53530          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/setLabels",
53531          "httpMethod": "POST",
53532          "parameters": {
53533            "instance": {
53534              "description": "Name of the instance scoping this request.",
53535              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53536              "location": "path",
53537              "required": true,
53538              "type": "string"
53539            },
53540            "project": {
53541              "description": "Project ID for this request.",
53542              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53543              "location": "path",
53544              "required": true,
53545              "type": "string"
53546            },
53547            "requestId": {
53548              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
53549              "location": "query",
53550              "type": "string"
53551            },
53552            "zone": {
53553              "description": "The name of the zone for this request.",
53554              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53555              "location": "path",
53556              "required": true,
53557              "type": "string"
53558            }
53559          },
53560          "parameterOrder": [
53561            "project",
53562            "zone",
53563            "instance"
53564          ],
53565          "request": {
53566            "$ref": "InstancesSetLabelsRequest"
53567          },
53568          "response": {
53569            "$ref": "Operation"
53570          },
53571          "scopes": [
53572            "https://www.googleapis.com/auth/cloud-platform",
53573            "https://www.googleapis.com/auth/compute"
53574          ],
53575          "description": "Sets labels on an instance. To learn more about labels, read the Labeling Resources documentation."
53576        },
53577        "setName": {
53578          "id": "compute.instances.setName",
53579          "path": "projects/{project}/zones/{zone}/instances/{instance}/setName",
53580          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/setName",
53581          "httpMethod": "POST",
53582          "parameters": {
53583            "instance": {
53584              "description": "The instance name for this request.",
53585              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53586              "location": "path",
53587              "required": true,
53588              "type": "string"
53589            },
53590            "project": {
53591              "description": "Project ID for this request.",
53592              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53593              "location": "path",
53594              "required": true,
53595              "type": "string"
53596            },
53597            "requestId": {
53598              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
53599              "location": "query",
53600              "type": "string"
53601            },
53602            "zone": {
53603              "description": "The name of the zone for this request.",
53604              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53605              "location": "path",
53606              "required": true,
53607              "type": "string"
53608            }
53609          },
53610          "parameterOrder": [
53611            "project",
53612            "zone",
53613            "instance"
53614          ],
53615          "request": {
53616            "$ref": "InstancesSetNameRequest"
53617          },
53618          "response": {
53619            "$ref": "Operation"
53620          },
53621          "scopes": [
53622            "https://www.googleapis.com/auth/cloud-platform",
53623            "https://www.googleapis.com/auth/compute"
53624          ],
53625          "description": "Sets name of an instance."
53626        },
53627        "setDiskAutoDelete": {
53628          "id": "compute.instances.setDiskAutoDelete",
53629          "path": "projects/{project}/zones/{zone}/instances/{instance}/setDiskAutoDelete",
53630          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/setDiskAutoDelete",
53631          "httpMethod": "POST",
53632          "parameters": {
53633            "autoDelete": {
53634              "description": "Whether to auto-delete the disk when the instance is deleted.",
53635              "location": "query",
53636              "required": true,
53637              "type": "boolean"
53638            },
53639            "deviceName": {
53640              "description": "The device name of the disk to modify. Make a get() request on the instance to view currently attached disks and device names.",
53641              "pattern": "\\w[\\w.-]{0,254}",
53642              "location": "query",
53643              "required": true,
53644              "type": "string"
53645            },
53646            "instance": {
53647              "description": "The instance name for this request.",
53648              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53649              "location": "path",
53650              "required": true,
53651              "type": "string"
53652            },
53653            "project": {
53654              "description": "Project ID for this request.",
53655              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53656              "location": "path",
53657              "required": true,
53658              "type": "string"
53659            },
53660            "requestId": {
53661              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
53662              "location": "query",
53663              "type": "string"
53664            },
53665            "zone": {
53666              "description": "The name of the zone for this request.",
53667              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53668              "location": "path",
53669              "required": true,
53670              "type": "string"
53671            }
53672          },
53673          "parameterOrder": [
53674            "project",
53675            "zone",
53676            "instance",
53677            "autoDelete",
53678            "deviceName"
53679          ],
53680          "response": {
53681            "$ref": "Operation"
53682          },
53683          "scopes": [
53684            "https://www.googleapis.com/auth/cloud-platform",
53685            "https://www.googleapis.com/auth/compute"
53686          ],
53687          "description": "Sets the auto-delete flag for a disk attached to an instance."
53688        },
53689        "start": {
53690          "id": "compute.instances.start",
53691          "path": "projects/{project}/zones/{zone}/instances/{instance}/start",
53692          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/start",
53693          "httpMethod": "POST",
53694          "parameters": {
53695            "instance": {
53696              "description": "Name of the instance resource to start.",
53697              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53698              "location": "path",
53699              "required": true,
53700              "type": "string"
53701            },
53702            "project": {
53703              "description": "Project ID for this request.",
53704              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53705              "location": "path",
53706              "required": true,
53707              "type": "string"
53708            },
53709            "requestId": {
53710              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
53711              "location": "query",
53712              "type": "string"
53713            },
53714            "zone": {
53715              "description": "The name of the zone for this request.",
53716              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53717              "location": "path",
53718              "required": true,
53719              "type": "string"
53720            }
53721          },
53722          "parameterOrder": [
53723            "project",
53724            "zone",
53725            "instance"
53726          ],
53727          "response": {
53728            "$ref": "Operation"
53729          },
53730          "scopes": [
53731            "https://www.googleapis.com/auth/cloud-platform",
53732            "https://www.googleapis.com/auth/compute"
53733          ],
53734          "description": "Starts an instance that was stopped using the instances().stop method. For more information, see Restart an instance."
53735        },
53736        "startWithEncryptionKey": {
53737          "id": "compute.instances.startWithEncryptionKey",
53738          "path": "projects/{project}/zones/{zone}/instances/{instance}/startWithEncryptionKey",
53739          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/startWithEncryptionKey",
53740          "httpMethod": "POST",
53741          "parameters": {
53742            "instance": {
53743              "description": "Name of the instance resource to start.",
53744              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53745              "location": "path",
53746              "required": true,
53747              "type": "string"
53748            },
53749            "project": {
53750              "description": "Project ID for this request.",
53751              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53752              "location": "path",
53753              "required": true,
53754              "type": "string"
53755            },
53756            "requestId": {
53757              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
53758              "location": "query",
53759              "type": "string"
53760            },
53761            "zone": {
53762              "description": "The name of the zone for this request.",
53763              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53764              "location": "path",
53765              "required": true,
53766              "type": "string"
53767            }
53768          },
53769          "parameterOrder": [
53770            "project",
53771            "zone",
53772            "instance"
53773          ],
53774          "request": {
53775            "$ref": "InstancesStartWithEncryptionKeyRequest"
53776          },
53777          "response": {
53778            "$ref": "Operation"
53779          },
53780          "scopes": [
53781            "https://www.googleapis.com/auth/cloud-platform",
53782            "https://www.googleapis.com/auth/compute"
53783          ],
53784          "description": "Starts an instance that was stopped using the instances().stop method. For more information, see Restart an instance."
53785        },
53786        "stop": {
53787          "id": "compute.instances.stop",
53788          "path": "projects/{project}/zones/{zone}/instances/{instance}/stop",
53789          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/stop",
53790          "httpMethod": "POST",
53791          "parameters": {
53792            "discardLocalSsd": {
53793              "description": "This property is required if the instance has any attached Local SSD disks. If false, Local SSD data will be preserved when the instance is suspended. If true, the contents of any attached Local SSD disks will be discarded.",
53794              "location": "query",
53795              "type": "boolean"
53796            },
53797            "instance": {
53798              "description": "Name of the instance resource to stop.",
53799              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53800              "location": "path",
53801              "required": true,
53802              "type": "string"
53803            },
53804            "project": {
53805              "description": "Project ID for this request.",
53806              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53807              "location": "path",
53808              "required": true,
53809              "type": "string"
53810            },
53811            "requestId": {
53812              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
53813              "location": "query",
53814              "type": "string"
53815            },
53816            "zone": {
53817              "description": "The name of the zone for this request.",
53818              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53819              "location": "path",
53820              "required": true,
53821              "type": "string"
53822            }
53823          },
53824          "parameterOrder": [
53825            "project",
53826            "zone",
53827            "instance"
53828          ],
53829          "response": {
53830            "$ref": "Operation"
53831          },
53832          "scopes": [
53833            "https://www.googleapis.com/auth/cloud-platform",
53834            "https://www.googleapis.com/auth/compute"
53835          ],
53836          "description": "Stops a running instance, shutting it down cleanly, and allows you to restart the instance at a later time. Stopped instances do not incur VM usage charges while they are stopped. However, resources that the VM is using, such as persistent disks and static IP addresses, will continue to be charged until they are deleted. For more information, see Stopping an instance."
53837        },
53838        "getIamPolicy": {
53839          "id": "compute.instances.getIamPolicy",
53840          "path": "projects/{project}/zones/{zone}/instances/{resource}/getIamPolicy",
53841          "flatPath": "projects/{project}/zones/{zone}/instances/{resource}/getIamPolicy",
53842          "httpMethod": "GET",
53843          "parameters": {
53844            "optionsRequestedPolicyVersion": {
53845              "description": "Requested IAM Policy version.",
53846              "location": "query",
53847              "type": "integer",
53848              "format": "int32"
53849            },
53850            "project": {
53851              "description": "Project ID for this request.",
53852              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53853              "location": "path",
53854              "required": true,
53855              "type": "string"
53856            },
53857            "resource": {
53858              "description": "Name or id of the resource for this request.",
53859              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53860              "location": "path",
53861              "required": true,
53862              "type": "string"
53863            },
53864            "zone": {
53865              "description": "The name of the zone for this request.",
53866              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53867              "location": "path",
53868              "required": true,
53869              "type": "string"
53870            }
53871          },
53872          "parameterOrder": [
53873            "project",
53874            "zone",
53875            "resource"
53876          ],
53877          "response": {
53878            "$ref": "Policy"
53879          },
53880          "scopes": [
53881            "https://www.googleapis.com/auth/cloud-platform",
53882            "https://www.googleapis.com/auth/compute",
53883            "https://www.googleapis.com/auth/compute.readonly"
53884          ],
53885          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
53886        },
53887        "setIamPolicy": {
53888          "id": "compute.instances.setIamPolicy",
53889          "path": "projects/{project}/zones/{zone}/instances/{resource}/setIamPolicy",
53890          "flatPath": "projects/{project}/zones/{zone}/instances/{resource}/setIamPolicy",
53891          "httpMethod": "POST",
53892          "parameters": {
53893            "project": {
53894              "description": "Project ID for this request.",
53895              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53896              "location": "path",
53897              "required": true,
53898              "type": "string"
53899            },
53900            "resource": {
53901              "description": "Name or id of the resource for this request.",
53902              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53903              "location": "path",
53904              "required": true,
53905              "type": "string"
53906            },
53907            "zone": {
53908              "description": "The name of the zone for this request.",
53909              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53910              "location": "path",
53911              "required": true,
53912              "type": "string"
53913            }
53914          },
53915          "parameterOrder": [
53916            "project",
53917            "zone",
53918            "resource"
53919          ],
53920          "request": {
53921            "$ref": "ZoneSetPolicyRequest"
53922          },
53923          "response": {
53924            "$ref": "Policy"
53925          },
53926          "scopes": [
53927            "https://www.googleapis.com/auth/cloud-platform",
53928            "https://www.googleapis.com/auth/compute"
53929          ],
53930          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
53931        },
53932        "testIamPermissions": {
53933          "id": "compute.instances.testIamPermissions",
53934          "path": "projects/{project}/zones/{zone}/instances/{resource}/testIamPermissions",
53935          "flatPath": "projects/{project}/zones/{zone}/instances/{resource}/testIamPermissions",
53936          "httpMethod": "POST",
53937          "parameters": {
53938            "project": {
53939              "description": "Project ID for this request.",
53940              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53941              "location": "path",
53942              "required": true,
53943              "type": "string"
53944            },
53945            "resource": {
53946              "description": "Name or id of the resource for this request.",
53947              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53948              "location": "path",
53949              "required": true,
53950              "type": "string"
53951            },
53952            "zone": {
53953              "description": "The name of the zone for this request.",
53954              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
53955              "location": "path",
53956              "required": true,
53957              "type": "string"
53958            }
53959          },
53960          "parameterOrder": [
53961            "project",
53962            "zone",
53963            "resource"
53964          ],
53965          "request": {
53966            "$ref": "TestPermissionsRequest"
53967          },
53968          "response": {
53969            "$ref": "TestPermissionsResponse"
53970          },
53971          "scopes": [
53972            "https://www.googleapis.com/auth/cloud-platform",
53973            "https://www.googleapis.com/auth/compute",
53974            "https://www.googleapis.com/auth/compute.readonly"
53975          ],
53976          "description": "Returns permissions that a caller has on the specified resource."
53977        },
53978        "setServiceAccount": {
53979          "id": "compute.instances.setServiceAccount",
53980          "path": "projects/{project}/zones/{zone}/instances/{instance}/setServiceAccount",
53981          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/setServiceAccount",
53982          "httpMethod": "POST",
53983          "parameters": {
53984            "instance": {
53985              "description": "Name of the instance resource to start.",
53986              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
53987              "location": "path",
53988              "required": true,
53989              "type": "string"
53990            },
53991            "project": {
53992              "description": "Project ID for this request.",
53993              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
53994              "location": "path",
53995              "required": true,
53996              "type": "string"
53997            },
53998            "requestId": {
53999              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
54000              "location": "query",
54001              "type": "string"
54002            },
54003            "zone": {
54004              "description": "The name of the zone for this request.",
54005              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54006              "location": "path",
54007              "required": true,
54008              "type": "string"
54009            }
54010          },
54011          "parameterOrder": [
54012            "project",
54013            "zone",
54014            "instance"
54015          ],
54016          "request": {
54017            "$ref": "InstancesSetServiceAccountRequest"
54018          },
54019          "response": {
54020            "$ref": "Operation"
54021          },
54022          "scopes": [
54023            "https://www.googleapis.com/auth/cloud-platform",
54024            "https://www.googleapis.com/auth/compute"
54025          ],
54026          "description": "Sets the service account on the instance. For more information, read Changing the service account and access scopes for an instance."
54027        },
54028        "setDeletionProtection": {
54029          "id": "compute.instances.setDeletionProtection",
54030          "path": "projects/{project}/zones/{zone}/instances/{resource}/setDeletionProtection",
54031          "flatPath": "projects/{project}/zones/{zone}/instances/{resource}/setDeletionProtection",
54032          "httpMethod": "POST",
54033          "parameters": {
54034            "deletionProtection": {
54035              "description": "Whether the resource should be protected against deletion.",
54036              "default": "true",
54037              "location": "query",
54038              "type": "boolean"
54039            },
54040            "project": {
54041              "description": "Project ID for this request.",
54042              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54043              "location": "path",
54044              "required": true,
54045              "type": "string"
54046            },
54047            "requestId": {
54048              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
54049              "location": "query",
54050              "type": "string"
54051            },
54052            "resource": {
54053              "description": "Name or id of the resource for this request.",
54054              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
54055              "location": "path",
54056              "required": true,
54057              "type": "string"
54058            },
54059            "zone": {
54060              "description": "The name of the zone for this request.",
54061              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54062              "location": "path",
54063              "required": true,
54064              "type": "string"
54065            }
54066          },
54067          "parameterOrder": [
54068            "project",
54069            "zone",
54070            "resource"
54071          ],
54072          "response": {
54073            "$ref": "Operation"
54074          },
54075          "scopes": [
54076            "https://www.googleapis.com/auth/cloud-platform",
54077            "https://www.googleapis.com/auth/compute"
54078          ],
54079          "description": "Sets deletion protection on the instance."
54080        },
54081        "suspend": {
54082          "id": "compute.instances.suspend",
54083          "path": "projects/{project}/zones/{zone}/instances/{instance}/suspend",
54084          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/suspend",
54085          "httpMethod": "POST",
54086          "parameters": {
54087            "discardLocalSsd": {
54088              "description": "This property is required if the instance has any attached Local SSD disks. If false, Local SSD data will be preserved when the instance is suspended. If true, the contents of any attached Local SSD disks will be discarded.",
54089              "location": "query",
54090              "type": "boolean"
54091            },
54092            "instance": {
54093              "description": "Name of the instance resource to suspend.",
54094              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
54095              "location": "path",
54096              "required": true,
54097              "type": "string"
54098            },
54099            "project": {
54100              "description": "Project ID for this request.",
54101              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54102              "location": "path",
54103              "required": true,
54104              "type": "string"
54105            },
54106            "requestId": {
54107              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
54108              "location": "query",
54109              "type": "string"
54110            },
54111            "zone": {
54112              "description": "The name of the zone for this request.",
54113              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54114              "location": "path",
54115              "required": true,
54116              "type": "string"
54117            }
54118          },
54119          "parameterOrder": [
54120            "project",
54121            "zone",
54122            "instance"
54123          ],
54124          "response": {
54125            "$ref": "Operation"
54126          },
54127          "scopes": [
54128            "https://www.googleapis.com/auth/cloud-platform",
54129            "https://www.googleapis.com/auth/compute"
54130          ],
54131          "description": "This method suspends a running instance, saving its state to persistent storage, and allows you to resume the instance at a later time. Suspended instances have no compute costs (cores or RAM), and incur only storage charges for the saved VM memory and localSSD data. Any charged resources the virtual machine was using, such as persistent disks and static IP addresses, will continue to be charged while the instance is suspended. For more information, see Suspending and resuming an instance."
54132        },
54133        "resume": {
54134          "id": "compute.instances.resume",
54135          "path": "projects/{project}/zones/{zone}/instances/{instance}/resume",
54136          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/resume",
54137          "httpMethod": "POST",
54138          "parameters": {
54139            "instance": {
54140              "description": "Name of the instance resource to resume.",
54141              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
54142              "location": "path",
54143              "required": true,
54144              "type": "string"
54145            },
54146            "project": {
54147              "description": "Project ID for this request.",
54148              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54149              "location": "path",
54150              "required": true,
54151              "type": "string"
54152            },
54153            "requestId": {
54154              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
54155              "location": "query",
54156              "type": "string"
54157            },
54158            "zone": {
54159              "description": "The name of the zone for this request.",
54160              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54161              "location": "path",
54162              "required": true,
54163              "type": "string"
54164            }
54165          },
54166          "parameterOrder": [
54167            "project",
54168            "zone",
54169            "instance"
54170          ],
54171          "response": {
54172            "$ref": "Operation"
54173          },
54174          "scopes": [
54175            "https://www.googleapis.com/auth/cloud-platform",
54176            "https://www.googleapis.com/auth/compute"
54177          ],
54178          "description": "Resumes an instance that was suspended using the instances().suspend method."
54179        },
54180        "addResourcePolicies": {
54181          "id": "compute.instances.addResourcePolicies",
54182          "path": "projects/{project}/zones/{zone}/instances/{instance}/addResourcePolicies",
54183          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/addResourcePolicies",
54184          "httpMethod": "POST",
54185          "parameters": {
54186            "instance": {
54187              "description": "The instance name for this request.",
54188              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
54189              "location": "path",
54190              "required": true,
54191              "type": "string"
54192            },
54193            "project": {
54194              "description": "Project ID for this request.",
54195              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54196              "location": "path",
54197              "required": true,
54198              "type": "string"
54199            },
54200            "requestId": {
54201              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
54202              "location": "query",
54203              "type": "string"
54204            },
54205            "zone": {
54206              "description": "The name of the zone for this request.",
54207              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54208              "location": "path",
54209              "required": true,
54210              "type": "string"
54211            }
54212          },
54213          "parameterOrder": [
54214            "project",
54215            "zone",
54216            "instance"
54217          ],
54218          "request": {
54219            "$ref": "InstancesAddResourcePoliciesRequest"
54220          },
54221          "response": {
54222            "$ref": "Operation"
54223          },
54224          "scopes": [
54225            "https://www.googleapis.com/auth/cloud-platform",
54226            "https://www.googleapis.com/auth/compute"
54227          ],
54228          "description": "Adds existing resource policies to an instance. You can only add one policy right now which will be applied to this instance for scheduling live migrations."
54229        },
54230        "removeResourcePolicies": {
54231          "id": "compute.instances.removeResourcePolicies",
54232          "path": "projects/{project}/zones/{zone}/instances/{instance}/removeResourcePolicies",
54233          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/removeResourcePolicies",
54234          "httpMethod": "POST",
54235          "parameters": {
54236            "instance": {
54237              "description": "The instance name for this request.",
54238              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
54239              "location": "path",
54240              "required": true,
54241              "type": "string"
54242            },
54243            "project": {
54244              "description": "Project ID for this request.",
54245              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54246              "location": "path",
54247              "required": true,
54248              "type": "string"
54249            },
54250            "requestId": {
54251              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
54252              "location": "query",
54253              "type": "string"
54254            },
54255            "zone": {
54256              "description": "The name of the zone for this request.",
54257              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54258              "location": "path",
54259              "required": true,
54260              "type": "string"
54261            }
54262          },
54263          "parameterOrder": [
54264            "project",
54265            "zone",
54266            "instance"
54267          ],
54268          "request": {
54269            "$ref": "InstancesRemoveResourcePoliciesRequest"
54270          },
54271          "response": {
54272            "$ref": "Operation"
54273          },
54274          "scopes": [
54275            "https://www.googleapis.com/auth/cloud-platform",
54276            "https://www.googleapis.com/auth/compute"
54277          ],
54278          "description": "Removes resource policies from an instance."
54279        },
54280        "update": {
54281          "id": "compute.instances.update",
54282          "path": "projects/{project}/zones/{zone}/instances/{instance}",
54283          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}",
54284          "httpMethod": "PUT",
54285          "parameters": {
54286            "instance": {
54287              "description": "Name of the instance resource to update.",
54288              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
54289              "location": "path",
54290              "required": true,
54291              "type": "string"
54292            },
54293            "minimalAction": {
54294              "description": "Specifies the action to take when updating an instance even if the updated properties do not require it. If not specified, then Compute Engine acts based on the minimum action that the updated properties require.",
54295              "location": "query",
54296              "type": "string",
54297              "enumDescriptions": [
54298                "",
54299                "No changes can be made to the instance.",
54300                "The instance will not restart.",
54301                "The instance will restart."
54302              ],
54303              "enum": [
54304                "INVALID",
54305                "NO_EFFECT",
54306                "REFRESH",
54307                "RESTART"
54308              ]
54309            },
54310            "mostDisruptiveAllowedAction": {
54311              "description": "Specifies the most disruptive action that can be taken on the instance as part of the update. Compute Engine returns an error if the instance properties require a more disruptive action as part of the instance update. Valid options from lowest to highest are NO_EFFECT, REFRESH, and RESTART.",
54312              "location": "query",
54313              "type": "string",
54314              "enumDescriptions": [
54315                "",
54316                "No changes can be made to the instance.",
54317                "The instance will not restart.",
54318                "The instance will restart."
54319              ],
54320              "enum": [
54321                "INVALID",
54322                "NO_EFFECT",
54323                "REFRESH",
54324                "RESTART"
54325              ]
54326            },
54327            "project": {
54328              "description": "Project ID for this request.",
54329              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54330              "location": "path",
54331              "required": true,
54332              "type": "string"
54333            },
54334            "requestId": {
54335              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
54336              "location": "query",
54337              "type": "string"
54338            },
54339            "zone": {
54340              "description": "The name of the zone for this request.",
54341              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54342              "location": "path",
54343              "required": true,
54344              "type": "string"
54345            }
54346          },
54347          "parameterOrder": [
54348            "project",
54349            "zone",
54350            "instance"
54351          ],
54352          "request": {
54353            "$ref": "Instance"
54354          },
54355          "response": {
54356            "$ref": "Operation"
54357          },
54358          "scopes": [
54359            "https://www.googleapis.com/auth/cloud-platform",
54360            "https://www.googleapis.com/auth/compute"
54361          ],
54362          "description": "Updates an instance only if the necessary resources are available. This method can update only a specific set of instance properties. See Updating a running instance for a list of updatable instance properties."
54363        },
54364        "updateShieldedInstanceConfig": {
54365          "id": "compute.instances.updateShieldedInstanceConfig",
54366          "path": "projects/{project}/zones/{zone}/instances/{instance}/updateShieldedInstanceConfig",
54367          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/updateShieldedInstanceConfig",
54368          "httpMethod": "PATCH",
54369          "parameters": {
54370            "instance": {
54371              "description": "Name or id of the instance scoping this request.",
54372              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
54373              "location": "path",
54374              "required": true,
54375              "type": "string"
54376            },
54377            "project": {
54378              "description": "Project ID for this request.",
54379              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54380              "location": "path",
54381              "required": true,
54382              "type": "string"
54383            },
54384            "requestId": {
54385              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
54386              "location": "query",
54387              "type": "string"
54388            },
54389            "zone": {
54390              "description": "The name of the zone for this request.",
54391              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54392              "location": "path",
54393              "required": true,
54394              "type": "string"
54395            }
54396          },
54397          "parameterOrder": [
54398            "project",
54399            "zone",
54400            "instance"
54401          ],
54402          "request": {
54403            "$ref": "ShieldedInstanceConfig"
54404          },
54405          "response": {
54406            "$ref": "Operation"
54407          },
54408          "scopes": [
54409            "https://www.googleapis.com/auth/cloud-platform",
54410            "https://www.googleapis.com/auth/compute"
54411          ],
54412          "description": "Updates the Shielded Instance config for an instance. You can only use this method on a stopped instance. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
54413        },
54414        "updateDisplayDevice": {
54415          "id": "compute.instances.updateDisplayDevice",
54416          "path": "projects/{project}/zones/{zone}/instances/{instance}/updateDisplayDevice",
54417          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/updateDisplayDevice",
54418          "httpMethod": "PATCH",
54419          "parameters": {
54420            "instance": {
54421              "description": "Name of the instance scoping this request.",
54422              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54423              "location": "path",
54424              "required": true,
54425              "type": "string"
54426            },
54427            "project": {
54428              "description": "Project ID for this request.",
54429              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54430              "location": "path",
54431              "required": true,
54432              "type": "string"
54433            },
54434            "requestId": {
54435              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
54436              "location": "query",
54437              "type": "string"
54438            },
54439            "zone": {
54440              "description": "The name of the zone for this request.",
54441              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54442              "location": "path",
54443              "required": true,
54444              "type": "string"
54445            }
54446          },
54447          "parameterOrder": [
54448            "project",
54449            "zone",
54450            "instance"
54451          ],
54452          "request": {
54453            "$ref": "DisplayDevice"
54454          },
54455          "response": {
54456            "$ref": "Operation"
54457          },
54458          "scopes": [
54459            "https://www.googleapis.com/auth/cloud-platform",
54460            "https://www.googleapis.com/auth/compute"
54461          ],
54462          "description": "Updates the Display config for a VM instance. You can only use this method on a stopped VM instance. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
54463        },
54464        "setShieldedInstanceIntegrityPolicy": {
54465          "id": "compute.instances.setShieldedInstanceIntegrityPolicy",
54466          "path": "projects/{project}/zones/{zone}/instances/{instance}/setShieldedInstanceIntegrityPolicy",
54467          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/setShieldedInstanceIntegrityPolicy",
54468          "httpMethod": "PATCH",
54469          "parameters": {
54470            "instance": {
54471              "description": "Name or id of the instance scoping this request.",
54472              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
54473              "location": "path",
54474              "required": true,
54475              "type": "string"
54476            },
54477            "project": {
54478              "description": "Project ID for this request.",
54479              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54480              "location": "path",
54481              "required": true,
54482              "type": "string"
54483            },
54484            "requestId": {
54485              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
54486              "location": "query",
54487              "type": "string"
54488            },
54489            "zone": {
54490              "description": "The name of the zone for this request.",
54491              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54492              "location": "path",
54493              "required": true,
54494              "type": "string"
54495            }
54496          },
54497          "parameterOrder": [
54498            "project",
54499            "zone",
54500            "instance"
54501          ],
54502          "request": {
54503            "$ref": "ShieldedInstanceIntegrityPolicy"
54504          },
54505          "response": {
54506            "$ref": "Operation"
54507          },
54508          "scopes": [
54509            "https://www.googleapis.com/auth/cloud-platform",
54510            "https://www.googleapis.com/auth/compute"
54511          ],
54512          "description": "Sets the Shielded Instance integrity policy for an instance. You can only use this method on a running instance. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
54513        },
54514        "setSecurityPolicy": {
54515          "id": "compute.instances.setSecurityPolicy",
54516          "path": "projects/{project}/zones/{zone}/instances/{instance}/setSecurityPolicy",
54517          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/setSecurityPolicy",
54518          "httpMethod": "POST",
54519          "parameters": {
54520            "instance": {
54521              "description": "Name of the Instance resource to which the security policy should be set. The name should conform to RFC1035.",
54522              "location": "path",
54523              "required": true,
54524              "type": "string"
54525            },
54526            "project": {
54527              "description": "Project ID for this request.",
54528              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54529              "location": "path",
54530              "required": true,
54531              "type": "string"
54532            },
54533            "requestId": {
54534              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
54535              "location": "query",
54536              "type": "string"
54537            },
54538            "zone": {
54539              "description": "Name of the zone scoping this request.",
54540              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54541              "location": "path",
54542              "required": true,
54543              "type": "string"
54544            }
54545          },
54546          "parameterOrder": [
54547            "project",
54548            "zone",
54549            "instance"
54550          ],
54551          "request": {
54552            "$ref": "InstancesSetSecurityPolicyRequest"
54553          },
54554          "response": {
54555            "$ref": "Operation"
54556          },
54557          "scopes": [
54558            "https://www.googleapis.com/auth/cloud-platform",
54559            "https://www.googleapis.com/auth/compute"
54560          ],
54561          "description": "Sets the Google Cloud Armor security policy for the specified instance. For more information, see Google Cloud Armor Overview"
54562        },
54563        "getShieldedInstanceIdentity": {
54564          "id": "compute.instances.getShieldedInstanceIdentity",
54565          "path": "projects/{project}/zones/{zone}/instances/{instance}/getShieldedInstanceIdentity",
54566          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/getShieldedInstanceIdentity",
54567          "httpMethod": "GET",
54568          "parameters": {
54569            "instance": {
54570              "description": "Name or id of the instance scoping this request.",
54571              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
54572              "location": "path",
54573              "required": true,
54574              "type": "string"
54575            },
54576            "project": {
54577              "description": "Project ID for this request.",
54578              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54579              "location": "path",
54580              "required": true,
54581              "type": "string"
54582            },
54583            "zone": {
54584              "description": "The name of the zone for this request.",
54585              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54586              "location": "path",
54587              "required": true,
54588              "type": "string"
54589            }
54590          },
54591          "parameterOrder": [
54592            "project",
54593            "zone",
54594            "instance"
54595          ],
54596          "response": {
54597            "$ref": "ShieldedInstanceIdentity"
54598          },
54599          "scopes": [
54600            "https://www.googleapis.com/auth/cloud-platform",
54601            "https://www.googleapis.com/auth/compute",
54602            "https://www.googleapis.com/auth/compute.readonly"
54603          ],
54604          "description": "Returns the Shielded Instance Identity of an instance"
54605        },
54606        "bulkInsert": {
54607          "id": "compute.instances.bulkInsert",
54608          "path": "projects/{project}/zones/{zone}/instances/bulkInsert",
54609          "flatPath": "projects/{project}/zones/{zone}/instances/bulkInsert",
54610          "httpMethod": "POST",
54611          "parameters": {
54612            "project": {
54613              "description": "Project ID for this request.",
54614              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54615              "location": "path",
54616              "required": true,
54617              "type": "string"
54618            },
54619            "requestId": {
54620              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
54621              "location": "query",
54622              "type": "string"
54623            },
54624            "zone": {
54625              "description": "The name of the zone for this request.",
54626              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54627              "location": "path",
54628              "required": true,
54629              "type": "string"
54630            }
54631          },
54632          "parameterOrder": [
54633            "project",
54634            "zone"
54635          ],
54636          "request": {
54637            "$ref": "BulkInsertInstanceResource"
54638          },
54639          "response": {
54640            "$ref": "Operation"
54641          },
54642          "scopes": [
54643            "https://www.googleapis.com/auth/cloud-platform",
54644            "https://www.googleapis.com/auth/compute"
54645          ],
54646          "description": "Creates multiple instances. Count specifies the number of instances to create. For more information, see About bulk creation of VMs."
54647        },
54648        "getEffectiveFirewalls": {
54649          "id": "compute.instances.getEffectiveFirewalls",
54650          "path": "projects/{project}/zones/{zone}/instances/{instance}/getEffectiveFirewalls",
54651          "flatPath": "projects/{project}/zones/{zone}/instances/{instance}/getEffectiveFirewalls",
54652          "httpMethod": "GET",
54653          "parameters": {
54654            "instance": {
54655              "description": "Name of the instance scoping this request.",
54656              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54657              "location": "path",
54658              "required": true,
54659              "type": "string"
54660            },
54661            "networkInterface": {
54662              "description": "The name of the network interface to get the effective firewalls.",
54663              "location": "query",
54664              "required": true,
54665              "type": "string"
54666            },
54667            "project": {
54668              "description": "Project ID for this request.",
54669              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54670              "location": "path",
54671              "required": true,
54672              "type": "string"
54673            },
54674            "zone": {
54675              "description": "The name of the zone for this request.",
54676              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54677              "location": "path",
54678              "required": true,
54679              "type": "string"
54680            }
54681          },
54682          "parameterOrder": [
54683            "project",
54684            "zone",
54685            "instance",
54686            "networkInterface"
54687          ],
54688          "response": {
54689            "$ref": "InstancesGetEffectiveFirewallsResponse"
54690          },
54691          "scopes": [
54692            "https://www.googleapis.com/auth/cloud-platform",
54693            "https://www.googleapis.com/auth/compute",
54694            "https://www.googleapis.com/auth/compute.readonly"
54695          ],
54696          "description": "Returns effective firewalls applied to an interface of the instance."
54697        }
54698      }
54699    },
54700    "regionInstances": {
54701      "methods": {
54702        "bulkInsert": {
54703          "id": "compute.regionInstances.bulkInsert",
54704          "path": "projects/{project}/regions/{region}/instances/bulkInsert",
54705          "flatPath": "projects/{project}/regions/{region}/instances/bulkInsert",
54706          "httpMethod": "POST",
54707          "parameters": {
54708            "project": {
54709              "description": "Project ID for this request.",
54710              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54711              "location": "path",
54712              "required": true,
54713              "type": "string"
54714            },
54715            "region": {
54716              "description": "The name of the region for this request.",
54717              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54718              "location": "path",
54719              "required": true,
54720              "type": "string"
54721            },
54722            "requestId": {
54723              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
54724              "location": "query",
54725              "type": "string"
54726            }
54727          },
54728          "parameterOrder": [
54729            "project",
54730            "region"
54731          ],
54732          "request": {
54733            "$ref": "BulkInsertInstanceResource"
54734          },
54735          "response": {
54736            "$ref": "Operation"
54737          },
54738          "scopes": [
54739            "https://www.googleapis.com/auth/cloud-platform",
54740            "https://www.googleapis.com/auth/compute"
54741          ],
54742          "description": "Creates multiple instances in a given region. Count specifies the number of instances to create."
54743        }
54744      }
54745    },
54746    "reservations": {
54747      "methods": {
54748        "list": {
54749          "id": "compute.reservations.list",
54750          "path": "projects/{project}/zones/{zone}/reservations",
54751          "flatPath": "projects/{project}/zones/{zone}/reservations",
54752          "httpMethod": "GET",
54753          "parameters": {
54754            "filter": {
54755              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
54756              "location": "query",
54757              "type": "string"
54758            },
54759            "maxResults": {
54760              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
54761              "default": "500",
54762              "minimum": "0",
54763              "location": "query",
54764              "type": "integer",
54765              "format": "uint32"
54766            },
54767            "orderBy": {
54768              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
54769              "location": "query",
54770              "type": "string"
54771            },
54772            "pageToken": {
54773              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
54774              "location": "query",
54775              "type": "string"
54776            },
54777            "project": {
54778              "description": "Project ID for this request.",
54779              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54780              "location": "path",
54781              "required": true,
54782              "type": "string"
54783            },
54784            "returnPartialSuccess": {
54785              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
54786              "location": "query",
54787              "type": "boolean"
54788            },
54789            "zone": {
54790              "description": "Name of the zone for this request.",
54791              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54792              "location": "path",
54793              "required": true,
54794              "type": "string"
54795            }
54796          },
54797          "parameterOrder": [
54798            "project",
54799            "zone"
54800          ],
54801          "response": {
54802            "$ref": "ReservationList"
54803          },
54804          "scopes": [
54805            "https://www.googleapis.com/auth/cloud-platform",
54806            "https://www.googleapis.com/auth/compute",
54807            "https://www.googleapis.com/auth/compute.readonly"
54808          ],
54809          "description": "A list of all the reservations that have been configured for the specified project in specified zone."
54810        },
54811        "aggregatedList": {
54812          "id": "compute.reservations.aggregatedList",
54813          "path": "projects/{project}/aggregated/reservations",
54814          "flatPath": "projects/{project}/aggregated/reservations",
54815          "httpMethod": "GET",
54816          "parameters": {
54817            "filter": {
54818              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
54819              "location": "query",
54820              "type": "string"
54821            },
54822            "includeAllScopes": {
54823              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
54824              "location": "query",
54825              "type": "boolean"
54826            },
54827            "maxResults": {
54828              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
54829              "default": "500",
54830              "minimum": "0",
54831              "location": "query",
54832              "type": "integer",
54833              "format": "uint32"
54834            },
54835            "orderBy": {
54836              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
54837              "location": "query",
54838              "type": "string"
54839            },
54840            "pageToken": {
54841              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
54842              "location": "query",
54843              "type": "string"
54844            },
54845            "project": {
54846              "description": "Project ID for this request.",
54847              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54848              "location": "path",
54849              "required": true,
54850              "type": "string"
54851            },
54852            "returnPartialSuccess": {
54853              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
54854              "location": "query",
54855              "type": "boolean"
54856            },
54857            "serviceProjectNumber": {
54858              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
54859              "location": "query",
54860              "type": "string",
54861              "format": "int64"
54862            }
54863          },
54864          "parameterOrder": [
54865            "project"
54866          ],
54867          "response": {
54868            "$ref": "ReservationAggregatedList"
54869          },
54870          "scopes": [
54871            "https://www.googleapis.com/auth/cloud-platform",
54872            "https://www.googleapis.com/auth/compute",
54873            "https://www.googleapis.com/auth/compute.readonly"
54874          ],
54875          "description": "Retrieves an aggregated list of reservations. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
54876        },
54877        "get": {
54878          "id": "compute.reservations.get",
54879          "path": "projects/{project}/zones/{zone}/reservations/{reservation}",
54880          "flatPath": "projects/{project}/zones/{zone}/reservations/{reservation}",
54881          "httpMethod": "GET",
54882          "parameters": {
54883            "project": {
54884              "description": "Project ID for this request.",
54885              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54886              "location": "path",
54887              "required": true,
54888              "type": "string"
54889            },
54890            "reservation": {
54891              "description": "Name of the reservation to retrieve.",
54892              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
54893              "location": "path",
54894              "required": true,
54895              "type": "string"
54896            },
54897            "zone": {
54898              "description": "Name of the zone for this request.",
54899              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54900              "location": "path",
54901              "required": true,
54902              "type": "string"
54903            }
54904          },
54905          "parameterOrder": [
54906            "project",
54907            "zone",
54908            "reservation"
54909          ],
54910          "response": {
54911            "$ref": "Reservation"
54912          },
54913          "scopes": [
54914            "https://www.googleapis.com/auth/cloud-platform",
54915            "https://www.googleapis.com/auth/compute",
54916            "https://www.googleapis.com/auth/compute.readonly"
54917          ],
54918          "description": "Retrieves information about the specified reservation."
54919        },
54920        "insert": {
54921          "id": "compute.reservations.insert",
54922          "path": "projects/{project}/zones/{zone}/reservations",
54923          "flatPath": "projects/{project}/zones/{zone}/reservations",
54924          "httpMethod": "POST",
54925          "parameters": {
54926            "project": {
54927              "description": "Project ID for this request.",
54928              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54929              "location": "path",
54930              "required": true,
54931              "type": "string"
54932            },
54933            "requestId": {
54934              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
54935              "location": "query",
54936              "type": "string"
54937            },
54938            "zone": {
54939              "description": "Name of the zone for this request.",
54940              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54941              "location": "path",
54942              "required": true,
54943              "type": "string"
54944            }
54945          },
54946          "parameterOrder": [
54947            "project",
54948            "zone"
54949          ],
54950          "request": {
54951            "$ref": "Reservation"
54952          },
54953          "response": {
54954            "$ref": "Operation"
54955          },
54956          "scopes": [
54957            "https://www.googleapis.com/auth/cloud-platform",
54958            "https://www.googleapis.com/auth/compute"
54959          ],
54960          "description": "Creates a new reservation. For more information, read Reserving zonal resources."
54961        },
54962        "delete": {
54963          "id": "compute.reservations.delete",
54964          "path": "projects/{project}/zones/{zone}/reservations/{reservation}",
54965          "flatPath": "projects/{project}/zones/{zone}/reservations/{reservation}",
54966          "httpMethod": "DELETE",
54967          "parameters": {
54968            "project": {
54969              "description": "Project ID for this request.",
54970              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
54971              "location": "path",
54972              "required": true,
54973              "type": "string"
54974            },
54975            "requestId": {
54976              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
54977              "location": "query",
54978              "type": "string"
54979            },
54980            "reservation": {
54981              "description": "Name of the reservation to delete.",
54982              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
54983              "location": "path",
54984              "required": true,
54985              "type": "string"
54986            },
54987            "zone": {
54988              "description": "Name of the zone for this request.",
54989              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
54990              "location": "path",
54991              "required": true,
54992              "type": "string"
54993            }
54994          },
54995          "parameterOrder": [
54996            "project",
54997            "zone",
54998            "reservation"
54999          ],
55000          "response": {
55001            "$ref": "Operation"
55002          },
55003          "scopes": [
55004            "https://www.googleapis.com/auth/cloud-platform",
55005            "https://www.googleapis.com/auth/compute"
55006          ],
55007          "description": "Deletes the specified reservation."
55008        },
55009        "resize": {
55010          "id": "compute.reservations.resize",
55011          "path": "projects/{project}/zones/{zone}/reservations/{reservation}/resize",
55012          "flatPath": "projects/{project}/zones/{zone}/reservations/{reservation}/resize",
55013          "httpMethod": "POST",
55014          "parameters": {
55015            "project": {
55016              "description": "Project ID for this request.",
55017              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55018              "location": "path",
55019              "required": true,
55020              "type": "string"
55021            },
55022            "requestId": {
55023              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
55024              "location": "query",
55025              "type": "string"
55026            },
55027            "reservation": {
55028              "description": "Name of the reservation to update.",
55029              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
55030              "location": "path",
55031              "required": true,
55032              "type": "string"
55033            },
55034            "zone": {
55035              "description": "Name of the zone for this request.",
55036              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
55037              "location": "path",
55038              "required": true,
55039              "type": "string"
55040            }
55041          },
55042          "parameterOrder": [
55043            "project",
55044            "zone",
55045            "reservation"
55046          ],
55047          "request": {
55048            "$ref": "ReservationsResizeRequest"
55049          },
55050          "response": {
55051            "$ref": "Operation"
55052          },
55053          "scopes": [
55054            "https://www.googleapis.com/auth/cloud-platform",
55055            "https://www.googleapis.com/auth/compute"
55056          ],
55057          "description": "Resizes the reservation (applicable to standalone reservations only). For more information, read Modifying reservations."
55058        },
55059        "update": {
55060          "id": "compute.reservations.update",
55061          "path": "projects/{project}/zones/{zone}/reservations/{reservation}",
55062          "flatPath": "projects/{project}/zones/{zone}/reservations/{reservation}",
55063          "httpMethod": "PATCH",
55064          "parameters": {
55065            "paths": {
55066              "location": "query",
55067              "repeated": true,
55068              "type": "string"
55069            },
55070            "project": {
55071              "description": "Project ID for this request.",
55072              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55073              "location": "path",
55074              "required": true,
55075              "type": "string"
55076            },
55077            "requestId": {
55078              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
55079              "location": "query",
55080              "type": "string"
55081            },
55082            "reservation": {
55083              "description": "Name of the reservation to update.",
55084              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
55085              "location": "path",
55086              "required": true,
55087              "type": "string"
55088            },
55089            "updateMask": {
55090              "description": "Update_mask indicates fields to be updated as part of this request.",
55091              "location": "query",
55092              "type": "string",
55093              "format": "google-fieldmask"
55094            },
55095            "zone": {
55096              "description": "Name of the zone for this request.",
55097              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
55098              "location": "path",
55099              "required": true,
55100              "type": "string"
55101            }
55102          },
55103          "parameterOrder": [
55104            "project",
55105            "zone",
55106            "reservation"
55107          ],
55108          "request": {
55109            "$ref": "Reservation"
55110          },
55111          "response": {
55112            "$ref": "Operation"
55113          },
55114          "scopes": [
55115            "https://www.googleapis.com/auth/cloud-platform",
55116            "https://www.googleapis.com/auth/compute"
55117          ],
55118          "description": "Update share settings of the reservation."
55119        },
55120        "getIamPolicy": {
55121          "id": "compute.reservations.getIamPolicy",
55122          "path": "projects/{project}/zones/{zone}/reservations/{resource}/getIamPolicy",
55123          "flatPath": "projects/{project}/zones/{zone}/reservations/{resource}/getIamPolicy",
55124          "httpMethod": "GET",
55125          "parameters": {
55126            "optionsRequestedPolicyVersion": {
55127              "description": "Requested IAM Policy version.",
55128              "location": "query",
55129              "type": "integer",
55130              "format": "int32"
55131            },
55132            "project": {
55133              "description": "Project ID for this request.",
55134              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55135              "location": "path",
55136              "required": true,
55137              "type": "string"
55138            },
55139            "resource": {
55140              "description": "Name or id of the resource for this request.",
55141              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
55142              "location": "path",
55143              "required": true,
55144              "type": "string"
55145            },
55146            "zone": {
55147              "description": "The name of the zone for this request.",
55148              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
55149              "location": "path",
55150              "required": true,
55151              "type": "string"
55152            }
55153          },
55154          "parameterOrder": [
55155            "project",
55156            "zone",
55157            "resource"
55158          ],
55159          "response": {
55160            "$ref": "Policy"
55161          },
55162          "scopes": [
55163            "https://www.googleapis.com/auth/cloud-platform",
55164            "https://www.googleapis.com/auth/compute",
55165            "https://www.googleapis.com/auth/compute.readonly"
55166          ],
55167          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
55168        },
55169        "setIamPolicy": {
55170          "id": "compute.reservations.setIamPolicy",
55171          "path": "projects/{project}/zones/{zone}/reservations/{resource}/setIamPolicy",
55172          "flatPath": "projects/{project}/zones/{zone}/reservations/{resource}/setIamPolicy",
55173          "httpMethod": "POST",
55174          "parameters": {
55175            "project": {
55176              "description": "Project ID for this request.",
55177              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55178              "location": "path",
55179              "required": true,
55180              "type": "string"
55181            },
55182            "resource": {
55183              "description": "Name or id of the resource for this request.",
55184              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
55185              "location": "path",
55186              "required": true,
55187              "type": "string"
55188            },
55189            "zone": {
55190              "description": "The name of the zone for this request.",
55191              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
55192              "location": "path",
55193              "required": true,
55194              "type": "string"
55195            }
55196          },
55197          "parameterOrder": [
55198            "project",
55199            "zone",
55200            "resource"
55201          ],
55202          "request": {
55203            "$ref": "ZoneSetPolicyRequest"
55204          },
55205          "response": {
55206            "$ref": "Policy"
55207          },
55208          "scopes": [
55209            "https://www.googleapis.com/auth/cloud-platform",
55210            "https://www.googleapis.com/auth/compute"
55211          ],
55212          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
55213        },
55214        "testIamPermissions": {
55215          "id": "compute.reservations.testIamPermissions",
55216          "path": "projects/{project}/zones/{zone}/reservations/{resource}/testIamPermissions",
55217          "flatPath": "projects/{project}/zones/{zone}/reservations/{resource}/testIamPermissions",
55218          "httpMethod": "POST",
55219          "parameters": {
55220            "project": {
55221              "description": "Project ID for this request.",
55222              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55223              "location": "path",
55224              "required": true,
55225              "type": "string"
55226            },
55227            "resource": {
55228              "description": "Name or id of the resource for this request.",
55229              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
55230              "location": "path",
55231              "required": true,
55232              "type": "string"
55233            },
55234            "zone": {
55235              "description": "The name of the zone for this request.",
55236              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
55237              "location": "path",
55238              "required": true,
55239              "type": "string"
55240            }
55241          },
55242          "parameterOrder": [
55243            "project",
55244            "zone",
55245            "resource"
55246          ],
55247          "request": {
55248            "$ref": "TestPermissionsRequest"
55249          },
55250          "response": {
55251            "$ref": "TestPermissionsResponse"
55252          },
55253          "scopes": [
55254            "https://www.googleapis.com/auth/cloud-platform",
55255            "https://www.googleapis.com/auth/compute",
55256            "https://www.googleapis.com/auth/compute.readonly"
55257          ],
55258          "description": "Returns permissions that a caller has on the specified resource."
55259        }
55260      }
55261    },
55262    "instanceGroups": {
55263      "methods": {
55264        "list": {
55265          "id": "compute.instanceGroups.list",
55266          "path": "projects/{project}/zones/{zone}/instanceGroups",
55267          "flatPath": "projects/{project}/zones/{zone}/instanceGroups",
55268          "httpMethod": "GET",
55269          "parameters": {
55270            "filter": {
55271              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
55272              "location": "query",
55273              "type": "string"
55274            },
55275            "maxResults": {
55276              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
55277              "default": "500",
55278              "minimum": "0",
55279              "location": "query",
55280              "type": "integer",
55281              "format": "uint32"
55282            },
55283            "orderBy": {
55284              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
55285              "location": "query",
55286              "type": "string"
55287            },
55288            "pageToken": {
55289              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
55290              "location": "query",
55291              "type": "string"
55292            },
55293            "project": {
55294              "description": "Project ID for this request.",
55295              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55296              "location": "path",
55297              "required": true,
55298              "type": "string"
55299            },
55300            "returnPartialSuccess": {
55301              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
55302              "location": "query",
55303              "type": "boolean"
55304            },
55305            "zone": {
55306              "description": "The name of the zone where the instance group is located.",
55307              "location": "path",
55308              "required": true,
55309              "type": "string"
55310            }
55311          },
55312          "parameterOrder": [
55313            "project",
55314            "zone"
55315          ],
55316          "response": {
55317            "$ref": "InstanceGroupList"
55318          },
55319          "scopes": [
55320            "https://www.googleapis.com/auth/cloud-platform",
55321            "https://www.googleapis.com/auth/compute",
55322            "https://www.googleapis.com/auth/compute.readonly"
55323          ],
55324          "description": "Retrieves the list of zonal instance group resources contained within the specified zone. For managed instance groups, use the instanceGroupManagers or regionInstanceGroupManagers methods instead."
55325        },
55326        "aggregatedList": {
55327          "id": "compute.instanceGroups.aggregatedList",
55328          "path": "projects/{project}/aggregated/instanceGroups",
55329          "flatPath": "projects/{project}/aggregated/instanceGroups",
55330          "httpMethod": "GET",
55331          "parameters": {
55332            "filter": {
55333              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
55334              "location": "query",
55335              "type": "string"
55336            },
55337            "includeAllScopes": {
55338              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
55339              "location": "query",
55340              "type": "boolean"
55341            },
55342            "maxResults": {
55343              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
55344              "default": "500",
55345              "minimum": "0",
55346              "location": "query",
55347              "type": "integer",
55348              "format": "uint32"
55349            },
55350            "orderBy": {
55351              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
55352              "location": "query",
55353              "type": "string"
55354            },
55355            "pageToken": {
55356              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
55357              "location": "query",
55358              "type": "string"
55359            },
55360            "project": {
55361              "description": "Project ID for this request.",
55362              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55363              "location": "path",
55364              "required": true,
55365              "type": "string"
55366            },
55367            "returnPartialSuccess": {
55368              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
55369              "location": "query",
55370              "type": "boolean"
55371            },
55372            "serviceProjectNumber": {
55373              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
55374              "location": "query",
55375              "type": "string",
55376              "format": "int64"
55377            }
55378          },
55379          "parameterOrder": [
55380            "project"
55381          ],
55382          "response": {
55383            "$ref": "InstanceGroupAggregatedList"
55384          },
55385          "scopes": [
55386            "https://www.googleapis.com/auth/cloud-platform",
55387            "https://www.googleapis.com/auth/compute",
55388            "https://www.googleapis.com/auth/compute.readonly"
55389          ],
55390          "description": "Retrieves the list of instance groups and sorts them by zone. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
55391        },
55392        "get": {
55393          "id": "compute.instanceGroups.get",
55394          "path": "projects/{project}/zones/{zone}/instanceGroups/{instanceGroup}",
55395          "flatPath": "projects/{project}/zones/{zone}/instanceGroups/{instanceGroup}",
55396          "httpMethod": "GET",
55397          "parameters": {
55398            "instanceGroup": {
55399              "description": "The name of the instance group.",
55400              "location": "path",
55401              "required": true,
55402              "type": "string"
55403            },
55404            "project": {
55405              "description": "Project ID for this request.",
55406              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55407              "location": "path",
55408              "required": true,
55409              "type": "string"
55410            },
55411            "zone": {
55412              "description": "The name of the zone where the instance group is located.",
55413              "location": "path",
55414              "required": true,
55415              "type": "string"
55416            }
55417          },
55418          "parameterOrder": [
55419            "project",
55420            "zone",
55421            "instanceGroup"
55422          ],
55423          "response": {
55424            "$ref": "InstanceGroup"
55425          },
55426          "scopes": [
55427            "https://www.googleapis.com/auth/cloud-platform",
55428            "https://www.googleapis.com/auth/compute",
55429            "https://www.googleapis.com/auth/compute.readonly"
55430          ],
55431          "description": "Returns the specified zonal instance group. Get a list of available zonal instance groups by making a list() request. For managed instance groups, use the instanceGroupManagers or regionInstanceGroupManagers methods instead."
55432        },
55433        "insert": {
55434          "id": "compute.instanceGroups.insert",
55435          "path": "projects/{project}/zones/{zone}/instanceGroups",
55436          "flatPath": "projects/{project}/zones/{zone}/instanceGroups",
55437          "httpMethod": "POST",
55438          "parameters": {
55439            "project": {
55440              "description": "Project ID for this request.",
55441              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55442              "location": "path",
55443              "required": true,
55444              "type": "string"
55445            },
55446            "requestId": {
55447              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
55448              "location": "query",
55449              "type": "string"
55450            },
55451            "zone": {
55452              "description": "The name of the zone where you want to create the instance group.",
55453              "location": "path",
55454              "required": true,
55455              "type": "string"
55456            }
55457          },
55458          "parameterOrder": [
55459            "project",
55460            "zone"
55461          ],
55462          "request": {
55463            "$ref": "InstanceGroup"
55464          },
55465          "response": {
55466            "$ref": "Operation"
55467          },
55468          "scopes": [
55469            "https://www.googleapis.com/auth/cloud-platform",
55470            "https://www.googleapis.com/auth/compute"
55471          ],
55472          "description": "Creates an instance group in the specified project using the parameters that are included in the request."
55473        },
55474        "delete": {
55475          "id": "compute.instanceGroups.delete",
55476          "path": "projects/{project}/zones/{zone}/instanceGroups/{instanceGroup}",
55477          "flatPath": "projects/{project}/zones/{zone}/instanceGroups/{instanceGroup}",
55478          "httpMethod": "DELETE",
55479          "parameters": {
55480            "instanceGroup": {
55481              "description": "The name of the instance group to delete.",
55482              "location": "path",
55483              "required": true,
55484              "type": "string"
55485            },
55486            "project": {
55487              "description": "Project ID for this request.",
55488              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55489              "location": "path",
55490              "required": true,
55491              "type": "string"
55492            },
55493            "requestId": {
55494              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
55495              "location": "query",
55496              "type": "string"
55497            },
55498            "zone": {
55499              "description": "The name of the zone where the instance group is located.",
55500              "location": "path",
55501              "required": true,
55502              "type": "string"
55503            }
55504          },
55505          "parameterOrder": [
55506            "project",
55507            "zone",
55508            "instanceGroup"
55509          ],
55510          "response": {
55511            "$ref": "Operation"
55512          },
55513          "scopes": [
55514            "https://www.googleapis.com/auth/cloud-platform",
55515            "https://www.googleapis.com/auth/compute"
55516          ],
55517          "description": "Deletes the specified instance group. The instances in the group are not deleted. Note that instance group must not belong to a backend service. Read Deleting an instance group for more information."
55518        },
55519        "addInstances": {
55520          "id": "compute.instanceGroups.addInstances",
55521          "path": "projects/{project}/zones/{zone}/instanceGroups/{instanceGroup}/addInstances",
55522          "flatPath": "projects/{project}/zones/{zone}/instanceGroups/{instanceGroup}/addInstances",
55523          "httpMethod": "POST",
55524          "parameters": {
55525            "instanceGroup": {
55526              "description": "The name of the instance group where you are adding instances.",
55527              "location": "path",
55528              "required": true,
55529              "type": "string"
55530            },
55531            "project": {
55532              "description": "Project ID for this request.",
55533              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55534              "location": "path",
55535              "required": true,
55536              "type": "string"
55537            },
55538            "requestId": {
55539              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
55540              "location": "query",
55541              "type": "string"
55542            },
55543            "zone": {
55544              "description": "The name of the zone where the instance group is located.",
55545              "location": "path",
55546              "required": true,
55547              "type": "string"
55548            }
55549          },
55550          "parameterOrder": [
55551            "project",
55552            "zone",
55553            "instanceGroup"
55554          ],
55555          "request": {
55556            "$ref": "InstanceGroupsAddInstancesRequest"
55557          },
55558          "response": {
55559            "$ref": "Operation"
55560          },
55561          "scopes": [
55562            "https://www.googleapis.com/auth/cloud-platform",
55563            "https://www.googleapis.com/auth/compute"
55564          ],
55565          "description": "Adds a list of instances to the specified instance group. All of the instances in the instance group must be in the same network/subnetwork. Read Adding instances for more information."
55566        },
55567        "removeInstances": {
55568          "id": "compute.instanceGroups.removeInstances",
55569          "path": "projects/{project}/zones/{zone}/instanceGroups/{instanceGroup}/removeInstances",
55570          "flatPath": "projects/{project}/zones/{zone}/instanceGroups/{instanceGroup}/removeInstances",
55571          "httpMethod": "POST",
55572          "parameters": {
55573            "instanceGroup": {
55574              "description": "The name of the instance group where the specified instances will be removed.",
55575              "location": "path",
55576              "required": true,
55577              "type": "string"
55578            },
55579            "project": {
55580              "description": "Project ID for this request.",
55581              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55582              "location": "path",
55583              "required": true,
55584              "type": "string"
55585            },
55586            "requestId": {
55587              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
55588              "location": "query",
55589              "type": "string"
55590            },
55591            "zone": {
55592              "description": "The name of the zone where the instance group is located.",
55593              "location": "path",
55594              "required": true,
55595              "type": "string"
55596            }
55597          },
55598          "parameterOrder": [
55599            "project",
55600            "zone",
55601            "instanceGroup"
55602          ],
55603          "request": {
55604            "$ref": "InstanceGroupsRemoveInstancesRequest"
55605          },
55606          "response": {
55607            "$ref": "Operation"
55608          },
55609          "scopes": [
55610            "https://www.googleapis.com/auth/cloud-platform",
55611            "https://www.googleapis.com/auth/compute"
55612          ],
55613          "description": "Removes one or more instances from the specified instance group, but does not delete those instances. If the group is part of a backend service that has enabled connection draining, it can take up to 60 seconds after the connection draining duration before the VM instance is removed or deleted."
55614        },
55615        "listInstances": {
55616          "id": "compute.instanceGroups.listInstances",
55617          "path": "projects/{project}/zones/{zone}/instanceGroups/{instanceGroup}/listInstances",
55618          "flatPath": "projects/{project}/zones/{zone}/instanceGroups/{instanceGroup}/listInstances",
55619          "httpMethod": "POST",
55620          "parameters": {
55621            "filter": {
55622              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
55623              "location": "query",
55624              "type": "string"
55625            },
55626            "instanceGroup": {
55627              "description": "The name of the instance group from which you want to generate a list of included instances.",
55628              "location": "path",
55629              "required": true,
55630              "type": "string"
55631            },
55632            "maxResults": {
55633              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
55634              "default": "500",
55635              "minimum": "0",
55636              "location": "query",
55637              "type": "integer",
55638              "format": "uint32"
55639            },
55640            "orderBy": {
55641              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
55642              "location": "query",
55643              "type": "string"
55644            },
55645            "pageToken": {
55646              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
55647              "location": "query",
55648              "type": "string"
55649            },
55650            "project": {
55651              "description": "Project ID for this request.",
55652              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55653              "location": "path",
55654              "required": true,
55655              "type": "string"
55656            },
55657            "returnPartialSuccess": {
55658              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
55659              "location": "query",
55660              "type": "boolean"
55661            },
55662            "zone": {
55663              "description": "The name of the zone where the instance group is located.",
55664              "location": "path",
55665              "required": true,
55666              "type": "string"
55667            }
55668          },
55669          "parameterOrder": [
55670            "project",
55671            "zone",
55672            "instanceGroup"
55673          ],
55674          "request": {
55675            "$ref": "InstanceGroupsListInstancesRequest"
55676          },
55677          "response": {
55678            "$ref": "InstanceGroupsListInstances"
55679          },
55680          "scopes": [
55681            "https://www.googleapis.com/auth/cloud-platform",
55682            "https://www.googleapis.com/auth/compute",
55683            "https://www.googleapis.com/auth/compute.readonly"
55684          ],
55685          "description": "Lists the instances in the specified instance group. The orderBy query parameter is not supported. The filter query parameter is supported, but only for expressions that use `eq` (equal) or `ne` (not equal) operators."
55686        },
55687        "setNamedPorts": {
55688          "id": "compute.instanceGroups.setNamedPorts",
55689          "path": "projects/{project}/zones/{zone}/instanceGroups/{instanceGroup}/setNamedPorts",
55690          "flatPath": "projects/{project}/zones/{zone}/instanceGroups/{instanceGroup}/setNamedPorts",
55691          "httpMethod": "POST",
55692          "parameters": {
55693            "instanceGroup": {
55694              "description": "The name of the instance group where the named ports are updated.",
55695              "location": "path",
55696              "required": true,
55697              "type": "string"
55698            },
55699            "project": {
55700              "description": "Project ID for this request.",
55701              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55702              "location": "path",
55703              "required": true,
55704              "type": "string"
55705            },
55706            "requestId": {
55707              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
55708              "location": "query",
55709              "type": "string"
55710            },
55711            "zone": {
55712              "description": "The name of the zone where the instance group is located.",
55713              "location": "path",
55714              "required": true,
55715              "type": "string"
55716            }
55717          },
55718          "parameterOrder": [
55719            "project",
55720            "zone",
55721            "instanceGroup"
55722          ],
55723          "request": {
55724            "$ref": "InstanceGroupsSetNamedPortsRequest"
55725          },
55726          "response": {
55727            "$ref": "Operation"
55728          },
55729          "scopes": [
55730            "https://www.googleapis.com/auth/cloud-platform",
55731            "https://www.googleapis.com/auth/compute"
55732          ],
55733          "description": "Sets the named ports for the specified instance group."
55734        }
55735      }
55736    },
55737    "regionInstanceGroups": {
55738      "methods": {
55739        "list": {
55740          "id": "compute.regionInstanceGroups.list",
55741          "path": "projects/{project}/regions/{region}/instanceGroups",
55742          "flatPath": "projects/{project}/regions/{region}/instanceGroups",
55743          "httpMethod": "GET",
55744          "parameters": {
55745            "filter": {
55746              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
55747              "location": "query",
55748              "type": "string"
55749            },
55750            "maxResults": {
55751              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
55752              "default": "500",
55753              "minimum": "0",
55754              "location": "query",
55755              "type": "integer",
55756              "format": "uint32"
55757            },
55758            "orderBy": {
55759              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
55760              "location": "query",
55761              "type": "string"
55762            },
55763            "pageToken": {
55764              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
55765              "location": "query",
55766              "type": "string"
55767            },
55768            "project": {
55769              "description": "Project ID for this request.",
55770              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55771              "location": "path",
55772              "required": true,
55773              "type": "string"
55774            },
55775            "region": {
55776              "description": "Name of the region scoping this request.",
55777              "location": "path",
55778              "required": true,
55779              "type": "string"
55780            },
55781            "returnPartialSuccess": {
55782              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
55783              "location": "query",
55784              "type": "boolean"
55785            }
55786          },
55787          "parameterOrder": [
55788            "project",
55789            "region"
55790          ],
55791          "response": {
55792            "$ref": "RegionInstanceGroupList"
55793          },
55794          "scopes": [
55795            "https://www.googleapis.com/auth/cloud-platform",
55796            "https://www.googleapis.com/auth/compute",
55797            "https://www.googleapis.com/auth/compute.readonly"
55798          ],
55799          "description": "Retrieves the list of instance group resources contained within the specified region."
55800        },
55801        "get": {
55802          "id": "compute.regionInstanceGroups.get",
55803          "path": "projects/{project}/regions/{region}/instanceGroups/{instanceGroup}",
55804          "flatPath": "projects/{project}/regions/{region}/instanceGroups/{instanceGroup}",
55805          "httpMethod": "GET",
55806          "parameters": {
55807            "instanceGroup": {
55808              "description": "Name of the instance group resource to return.",
55809              "location": "path",
55810              "required": true,
55811              "type": "string"
55812            },
55813            "project": {
55814              "description": "Project ID for this request.",
55815              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55816              "location": "path",
55817              "required": true,
55818              "type": "string"
55819            },
55820            "region": {
55821              "description": "Name of the region scoping this request.",
55822              "location": "path",
55823              "required": true,
55824              "type": "string"
55825            }
55826          },
55827          "parameterOrder": [
55828            "project",
55829            "region",
55830            "instanceGroup"
55831          ],
55832          "response": {
55833            "$ref": "InstanceGroup"
55834          },
55835          "scopes": [
55836            "https://www.googleapis.com/auth/cloud-platform",
55837            "https://www.googleapis.com/auth/compute",
55838            "https://www.googleapis.com/auth/compute.readonly"
55839          ],
55840          "description": "Returns the specified instance group resource."
55841        },
55842        "listInstances": {
55843          "id": "compute.regionInstanceGroups.listInstances",
55844          "path": "projects/{project}/regions/{region}/instanceGroups/{instanceGroup}/listInstances",
55845          "flatPath": "projects/{project}/regions/{region}/instanceGroups/{instanceGroup}/listInstances",
55846          "httpMethod": "POST",
55847          "parameters": {
55848            "filter": {
55849              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
55850              "location": "query",
55851              "type": "string"
55852            },
55853            "instanceGroup": {
55854              "description": "Name of the regional instance group for which we want to list the instances.",
55855              "location": "path",
55856              "required": true,
55857              "type": "string"
55858            },
55859            "maxResults": {
55860              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
55861              "default": "500",
55862              "minimum": "0",
55863              "location": "query",
55864              "type": "integer",
55865              "format": "uint32"
55866            },
55867            "orderBy": {
55868              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
55869              "location": "query",
55870              "type": "string"
55871            },
55872            "pageToken": {
55873              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
55874              "location": "query",
55875              "type": "string"
55876            },
55877            "project": {
55878              "description": "Project ID for this request.",
55879              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55880              "location": "path",
55881              "required": true,
55882              "type": "string"
55883            },
55884            "region": {
55885              "description": "Name of the region scoping this request.",
55886              "location": "path",
55887              "required": true,
55888              "type": "string"
55889            },
55890            "returnPartialSuccess": {
55891              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
55892              "location": "query",
55893              "type": "boolean"
55894            }
55895          },
55896          "parameterOrder": [
55897            "project",
55898            "region",
55899            "instanceGroup"
55900          ],
55901          "request": {
55902            "$ref": "RegionInstanceGroupsListInstancesRequest"
55903          },
55904          "response": {
55905            "$ref": "RegionInstanceGroupsListInstances"
55906          },
55907          "scopes": [
55908            "https://www.googleapis.com/auth/cloud-platform",
55909            "https://www.googleapis.com/auth/compute",
55910            "https://www.googleapis.com/auth/compute.readonly"
55911          ],
55912          "description": "Lists the instances in the specified instance group and displays information about the named ports. Depending on the specified options, this method can list all instances or only the instances that are running. The orderBy query parameter is not supported."
55913        },
55914        "setNamedPorts": {
55915          "id": "compute.regionInstanceGroups.setNamedPorts",
55916          "path": "projects/{project}/regions/{region}/instanceGroups/{instanceGroup}/setNamedPorts",
55917          "flatPath": "projects/{project}/regions/{region}/instanceGroups/{instanceGroup}/setNamedPorts",
55918          "httpMethod": "POST",
55919          "parameters": {
55920            "instanceGroup": {
55921              "description": "The name of the regional instance group where the named ports are updated.",
55922              "location": "path",
55923              "required": true,
55924              "type": "string"
55925            },
55926            "project": {
55927              "description": "Project ID for this request.",
55928              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55929              "location": "path",
55930              "required": true,
55931              "type": "string"
55932            },
55933            "region": {
55934              "description": "Name of the region scoping this request.",
55935              "location": "path",
55936              "required": true,
55937              "type": "string"
55938            },
55939            "requestId": {
55940              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
55941              "location": "query",
55942              "type": "string"
55943            }
55944          },
55945          "parameterOrder": [
55946            "project",
55947            "region",
55948            "instanceGroup"
55949          ],
55950          "request": {
55951            "$ref": "RegionInstanceGroupsSetNamedPortsRequest"
55952          },
55953          "response": {
55954            "$ref": "Operation"
55955          },
55956          "scopes": [
55957            "https://www.googleapis.com/auth/cloud-platform",
55958            "https://www.googleapis.com/auth/compute"
55959          ],
55960          "description": "Sets the named ports for the specified regional instance group."
55961        }
55962      }
55963    },
55964    "instanceGroupManagers": {
55965      "methods": {
55966        "list": {
55967          "id": "compute.instanceGroupManagers.list",
55968          "path": "projects/{project}/zones/{zone}/instanceGroupManagers",
55969          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers",
55970          "httpMethod": "GET",
55971          "parameters": {
55972            "filter": {
55973              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
55974              "location": "query",
55975              "type": "string"
55976            },
55977            "maxResults": {
55978              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
55979              "default": "500",
55980              "minimum": "0",
55981              "location": "query",
55982              "type": "integer",
55983              "format": "uint32"
55984            },
55985            "orderBy": {
55986              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
55987              "location": "query",
55988              "type": "string"
55989            },
55990            "pageToken": {
55991              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
55992              "location": "query",
55993              "type": "string"
55994            },
55995            "project": {
55996              "description": "Project ID for this request.",
55997              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
55998              "location": "path",
55999              "required": true,
56000              "type": "string"
56001            },
56002            "returnPartialSuccess": {
56003              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
56004              "location": "query",
56005              "type": "boolean"
56006            },
56007            "zone": {
56008              "description": "The name of the zone where the managed instance group is located.",
56009              "location": "path",
56010              "required": true,
56011              "type": "string"
56012            }
56013          },
56014          "parameterOrder": [
56015            "project",
56016            "zone"
56017          ],
56018          "response": {
56019            "$ref": "InstanceGroupManagerList"
56020          },
56021          "scopes": [
56022            "https://www.googleapis.com/auth/cloud-platform",
56023            "https://www.googleapis.com/auth/compute",
56024            "https://www.googleapis.com/auth/compute.readonly"
56025          ],
56026          "description": "Retrieves a list of managed instance groups that are contained within the specified project and zone."
56027        },
56028        "aggregatedList": {
56029          "id": "compute.instanceGroupManagers.aggregatedList",
56030          "path": "projects/{project}/aggregated/instanceGroupManagers",
56031          "flatPath": "projects/{project}/aggregated/instanceGroupManagers",
56032          "httpMethod": "GET",
56033          "parameters": {
56034            "filter": {
56035              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
56036              "location": "query",
56037              "type": "string"
56038            },
56039            "includeAllScopes": {
56040              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
56041              "location": "query",
56042              "type": "boolean"
56043            },
56044            "maxResults": {
56045              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
56046              "default": "500",
56047              "minimum": "0",
56048              "location": "query",
56049              "type": "integer",
56050              "format": "uint32"
56051            },
56052            "orderBy": {
56053              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
56054              "location": "query",
56055              "type": "string"
56056            },
56057            "pageToken": {
56058              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
56059              "location": "query",
56060              "type": "string"
56061            },
56062            "project": {
56063              "description": "Project ID for this request.",
56064              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56065              "location": "path",
56066              "required": true,
56067              "type": "string"
56068            },
56069            "returnPartialSuccess": {
56070              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
56071              "location": "query",
56072              "type": "boolean"
56073            },
56074            "serviceProjectNumber": {
56075              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
56076              "location": "query",
56077              "type": "string",
56078              "format": "int64"
56079            }
56080          },
56081          "parameterOrder": [
56082            "project"
56083          ],
56084          "response": {
56085            "$ref": "InstanceGroupManagerAggregatedList"
56086          },
56087          "scopes": [
56088            "https://www.googleapis.com/auth/cloud-platform",
56089            "https://www.googleapis.com/auth/compute",
56090            "https://www.googleapis.com/auth/compute.readonly"
56091          ],
56092          "description": "Retrieves the list of managed instance groups and groups them by zone. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
56093        },
56094        "get": {
56095          "id": "compute.instanceGroupManagers.get",
56096          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}",
56097          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}",
56098          "httpMethod": "GET",
56099          "parameters": {
56100            "instanceGroupManager": {
56101              "description": "The name of the managed instance group.",
56102              "location": "path",
56103              "required": true,
56104              "type": "string"
56105            },
56106            "project": {
56107              "description": "Project ID for this request.",
56108              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56109              "location": "path",
56110              "required": true,
56111              "type": "string"
56112            },
56113            "zone": {
56114              "description": "The name of the zone where the managed instance group is located.",
56115              "location": "path",
56116              "required": true,
56117              "type": "string"
56118            }
56119          },
56120          "parameterOrder": [
56121            "project",
56122            "zone",
56123            "instanceGroupManager"
56124          ],
56125          "response": {
56126            "$ref": "InstanceGroupManager"
56127          },
56128          "scopes": [
56129            "https://www.googleapis.com/auth/cloud-platform",
56130            "https://www.googleapis.com/auth/compute",
56131            "https://www.googleapis.com/auth/compute.readonly"
56132          ],
56133          "description": "Returns all of the details about the specified managed instance group."
56134        },
56135        "insert": {
56136          "id": "compute.instanceGroupManagers.insert",
56137          "path": "projects/{project}/zones/{zone}/instanceGroupManagers",
56138          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers",
56139          "httpMethod": "POST",
56140          "parameters": {
56141            "project": {
56142              "description": "Project ID for this request.",
56143              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56144              "location": "path",
56145              "required": true,
56146              "type": "string"
56147            },
56148            "requestId": {
56149              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
56150              "location": "query",
56151              "type": "string"
56152            },
56153            "zone": {
56154              "description": "The name of the zone where you want to create the managed instance group.",
56155              "location": "path",
56156              "required": true,
56157              "type": "string"
56158            }
56159          },
56160          "parameterOrder": [
56161            "project",
56162            "zone"
56163          ],
56164          "request": {
56165            "$ref": "InstanceGroupManager"
56166          },
56167          "response": {
56168            "$ref": "Operation"
56169          },
56170          "scopes": [
56171            "https://www.googleapis.com/auth/cloud-platform",
56172            "https://www.googleapis.com/auth/compute"
56173          ],
56174          "description": "Creates a managed instance group using the information that you specify in the request. After the group is created, instances in the group are created using the specified instance template. This operation is marked as DONE when the group is created even if the instances in the group have not yet been created. You must separately verify the status of the individual instances with the listmanagedinstances method. A managed instance group can have up to 1000 VM instances per group. Please contact Cloud Support if you need an increase in this limit."
56175        },
56176        "patch": {
56177          "id": "compute.instanceGroupManagers.patch",
56178          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}",
56179          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}",
56180          "httpMethod": "PATCH",
56181          "parameters": {
56182            "instanceGroupManager": {
56183              "description": "The name of the instance group manager.",
56184              "location": "path",
56185              "required": true,
56186              "type": "string"
56187            },
56188            "project": {
56189              "description": "Project ID for this request.",
56190              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56191              "location": "path",
56192              "required": true,
56193              "type": "string"
56194            },
56195            "requestId": {
56196              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
56197              "location": "query",
56198              "type": "string"
56199            },
56200            "zone": {
56201              "description": "The name of the zone where you want to create the managed instance group.",
56202              "location": "path",
56203              "required": true,
56204              "type": "string"
56205            }
56206          },
56207          "parameterOrder": [
56208            "project",
56209            "zone",
56210            "instanceGroupManager"
56211          ],
56212          "request": {
56213            "$ref": "InstanceGroupManager"
56214          },
56215          "response": {
56216            "$ref": "Operation"
56217          },
56218          "scopes": [
56219            "https://www.googleapis.com/auth/cloud-platform",
56220            "https://www.googleapis.com/auth/compute"
56221          ],
56222          "description": "Updates a managed instance group using the information that you specify in the request. This operation is marked as DONE when the group is patched even if the instances in the group are still in the process of being patched. You must separately verify the status of the individual instances with the listManagedInstances method. This method supports PATCH semantics and uses the JSON merge patch format and processing rules. If you update your group to specify a new template or instance configuration, it's possible that your intended specification for each VM in the group is different from the current state of that VM. To learn how to apply an updated configuration to the VMs in a MIG, see Updating instances in a MIG."
56223        },
56224        "delete": {
56225          "id": "compute.instanceGroupManagers.delete",
56226          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}",
56227          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}",
56228          "httpMethod": "DELETE",
56229          "parameters": {
56230            "instanceGroupManager": {
56231              "description": "The name of the managed instance group to delete.",
56232              "location": "path",
56233              "required": true,
56234              "type": "string"
56235            },
56236            "project": {
56237              "description": "Project ID for this request.",
56238              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56239              "location": "path",
56240              "required": true,
56241              "type": "string"
56242            },
56243            "requestId": {
56244              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
56245              "location": "query",
56246              "type": "string"
56247            },
56248            "zone": {
56249              "description": "The name of the zone where the managed instance group is located.",
56250              "location": "path",
56251              "required": true,
56252              "type": "string"
56253            }
56254          },
56255          "parameterOrder": [
56256            "project",
56257            "zone",
56258            "instanceGroupManager"
56259          ],
56260          "response": {
56261            "$ref": "Operation"
56262          },
56263          "scopes": [
56264            "https://www.googleapis.com/auth/cloud-platform",
56265            "https://www.googleapis.com/auth/compute"
56266          ],
56267          "description": "Deletes the specified managed instance group and all of the instances in that group. Note that the instance group must not belong to a backend service. Read Deleting an instance group for more information."
56268        },
56269        "deleteInstances": {
56270          "id": "compute.instanceGroupManagers.deleteInstances",
56271          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/deleteInstances",
56272          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/deleteInstances",
56273          "httpMethod": "POST",
56274          "parameters": {
56275            "instanceGroupManager": {
56276              "description": "The name of the managed instance group.",
56277              "location": "path",
56278              "required": true,
56279              "type": "string"
56280            },
56281            "project": {
56282              "description": "Project ID for this request.",
56283              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56284              "location": "path",
56285              "required": true,
56286              "type": "string"
56287            },
56288            "requestId": {
56289              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
56290              "location": "query",
56291              "type": "string"
56292            },
56293            "zone": {
56294              "description": "The name of the zone where the managed instance group is located.",
56295              "location": "path",
56296              "required": true,
56297              "type": "string"
56298            }
56299          },
56300          "parameterOrder": [
56301            "project",
56302            "zone",
56303            "instanceGroupManager"
56304          ],
56305          "request": {
56306            "$ref": "InstanceGroupManagersDeleteInstancesRequest"
56307          },
56308          "response": {
56309            "$ref": "Operation"
56310          },
56311          "scopes": [
56312            "https://www.googleapis.com/auth/cloud-platform",
56313            "https://www.googleapis.com/auth/compute"
56314          ],
56315          "description": "Flags the specified instances in the managed instance group for immediate deletion. The instances are also removed from any target pools of which they were a member. This method reduces the targetSize of the managed instance group by the number of instances that you delete. This operation is marked as DONE when the action is scheduled even if the instances are still being deleted. You must separately verify the status of the deleting action with the listmanagedinstances method. If the group is part of a backend service that has enabled connection draining, it can take up to 60 seconds after the connection draining duration has elapsed before the VM instance is removed or deleted. You can specify a maximum of 1000 instances with this method per request."
56316        },
56317        "abandonInstances": {
56318          "id": "compute.instanceGroupManagers.abandonInstances",
56319          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/abandonInstances",
56320          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/abandonInstances",
56321          "httpMethod": "POST",
56322          "parameters": {
56323            "instanceGroupManager": {
56324              "description": "The name of the managed instance group.",
56325              "location": "path",
56326              "required": true,
56327              "type": "string"
56328            },
56329            "project": {
56330              "description": "Project ID for this request.",
56331              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56332              "location": "path",
56333              "required": true,
56334              "type": "string"
56335            },
56336            "requestId": {
56337              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
56338              "location": "query",
56339              "type": "string"
56340            },
56341            "zone": {
56342              "description": "The name of the zone where the managed instance group is located.",
56343              "location": "path",
56344              "required": true,
56345              "type": "string"
56346            }
56347          },
56348          "parameterOrder": [
56349            "project",
56350            "zone",
56351            "instanceGroupManager"
56352          ],
56353          "request": {
56354            "$ref": "InstanceGroupManagersAbandonInstancesRequest"
56355          },
56356          "response": {
56357            "$ref": "Operation"
56358          },
56359          "scopes": [
56360            "https://www.googleapis.com/auth/cloud-platform",
56361            "https://www.googleapis.com/auth/compute"
56362          ],
56363          "description": "Flags the specified instances to be removed from the managed instance group. Abandoning an instance does not delete the instance, but it does remove the instance from any target pools that are applied by the managed instance group. This method reduces the targetSize of the managed instance group by the number of instances that you abandon. This operation is marked as DONE when the action is scheduled even if the instances have not yet been removed from the group. You must separately verify the status of the abandoning action with the listmanagedinstances method. If the group is part of a backend service that has enabled connection draining, it can take up to 60 seconds after the connection draining duration has elapsed before the VM instance is removed or deleted. You can specify a maximum of 1000 instances with this method per request."
56364        },
56365        "recreateInstances": {
56366          "id": "compute.instanceGroupManagers.recreateInstances",
56367          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/recreateInstances",
56368          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/recreateInstances",
56369          "httpMethod": "POST",
56370          "parameters": {
56371            "instanceGroupManager": {
56372              "description": "The name of the managed instance group.",
56373              "location": "path",
56374              "required": true,
56375              "type": "string"
56376            },
56377            "project": {
56378              "description": "Project ID for this request.",
56379              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56380              "location": "path",
56381              "required": true,
56382              "type": "string"
56383            },
56384            "requestId": {
56385              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
56386              "location": "query",
56387              "type": "string"
56388            },
56389            "zone": {
56390              "description": "The name of the zone where the managed instance group is located.",
56391              "location": "path",
56392              "required": true,
56393              "type": "string"
56394            }
56395          },
56396          "parameterOrder": [
56397            "project",
56398            "zone",
56399            "instanceGroupManager"
56400          ],
56401          "request": {
56402            "$ref": "InstanceGroupManagersRecreateInstancesRequest"
56403          },
56404          "response": {
56405            "$ref": "Operation"
56406          },
56407          "scopes": [
56408            "https://www.googleapis.com/auth/cloud-platform",
56409            "https://www.googleapis.com/auth/compute"
56410          ],
56411          "description": "Flags the specified VM instances in the managed instance group to be immediately recreated. Each instance is recreated using the group's current configuration. This operation is marked as DONE when the flag is set even if the instances have not yet been recreated. You must separately verify the status of each instance by checking its currentAction field; for more information, see Checking the status of managed instances. If the group is part of a backend service that has enabled connection draining, it can take up to 60 seconds after the connection draining duration has elapsed before the VM instance is removed or deleted. You can specify a maximum of 1000 instances with this method per request."
56412        },
56413        "resize": {
56414          "id": "compute.instanceGroupManagers.resize",
56415          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/resize",
56416          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/resize",
56417          "httpMethod": "POST",
56418          "parameters": {
56419            "instanceGroupManager": {
56420              "description": "The name of the managed instance group.",
56421              "location": "path",
56422              "required": true,
56423              "type": "string"
56424            },
56425            "project": {
56426              "description": "Project ID for this request.",
56427              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56428              "location": "path",
56429              "required": true,
56430              "type": "string"
56431            },
56432            "requestId": {
56433              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
56434              "location": "query",
56435              "type": "string"
56436            },
56437            "size": {
56438              "description": "The number of running instances that the managed instance group should maintain at any given time. The group automatically adds or removes instances to maintain the number of instances specified by this parameter.",
56439              "location": "query",
56440              "required": true,
56441              "type": "integer",
56442              "format": "int32"
56443            },
56444            "zone": {
56445              "description": "The name of the zone where the managed instance group is located.",
56446              "location": "path",
56447              "required": true,
56448              "type": "string"
56449            }
56450          },
56451          "parameterOrder": [
56452            "project",
56453            "zone",
56454            "instanceGroupManager",
56455            "size"
56456          ],
56457          "response": {
56458            "$ref": "Operation"
56459          },
56460          "scopes": [
56461            "https://www.googleapis.com/auth/cloud-platform",
56462            "https://www.googleapis.com/auth/compute"
56463          ],
56464          "description": "Resizes the managed instance group. If you increase the size, the group creates new instances using the current instance template. If you decrease the size, the group deletes instances. The resize operation is marked DONE when the resize actions are scheduled even if the group has not yet added or deleted any instances. You must separately verify the status of the creating or deleting actions with the listmanagedinstances method. When resizing down, the instance group arbitrarily chooses the order in which VMs are deleted. The group takes into account some VM attributes when making the selection including: + The status of the VM instance. + The health of the VM instance. + The instance template version the VM is based on. + For regional managed instance groups, the location of the VM instance. This list is subject to change. If the group is part of a backend service that has enabled connection draining, it can take up to 60 seconds after the connection draining duration has elapsed before the VM instance is removed or deleted."
56465        },
56466        "setInstanceTemplate": {
56467          "id": "compute.instanceGroupManagers.setInstanceTemplate",
56468          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/setInstanceTemplate",
56469          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/setInstanceTemplate",
56470          "httpMethod": "POST",
56471          "parameters": {
56472            "instanceGroupManager": {
56473              "description": "The name of the managed instance group.",
56474              "location": "path",
56475              "required": true,
56476              "type": "string"
56477            },
56478            "project": {
56479              "description": "Project ID for this request.",
56480              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56481              "location": "path",
56482              "required": true,
56483              "type": "string"
56484            },
56485            "requestId": {
56486              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
56487              "location": "query",
56488              "type": "string"
56489            },
56490            "zone": {
56491              "description": "The name of the zone where the managed instance group is located.",
56492              "location": "path",
56493              "required": true,
56494              "type": "string"
56495            }
56496          },
56497          "parameterOrder": [
56498            "project",
56499            "zone",
56500            "instanceGroupManager"
56501          ],
56502          "request": {
56503            "$ref": "InstanceGroupManagersSetInstanceTemplateRequest"
56504          },
56505          "response": {
56506            "$ref": "Operation"
56507          },
56508          "scopes": [
56509            "https://www.googleapis.com/auth/cloud-platform",
56510            "https://www.googleapis.com/auth/compute"
56511          ],
56512          "description": "Specifies the instance template to use when creating new instances in this group. The templates for existing instances in the group do not change unless you run recreateInstances, run applyUpdatesToInstances, or set the group's updatePolicy.type to PROACTIVE."
56513        },
56514        "setTargetPools": {
56515          "id": "compute.instanceGroupManagers.setTargetPools",
56516          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/setTargetPools",
56517          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/setTargetPools",
56518          "httpMethod": "POST",
56519          "parameters": {
56520            "instanceGroupManager": {
56521              "description": "The name of the managed instance group.",
56522              "location": "path",
56523              "required": true,
56524              "type": "string"
56525            },
56526            "project": {
56527              "description": "Project ID for this request.",
56528              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56529              "location": "path",
56530              "required": true,
56531              "type": "string"
56532            },
56533            "requestId": {
56534              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
56535              "location": "query",
56536              "type": "string"
56537            },
56538            "zone": {
56539              "description": "The name of the zone where the managed instance group is located.",
56540              "location": "path",
56541              "required": true,
56542              "type": "string"
56543            }
56544          },
56545          "parameterOrder": [
56546            "project",
56547            "zone",
56548            "instanceGroupManager"
56549          ],
56550          "request": {
56551            "$ref": "InstanceGroupManagersSetTargetPoolsRequest"
56552          },
56553          "response": {
56554            "$ref": "Operation"
56555          },
56556          "scopes": [
56557            "https://www.googleapis.com/auth/cloud-platform",
56558            "https://www.googleapis.com/auth/compute"
56559          ],
56560          "description": "Modifies the target pools to which all instances in this managed instance group are assigned. The target pools automatically apply to all of the instances in the managed instance group. This operation is marked DONE when you make the request even if the instances have not yet been added to their target pools. The change might take some time to apply to all of the instances in the group depending on the size of the group."
56561        },
56562        "listManagedInstances": {
56563          "id": "compute.instanceGroupManagers.listManagedInstances",
56564          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/listManagedInstances",
56565          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/listManagedInstances",
56566          "httpMethod": "POST",
56567          "parameters": {
56568            "filter": {
56569              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
56570              "location": "query",
56571              "type": "string"
56572            },
56573            "instanceGroupManager": {
56574              "description": "The name of the managed instance group.",
56575              "location": "path",
56576              "required": true,
56577              "type": "string"
56578            },
56579            "maxResults": {
56580              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
56581              "default": "500",
56582              "minimum": "0",
56583              "location": "query",
56584              "type": "integer",
56585              "format": "uint32"
56586            },
56587            "orderBy": {
56588              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
56589              "location": "query",
56590              "type": "string"
56591            },
56592            "pageToken": {
56593              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
56594              "location": "query",
56595              "type": "string"
56596            },
56597            "project": {
56598              "description": "Project ID for this request.",
56599              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56600              "location": "path",
56601              "required": true,
56602              "type": "string"
56603            },
56604            "returnPartialSuccess": {
56605              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
56606              "location": "query",
56607              "type": "boolean"
56608            },
56609            "zone": {
56610              "description": "The name of the zone where the managed instance group is located.",
56611              "location": "path",
56612              "required": true,
56613              "type": "string"
56614            }
56615          },
56616          "parameterOrder": [
56617            "project",
56618            "zone",
56619            "instanceGroupManager"
56620          ],
56621          "response": {
56622            "$ref": "InstanceGroupManagersListManagedInstancesResponse"
56623          },
56624          "scopes": [
56625            "https://www.googleapis.com/auth/cloud-platform",
56626            "https://www.googleapis.com/auth/compute",
56627            "https://www.googleapis.com/auth/compute.readonly"
56628          ],
56629          "description": "Lists all of the instances in the managed instance group. Each instance in the list has a currentAction, which indicates the action that the managed instance group is performing on the instance. For example, if the group is still creating an instance, the currentAction is CREATING. If a previous action failed, the list displays the errors for that failed action. The orderBy query parameter is not supported. The `pageToken` query parameter is supported only if the group's `listManagedInstancesResults` field is set to `PAGINATED`."
56630        },
56631        "listErrors": {
56632          "id": "compute.instanceGroupManagers.listErrors",
56633          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/listErrors",
56634          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/listErrors",
56635          "httpMethod": "GET",
56636          "parameters": {
56637            "filter": {
56638              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
56639              "location": "query",
56640              "type": "string"
56641            },
56642            "instanceGroupManager": {
56643              "description": "The name of the managed instance group. It must be a string that meets the requirements in RFC1035, or an unsigned long integer: must match regexp pattern: (?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?)|1-9{0,19}.",
56644              "location": "path",
56645              "required": true,
56646              "type": "string"
56647            },
56648            "maxResults": {
56649              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
56650              "default": "500",
56651              "minimum": "0",
56652              "location": "query",
56653              "type": "integer",
56654              "format": "uint32"
56655            },
56656            "orderBy": {
56657              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
56658              "location": "query",
56659              "type": "string"
56660            },
56661            "pageToken": {
56662              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
56663              "location": "query",
56664              "type": "string"
56665            },
56666            "project": {
56667              "description": "Project ID for this request.",
56668              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56669              "location": "path",
56670              "required": true,
56671              "type": "string"
56672            },
56673            "returnPartialSuccess": {
56674              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
56675              "location": "query",
56676              "type": "boolean"
56677            },
56678            "zone": {
56679              "description": "The name of the zone where the managed instance group is located. It should conform to RFC1035.",
56680              "location": "path",
56681              "required": true,
56682              "type": "string"
56683            }
56684          },
56685          "parameterOrder": [
56686            "project",
56687            "zone",
56688            "instanceGroupManager"
56689          ],
56690          "response": {
56691            "$ref": "InstanceGroupManagersListErrorsResponse"
56692          },
56693          "scopes": [
56694            "https://www.googleapis.com/auth/cloud-platform",
56695            "https://www.googleapis.com/auth/compute",
56696            "https://www.googleapis.com/auth/compute.readonly"
56697          ],
56698          "description": "Lists all errors thrown by actions on instances for a given managed instance group. The filter and orderBy query parameters are not supported."
56699        },
56700        "listPerInstanceConfigs": {
56701          "id": "compute.instanceGroupManagers.listPerInstanceConfigs",
56702          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/listPerInstanceConfigs",
56703          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/listPerInstanceConfigs",
56704          "httpMethod": "POST",
56705          "parameters": {
56706            "filter": {
56707              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
56708              "location": "query",
56709              "type": "string"
56710            },
56711            "instanceGroupManager": {
56712              "description": "The name of the managed instance group. It should conform to RFC1035.",
56713              "location": "path",
56714              "required": true,
56715              "type": "string"
56716            },
56717            "maxResults": {
56718              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
56719              "default": "500",
56720              "minimum": "0",
56721              "location": "query",
56722              "type": "integer",
56723              "format": "uint32"
56724            },
56725            "orderBy": {
56726              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
56727              "location": "query",
56728              "type": "string"
56729            },
56730            "pageToken": {
56731              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
56732              "location": "query",
56733              "type": "string"
56734            },
56735            "project": {
56736              "description": "Project ID for this request.",
56737              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56738              "location": "path",
56739              "required": true,
56740              "type": "string"
56741            },
56742            "returnPartialSuccess": {
56743              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
56744              "location": "query",
56745              "type": "boolean"
56746            },
56747            "zone": {
56748              "description": "The name of the zone where the managed instance group is located. It should conform to RFC1035.",
56749              "location": "path",
56750              "required": true,
56751              "type": "string"
56752            }
56753          },
56754          "parameterOrder": [
56755            "project",
56756            "zone",
56757            "instanceGroupManager"
56758          ],
56759          "response": {
56760            "$ref": "InstanceGroupManagersListPerInstanceConfigsResp"
56761          },
56762          "scopes": [
56763            "https://www.googleapis.com/auth/cloud-platform",
56764            "https://www.googleapis.com/auth/compute",
56765            "https://www.googleapis.com/auth/compute.readonly"
56766          ],
56767          "description": "Lists all of the per-instance configurations defined for the managed instance group. The orderBy query parameter is not supported."
56768        },
56769        "updatePerInstanceConfigs": {
56770          "id": "compute.instanceGroupManagers.updatePerInstanceConfigs",
56771          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/updatePerInstanceConfigs",
56772          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/updatePerInstanceConfigs",
56773          "httpMethod": "POST",
56774          "parameters": {
56775            "instanceGroupManager": {
56776              "description": "The name of the managed instance group. It should conform to RFC1035.",
56777              "location": "path",
56778              "required": true,
56779              "type": "string"
56780            },
56781            "project": {
56782              "description": "Project ID for this request.",
56783              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56784              "location": "path",
56785              "required": true,
56786              "type": "string"
56787            },
56788            "requestId": {
56789              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
56790              "location": "query",
56791              "type": "string"
56792            },
56793            "zone": {
56794              "description": "The name of the zone where the managed instance group is located. It should conform to RFC1035.",
56795              "location": "path",
56796              "required": true,
56797              "type": "string"
56798            }
56799          },
56800          "parameterOrder": [
56801            "project",
56802            "zone",
56803            "instanceGroupManager"
56804          ],
56805          "request": {
56806            "$ref": "InstanceGroupManagersUpdatePerInstanceConfigsReq"
56807          },
56808          "response": {
56809            "$ref": "Operation"
56810          },
56811          "scopes": [
56812            "https://www.googleapis.com/auth/cloud-platform",
56813            "https://www.googleapis.com/auth/compute"
56814          ],
56815          "description": "Inserts or updates per-instance configurations for the managed instance group. perInstanceConfig.name serves as a key used to distinguish whether to perform insert or patch."
56816        },
56817        "patchPerInstanceConfigs": {
56818          "id": "compute.instanceGroupManagers.patchPerInstanceConfigs",
56819          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/patchPerInstanceConfigs",
56820          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/patchPerInstanceConfigs",
56821          "httpMethod": "POST",
56822          "parameters": {
56823            "instanceGroupManager": {
56824              "description": "The name of the managed instance group. It should conform to RFC1035.",
56825              "location": "path",
56826              "required": true,
56827              "type": "string"
56828            },
56829            "project": {
56830              "description": "Project ID for this request.",
56831              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56832              "location": "path",
56833              "required": true,
56834              "type": "string"
56835            },
56836            "requestId": {
56837              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
56838              "location": "query",
56839              "type": "string"
56840            },
56841            "zone": {
56842              "description": "The name of the zone where the managed instance group is located. It should conform to RFC1035.",
56843              "location": "path",
56844              "required": true,
56845              "type": "string"
56846            }
56847          },
56848          "parameterOrder": [
56849            "project",
56850            "zone",
56851            "instanceGroupManager"
56852          ],
56853          "request": {
56854            "$ref": "InstanceGroupManagersPatchPerInstanceConfigsReq"
56855          },
56856          "response": {
56857            "$ref": "Operation"
56858          },
56859          "scopes": [
56860            "https://www.googleapis.com/auth/cloud-platform",
56861            "https://www.googleapis.com/auth/compute"
56862          ],
56863          "description": "Inserts or patches per-instance configurations for the managed instance group. perInstanceConfig.name serves as a key used to distinguish whether to perform insert or patch."
56864        },
56865        "deletePerInstanceConfigs": {
56866          "id": "compute.instanceGroupManagers.deletePerInstanceConfigs",
56867          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/deletePerInstanceConfigs",
56868          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/deletePerInstanceConfigs",
56869          "httpMethod": "POST",
56870          "parameters": {
56871            "instanceGroupManager": {
56872              "description": "The name of the managed instance group. It should conform to RFC1035.",
56873              "location": "path",
56874              "required": true,
56875              "type": "string"
56876            },
56877            "project": {
56878              "description": "Project ID for this request.",
56879              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56880              "location": "path",
56881              "required": true,
56882              "type": "string"
56883            },
56884            "zone": {
56885              "description": "The name of the zone where the managed instance group is located. It should conform to RFC1035.",
56886              "location": "path",
56887              "required": true,
56888              "type": "string"
56889            }
56890          },
56891          "parameterOrder": [
56892            "project",
56893            "zone",
56894            "instanceGroupManager"
56895          ],
56896          "request": {
56897            "$ref": "InstanceGroupManagersDeletePerInstanceConfigsReq"
56898          },
56899          "response": {
56900            "$ref": "Operation"
56901          },
56902          "scopes": [
56903            "https://www.googleapis.com/auth/cloud-platform",
56904            "https://www.googleapis.com/auth/compute"
56905          ],
56906          "description": "Deletes selected per-instance configurations for the managed instance group."
56907        },
56908        "applyUpdatesToInstances": {
56909          "id": "compute.instanceGroupManagers.applyUpdatesToInstances",
56910          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/applyUpdatesToInstances",
56911          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/applyUpdatesToInstances",
56912          "httpMethod": "POST",
56913          "parameters": {
56914            "instanceGroupManager": {
56915              "description": "The name of the managed instance group, should conform to RFC1035.",
56916              "location": "path",
56917              "required": true,
56918              "type": "string"
56919            },
56920            "project": {
56921              "description": "Project ID for this request.",
56922              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56923              "location": "path",
56924              "required": true,
56925              "type": "string"
56926            },
56927            "zone": {
56928              "description": "The name of the zone where the managed instance group is located. Should conform to RFC1035.",
56929              "location": "path",
56930              "required": true,
56931              "type": "string"
56932            }
56933          },
56934          "parameterOrder": [
56935            "project",
56936            "zone",
56937            "instanceGroupManager"
56938          ],
56939          "request": {
56940            "$ref": "InstanceGroupManagersApplyUpdatesRequest"
56941          },
56942          "response": {
56943            "$ref": "Operation"
56944          },
56945          "scopes": [
56946            "https://www.googleapis.com/auth/cloud-platform",
56947            "https://www.googleapis.com/auth/compute"
56948          ],
56949          "description": "Applies changes to selected instances on the managed instance group. This method can be used to apply new overrides and/or new versions."
56950        },
56951        "createInstances": {
56952          "id": "compute.instanceGroupManagers.createInstances",
56953          "path": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/createInstances",
56954          "flatPath": "projects/{project}/zones/{zone}/instanceGroupManagers/{instanceGroupManager}/createInstances",
56955          "httpMethod": "POST",
56956          "parameters": {
56957            "instanceGroupManager": {
56958              "description": "The name of the managed instance group. It should conform to RFC1035.",
56959              "location": "path",
56960              "required": true,
56961              "type": "string"
56962            },
56963            "project": {
56964              "description": "Project ID for this request.",
56965              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
56966              "location": "path",
56967              "required": true,
56968              "type": "string"
56969            },
56970            "requestId": {
56971              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
56972              "location": "query",
56973              "type": "string"
56974            },
56975            "zone": {
56976              "description": "The name of the zone where the managed instance group is located. It should conform to RFC1035.",
56977              "location": "path",
56978              "required": true,
56979              "type": "string"
56980            }
56981          },
56982          "parameterOrder": [
56983            "project",
56984            "zone",
56985            "instanceGroupManager"
56986          ],
56987          "request": {
56988            "$ref": "InstanceGroupManagersCreateInstancesRequest"
56989          },
56990          "response": {
56991            "$ref": "Operation"
56992          },
56993          "scopes": [
56994            "https://www.googleapis.com/auth/cloud-platform",
56995            "https://www.googleapis.com/auth/compute"
56996          ],
56997          "description": "Creates instances with per-instance configurations in this managed instance group. Instances are created using the current instance template. The create instances operation is marked DONE if the createInstances request is successful. The underlying actions take additional time. You must separately verify the status of the creating or actions with the listmanagedinstances method."
56998        }
56999      }
57000    },
57001    "regionInstanceGroupManagers": {
57002      "methods": {
57003        "list": {
57004          "id": "compute.regionInstanceGroupManagers.list",
57005          "path": "projects/{project}/regions/{region}/instanceGroupManagers",
57006          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers",
57007          "httpMethod": "GET",
57008          "parameters": {
57009            "filter": {
57010              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
57011              "location": "query",
57012              "type": "string"
57013            },
57014            "maxResults": {
57015              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
57016              "default": "500",
57017              "minimum": "0",
57018              "location": "query",
57019              "type": "integer",
57020              "format": "uint32"
57021            },
57022            "orderBy": {
57023              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
57024              "location": "query",
57025              "type": "string"
57026            },
57027            "pageToken": {
57028              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
57029              "location": "query",
57030              "type": "string"
57031            },
57032            "project": {
57033              "description": "Project ID for this request.",
57034              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57035              "location": "path",
57036              "required": true,
57037              "type": "string"
57038            },
57039            "region": {
57040              "description": "Name of the region scoping this request.",
57041              "location": "path",
57042              "required": true,
57043              "type": "string"
57044            },
57045            "returnPartialSuccess": {
57046              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
57047              "location": "query",
57048              "type": "boolean"
57049            }
57050          },
57051          "parameterOrder": [
57052            "project",
57053            "region"
57054          ],
57055          "response": {
57056            "$ref": "RegionInstanceGroupManagerList"
57057          },
57058          "scopes": [
57059            "https://www.googleapis.com/auth/cloud-platform",
57060            "https://www.googleapis.com/auth/compute",
57061            "https://www.googleapis.com/auth/compute.readonly"
57062          ],
57063          "description": "Retrieves the list of managed instance groups that are contained within the specified region."
57064        },
57065        "get": {
57066          "id": "compute.regionInstanceGroupManagers.get",
57067          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}",
57068          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}",
57069          "httpMethod": "GET",
57070          "parameters": {
57071            "instanceGroupManager": {
57072              "description": "Name of the managed instance group to return.",
57073              "location": "path",
57074              "required": true,
57075              "type": "string"
57076            },
57077            "project": {
57078              "description": "Project ID for this request.",
57079              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57080              "location": "path",
57081              "required": true,
57082              "type": "string"
57083            },
57084            "region": {
57085              "description": "Name of the region scoping this request.",
57086              "location": "path",
57087              "required": true,
57088              "type": "string"
57089            }
57090          },
57091          "parameterOrder": [
57092            "project",
57093            "region",
57094            "instanceGroupManager"
57095          ],
57096          "response": {
57097            "$ref": "InstanceGroupManager"
57098          },
57099          "scopes": [
57100            "https://www.googleapis.com/auth/cloud-platform",
57101            "https://www.googleapis.com/auth/compute",
57102            "https://www.googleapis.com/auth/compute.readonly"
57103          ],
57104          "description": "Returns all of the details about the specified managed instance group."
57105        },
57106        "insert": {
57107          "id": "compute.regionInstanceGroupManagers.insert",
57108          "path": "projects/{project}/regions/{region}/instanceGroupManagers",
57109          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers",
57110          "httpMethod": "POST",
57111          "parameters": {
57112            "project": {
57113              "description": "Project ID for this request.",
57114              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57115              "location": "path",
57116              "required": true,
57117              "type": "string"
57118            },
57119            "region": {
57120              "description": "Name of the region scoping this request.",
57121              "location": "path",
57122              "required": true,
57123              "type": "string"
57124            },
57125            "requestId": {
57126              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
57127              "location": "query",
57128              "type": "string"
57129            }
57130          },
57131          "parameterOrder": [
57132            "project",
57133            "region"
57134          ],
57135          "request": {
57136            "$ref": "InstanceGroupManager"
57137          },
57138          "response": {
57139            "$ref": "Operation"
57140          },
57141          "scopes": [
57142            "https://www.googleapis.com/auth/cloud-platform",
57143            "https://www.googleapis.com/auth/compute"
57144          ],
57145          "description": "Creates a managed instance group using the information that you specify in the request. After the group is created, instances in the group are created using the specified instance template. This operation is marked as DONE when the group is created even if the instances in the group have not yet been created. You must separately verify the status of the individual instances with the listmanagedinstances method. A regional managed instance group can contain up to 2000 instances."
57146        },
57147        "patch": {
57148          "id": "compute.regionInstanceGroupManagers.patch",
57149          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}",
57150          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}",
57151          "httpMethod": "PATCH",
57152          "parameters": {
57153            "instanceGroupManager": {
57154              "description": "The name of the instance group manager.",
57155              "location": "path",
57156              "required": true,
57157              "type": "string"
57158            },
57159            "project": {
57160              "description": "Project ID for this request.",
57161              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57162              "location": "path",
57163              "required": true,
57164              "type": "string"
57165            },
57166            "region": {
57167              "description": "Name of the region scoping this request.",
57168              "location": "path",
57169              "required": true,
57170              "type": "string"
57171            },
57172            "requestId": {
57173              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
57174              "location": "query",
57175              "type": "string"
57176            }
57177          },
57178          "parameterOrder": [
57179            "project",
57180            "region",
57181            "instanceGroupManager"
57182          ],
57183          "request": {
57184            "$ref": "InstanceGroupManager"
57185          },
57186          "response": {
57187            "$ref": "Operation"
57188          },
57189          "scopes": [
57190            "https://www.googleapis.com/auth/cloud-platform",
57191            "https://www.googleapis.com/auth/compute"
57192          ],
57193          "description": "Updates a managed instance group using the information that you specify in the request. This operation is marked as DONE when the group is patched even if the instances in the group are still in the process of being patched. You must separately verify the status of the individual instances with the listmanagedinstances method. This method supports PATCH semantics and uses the JSON merge patch format and processing rules. If you update your group to specify a new template or instance configuration, it's possible that your intended specification for each VM in the group is different from the current state of that VM. To learn how to apply an updated configuration to the VMs in a MIG, see Updating instances in a MIG."
57194        },
57195        "delete": {
57196          "id": "compute.regionInstanceGroupManagers.delete",
57197          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}",
57198          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}",
57199          "httpMethod": "DELETE",
57200          "parameters": {
57201            "instanceGroupManager": {
57202              "description": "Name of the managed instance group to delete.",
57203              "location": "path",
57204              "required": true,
57205              "type": "string"
57206            },
57207            "project": {
57208              "description": "Project ID for this request.",
57209              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57210              "location": "path",
57211              "required": true,
57212              "type": "string"
57213            },
57214            "region": {
57215              "description": "Name of the region scoping this request.",
57216              "location": "path",
57217              "required": true,
57218              "type": "string"
57219            },
57220            "requestId": {
57221              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
57222              "location": "query",
57223              "type": "string"
57224            }
57225          },
57226          "parameterOrder": [
57227            "project",
57228            "region",
57229            "instanceGroupManager"
57230          ],
57231          "response": {
57232            "$ref": "Operation"
57233          },
57234          "scopes": [
57235            "https://www.googleapis.com/auth/cloud-platform",
57236            "https://www.googleapis.com/auth/compute"
57237          ],
57238          "description": "Deletes the specified managed instance group and all of the instances in that group."
57239        },
57240        "deleteInstances": {
57241          "id": "compute.regionInstanceGroupManagers.deleteInstances",
57242          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/deleteInstances",
57243          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/deleteInstances",
57244          "httpMethod": "POST",
57245          "parameters": {
57246            "instanceGroupManager": {
57247              "description": "Name of the managed instance group.",
57248              "location": "path",
57249              "required": true,
57250              "type": "string"
57251            },
57252            "project": {
57253              "description": "Project ID for this request.",
57254              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57255              "location": "path",
57256              "required": true,
57257              "type": "string"
57258            },
57259            "region": {
57260              "description": "Name of the region scoping this request.",
57261              "location": "path",
57262              "required": true,
57263              "type": "string"
57264            },
57265            "requestId": {
57266              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
57267              "location": "query",
57268              "type": "string"
57269            }
57270          },
57271          "parameterOrder": [
57272            "project",
57273            "region",
57274            "instanceGroupManager"
57275          ],
57276          "request": {
57277            "$ref": "RegionInstanceGroupManagersDeleteInstancesRequest"
57278          },
57279          "response": {
57280            "$ref": "Operation"
57281          },
57282          "scopes": [
57283            "https://www.googleapis.com/auth/cloud-platform",
57284            "https://www.googleapis.com/auth/compute"
57285          ],
57286          "description": "Flags the specified instances in the managed instance group to be immediately deleted. The instances are also removed from any target pools of which they were a member. This method reduces the targetSize of the managed instance group by the number of instances that you delete. The deleteInstances operation is marked DONE if the deleteInstances request is successful. The underlying actions take additional time. You must separately verify the status of the deleting action with the listmanagedinstances method. If the group is part of a backend service that has enabled connection draining, it can take up to 60 seconds after the connection draining duration has elapsed before the VM instance is removed or deleted. You can specify a maximum of 1000 instances with this method per request."
57287        },
57288        "abandonInstances": {
57289          "id": "compute.regionInstanceGroupManagers.abandonInstances",
57290          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/abandonInstances",
57291          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/abandonInstances",
57292          "httpMethod": "POST",
57293          "parameters": {
57294            "instanceGroupManager": {
57295              "description": "Name of the managed instance group.",
57296              "location": "path",
57297              "required": true,
57298              "type": "string"
57299            },
57300            "project": {
57301              "description": "Project ID for this request.",
57302              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57303              "location": "path",
57304              "required": true,
57305              "type": "string"
57306            },
57307            "region": {
57308              "description": "Name of the region scoping this request.",
57309              "location": "path",
57310              "required": true,
57311              "type": "string"
57312            },
57313            "requestId": {
57314              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
57315              "location": "query",
57316              "type": "string"
57317            }
57318          },
57319          "parameterOrder": [
57320            "project",
57321            "region",
57322            "instanceGroupManager"
57323          ],
57324          "request": {
57325            "$ref": "RegionInstanceGroupManagersAbandonInstancesRequest"
57326          },
57327          "response": {
57328            "$ref": "Operation"
57329          },
57330          "scopes": [
57331            "https://www.googleapis.com/auth/cloud-platform",
57332            "https://www.googleapis.com/auth/compute"
57333          ],
57334          "description": "Flags the specified instances to be immediately removed from the managed instance group. Abandoning an instance does not delete the instance, but it does remove the instance from any target pools that are applied by the managed instance group. This method reduces the targetSize of the managed instance group by the number of instances that you abandon. This operation is marked as DONE when the action is scheduled even if the instances have not yet been removed from the group. You must separately verify the status of the abandoning action with the listmanagedinstances method. If the group is part of a backend service that has enabled connection draining, it can take up to 60 seconds after the connection draining duration has elapsed before the VM instance is removed or deleted. You can specify a maximum of 1000 instances with this method per request."
57335        },
57336        "recreateInstances": {
57337          "id": "compute.regionInstanceGroupManagers.recreateInstances",
57338          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/recreateInstances",
57339          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/recreateInstances",
57340          "httpMethod": "POST",
57341          "parameters": {
57342            "instanceGroupManager": {
57343              "description": "Name of the managed instance group.",
57344              "location": "path",
57345              "required": true,
57346              "type": "string"
57347            },
57348            "project": {
57349              "description": "Project ID for this request.",
57350              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57351              "location": "path",
57352              "required": true,
57353              "type": "string"
57354            },
57355            "region": {
57356              "description": "Name of the region scoping this request.",
57357              "location": "path",
57358              "required": true,
57359              "type": "string"
57360            },
57361            "requestId": {
57362              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
57363              "location": "query",
57364              "type": "string"
57365            }
57366          },
57367          "parameterOrder": [
57368            "project",
57369            "region",
57370            "instanceGroupManager"
57371          ],
57372          "request": {
57373            "$ref": "RegionInstanceGroupManagersRecreateRequest"
57374          },
57375          "response": {
57376            "$ref": "Operation"
57377          },
57378          "scopes": [
57379            "https://www.googleapis.com/auth/cloud-platform",
57380            "https://www.googleapis.com/auth/compute"
57381          ],
57382          "description": "Flags the specified VM instances in the managed instance group to be immediately recreated. Each instance is recreated using the group's current configuration. This operation is marked as DONE when the flag is set even if the instances have not yet been recreated. You must separately verify the status of each instance by checking its currentAction field; for more information, see Checking the status of managed instances. If the group is part of a backend service that has enabled connection draining, it can take up to 60 seconds after the connection draining duration has elapsed before the VM instance is removed or deleted. You can specify a maximum of 1000 instances with this method per request."
57383        },
57384        "resize": {
57385          "id": "compute.regionInstanceGroupManagers.resize",
57386          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/resize",
57387          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/resize",
57388          "httpMethod": "POST",
57389          "parameters": {
57390            "instanceGroupManager": {
57391              "description": "Name of the managed instance group.",
57392              "location": "path",
57393              "required": true,
57394              "type": "string"
57395            },
57396            "project": {
57397              "description": "Project ID for this request.",
57398              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57399              "location": "path",
57400              "required": true,
57401              "type": "string"
57402            },
57403            "region": {
57404              "description": "Name of the region scoping this request.",
57405              "location": "path",
57406              "required": true,
57407              "type": "string"
57408            },
57409            "requestId": {
57410              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
57411              "location": "query",
57412              "type": "string"
57413            },
57414            "size": {
57415              "description": "Number of instances that should exist in this instance group manager.",
57416              "minimum": "0",
57417              "location": "query",
57418              "required": true,
57419              "type": "integer",
57420              "format": "int32"
57421            }
57422          },
57423          "parameterOrder": [
57424            "project",
57425            "region",
57426            "instanceGroupManager",
57427            "size"
57428          ],
57429          "response": {
57430            "$ref": "Operation"
57431          },
57432          "scopes": [
57433            "https://www.googleapis.com/auth/cloud-platform",
57434            "https://www.googleapis.com/auth/compute"
57435          ],
57436          "description": "Changes the intended size of the managed instance group. If you increase the size, the group creates new instances using the current instance template. If you decrease the size, the group deletes one or more instances. The resize operation is marked DONE if the resize request is successful. The underlying actions take additional time. You must separately verify the status of the creating or deleting actions with the listmanagedinstances method. If the group is part of a backend service that has enabled connection draining, it can take up to 60 seconds after the connection draining duration has elapsed before the VM instance is removed or deleted."
57437        },
57438        "setInstanceTemplate": {
57439          "id": "compute.regionInstanceGroupManagers.setInstanceTemplate",
57440          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/setInstanceTemplate",
57441          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/setInstanceTemplate",
57442          "httpMethod": "POST",
57443          "parameters": {
57444            "instanceGroupManager": {
57445              "description": "The name of the managed instance group.",
57446              "location": "path",
57447              "required": true,
57448              "type": "string"
57449            },
57450            "project": {
57451              "description": "Project ID for this request.",
57452              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57453              "location": "path",
57454              "required": true,
57455              "type": "string"
57456            },
57457            "region": {
57458              "description": "Name of the region scoping this request.",
57459              "location": "path",
57460              "required": true,
57461              "type": "string"
57462            },
57463            "requestId": {
57464              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
57465              "location": "query",
57466              "type": "string"
57467            }
57468          },
57469          "parameterOrder": [
57470            "project",
57471            "region",
57472            "instanceGroupManager"
57473          ],
57474          "request": {
57475            "$ref": "RegionInstanceGroupManagersSetTemplateRequest"
57476          },
57477          "response": {
57478            "$ref": "Operation"
57479          },
57480          "scopes": [
57481            "https://www.googleapis.com/auth/cloud-platform",
57482            "https://www.googleapis.com/auth/compute"
57483          ],
57484          "description": "Sets the instance template to use when creating new instances or recreating instances in this group. Existing instances are not affected."
57485        },
57486        "setTargetPools": {
57487          "id": "compute.regionInstanceGroupManagers.setTargetPools",
57488          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/setTargetPools",
57489          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/setTargetPools",
57490          "httpMethod": "POST",
57491          "parameters": {
57492            "instanceGroupManager": {
57493              "description": "Name of the managed instance group.",
57494              "location": "path",
57495              "required": true,
57496              "type": "string"
57497            },
57498            "project": {
57499              "description": "Project ID for this request.",
57500              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57501              "location": "path",
57502              "required": true,
57503              "type": "string"
57504            },
57505            "region": {
57506              "description": "Name of the region scoping this request.",
57507              "location": "path",
57508              "required": true,
57509              "type": "string"
57510            },
57511            "requestId": {
57512              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
57513              "location": "query",
57514              "type": "string"
57515            }
57516          },
57517          "parameterOrder": [
57518            "project",
57519            "region",
57520            "instanceGroupManager"
57521          ],
57522          "request": {
57523            "$ref": "RegionInstanceGroupManagersSetTargetPoolsRequest"
57524          },
57525          "response": {
57526            "$ref": "Operation"
57527          },
57528          "scopes": [
57529            "https://www.googleapis.com/auth/cloud-platform",
57530            "https://www.googleapis.com/auth/compute"
57531          ],
57532          "description": "Modifies the target pools to which all new instances in this group are assigned. Existing instances in the group are not affected."
57533        },
57534        "listManagedInstances": {
57535          "id": "compute.regionInstanceGroupManagers.listManagedInstances",
57536          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/listManagedInstances",
57537          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/listManagedInstances",
57538          "httpMethod": "POST",
57539          "parameters": {
57540            "filter": {
57541              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
57542              "location": "query",
57543              "type": "string"
57544            },
57545            "instanceGroupManager": {
57546              "description": "The name of the managed instance group.",
57547              "location": "path",
57548              "required": true,
57549              "type": "string"
57550            },
57551            "maxResults": {
57552              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
57553              "default": "500",
57554              "minimum": "0",
57555              "location": "query",
57556              "type": "integer",
57557              "format": "uint32"
57558            },
57559            "orderBy": {
57560              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
57561              "location": "query",
57562              "type": "string"
57563            },
57564            "pageToken": {
57565              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
57566              "location": "query",
57567              "type": "string"
57568            },
57569            "project": {
57570              "description": "Project ID for this request.",
57571              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57572              "location": "path",
57573              "required": true,
57574              "type": "string"
57575            },
57576            "region": {
57577              "description": "Name of the region scoping this request.",
57578              "location": "path",
57579              "required": true,
57580              "type": "string"
57581            },
57582            "returnPartialSuccess": {
57583              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
57584              "location": "query",
57585              "type": "boolean"
57586            }
57587          },
57588          "parameterOrder": [
57589            "project",
57590            "region",
57591            "instanceGroupManager"
57592          ],
57593          "response": {
57594            "$ref": "RegionInstanceGroupManagersListInstancesResponse"
57595          },
57596          "scopes": [
57597            "https://www.googleapis.com/auth/cloud-platform",
57598            "https://www.googleapis.com/auth/compute",
57599            "https://www.googleapis.com/auth/compute.readonly"
57600          ],
57601          "description": "Lists the instances in the managed instance group and instances that are scheduled to be created. The list includes any current actions that the group has scheduled for its instances. The orderBy query parameter is not supported. The `pageToken` query parameter is supported only if the group's `listManagedInstancesResults` field is set to `PAGINATED`."
57602        },
57603        "listErrors": {
57604          "id": "compute.regionInstanceGroupManagers.listErrors",
57605          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/listErrors",
57606          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/listErrors",
57607          "httpMethod": "GET",
57608          "parameters": {
57609            "filter": {
57610              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
57611              "location": "query",
57612              "type": "string"
57613            },
57614            "instanceGroupManager": {
57615              "description": "The name of the managed instance group. It must be a string that meets the requirements in RFC1035, or an unsigned long integer: must match regexp pattern: (?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?)|1-9{0,19}.",
57616              "location": "path",
57617              "required": true,
57618              "type": "string"
57619            },
57620            "maxResults": {
57621              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
57622              "default": "500",
57623              "minimum": "0",
57624              "location": "query",
57625              "type": "integer",
57626              "format": "uint32"
57627            },
57628            "orderBy": {
57629              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
57630              "location": "query",
57631              "type": "string"
57632            },
57633            "pageToken": {
57634              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
57635              "location": "query",
57636              "type": "string"
57637            },
57638            "project": {
57639              "description": "Project ID for this request.",
57640              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57641              "location": "path",
57642              "required": true,
57643              "type": "string"
57644            },
57645            "region": {
57646              "description": "Name of the region scoping this request. This should conform to RFC1035.",
57647              "location": "path",
57648              "required": true,
57649              "type": "string"
57650            },
57651            "returnPartialSuccess": {
57652              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
57653              "location": "query",
57654              "type": "boolean"
57655            }
57656          },
57657          "parameterOrder": [
57658            "project",
57659            "region",
57660            "instanceGroupManager"
57661          ],
57662          "response": {
57663            "$ref": "RegionInstanceGroupManagersListErrorsResponse"
57664          },
57665          "scopes": [
57666            "https://www.googleapis.com/auth/cloud-platform",
57667            "https://www.googleapis.com/auth/compute",
57668            "https://www.googleapis.com/auth/compute.readonly"
57669          ],
57670          "description": "Lists all errors thrown by actions on instances for a given regional managed instance group. The filter and orderBy query parameters are not supported."
57671        },
57672        "listPerInstanceConfigs": {
57673          "id": "compute.regionInstanceGroupManagers.listPerInstanceConfigs",
57674          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/listPerInstanceConfigs",
57675          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/listPerInstanceConfigs",
57676          "httpMethod": "POST",
57677          "parameters": {
57678            "filter": {
57679              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
57680              "location": "query",
57681              "type": "string"
57682            },
57683            "instanceGroupManager": {
57684              "description": "The name of the managed instance group. It should conform to RFC1035.",
57685              "location": "path",
57686              "required": true,
57687              "type": "string"
57688            },
57689            "maxResults": {
57690              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
57691              "default": "500",
57692              "minimum": "0",
57693              "location": "query",
57694              "type": "integer",
57695              "format": "uint32"
57696            },
57697            "orderBy": {
57698              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
57699              "location": "query",
57700              "type": "string"
57701            },
57702            "pageToken": {
57703              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
57704              "location": "query",
57705              "type": "string"
57706            },
57707            "project": {
57708              "description": "Project ID for this request.",
57709              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57710              "location": "path",
57711              "required": true,
57712              "type": "string"
57713            },
57714            "region": {
57715              "description": "Name of the region scoping this request, should conform to RFC1035.",
57716              "location": "path",
57717              "required": true,
57718              "type": "string"
57719            },
57720            "returnPartialSuccess": {
57721              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
57722              "location": "query",
57723              "type": "boolean"
57724            }
57725          },
57726          "parameterOrder": [
57727            "project",
57728            "region",
57729            "instanceGroupManager"
57730          ],
57731          "response": {
57732            "$ref": "RegionInstanceGroupManagersListInstanceConfigsResp"
57733          },
57734          "scopes": [
57735            "https://www.googleapis.com/auth/cloud-platform",
57736            "https://www.googleapis.com/auth/compute",
57737            "https://www.googleapis.com/auth/compute.readonly"
57738          ],
57739          "description": "Lists all of the per-instance configurations defined for the managed instance group. The orderBy query parameter is not supported."
57740        },
57741        "updatePerInstanceConfigs": {
57742          "id": "compute.regionInstanceGroupManagers.updatePerInstanceConfigs",
57743          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/updatePerInstanceConfigs",
57744          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/updatePerInstanceConfigs",
57745          "httpMethod": "POST",
57746          "parameters": {
57747            "instanceGroupManager": {
57748              "description": "The name of the managed instance group. It should conform to RFC1035.",
57749              "location": "path",
57750              "required": true,
57751              "type": "string"
57752            },
57753            "project": {
57754              "description": "Project ID for this request.",
57755              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57756              "location": "path",
57757              "required": true,
57758              "type": "string"
57759            },
57760            "region": {
57761              "description": "Name of the region scoping this request, should conform to RFC1035.",
57762              "location": "path",
57763              "required": true,
57764              "type": "string"
57765            },
57766            "requestId": {
57767              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
57768              "location": "query",
57769              "type": "string"
57770            }
57771          },
57772          "parameterOrder": [
57773            "project",
57774            "region",
57775            "instanceGroupManager"
57776          ],
57777          "request": {
57778            "$ref": "RegionInstanceGroupManagerUpdateInstanceConfigReq"
57779          },
57780          "response": {
57781            "$ref": "Operation"
57782          },
57783          "scopes": [
57784            "https://www.googleapis.com/auth/cloud-platform",
57785            "https://www.googleapis.com/auth/compute"
57786          ],
57787          "description": "Inserts or updates per-instance configurations for the managed instance group. perInstanceConfig.name serves as a key used to distinguish whether to perform insert or patch."
57788        },
57789        "patchPerInstanceConfigs": {
57790          "id": "compute.regionInstanceGroupManagers.patchPerInstanceConfigs",
57791          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/patchPerInstanceConfigs",
57792          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/patchPerInstanceConfigs",
57793          "httpMethod": "POST",
57794          "parameters": {
57795            "instanceGroupManager": {
57796              "description": "The name of the managed instance group. It should conform to RFC1035.",
57797              "location": "path",
57798              "required": true,
57799              "type": "string"
57800            },
57801            "project": {
57802              "description": "Project ID for this request.",
57803              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57804              "location": "path",
57805              "required": true,
57806              "type": "string"
57807            },
57808            "region": {
57809              "description": "Name of the region scoping this request, should conform to RFC1035.",
57810              "location": "path",
57811              "required": true,
57812              "type": "string"
57813            },
57814            "requestId": {
57815              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
57816              "location": "query",
57817              "type": "string"
57818            }
57819          },
57820          "parameterOrder": [
57821            "project",
57822            "region",
57823            "instanceGroupManager"
57824          ],
57825          "request": {
57826            "$ref": "RegionInstanceGroupManagerPatchInstanceConfigReq"
57827          },
57828          "response": {
57829            "$ref": "Operation"
57830          },
57831          "scopes": [
57832            "https://www.googleapis.com/auth/cloud-platform",
57833            "https://www.googleapis.com/auth/compute"
57834          ],
57835          "description": "Inserts or patches per-instance configurations for the managed instance group. perInstanceConfig.name serves as a key used to distinguish whether to perform insert or patch."
57836        },
57837        "deletePerInstanceConfigs": {
57838          "id": "compute.regionInstanceGroupManagers.deletePerInstanceConfigs",
57839          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/deletePerInstanceConfigs",
57840          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/deletePerInstanceConfigs",
57841          "httpMethod": "POST",
57842          "parameters": {
57843            "instanceGroupManager": {
57844              "description": "The name of the managed instance group. It should conform to RFC1035.",
57845              "location": "path",
57846              "required": true,
57847              "type": "string"
57848            },
57849            "project": {
57850              "description": "Project ID for this request.",
57851              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57852              "location": "path",
57853              "required": true,
57854              "type": "string"
57855            },
57856            "region": {
57857              "description": "Name of the region scoping this request, should conform to RFC1035.",
57858              "location": "path",
57859              "required": true,
57860              "type": "string"
57861            }
57862          },
57863          "parameterOrder": [
57864            "project",
57865            "region",
57866            "instanceGroupManager"
57867          ],
57868          "request": {
57869            "$ref": "RegionInstanceGroupManagerDeleteInstanceConfigReq"
57870          },
57871          "response": {
57872            "$ref": "Operation"
57873          },
57874          "scopes": [
57875            "https://www.googleapis.com/auth/cloud-platform",
57876            "https://www.googleapis.com/auth/compute"
57877          ],
57878          "description": "Deletes selected per-instance configurations for the managed instance group."
57879        },
57880        "applyUpdatesToInstances": {
57881          "id": "compute.regionInstanceGroupManagers.applyUpdatesToInstances",
57882          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/applyUpdatesToInstances",
57883          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/applyUpdatesToInstances",
57884          "httpMethod": "POST",
57885          "parameters": {
57886            "instanceGroupManager": {
57887              "description": "The name of the managed instance group, should conform to RFC1035.",
57888              "location": "path",
57889              "required": true,
57890              "type": "string"
57891            },
57892            "project": {
57893              "description": "Project ID for this request.",
57894              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57895              "location": "path",
57896              "required": true,
57897              "type": "string"
57898            },
57899            "region": {
57900              "description": "Name of the region scoping this request, should conform to RFC1035.",
57901              "location": "path",
57902              "required": true,
57903              "type": "string"
57904            }
57905          },
57906          "parameterOrder": [
57907            "project",
57908            "region",
57909            "instanceGroupManager"
57910          ],
57911          "request": {
57912            "$ref": "RegionInstanceGroupManagersApplyUpdatesRequest"
57913          },
57914          "response": {
57915            "$ref": "Operation"
57916          },
57917          "scopes": [
57918            "https://www.googleapis.com/auth/cloud-platform",
57919            "https://www.googleapis.com/auth/compute"
57920          ],
57921          "description": "Apply updates to selected instances the managed instance group."
57922        },
57923        "createInstances": {
57924          "id": "compute.regionInstanceGroupManagers.createInstances",
57925          "path": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/createInstances",
57926          "flatPath": "projects/{project}/regions/{region}/instanceGroupManagers/{instanceGroupManager}/createInstances",
57927          "httpMethod": "POST",
57928          "parameters": {
57929            "instanceGroupManager": {
57930              "description": "The name of the managed instance group. It should conform to RFC1035.",
57931              "location": "path",
57932              "required": true,
57933              "type": "string"
57934            },
57935            "project": {
57936              "description": "Project ID for this request.",
57937              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
57938              "location": "path",
57939              "required": true,
57940              "type": "string"
57941            },
57942            "region": {
57943              "description": "The name of the region where the managed instance group is located. It should conform to RFC1035.",
57944              "location": "path",
57945              "required": true,
57946              "type": "string"
57947            },
57948            "requestId": {
57949              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
57950              "location": "query",
57951              "type": "string"
57952            }
57953          },
57954          "parameterOrder": [
57955            "project",
57956            "region",
57957            "instanceGroupManager"
57958          ],
57959          "request": {
57960            "$ref": "RegionInstanceGroupManagersCreateInstancesRequest"
57961          },
57962          "response": {
57963            "$ref": "Operation"
57964          },
57965          "scopes": [
57966            "https://www.googleapis.com/auth/cloud-platform",
57967            "https://www.googleapis.com/auth/compute"
57968          ],
57969          "description": "Creates instances with per-instance configurations in this regional managed instance group. Instances are created using the current instance template. The create instances operation is marked DONE if the createInstances request is successful. The underlying actions take additional time. You must separately verify the status of the creating or actions with the listmanagedinstances method."
57970        }
57971      }
57972    },
57973    "autoscalers": {
57974      "methods": {
57975        "list": {
57976          "id": "compute.autoscalers.list",
57977          "path": "projects/{project}/zones/{zone}/autoscalers",
57978          "flatPath": "projects/{project}/zones/{zone}/autoscalers",
57979          "httpMethod": "GET",
57980          "parameters": {
57981            "filter": {
57982              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
57983              "location": "query",
57984              "type": "string"
57985            },
57986            "maxResults": {
57987              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
57988              "default": "500",
57989              "minimum": "0",
57990              "location": "query",
57991              "type": "integer",
57992              "format": "uint32"
57993            },
57994            "orderBy": {
57995              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
57996              "location": "query",
57997              "type": "string"
57998            },
57999            "pageToken": {
58000              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
58001              "location": "query",
58002              "type": "string"
58003            },
58004            "project": {
58005              "description": "Project ID for this request.",
58006              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58007              "location": "path",
58008              "required": true,
58009              "type": "string"
58010            },
58011            "returnPartialSuccess": {
58012              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
58013              "location": "query",
58014              "type": "boolean"
58015            },
58016            "zone": {
58017              "description": "Name of the zone for this request.",
58018              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
58019              "location": "path",
58020              "required": true,
58021              "type": "string"
58022            }
58023          },
58024          "parameterOrder": [
58025            "project",
58026            "zone"
58027          ],
58028          "response": {
58029            "$ref": "AutoscalerList"
58030          },
58031          "scopes": [
58032            "https://www.googleapis.com/auth/cloud-platform",
58033            "https://www.googleapis.com/auth/compute",
58034            "https://www.googleapis.com/auth/compute.readonly"
58035          ],
58036          "description": "Retrieves a list of autoscalers contained within the specified zone."
58037        },
58038        "aggregatedList": {
58039          "id": "compute.autoscalers.aggregatedList",
58040          "path": "projects/{project}/aggregated/autoscalers",
58041          "flatPath": "projects/{project}/aggregated/autoscalers",
58042          "httpMethod": "GET",
58043          "parameters": {
58044            "filter": {
58045              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
58046              "location": "query",
58047              "type": "string"
58048            },
58049            "includeAllScopes": {
58050              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
58051              "location": "query",
58052              "type": "boolean"
58053            },
58054            "maxResults": {
58055              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
58056              "default": "500",
58057              "minimum": "0",
58058              "location": "query",
58059              "type": "integer",
58060              "format": "uint32"
58061            },
58062            "orderBy": {
58063              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
58064              "location": "query",
58065              "type": "string"
58066            },
58067            "pageToken": {
58068              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
58069              "location": "query",
58070              "type": "string"
58071            },
58072            "project": {
58073              "description": "Project ID for this request.",
58074              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58075              "location": "path",
58076              "required": true,
58077              "type": "string"
58078            },
58079            "returnPartialSuccess": {
58080              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
58081              "location": "query",
58082              "type": "boolean"
58083            },
58084            "serviceProjectNumber": {
58085              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
58086              "location": "query",
58087              "type": "string",
58088              "format": "int64"
58089            }
58090          },
58091          "parameterOrder": [
58092            "project"
58093          ],
58094          "response": {
58095            "$ref": "AutoscalerAggregatedList"
58096          },
58097          "scopes": [
58098            "https://www.googleapis.com/auth/cloud-platform",
58099            "https://www.googleapis.com/auth/compute",
58100            "https://www.googleapis.com/auth/compute.readonly"
58101          ],
58102          "description": "Retrieves an aggregated list of autoscalers. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
58103        },
58104        "get": {
58105          "id": "compute.autoscalers.get",
58106          "path": "projects/{project}/zones/{zone}/autoscalers/{autoscaler}",
58107          "flatPath": "projects/{project}/zones/{zone}/autoscalers/{autoscaler}",
58108          "httpMethod": "GET",
58109          "parameters": {
58110            "autoscaler": {
58111              "description": "Name of the autoscaler to return.",
58112              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
58113              "location": "path",
58114              "required": true,
58115              "type": "string"
58116            },
58117            "project": {
58118              "description": "Project ID for this request.",
58119              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58120              "location": "path",
58121              "required": true,
58122              "type": "string"
58123            },
58124            "zone": {
58125              "description": "Name of the zone for this request.",
58126              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
58127              "location": "path",
58128              "required": true,
58129              "type": "string"
58130            }
58131          },
58132          "parameterOrder": [
58133            "project",
58134            "zone",
58135            "autoscaler"
58136          ],
58137          "response": {
58138            "$ref": "Autoscaler"
58139          },
58140          "scopes": [
58141            "https://www.googleapis.com/auth/cloud-platform",
58142            "https://www.googleapis.com/auth/compute",
58143            "https://www.googleapis.com/auth/compute.readonly"
58144          ],
58145          "description": "Returns the specified autoscaler resource."
58146        },
58147        "insert": {
58148          "id": "compute.autoscalers.insert",
58149          "path": "projects/{project}/zones/{zone}/autoscalers",
58150          "flatPath": "projects/{project}/zones/{zone}/autoscalers",
58151          "httpMethod": "POST",
58152          "parameters": {
58153            "project": {
58154              "description": "Project ID for this request.",
58155              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58156              "location": "path",
58157              "required": true,
58158              "type": "string"
58159            },
58160            "requestId": {
58161              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
58162              "location": "query",
58163              "type": "string"
58164            },
58165            "zone": {
58166              "description": "Name of the zone for this request.",
58167              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
58168              "location": "path",
58169              "required": true,
58170              "type": "string"
58171            }
58172          },
58173          "parameterOrder": [
58174            "project",
58175            "zone"
58176          ],
58177          "request": {
58178            "$ref": "Autoscaler"
58179          },
58180          "response": {
58181            "$ref": "Operation"
58182          },
58183          "scopes": [
58184            "https://www.googleapis.com/auth/cloud-platform",
58185            "https://www.googleapis.com/auth/compute"
58186          ],
58187          "description": "Creates an autoscaler in the specified project using the data included in the request."
58188        },
58189        "update": {
58190          "id": "compute.autoscalers.update",
58191          "path": "projects/{project}/zones/{zone}/autoscalers",
58192          "flatPath": "projects/{project}/zones/{zone}/autoscalers",
58193          "httpMethod": "PUT",
58194          "parameters": {
58195            "autoscaler": {
58196              "description": "Name of the autoscaler to update.",
58197              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
58198              "location": "query",
58199              "type": "string"
58200            },
58201            "project": {
58202              "description": "Project ID for this request.",
58203              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58204              "location": "path",
58205              "required": true,
58206              "type": "string"
58207            },
58208            "requestId": {
58209              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
58210              "location": "query",
58211              "type": "string"
58212            },
58213            "zone": {
58214              "description": "Name of the zone for this request.",
58215              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
58216              "location": "path",
58217              "required": true,
58218              "type": "string"
58219            }
58220          },
58221          "parameterOrder": [
58222            "project",
58223            "zone"
58224          ],
58225          "request": {
58226            "$ref": "Autoscaler"
58227          },
58228          "response": {
58229            "$ref": "Operation"
58230          },
58231          "scopes": [
58232            "https://www.googleapis.com/auth/cloud-platform",
58233            "https://www.googleapis.com/auth/compute"
58234          ],
58235          "description": "Updates an autoscaler in the specified project using the data included in the request."
58236        },
58237        "patch": {
58238          "id": "compute.autoscalers.patch",
58239          "path": "projects/{project}/zones/{zone}/autoscalers",
58240          "flatPath": "projects/{project}/zones/{zone}/autoscalers",
58241          "httpMethod": "PATCH",
58242          "parameters": {
58243            "autoscaler": {
58244              "description": "Name of the autoscaler to patch.",
58245              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
58246              "location": "query",
58247              "type": "string"
58248            },
58249            "project": {
58250              "description": "Project ID for this request.",
58251              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58252              "location": "path",
58253              "required": true,
58254              "type": "string"
58255            },
58256            "requestId": {
58257              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
58258              "location": "query",
58259              "type": "string"
58260            },
58261            "zone": {
58262              "description": "Name of the zone for this request.",
58263              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
58264              "location": "path",
58265              "required": true,
58266              "type": "string"
58267            }
58268          },
58269          "parameterOrder": [
58270            "project",
58271            "zone"
58272          ],
58273          "request": {
58274            "$ref": "Autoscaler"
58275          },
58276          "response": {
58277            "$ref": "Operation"
58278          },
58279          "scopes": [
58280            "https://www.googleapis.com/auth/cloud-platform",
58281            "https://www.googleapis.com/auth/compute"
58282          ],
58283          "description": "Updates an autoscaler in the specified project using the data included in the request. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
58284        },
58285        "delete": {
58286          "id": "compute.autoscalers.delete",
58287          "path": "projects/{project}/zones/{zone}/autoscalers/{autoscaler}",
58288          "flatPath": "projects/{project}/zones/{zone}/autoscalers/{autoscaler}",
58289          "httpMethod": "DELETE",
58290          "parameters": {
58291            "autoscaler": {
58292              "description": "Name of the autoscaler to delete.",
58293              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
58294              "location": "path",
58295              "required": true,
58296              "type": "string"
58297            },
58298            "project": {
58299              "description": "Project ID for this request.",
58300              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58301              "location": "path",
58302              "required": true,
58303              "type": "string"
58304            },
58305            "requestId": {
58306              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
58307              "location": "query",
58308              "type": "string"
58309            },
58310            "zone": {
58311              "description": "Name of the zone for this request.",
58312              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
58313              "location": "path",
58314              "required": true,
58315              "type": "string"
58316            }
58317          },
58318          "parameterOrder": [
58319            "project",
58320            "zone",
58321            "autoscaler"
58322          ],
58323          "response": {
58324            "$ref": "Operation"
58325          },
58326          "scopes": [
58327            "https://www.googleapis.com/auth/cloud-platform",
58328            "https://www.googleapis.com/auth/compute"
58329          ],
58330          "description": "Deletes the specified autoscaler."
58331        }
58332      }
58333    },
58334    "regionAutoscalers": {
58335      "methods": {
58336        "list": {
58337          "id": "compute.regionAutoscalers.list",
58338          "path": "projects/{project}/regions/{region}/autoscalers",
58339          "flatPath": "projects/{project}/regions/{region}/autoscalers",
58340          "httpMethod": "GET",
58341          "parameters": {
58342            "filter": {
58343              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
58344              "location": "query",
58345              "type": "string"
58346            },
58347            "maxResults": {
58348              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
58349              "default": "500",
58350              "minimum": "0",
58351              "location": "query",
58352              "type": "integer",
58353              "format": "uint32"
58354            },
58355            "orderBy": {
58356              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
58357              "location": "query",
58358              "type": "string"
58359            },
58360            "pageToken": {
58361              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
58362              "location": "query",
58363              "type": "string"
58364            },
58365            "project": {
58366              "description": "Project ID for this request.",
58367              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58368              "location": "path",
58369              "required": true,
58370              "type": "string"
58371            },
58372            "region": {
58373              "description": "Name of the region scoping this request.",
58374              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
58375              "location": "path",
58376              "required": true,
58377              "type": "string"
58378            },
58379            "returnPartialSuccess": {
58380              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
58381              "location": "query",
58382              "type": "boolean"
58383            }
58384          },
58385          "parameterOrder": [
58386            "project",
58387            "region"
58388          ],
58389          "response": {
58390            "$ref": "RegionAutoscalerList"
58391          },
58392          "scopes": [
58393            "https://www.googleapis.com/auth/cloud-platform",
58394            "https://www.googleapis.com/auth/compute",
58395            "https://www.googleapis.com/auth/compute.readonly"
58396          ],
58397          "description": "Retrieves a list of autoscalers contained within the specified region."
58398        },
58399        "get": {
58400          "id": "compute.regionAutoscalers.get",
58401          "path": "projects/{project}/regions/{region}/autoscalers/{autoscaler}",
58402          "flatPath": "projects/{project}/regions/{region}/autoscalers/{autoscaler}",
58403          "httpMethod": "GET",
58404          "parameters": {
58405            "autoscaler": {
58406              "description": "Name of the autoscaler to return.",
58407              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
58408              "location": "path",
58409              "required": true,
58410              "type": "string"
58411            },
58412            "project": {
58413              "description": "Project ID for this request.",
58414              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58415              "location": "path",
58416              "required": true,
58417              "type": "string"
58418            },
58419            "region": {
58420              "description": "Name of the region scoping this request.",
58421              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
58422              "location": "path",
58423              "required": true,
58424              "type": "string"
58425            }
58426          },
58427          "parameterOrder": [
58428            "project",
58429            "region",
58430            "autoscaler"
58431          ],
58432          "response": {
58433            "$ref": "Autoscaler"
58434          },
58435          "scopes": [
58436            "https://www.googleapis.com/auth/cloud-platform",
58437            "https://www.googleapis.com/auth/compute",
58438            "https://www.googleapis.com/auth/compute.readonly"
58439          ],
58440          "description": "Returns the specified autoscaler."
58441        },
58442        "insert": {
58443          "id": "compute.regionAutoscalers.insert",
58444          "path": "projects/{project}/regions/{region}/autoscalers",
58445          "flatPath": "projects/{project}/regions/{region}/autoscalers",
58446          "httpMethod": "POST",
58447          "parameters": {
58448            "project": {
58449              "description": "Project ID for this request.",
58450              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58451              "location": "path",
58452              "required": true,
58453              "type": "string"
58454            },
58455            "region": {
58456              "description": "Name of the region scoping this request.",
58457              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
58458              "location": "path",
58459              "required": true,
58460              "type": "string"
58461            },
58462            "requestId": {
58463              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
58464              "location": "query",
58465              "type": "string"
58466            }
58467          },
58468          "parameterOrder": [
58469            "project",
58470            "region"
58471          ],
58472          "request": {
58473            "$ref": "Autoscaler"
58474          },
58475          "response": {
58476            "$ref": "Operation"
58477          },
58478          "scopes": [
58479            "https://www.googleapis.com/auth/cloud-platform",
58480            "https://www.googleapis.com/auth/compute"
58481          ],
58482          "description": "Creates an autoscaler in the specified project using the data included in the request."
58483        },
58484        "update": {
58485          "id": "compute.regionAutoscalers.update",
58486          "path": "projects/{project}/regions/{region}/autoscalers",
58487          "flatPath": "projects/{project}/regions/{region}/autoscalers",
58488          "httpMethod": "PUT",
58489          "parameters": {
58490            "autoscaler": {
58491              "description": "Name of the autoscaler to update.",
58492              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
58493              "location": "query",
58494              "type": "string"
58495            },
58496            "project": {
58497              "description": "Project ID for this request.",
58498              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58499              "location": "path",
58500              "required": true,
58501              "type": "string"
58502            },
58503            "region": {
58504              "description": "Name of the region scoping this request.",
58505              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
58506              "location": "path",
58507              "required": true,
58508              "type": "string"
58509            },
58510            "requestId": {
58511              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
58512              "location": "query",
58513              "type": "string"
58514            }
58515          },
58516          "parameterOrder": [
58517            "project",
58518            "region"
58519          ],
58520          "request": {
58521            "$ref": "Autoscaler"
58522          },
58523          "response": {
58524            "$ref": "Operation"
58525          },
58526          "scopes": [
58527            "https://www.googleapis.com/auth/cloud-platform",
58528            "https://www.googleapis.com/auth/compute"
58529          ],
58530          "description": "Updates an autoscaler in the specified project using the data included in the request."
58531        },
58532        "patch": {
58533          "id": "compute.regionAutoscalers.patch",
58534          "path": "projects/{project}/regions/{region}/autoscalers",
58535          "flatPath": "projects/{project}/regions/{region}/autoscalers",
58536          "httpMethod": "PATCH",
58537          "parameters": {
58538            "autoscaler": {
58539              "description": "Name of the autoscaler to patch.",
58540              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
58541              "location": "query",
58542              "type": "string"
58543            },
58544            "project": {
58545              "description": "Project ID for this request.",
58546              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58547              "location": "path",
58548              "required": true,
58549              "type": "string"
58550            },
58551            "region": {
58552              "description": "Name of the region scoping this request.",
58553              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
58554              "location": "path",
58555              "required": true,
58556              "type": "string"
58557            },
58558            "requestId": {
58559              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
58560              "location": "query",
58561              "type": "string"
58562            }
58563          },
58564          "parameterOrder": [
58565            "project",
58566            "region"
58567          ],
58568          "request": {
58569            "$ref": "Autoscaler"
58570          },
58571          "response": {
58572            "$ref": "Operation"
58573          },
58574          "scopes": [
58575            "https://www.googleapis.com/auth/cloud-platform",
58576            "https://www.googleapis.com/auth/compute"
58577          ],
58578          "description": "Updates an autoscaler in the specified project using the data included in the request. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
58579        },
58580        "delete": {
58581          "id": "compute.regionAutoscalers.delete",
58582          "path": "projects/{project}/regions/{region}/autoscalers/{autoscaler}",
58583          "flatPath": "projects/{project}/regions/{region}/autoscalers/{autoscaler}",
58584          "httpMethod": "DELETE",
58585          "parameters": {
58586            "autoscaler": {
58587              "description": "Name of the autoscaler to delete.",
58588              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
58589              "location": "path",
58590              "required": true,
58591              "type": "string"
58592            },
58593            "project": {
58594              "description": "Project ID for this request.",
58595              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58596              "location": "path",
58597              "required": true,
58598              "type": "string"
58599            },
58600            "region": {
58601              "description": "Name of the region scoping this request.",
58602              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
58603              "location": "path",
58604              "required": true,
58605              "type": "string"
58606            },
58607            "requestId": {
58608              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
58609              "location": "query",
58610              "type": "string"
58611            }
58612          },
58613          "parameterOrder": [
58614            "project",
58615            "region",
58616            "autoscaler"
58617          ],
58618          "response": {
58619            "$ref": "Operation"
58620          },
58621          "scopes": [
58622            "https://www.googleapis.com/auth/cloud-platform",
58623            "https://www.googleapis.com/auth/compute"
58624          ],
58625          "description": "Deletes the specified autoscaler."
58626        }
58627      }
58628    },
58629    "backendBuckets": {
58630      "methods": {
58631        "list": {
58632          "id": "compute.backendBuckets.list",
58633          "path": "projects/{project}/global/backendBuckets",
58634          "flatPath": "projects/{project}/global/backendBuckets",
58635          "httpMethod": "GET",
58636          "parameters": {
58637            "filter": {
58638              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
58639              "location": "query",
58640              "type": "string"
58641            },
58642            "maxResults": {
58643              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
58644              "default": "500",
58645              "minimum": "0",
58646              "location": "query",
58647              "type": "integer",
58648              "format": "uint32"
58649            },
58650            "orderBy": {
58651              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
58652              "location": "query",
58653              "type": "string"
58654            },
58655            "pageToken": {
58656              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
58657              "location": "query",
58658              "type": "string"
58659            },
58660            "project": {
58661              "description": "Project ID for this request.",
58662              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58663              "location": "path",
58664              "required": true,
58665              "type": "string"
58666            },
58667            "returnPartialSuccess": {
58668              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
58669              "location": "query",
58670              "type": "boolean"
58671            }
58672          },
58673          "parameterOrder": [
58674            "project"
58675          ],
58676          "response": {
58677            "$ref": "BackendBucketList"
58678          },
58679          "scopes": [
58680            "https://www.googleapis.com/auth/cloud-platform",
58681            "https://www.googleapis.com/auth/compute",
58682            "https://www.googleapis.com/auth/compute.readonly"
58683          ],
58684          "description": "Retrieves the list of BackendBucket resources available to the specified project."
58685        },
58686        "get": {
58687          "id": "compute.backendBuckets.get",
58688          "path": "projects/{project}/global/backendBuckets/{backendBucket}",
58689          "flatPath": "projects/{project}/global/backendBuckets/{backendBucket}",
58690          "httpMethod": "GET",
58691          "parameters": {
58692            "backendBucket": {
58693              "description": "Name of the BackendBucket resource to return.",
58694              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
58695              "location": "path",
58696              "required": true,
58697              "type": "string"
58698            },
58699            "project": {
58700              "description": "Project ID for this request.",
58701              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58702              "location": "path",
58703              "required": true,
58704              "type": "string"
58705            }
58706          },
58707          "parameterOrder": [
58708            "project",
58709            "backendBucket"
58710          ],
58711          "response": {
58712            "$ref": "BackendBucket"
58713          },
58714          "scopes": [
58715            "https://www.googleapis.com/auth/cloud-platform",
58716            "https://www.googleapis.com/auth/compute",
58717            "https://www.googleapis.com/auth/compute.readonly"
58718          ],
58719          "description": "Returns the specified BackendBucket resource."
58720        },
58721        "insert": {
58722          "id": "compute.backendBuckets.insert",
58723          "path": "projects/{project}/global/backendBuckets",
58724          "flatPath": "projects/{project}/global/backendBuckets",
58725          "httpMethod": "POST",
58726          "parameters": {
58727            "project": {
58728              "description": "Project ID for this request.",
58729              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58730              "location": "path",
58731              "required": true,
58732              "type": "string"
58733            },
58734            "requestId": {
58735              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
58736              "location": "query",
58737              "type": "string"
58738            }
58739          },
58740          "parameterOrder": [
58741            "project"
58742          ],
58743          "request": {
58744            "$ref": "BackendBucket"
58745          },
58746          "response": {
58747            "$ref": "Operation"
58748          },
58749          "scopes": [
58750            "https://www.googleapis.com/auth/cloud-platform",
58751            "https://www.googleapis.com/auth/compute"
58752          ],
58753          "description": "Creates a BackendBucket resource in the specified project using the data included in the request."
58754        },
58755        "delete": {
58756          "id": "compute.backendBuckets.delete",
58757          "path": "projects/{project}/global/backendBuckets/{backendBucket}",
58758          "flatPath": "projects/{project}/global/backendBuckets/{backendBucket}",
58759          "httpMethod": "DELETE",
58760          "parameters": {
58761            "backendBucket": {
58762              "description": "Name of the BackendBucket resource to delete.",
58763              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
58764              "location": "path",
58765              "required": true,
58766              "type": "string"
58767            },
58768            "project": {
58769              "description": "Project ID for this request.",
58770              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58771              "location": "path",
58772              "required": true,
58773              "type": "string"
58774            },
58775            "requestId": {
58776              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
58777              "location": "query",
58778              "type": "string"
58779            }
58780          },
58781          "parameterOrder": [
58782            "project",
58783            "backendBucket"
58784          ],
58785          "response": {
58786            "$ref": "Operation"
58787          },
58788          "scopes": [
58789            "https://www.googleapis.com/auth/cloud-platform",
58790            "https://www.googleapis.com/auth/compute"
58791          ],
58792          "description": "Deletes the specified BackendBucket resource."
58793        },
58794        "update": {
58795          "id": "compute.backendBuckets.update",
58796          "path": "projects/{project}/global/backendBuckets/{backendBucket}",
58797          "flatPath": "projects/{project}/global/backendBuckets/{backendBucket}",
58798          "httpMethod": "PUT",
58799          "parameters": {
58800            "backendBucket": {
58801              "description": "Name of the BackendBucket resource to update.",
58802              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
58803              "location": "path",
58804              "required": true,
58805              "type": "string"
58806            },
58807            "project": {
58808              "description": "Project ID for this request.",
58809              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58810              "location": "path",
58811              "required": true,
58812              "type": "string"
58813            },
58814            "requestId": {
58815              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
58816              "location": "query",
58817              "type": "string"
58818            }
58819          },
58820          "parameterOrder": [
58821            "project",
58822            "backendBucket"
58823          ],
58824          "request": {
58825            "$ref": "BackendBucket"
58826          },
58827          "response": {
58828            "$ref": "Operation"
58829          },
58830          "scopes": [
58831            "https://www.googleapis.com/auth/cloud-platform",
58832            "https://www.googleapis.com/auth/compute"
58833          ],
58834          "description": "Updates the specified BackendBucket resource with the data included in the request."
58835        },
58836        "patch": {
58837          "id": "compute.backendBuckets.patch",
58838          "path": "projects/{project}/global/backendBuckets/{backendBucket}",
58839          "flatPath": "projects/{project}/global/backendBuckets/{backendBucket}",
58840          "httpMethod": "PATCH",
58841          "parameters": {
58842            "backendBucket": {
58843              "description": "Name of the BackendBucket resource to patch.",
58844              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
58845              "location": "path",
58846              "required": true,
58847              "type": "string"
58848            },
58849            "project": {
58850              "description": "Project ID for this request.",
58851              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58852              "location": "path",
58853              "required": true,
58854              "type": "string"
58855            },
58856            "requestId": {
58857              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
58858              "location": "query",
58859              "type": "string"
58860            }
58861          },
58862          "parameterOrder": [
58863            "project",
58864            "backendBucket"
58865          ],
58866          "request": {
58867            "$ref": "BackendBucket"
58868          },
58869          "response": {
58870            "$ref": "Operation"
58871          },
58872          "scopes": [
58873            "https://www.googleapis.com/auth/cloud-platform",
58874            "https://www.googleapis.com/auth/compute"
58875          ],
58876          "description": "Updates the specified BackendBucket resource with the data included in the request. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
58877        },
58878        "addSignedUrlKey": {
58879          "id": "compute.backendBuckets.addSignedUrlKey",
58880          "path": "projects/{project}/global/backendBuckets/{backendBucket}/addSignedUrlKey",
58881          "flatPath": "projects/{project}/global/backendBuckets/{backendBucket}/addSignedUrlKey",
58882          "httpMethod": "POST",
58883          "parameters": {
58884            "backendBucket": {
58885              "description": "Name of the BackendBucket resource to which the Signed URL Key should be added. The name should conform to RFC1035.",
58886              "location": "path",
58887              "required": true,
58888              "type": "string"
58889            },
58890            "project": {
58891              "description": "Project ID for this request.",
58892              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58893              "location": "path",
58894              "required": true,
58895              "type": "string"
58896            },
58897            "requestId": {
58898              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
58899              "location": "query",
58900              "type": "string"
58901            }
58902          },
58903          "parameterOrder": [
58904            "project",
58905            "backendBucket"
58906          ],
58907          "request": {
58908            "$ref": "SignedUrlKey"
58909          },
58910          "response": {
58911            "$ref": "Operation"
58912          },
58913          "scopes": [
58914            "https://www.googleapis.com/auth/cloud-platform",
58915            "https://www.googleapis.com/auth/compute"
58916          ],
58917          "description": "Adds a key for validating requests with signed URLs for this backend bucket."
58918        },
58919        "deleteSignedUrlKey": {
58920          "id": "compute.backendBuckets.deleteSignedUrlKey",
58921          "path": "projects/{project}/global/backendBuckets/{backendBucket}/deleteSignedUrlKey",
58922          "flatPath": "projects/{project}/global/backendBuckets/{backendBucket}/deleteSignedUrlKey",
58923          "httpMethod": "POST",
58924          "parameters": {
58925            "backendBucket": {
58926              "description": "Name of the BackendBucket resource to which the Signed URL Key should be added. The name should conform to RFC1035.",
58927              "location": "path",
58928              "required": true,
58929              "type": "string"
58930            },
58931            "keyName": {
58932              "description": "The name of the Signed URL Key to delete.",
58933              "location": "query",
58934              "required": true,
58935              "type": "string"
58936            },
58937            "project": {
58938              "description": "Project ID for this request.",
58939              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58940              "location": "path",
58941              "required": true,
58942              "type": "string"
58943            },
58944            "requestId": {
58945              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
58946              "location": "query",
58947              "type": "string"
58948            }
58949          },
58950          "parameterOrder": [
58951            "project",
58952            "backendBucket",
58953            "keyName"
58954          ],
58955          "response": {
58956            "$ref": "Operation"
58957          },
58958          "scopes": [
58959            "https://www.googleapis.com/auth/cloud-platform",
58960            "https://www.googleapis.com/auth/compute"
58961          ],
58962          "description": "Deletes a key for validating requests with signed URLs for this backend bucket."
58963        },
58964        "setEdgeSecurityPolicy": {
58965          "id": "compute.backendBuckets.setEdgeSecurityPolicy",
58966          "path": "projects/{project}/global/backendBuckets/{backendBucket}/setEdgeSecurityPolicy",
58967          "flatPath": "projects/{project}/global/backendBuckets/{backendBucket}/setEdgeSecurityPolicy",
58968          "httpMethod": "POST",
58969          "parameters": {
58970            "backendBucket": {
58971              "description": "Name of the BackendBucket resource to which the security policy should be set. The name should conform to RFC1035.",
58972              "location": "path",
58973              "required": true,
58974              "type": "string"
58975            },
58976            "project": {
58977              "description": "Project ID for this request.",
58978              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
58979              "location": "path",
58980              "required": true,
58981              "type": "string"
58982            },
58983            "requestId": {
58984              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
58985              "location": "query",
58986              "type": "string"
58987            }
58988          },
58989          "parameterOrder": [
58990            "project",
58991            "backendBucket"
58992          ],
58993          "request": {
58994            "$ref": "SecurityPolicyReference"
58995          },
58996          "response": {
58997            "$ref": "Operation"
58998          },
58999          "scopes": [
59000            "https://www.googleapis.com/auth/cloud-platform",
59001            "https://www.googleapis.com/auth/compute"
59002          ],
59003          "description": "Sets the edge security policy for the specified backend bucket."
59004        },
59005        "getIamPolicy": {
59006          "id": "compute.backendBuckets.getIamPolicy",
59007          "path": "projects/{project}/global/backendBuckets/{resource}/getIamPolicy",
59008          "flatPath": "projects/{project}/global/backendBuckets/{resource}/getIamPolicy",
59009          "httpMethod": "GET",
59010          "parameters": {
59011            "optionsRequestedPolicyVersion": {
59012              "description": "Requested IAM Policy version.",
59013              "location": "query",
59014              "type": "integer",
59015              "format": "int32"
59016            },
59017            "project": {
59018              "description": "Project ID for this request.",
59019              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59020              "location": "path",
59021              "required": true,
59022              "type": "string"
59023            },
59024            "resource": {
59025              "description": "Name or id of the resource for this request.",
59026              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
59027              "location": "path",
59028              "required": true,
59029              "type": "string"
59030            }
59031          },
59032          "parameterOrder": [
59033            "project",
59034            "resource"
59035          ],
59036          "response": {
59037            "$ref": "Policy"
59038          },
59039          "scopes": [
59040            "https://www.googleapis.com/auth/cloud-platform",
59041            "https://www.googleapis.com/auth/compute",
59042            "https://www.googleapis.com/auth/compute.readonly"
59043          ],
59044          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
59045        },
59046        "setIamPolicy": {
59047          "id": "compute.backendBuckets.setIamPolicy",
59048          "path": "projects/{project}/global/backendBuckets/{resource}/setIamPolicy",
59049          "flatPath": "projects/{project}/global/backendBuckets/{resource}/setIamPolicy",
59050          "httpMethod": "POST",
59051          "parameters": {
59052            "project": {
59053              "description": "Project ID for this request.",
59054              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59055              "location": "path",
59056              "required": true,
59057              "type": "string"
59058            },
59059            "resource": {
59060              "description": "Name or id of the resource for this request.",
59061              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
59062              "location": "path",
59063              "required": true,
59064              "type": "string"
59065            }
59066          },
59067          "parameterOrder": [
59068            "project",
59069            "resource"
59070          ],
59071          "request": {
59072            "$ref": "GlobalSetPolicyRequest"
59073          },
59074          "response": {
59075            "$ref": "Policy"
59076          },
59077          "scopes": [
59078            "https://www.googleapis.com/auth/cloud-platform",
59079            "https://www.googleapis.com/auth/compute"
59080          ],
59081          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
59082        },
59083        "testIamPermissions": {
59084          "id": "compute.backendBuckets.testIamPermissions",
59085          "path": "projects/{project}/global/backendBuckets/{resource}/testIamPermissions",
59086          "flatPath": "projects/{project}/global/backendBuckets/{resource}/testIamPermissions",
59087          "httpMethod": "POST",
59088          "parameters": {
59089            "project": {
59090              "description": "Project ID for this request.",
59091              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59092              "location": "path",
59093              "required": true,
59094              "type": "string"
59095            },
59096            "resource": {
59097              "description": "Name or id of the resource for this request.",
59098              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
59099              "location": "path",
59100              "required": true,
59101              "type": "string"
59102            }
59103          },
59104          "parameterOrder": [
59105            "project",
59106            "resource"
59107          ],
59108          "request": {
59109            "$ref": "TestPermissionsRequest"
59110          },
59111          "response": {
59112            "$ref": "TestPermissionsResponse"
59113          },
59114          "scopes": [
59115            "https://www.googleapis.com/auth/cloud-platform",
59116            "https://www.googleapis.com/auth/compute",
59117            "https://www.googleapis.com/auth/compute.readonly"
59118          ],
59119          "description": "Returns permissions that a caller has on the specified resource."
59120        }
59121      }
59122    },
59123    "backendServices": {
59124      "methods": {
59125        "list": {
59126          "id": "compute.backendServices.list",
59127          "path": "projects/{project}/global/backendServices",
59128          "flatPath": "projects/{project}/global/backendServices",
59129          "httpMethod": "GET",
59130          "parameters": {
59131            "filter": {
59132              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
59133              "location": "query",
59134              "type": "string"
59135            },
59136            "maxResults": {
59137              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
59138              "default": "500",
59139              "minimum": "0",
59140              "location": "query",
59141              "type": "integer",
59142              "format": "uint32"
59143            },
59144            "orderBy": {
59145              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
59146              "location": "query",
59147              "type": "string"
59148            },
59149            "pageToken": {
59150              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
59151              "location": "query",
59152              "type": "string"
59153            },
59154            "project": {
59155              "description": "Project ID for this request.",
59156              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59157              "location": "path",
59158              "required": true,
59159              "type": "string"
59160            },
59161            "returnPartialSuccess": {
59162              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
59163              "location": "query",
59164              "type": "boolean"
59165            }
59166          },
59167          "parameterOrder": [
59168            "project"
59169          ],
59170          "response": {
59171            "$ref": "BackendServiceList"
59172          },
59173          "scopes": [
59174            "https://www.googleapis.com/auth/cloud-platform",
59175            "https://www.googleapis.com/auth/compute",
59176            "https://www.googleapis.com/auth/compute.readonly"
59177          ],
59178          "description": "Retrieves the list of BackendService resources available to the specified project."
59179        },
59180        "aggregatedList": {
59181          "id": "compute.backendServices.aggregatedList",
59182          "path": "projects/{project}/aggregated/backendServices",
59183          "flatPath": "projects/{project}/aggregated/backendServices",
59184          "httpMethod": "GET",
59185          "parameters": {
59186            "filter": {
59187              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
59188              "location": "query",
59189              "type": "string"
59190            },
59191            "includeAllScopes": {
59192              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
59193              "location": "query",
59194              "type": "boolean"
59195            },
59196            "maxResults": {
59197              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
59198              "default": "500",
59199              "minimum": "0",
59200              "location": "query",
59201              "type": "integer",
59202              "format": "uint32"
59203            },
59204            "orderBy": {
59205              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
59206              "location": "query",
59207              "type": "string"
59208            },
59209            "pageToken": {
59210              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
59211              "location": "query",
59212              "type": "string"
59213            },
59214            "project": {
59215              "description": "Name of the project scoping this request.",
59216              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59217              "location": "path",
59218              "required": true,
59219              "type": "string"
59220            },
59221            "returnPartialSuccess": {
59222              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
59223              "location": "query",
59224              "type": "boolean"
59225            },
59226            "serviceProjectNumber": {
59227              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
59228              "location": "query",
59229              "type": "string",
59230              "format": "int64"
59231            }
59232          },
59233          "parameterOrder": [
59234            "project"
59235          ],
59236          "response": {
59237            "$ref": "BackendServiceAggregatedList"
59238          },
59239          "scopes": [
59240            "https://www.googleapis.com/auth/cloud-platform",
59241            "https://www.googleapis.com/auth/compute",
59242            "https://www.googleapis.com/auth/compute.readonly"
59243          ],
59244          "description": "Retrieves the list of all BackendService resources, regional and global, available to the specified project. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
59245        },
59246        "listUsable": {
59247          "id": "compute.backendServices.listUsable",
59248          "path": "projects/{project}/global/backendServices/listUsable",
59249          "flatPath": "projects/{project}/global/backendServices/listUsable",
59250          "httpMethod": "GET",
59251          "parameters": {
59252            "filter": {
59253              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
59254              "location": "query",
59255              "type": "string"
59256            },
59257            "maxResults": {
59258              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
59259              "default": "500",
59260              "minimum": "0",
59261              "location": "query",
59262              "type": "integer",
59263              "format": "uint32"
59264            },
59265            "orderBy": {
59266              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
59267              "location": "query",
59268              "type": "string"
59269            },
59270            "pageToken": {
59271              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
59272              "location": "query",
59273              "type": "string"
59274            },
59275            "project": {
59276              "description": "Project ID for this request.",
59277              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59278              "location": "path",
59279              "required": true,
59280              "type": "string"
59281            },
59282            "returnPartialSuccess": {
59283              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
59284              "location": "query",
59285              "type": "boolean"
59286            }
59287          },
59288          "parameterOrder": [
59289            "project"
59290          ],
59291          "response": {
59292            "$ref": "BackendServiceListUsable"
59293          },
59294          "scopes": [
59295            "https://www.googleapis.com/auth/cloud-platform",
59296            "https://www.googleapis.com/auth/compute",
59297            "https://www.googleapis.com/auth/compute.readonly"
59298          ],
59299          "description": "Retrieves an aggregated list of all usable backend services in the specified project."
59300        },
59301        "get": {
59302          "id": "compute.backendServices.get",
59303          "path": "projects/{project}/global/backendServices/{backendService}",
59304          "flatPath": "projects/{project}/global/backendServices/{backendService}",
59305          "httpMethod": "GET",
59306          "parameters": {
59307            "backendService": {
59308              "description": "Name of the BackendService resource to return.",
59309              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
59310              "location": "path",
59311              "required": true,
59312              "type": "string"
59313            },
59314            "project": {
59315              "description": "Project ID for this request.",
59316              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59317              "location": "path",
59318              "required": true,
59319              "type": "string"
59320            }
59321          },
59322          "parameterOrder": [
59323            "project",
59324            "backendService"
59325          ],
59326          "response": {
59327            "$ref": "BackendService"
59328          },
59329          "scopes": [
59330            "https://www.googleapis.com/auth/cloud-platform",
59331            "https://www.googleapis.com/auth/compute",
59332            "https://www.googleapis.com/auth/compute.readonly"
59333          ],
59334          "description": "Returns the specified BackendService resource."
59335        },
59336        "insert": {
59337          "id": "compute.backendServices.insert",
59338          "path": "projects/{project}/global/backendServices",
59339          "flatPath": "projects/{project}/global/backendServices",
59340          "httpMethod": "POST",
59341          "parameters": {
59342            "project": {
59343              "description": "Project ID for this request.",
59344              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59345              "location": "path",
59346              "required": true,
59347              "type": "string"
59348            },
59349            "requestId": {
59350              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
59351              "location": "query",
59352              "type": "string"
59353            }
59354          },
59355          "parameterOrder": [
59356            "project"
59357          ],
59358          "request": {
59359            "$ref": "BackendService"
59360          },
59361          "response": {
59362            "$ref": "Operation"
59363          },
59364          "scopes": [
59365            "https://www.googleapis.com/auth/cloud-platform",
59366            "https://www.googleapis.com/auth/compute"
59367          ],
59368          "description": "Creates a BackendService resource in the specified project using the data included in the request. For more information, see Backend services overview ."
59369        },
59370        "delete": {
59371          "id": "compute.backendServices.delete",
59372          "path": "projects/{project}/global/backendServices/{backendService}",
59373          "flatPath": "projects/{project}/global/backendServices/{backendService}",
59374          "httpMethod": "DELETE",
59375          "parameters": {
59376            "backendService": {
59377              "description": "Name of the BackendService resource to delete.",
59378              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
59379              "location": "path",
59380              "required": true,
59381              "type": "string"
59382            },
59383            "project": {
59384              "description": "Project ID for this request.",
59385              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59386              "location": "path",
59387              "required": true,
59388              "type": "string"
59389            },
59390            "requestId": {
59391              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
59392              "location": "query",
59393              "type": "string"
59394            }
59395          },
59396          "parameterOrder": [
59397            "project",
59398            "backendService"
59399          ],
59400          "response": {
59401            "$ref": "Operation"
59402          },
59403          "scopes": [
59404            "https://www.googleapis.com/auth/cloud-platform",
59405            "https://www.googleapis.com/auth/compute"
59406          ],
59407          "description": "Deletes the specified BackendService resource."
59408        },
59409        "update": {
59410          "id": "compute.backendServices.update",
59411          "path": "projects/{project}/global/backendServices/{backendService}",
59412          "flatPath": "projects/{project}/global/backendServices/{backendService}",
59413          "httpMethod": "PUT",
59414          "parameters": {
59415            "backendService": {
59416              "description": "Name of the BackendService resource to update.",
59417              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
59418              "location": "path",
59419              "required": true,
59420              "type": "string"
59421            },
59422            "project": {
59423              "description": "Project ID for this request.",
59424              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59425              "location": "path",
59426              "required": true,
59427              "type": "string"
59428            },
59429            "requestId": {
59430              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
59431              "location": "query",
59432              "type": "string"
59433            }
59434          },
59435          "parameterOrder": [
59436            "project",
59437            "backendService"
59438          ],
59439          "request": {
59440            "$ref": "BackendService"
59441          },
59442          "response": {
59443            "$ref": "Operation"
59444          },
59445          "scopes": [
59446            "https://www.googleapis.com/auth/cloud-platform",
59447            "https://www.googleapis.com/auth/compute"
59448          ],
59449          "description": "Updates the specified BackendService resource with the data included in the request. For more information, see Backend services overview."
59450        },
59451        "patch": {
59452          "id": "compute.backendServices.patch",
59453          "path": "projects/{project}/global/backendServices/{backendService}",
59454          "flatPath": "projects/{project}/global/backendServices/{backendService}",
59455          "httpMethod": "PATCH",
59456          "parameters": {
59457            "backendService": {
59458              "description": "Name of the BackendService resource to patch.",
59459              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
59460              "location": "path",
59461              "required": true,
59462              "type": "string"
59463            },
59464            "project": {
59465              "description": "Project ID for this request.",
59466              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59467              "location": "path",
59468              "required": true,
59469              "type": "string"
59470            },
59471            "requestId": {
59472              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
59473              "location": "query",
59474              "type": "string"
59475            }
59476          },
59477          "parameterOrder": [
59478            "project",
59479            "backendService"
59480          ],
59481          "request": {
59482            "$ref": "BackendService"
59483          },
59484          "response": {
59485            "$ref": "Operation"
59486          },
59487          "scopes": [
59488            "https://www.googleapis.com/auth/cloud-platform",
59489            "https://www.googleapis.com/auth/compute"
59490          ],
59491          "description": "Patches the specified BackendService resource with the data included in the request. For more information, see Backend services overview. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
59492        },
59493        "addSignedUrlKey": {
59494          "id": "compute.backendServices.addSignedUrlKey",
59495          "path": "projects/{project}/global/backendServices/{backendService}/addSignedUrlKey",
59496          "flatPath": "projects/{project}/global/backendServices/{backendService}/addSignedUrlKey",
59497          "httpMethod": "POST",
59498          "parameters": {
59499            "backendService": {
59500              "description": "Name of the BackendService resource to which the Signed URL Key should be added. The name should conform to RFC1035.",
59501              "location": "path",
59502              "required": true,
59503              "type": "string"
59504            },
59505            "project": {
59506              "description": "Project ID for this request.",
59507              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59508              "location": "path",
59509              "required": true,
59510              "type": "string"
59511            },
59512            "requestId": {
59513              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
59514              "location": "query",
59515              "type": "string"
59516            }
59517          },
59518          "parameterOrder": [
59519            "project",
59520            "backendService"
59521          ],
59522          "request": {
59523            "$ref": "SignedUrlKey"
59524          },
59525          "response": {
59526            "$ref": "Operation"
59527          },
59528          "scopes": [
59529            "https://www.googleapis.com/auth/cloud-platform",
59530            "https://www.googleapis.com/auth/compute"
59531          ],
59532          "description": "Adds a key for validating requests with signed URLs for this backend service."
59533        },
59534        "deleteSignedUrlKey": {
59535          "id": "compute.backendServices.deleteSignedUrlKey",
59536          "path": "projects/{project}/global/backendServices/{backendService}/deleteSignedUrlKey",
59537          "flatPath": "projects/{project}/global/backendServices/{backendService}/deleteSignedUrlKey",
59538          "httpMethod": "POST",
59539          "parameters": {
59540            "backendService": {
59541              "description": "Name of the BackendService resource to which the Signed URL Key should be added. The name should conform to RFC1035.",
59542              "location": "path",
59543              "required": true,
59544              "type": "string"
59545            },
59546            "keyName": {
59547              "description": "The name of the Signed URL Key to delete.",
59548              "location": "query",
59549              "required": true,
59550              "type": "string"
59551            },
59552            "project": {
59553              "description": "Project ID for this request.",
59554              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59555              "location": "path",
59556              "required": true,
59557              "type": "string"
59558            },
59559            "requestId": {
59560              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
59561              "location": "query",
59562              "type": "string"
59563            }
59564          },
59565          "parameterOrder": [
59566            "project",
59567            "backendService",
59568            "keyName"
59569          ],
59570          "response": {
59571            "$ref": "Operation"
59572          },
59573          "scopes": [
59574            "https://www.googleapis.com/auth/cloud-platform",
59575            "https://www.googleapis.com/auth/compute"
59576          ],
59577          "description": "Deletes a key for validating requests with signed URLs for this backend service."
59578        },
59579        "setSecurityPolicy": {
59580          "id": "compute.backendServices.setSecurityPolicy",
59581          "path": "projects/{project}/global/backendServices/{backendService}/setSecurityPolicy",
59582          "flatPath": "projects/{project}/global/backendServices/{backendService}/setSecurityPolicy",
59583          "httpMethod": "POST",
59584          "parameters": {
59585            "backendService": {
59586              "description": "Name of the BackendService resource to which the security policy should be set. The name should conform to RFC1035.",
59587              "location": "path",
59588              "required": true,
59589              "type": "string"
59590            },
59591            "project": {
59592              "description": "Project ID for this request.",
59593              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59594              "location": "path",
59595              "required": true,
59596              "type": "string"
59597            },
59598            "requestId": {
59599              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
59600              "location": "query",
59601              "type": "string"
59602            }
59603          },
59604          "parameterOrder": [
59605            "project",
59606            "backendService"
59607          ],
59608          "request": {
59609            "$ref": "SecurityPolicyReference"
59610          },
59611          "response": {
59612            "$ref": "Operation"
59613          },
59614          "scopes": [
59615            "https://www.googleapis.com/auth/cloud-platform",
59616            "https://www.googleapis.com/auth/compute"
59617          ],
59618          "description": "Sets the Google Cloud Armor security policy for the specified backend service. For more information, see Google Cloud Armor Overview"
59619        },
59620        "setEdgeSecurityPolicy": {
59621          "id": "compute.backendServices.setEdgeSecurityPolicy",
59622          "path": "projects/{project}/global/backendServices/{backendService}/setEdgeSecurityPolicy",
59623          "flatPath": "projects/{project}/global/backendServices/{backendService}/setEdgeSecurityPolicy",
59624          "httpMethod": "POST",
59625          "parameters": {
59626            "backendService": {
59627              "description": "Name of the BackendService resource to which the edge security policy should be set. The name should conform to RFC1035.",
59628              "location": "path",
59629              "required": true,
59630              "type": "string"
59631            },
59632            "project": {
59633              "description": "Project ID for this request.",
59634              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59635              "location": "path",
59636              "required": true,
59637              "type": "string"
59638            },
59639            "requestId": {
59640              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
59641              "location": "query",
59642              "type": "string"
59643            }
59644          },
59645          "parameterOrder": [
59646            "project",
59647            "backendService"
59648          ],
59649          "request": {
59650            "$ref": "SecurityPolicyReference"
59651          },
59652          "response": {
59653            "$ref": "Operation"
59654          },
59655          "scopes": [
59656            "https://www.googleapis.com/auth/cloud-platform",
59657            "https://www.googleapis.com/auth/compute"
59658          ],
59659          "description": "Sets the edge security policy for the specified backend service."
59660        },
59661        "getHealth": {
59662          "id": "compute.backendServices.getHealth",
59663          "path": "projects/{project}/global/backendServices/{backendService}/getHealth",
59664          "flatPath": "projects/{project}/global/backendServices/{backendService}/getHealth",
59665          "httpMethod": "POST",
59666          "parameters": {
59667            "backendService": {
59668              "description": "Name of the BackendService resource to which the queried instance belongs.",
59669              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
59670              "location": "path",
59671              "required": true,
59672              "type": "string"
59673            },
59674            "project": {
59675              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59676              "location": "path",
59677              "required": true,
59678              "type": "string"
59679            }
59680          },
59681          "parameterOrder": [
59682            "project",
59683            "backendService"
59684          ],
59685          "request": {
59686            "$ref": "ResourceGroupReference"
59687          },
59688          "response": {
59689            "$ref": "BackendServiceGroupHealth"
59690          },
59691          "scopes": [
59692            "https://www.googleapis.com/auth/cloud-platform",
59693            "https://www.googleapis.com/auth/compute",
59694            "https://www.googleapis.com/auth/compute.readonly"
59695          ],
59696          "description": "Gets the most recent health check results for this BackendService. Example request body: { \"group\": \"/zones/us-east1-b/instanceGroups/lb-backend-example\" }"
59697        },
59698        "getIamPolicy": {
59699          "id": "compute.backendServices.getIamPolicy",
59700          "path": "projects/{project}/global/backendServices/{resource}/getIamPolicy",
59701          "flatPath": "projects/{project}/global/backendServices/{resource}/getIamPolicy",
59702          "httpMethod": "GET",
59703          "parameters": {
59704            "optionsRequestedPolicyVersion": {
59705              "description": "Requested IAM Policy version.",
59706              "location": "query",
59707              "type": "integer",
59708              "format": "int32"
59709            },
59710            "project": {
59711              "description": "Project ID for this request.",
59712              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59713              "location": "path",
59714              "required": true,
59715              "type": "string"
59716            },
59717            "resource": {
59718              "description": "Name or id of the resource for this request.",
59719              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
59720              "location": "path",
59721              "required": true,
59722              "type": "string"
59723            }
59724          },
59725          "parameterOrder": [
59726            "project",
59727            "resource"
59728          ],
59729          "response": {
59730            "$ref": "Policy"
59731          },
59732          "scopes": [
59733            "https://www.googleapis.com/auth/cloud-platform",
59734            "https://www.googleapis.com/auth/compute",
59735            "https://www.googleapis.com/auth/compute.readonly"
59736          ],
59737          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
59738        },
59739        "setIamPolicy": {
59740          "id": "compute.backendServices.setIamPolicy",
59741          "path": "projects/{project}/global/backendServices/{resource}/setIamPolicy",
59742          "flatPath": "projects/{project}/global/backendServices/{resource}/setIamPolicy",
59743          "httpMethod": "POST",
59744          "parameters": {
59745            "project": {
59746              "description": "Project ID for this request.",
59747              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59748              "location": "path",
59749              "required": true,
59750              "type": "string"
59751            },
59752            "resource": {
59753              "description": "Name or id of the resource for this request.",
59754              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
59755              "location": "path",
59756              "required": true,
59757              "type": "string"
59758            }
59759          },
59760          "parameterOrder": [
59761            "project",
59762            "resource"
59763          ],
59764          "request": {
59765            "$ref": "GlobalSetPolicyRequest"
59766          },
59767          "response": {
59768            "$ref": "Policy"
59769          },
59770          "scopes": [
59771            "https://www.googleapis.com/auth/cloud-platform",
59772            "https://www.googleapis.com/auth/compute"
59773          ],
59774          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
59775        },
59776        "testIamPermissions": {
59777          "id": "compute.backendServices.testIamPermissions",
59778          "path": "projects/{project}/global/backendServices/{resource}/testIamPermissions",
59779          "flatPath": "projects/{project}/global/backendServices/{resource}/testIamPermissions",
59780          "httpMethod": "POST",
59781          "parameters": {
59782            "project": {
59783              "description": "Project ID for this request.",
59784              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59785              "location": "path",
59786              "required": true,
59787              "type": "string"
59788            },
59789            "resource": {
59790              "description": "Name or id of the resource for this request.",
59791              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
59792              "location": "path",
59793              "required": true,
59794              "type": "string"
59795            }
59796          },
59797          "parameterOrder": [
59798            "project",
59799            "resource"
59800          ],
59801          "request": {
59802            "$ref": "TestPermissionsRequest"
59803          },
59804          "response": {
59805            "$ref": "TestPermissionsResponse"
59806          },
59807          "scopes": [
59808            "https://www.googleapis.com/auth/cloud-platform",
59809            "https://www.googleapis.com/auth/compute",
59810            "https://www.googleapis.com/auth/compute.readonly"
59811          ],
59812          "description": "Returns permissions that a caller has on the specified resource."
59813        }
59814      }
59815    },
59816    "regionBackendServices": {
59817      "methods": {
59818        "list": {
59819          "id": "compute.regionBackendServices.list",
59820          "path": "projects/{project}/regions/{region}/backendServices",
59821          "flatPath": "projects/{project}/regions/{region}/backendServices",
59822          "httpMethod": "GET",
59823          "parameters": {
59824            "filter": {
59825              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
59826              "location": "query",
59827              "type": "string"
59828            },
59829            "maxResults": {
59830              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
59831              "default": "500",
59832              "minimum": "0",
59833              "location": "query",
59834              "type": "integer",
59835              "format": "uint32"
59836            },
59837            "orderBy": {
59838              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
59839              "location": "query",
59840              "type": "string"
59841            },
59842            "pageToken": {
59843              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
59844              "location": "query",
59845              "type": "string"
59846            },
59847            "project": {
59848              "description": "Project ID for this request.",
59849              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59850              "location": "path",
59851              "required": true,
59852              "type": "string"
59853            },
59854            "region": {
59855              "description": "Name of the region scoping this request.",
59856              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
59857              "location": "path",
59858              "required": true,
59859              "type": "string"
59860            },
59861            "returnPartialSuccess": {
59862              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
59863              "location": "query",
59864              "type": "boolean"
59865            }
59866          },
59867          "parameterOrder": [
59868            "project",
59869            "region"
59870          ],
59871          "response": {
59872            "$ref": "BackendServiceList"
59873          },
59874          "scopes": [
59875            "https://www.googleapis.com/auth/cloud-platform",
59876            "https://www.googleapis.com/auth/compute",
59877            "https://www.googleapis.com/auth/compute.readonly"
59878          ],
59879          "description": "Retrieves the list of regional BackendService resources available to the specified project in the given region."
59880        },
59881        "listUsable": {
59882          "id": "compute.regionBackendServices.listUsable",
59883          "path": "projects/{project}/regions/{region}/backendServices/listUsable",
59884          "flatPath": "projects/{project}/regions/{region}/backendServices/listUsable",
59885          "httpMethod": "GET",
59886          "parameters": {
59887            "filter": {
59888              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
59889              "location": "query",
59890              "type": "string"
59891            },
59892            "maxResults": {
59893              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
59894              "default": "500",
59895              "minimum": "0",
59896              "location": "query",
59897              "type": "integer",
59898              "format": "uint32"
59899            },
59900            "orderBy": {
59901              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
59902              "location": "query",
59903              "type": "string"
59904            },
59905            "pageToken": {
59906              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
59907              "location": "query",
59908              "type": "string"
59909            },
59910            "project": {
59911              "description": "Project ID for this request.",
59912              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59913              "location": "path",
59914              "required": true,
59915              "type": "string"
59916            },
59917            "region": {
59918              "description": "Name of the region scoping this request. It must be a string that meets the requirements in RFC1035.",
59919              "location": "path",
59920              "required": true,
59921              "type": "string"
59922            },
59923            "returnPartialSuccess": {
59924              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
59925              "location": "query",
59926              "type": "boolean"
59927            }
59928          },
59929          "parameterOrder": [
59930            "project",
59931            "region"
59932          ],
59933          "response": {
59934            "$ref": "BackendServiceListUsable"
59935          },
59936          "scopes": [
59937            "https://www.googleapis.com/auth/cloud-platform",
59938            "https://www.googleapis.com/auth/compute",
59939            "https://www.googleapis.com/auth/compute.readonly"
59940          ],
59941          "description": "Retrieves an aggregated list of all usable backend services in the specified project in the given region."
59942        },
59943        "get": {
59944          "id": "compute.regionBackendServices.get",
59945          "path": "projects/{project}/regions/{region}/backendServices/{backendService}",
59946          "flatPath": "projects/{project}/regions/{region}/backendServices/{backendService}",
59947          "httpMethod": "GET",
59948          "parameters": {
59949            "backendService": {
59950              "description": "Name of the BackendService resource to return.",
59951              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
59952              "location": "path",
59953              "required": true,
59954              "type": "string"
59955            },
59956            "project": {
59957              "description": "Project ID for this request.",
59958              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59959              "location": "path",
59960              "required": true,
59961              "type": "string"
59962            },
59963            "region": {
59964              "description": "Name of the region scoping this request.",
59965              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
59966              "location": "path",
59967              "required": true,
59968              "type": "string"
59969            }
59970          },
59971          "parameterOrder": [
59972            "project",
59973            "region",
59974            "backendService"
59975          ],
59976          "response": {
59977            "$ref": "BackendService"
59978          },
59979          "scopes": [
59980            "https://www.googleapis.com/auth/cloud-platform",
59981            "https://www.googleapis.com/auth/compute",
59982            "https://www.googleapis.com/auth/compute.readonly"
59983          ],
59984          "description": "Returns the specified regional BackendService resource."
59985        },
59986        "insert": {
59987          "id": "compute.regionBackendServices.insert",
59988          "path": "projects/{project}/regions/{region}/backendServices",
59989          "flatPath": "projects/{project}/regions/{region}/backendServices",
59990          "httpMethod": "POST",
59991          "parameters": {
59992            "project": {
59993              "description": "Project ID for this request.",
59994              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
59995              "location": "path",
59996              "required": true,
59997              "type": "string"
59998            },
59999            "region": {
60000              "description": "Name of the region scoping this request.",
60001              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60002              "location": "path",
60003              "required": true,
60004              "type": "string"
60005            },
60006            "requestId": {
60007              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
60008              "location": "query",
60009              "type": "string"
60010            }
60011          },
60012          "parameterOrder": [
60013            "project",
60014            "region"
60015          ],
60016          "request": {
60017            "$ref": "BackendService"
60018          },
60019          "response": {
60020            "$ref": "Operation"
60021          },
60022          "scopes": [
60023            "https://www.googleapis.com/auth/cloud-platform",
60024            "https://www.googleapis.com/auth/compute"
60025          ],
60026          "description": "Creates a regional BackendService resource in the specified project using the data included in the request. For more information, see Backend services overview."
60027        },
60028        "delete": {
60029          "id": "compute.regionBackendServices.delete",
60030          "path": "projects/{project}/regions/{region}/backendServices/{backendService}",
60031          "flatPath": "projects/{project}/regions/{region}/backendServices/{backendService}",
60032          "httpMethod": "DELETE",
60033          "parameters": {
60034            "backendService": {
60035              "description": "Name of the BackendService resource to delete.",
60036              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
60037              "location": "path",
60038              "required": true,
60039              "type": "string"
60040            },
60041            "project": {
60042              "description": "Project ID for this request.",
60043              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60044              "location": "path",
60045              "required": true,
60046              "type": "string"
60047            },
60048            "region": {
60049              "description": "Name of the region scoping this request.",
60050              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60051              "location": "path",
60052              "required": true,
60053              "type": "string"
60054            },
60055            "requestId": {
60056              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
60057              "location": "query",
60058              "type": "string"
60059            }
60060          },
60061          "parameterOrder": [
60062            "project",
60063            "region",
60064            "backendService"
60065          ],
60066          "response": {
60067            "$ref": "Operation"
60068          },
60069          "scopes": [
60070            "https://www.googleapis.com/auth/cloud-platform",
60071            "https://www.googleapis.com/auth/compute"
60072          ],
60073          "description": "Deletes the specified regional BackendService resource."
60074        },
60075        "update": {
60076          "id": "compute.regionBackendServices.update",
60077          "path": "projects/{project}/regions/{region}/backendServices/{backendService}",
60078          "flatPath": "projects/{project}/regions/{region}/backendServices/{backendService}",
60079          "httpMethod": "PUT",
60080          "parameters": {
60081            "backendService": {
60082              "description": "Name of the BackendService resource to update.",
60083              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
60084              "location": "path",
60085              "required": true,
60086              "type": "string"
60087            },
60088            "project": {
60089              "description": "Project ID for this request.",
60090              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60091              "location": "path",
60092              "required": true,
60093              "type": "string"
60094            },
60095            "region": {
60096              "description": "Name of the region scoping this request.",
60097              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60098              "location": "path",
60099              "required": true,
60100              "type": "string"
60101            },
60102            "requestId": {
60103              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
60104              "location": "query",
60105              "type": "string"
60106            }
60107          },
60108          "parameterOrder": [
60109            "project",
60110            "region",
60111            "backendService"
60112          ],
60113          "request": {
60114            "$ref": "BackendService"
60115          },
60116          "response": {
60117            "$ref": "Operation"
60118          },
60119          "scopes": [
60120            "https://www.googleapis.com/auth/cloud-platform",
60121            "https://www.googleapis.com/auth/compute"
60122          ],
60123          "description": "Updates the specified regional BackendService resource with the data included in the request. For more information, see Backend services overview ."
60124        },
60125        "patch": {
60126          "id": "compute.regionBackendServices.patch",
60127          "path": "projects/{project}/regions/{region}/backendServices/{backendService}",
60128          "flatPath": "projects/{project}/regions/{region}/backendServices/{backendService}",
60129          "httpMethod": "PATCH",
60130          "parameters": {
60131            "backendService": {
60132              "description": "Name of the BackendService resource to patch.",
60133              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
60134              "location": "path",
60135              "required": true,
60136              "type": "string"
60137            },
60138            "project": {
60139              "description": "Project ID for this request.",
60140              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60141              "location": "path",
60142              "required": true,
60143              "type": "string"
60144            },
60145            "region": {
60146              "description": "Name of the region scoping this request.",
60147              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60148              "location": "path",
60149              "required": true,
60150              "type": "string"
60151            },
60152            "requestId": {
60153              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
60154              "location": "query",
60155              "type": "string"
60156            }
60157          },
60158          "parameterOrder": [
60159            "project",
60160            "region",
60161            "backendService"
60162          ],
60163          "request": {
60164            "$ref": "BackendService"
60165          },
60166          "response": {
60167            "$ref": "Operation"
60168          },
60169          "scopes": [
60170            "https://www.googleapis.com/auth/cloud-platform",
60171            "https://www.googleapis.com/auth/compute"
60172          ],
60173          "description": "Updates the specified regional BackendService resource with the data included in the request. For more information, see Understanding backend services This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
60174        },
60175        "setSecurityPolicy": {
60176          "id": "compute.regionBackendServices.setSecurityPolicy",
60177          "path": "projects/{project}/regions/{region}/backendServices/{backendService}/setSecurityPolicy",
60178          "flatPath": "projects/{project}/regions/{region}/backendServices/{backendService}/setSecurityPolicy",
60179          "httpMethod": "POST",
60180          "parameters": {
60181            "backendService": {
60182              "description": "Name of the BackendService resource to which the security policy should be set. The name should conform to RFC1035.",
60183              "location": "path",
60184              "required": true,
60185              "type": "string"
60186            },
60187            "project": {
60188              "description": "Project ID for this request.",
60189              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60190              "location": "path",
60191              "required": true,
60192              "type": "string"
60193            },
60194            "region": {
60195              "description": "Name of the region scoping this request.",
60196              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60197              "location": "path",
60198              "required": true,
60199              "type": "string"
60200            },
60201            "requestId": {
60202              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
60203              "location": "query",
60204              "type": "string"
60205            }
60206          },
60207          "parameterOrder": [
60208            "project",
60209            "region",
60210            "backendService"
60211          ],
60212          "request": {
60213            "$ref": "SecurityPolicyReference"
60214          },
60215          "response": {
60216            "$ref": "Operation"
60217          },
60218          "scopes": [
60219            "https://www.googleapis.com/auth/cloud-platform",
60220            "https://www.googleapis.com/auth/compute"
60221          ],
60222          "description": "Sets the Google Cloud Armor security policy for the specified backend service. For more information, see Google Cloud Armor Overview"
60223        },
60224        "getHealth": {
60225          "id": "compute.regionBackendServices.getHealth",
60226          "path": "projects/{project}/regions/{region}/backendServices/{backendService}/getHealth",
60227          "flatPath": "projects/{project}/regions/{region}/backendServices/{backendService}/getHealth",
60228          "httpMethod": "POST",
60229          "parameters": {
60230            "backendService": {
60231              "description": "Name of the BackendService resource for which to get health.",
60232              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
60233              "location": "path",
60234              "required": true,
60235              "type": "string"
60236            },
60237            "project": {
60238              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60239              "location": "path",
60240              "required": true,
60241              "type": "string"
60242            },
60243            "region": {
60244              "description": "Name of the region scoping this request.",
60245              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60246              "location": "path",
60247              "required": true,
60248              "type": "string"
60249            }
60250          },
60251          "parameterOrder": [
60252            "project",
60253            "region",
60254            "backendService"
60255          ],
60256          "request": {
60257            "$ref": "ResourceGroupReference"
60258          },
60259          "response": {
60260            "$ref": "BackendServiceGroupHealth"
60261          },
60262          "scopes": [
60263            "https://www.googleapis.com/auth/cloud-platform",
60264            "https://www.googleapis.com/auth/compute",
60265            "https://www.googleapis.com/auth/compute.readonly"
60266          ],
60267          "description": "Gets the most recent health check results for this regional BackendService."
60268        },
60269        "getIamPolicy": {
60270          "id": "compute.regionBackendServices.getIamPolicy",
60271          "path": "projects/{project}/regions/{region}/backendServices/{resource}/getIamPolicy",
60272          "flatPath": "projects/{project}/regions/{region}/backendServices/{resource}/getIamPolicy",
60273          "httpMethod": "GET",
60274          "parameters": {
60275            "optionsRequestedPolicyVersion": {
60276              "description": "Requested IAM Policy version.",
60277              "location": "query",
60278              "type": "integer",
60279              "format": "int32"
60280            },
60281            "project": {
60282              "description": "Project ID for this request.",
60283              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60284              "location": "path",
60285              "required": true,
60286              "type": "string"
60287            },
60288            "region": {
60289              "description": "The name of the region for this request.",
60290              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60291              "location": "path",
60292              "required": true,
60293              "type": "string"
60294            },
60295            "resource": {
60296              "description": "Name or id of the resource for this request.",
60297              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
60298              "location": "path",
60299              "required": true,
60300              "type": "string"
60301            }
60302          },
60303          "parameterOrder": [
60304            "project",
60305            "region",
60306            "resource"
60307          ],
60308          "response": {
60309            "$ref": "Policy"
60310          },
60311          "scopes": [
60312            "https://www.googleapis.com/auth/cloud-platform",
60313            "https://www.googleapis.com/auth/compute",
60314            "https://www.googleapis.com/auth/compute.readonly"
60315          ],
60316          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
60317        },
60318        "setIamPolicy": {
60319          "id": "compute.regionBackendServices.setIamPolicy",
60320          "path": "projects/{project}/regions/{region}/backendServices/{resource}/setIamPolicy",
60321          "flatPath": "projects/{project}/regions/{region}/backendServices/{resource}/setIamPolicy",
60322          "httpMethod": "POST",
60323          "parameters": {
60324            "project": {
60325              "description": "Project ID for this request.",
60326              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60327              "location": "path",
60328              "required": true,
60329              "type": "string"
60330            },
60331            "region": {
60332              "description": "The name of the region for this request.",
60333              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60334              "location": "path",
60335              "required": true,
60336              "type": "string"
60337            },
60338            "resource": {
60339              "description": "Name or id of the resource for this request.",
60340              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
60341              "location": "path",
60342              "required": true,
60343              "type": "string"
60344            }
60345          },
60346          "parameterOrder": [
60347            "project",
60348            "region",
60349            "resource"
60350          ],
60351          "request": {
60352            "$ref": "RegionSetPolicyRequest"
60353          },
60354          "response": {
60355            "$ref": "Policy"
60356          },
60357          "scopes": [
60358            "https://www.googleapis.com/auth/cloud-platform",
60359            "https://www.googleapis.com/auth/compute"
60360          ],
60361          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
60362        },
60363        "testIamPermissions": {
60364          "id": "compute.regionBackendServices.testIamPermissions",
60365          "path": "projects/{project}/regions/{region}/backendServices/{resource}/testIamPermissions",
60366          "flatPath": "projects/{project}/regions/{region}/backendServices/{resource}/testIamPermissions",
60367          "httpMethod": "POST",
60368          "parameters": {
60369            "project": {
60370              "description": "Project ID for this request.",
60371              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60372              "location": "path",
60373              "required": true,
60374              "type": "string"
60375            },
60376            "region": {
60377              "description": "The name of the region for this request.",
60378              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60379              "location": "path",
60380              "required": true,
60381              "type": "string"
60382            },
60383            "resource": {
60384              "description": "Name or id of the resource for this request.",
60385              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
60386              "location": "path",
60387              "required": true,
60388              "type": "string"
60389            }
60390          },
60391          "parameterOrder": [
60392            "project",
60393            "region",
60394            "resource"
60395          ],
60396          "request": {
60397            "$ref": "TestPermissionsRequest"
60398          },
60399          "response": {
60400            "$ref": "TestPermissionsResponse"
60401          },
60402          "scopes": [
60403            "https://www.googleapis.com/auth/cloud-platform",
60404            "https://www.googleapis.com/auth/compute",
60405            "https://www.googleapis.com/auth/compute.readonly"
60406          ],
60407          "description": "Returns permissions that a caller has on the specified resource."
60408        }
60409      }
60410    },
60411    "regionCommitments": {
60412      "methods": {
60413        "list": {
60414          "id": "compute.regionCommitments.list",
60415          "path": "projects/{project}/regions/{region}/commitments",
60416          "flatPath": "projects/{project}/regions/{region}/commitments",
60417          "httpMethod": "GET",
60418          "parameters": {
60419            "filter": {
60420              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
60421              "location": "query",
60422              "type": "string"
60423            },
60424            "maxResults": {
60425              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
60426              "default": "500",
60427              "minimum": "0",
60428              "location": "query",
60429              "type": "integer",
60430              "format": "uint32"
60431            },
60432            "orderBy": {
60433              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
60434              "location": "query",
60435              "type": "string"
60436            },
60437            "pageToken": {
60438              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
60439              "location": "query",
60440              "type": "string"
60441            },
60442            "project": {
60443              "description": "Project ID for this request.",
60444              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60445              "location": "path",
60446              "required": true,
60447              "type": "string"
60448            },
60449            "region": {
60450              "description": "Name of the region for this request.",
60451              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60452              "location": "path",
60453              "required": true,
60454              "type": "string"
60455            },
60456            "returnPartialSuccess": {
60457              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
60458              "location": "query",
60459              "type": "boolean"
60460            }
60461          },
60462          "parameterOrder": [
60463            "project",
60464            "region"
60465          ],
60466          "response": {
60467            "$ref": "CommitmentList"
60468          },
60469          "scopes": [
60470            "https://www.googleapis.com/auth/cloud-platform",
60471            "https://www.googleapis.com/auth/compute",
60472            "https://www.googleapis.com/auth/compute.readonly"
60473          ],
60474          "description": "Retrieves a list of commitments contained within the specified region."
60475        },
60476        "aggregatedList": {
60477          "id": "compute.regionCommitments.aggregatedList",
60478          "path": "projects/{project}/aggregated/commitments",
60479          "flatPath": "projects/{project}/aggregated/commitments",
60480          "httpMethod": "GET",
60481          "parameters": {
60482            "filter": {
60483              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
60484              "location": "query",
60485              "type": "string"
60486            },
60487            "includeAllScopes": {
60488              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
60489              "location": "query",
60490              "type": "boolean"
60491            },
60492            "maxResults": {
60493              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
60494              "default": "500",
60495              "minimum": "0",
60496              "location": "query",
60497              "type": "integer",
60498              "format": "uint32"
60499            },
60500            "orderBy": {
60501              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
60502              "location": "query",
60503              "type": "string"
60504            },
60505            "pageToken": {
60506              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
60507              "location": "query",
60508              "type": "string"
60509            },
60510            "project": {
60511              "description": "Project ID for this request.",
60512              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60513              "location": "path",
60514              "required": true,
60515              "type": "string"
60516            },
60517            "returnPartialSuccess": {
60518              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
60519              "location": "query",
60520              "type": "boolean"
60521            },
60522            "serviceProjectNumber": {
60523              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
60524              "location": "query",
60525              "type": "string",
60526              "format": "int64"
60527            }
60528          },
60529          "parameterOrder": [
60530            "project"
60531          ],
60532          "response": {
60533            "$ref": "CommitmentAggregatedList"
60534          },
60535          "scopes": [
60536            "https://www.googleapis.com/auth/cloud-platform",
60537            "https://www.googleapis.com/auth/compute",
60538            "https://www.googleapis.com/auth/compute.readonly"
60539          ],
60540          "description": "Retrieves an aggregated list of commitments by region. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
60541        },
60542        "get": {
60543          "id": "compute.regionCommitments.get",
60544          "path": "projects/{project}/regions/{region}/commitments/{commitment}",
60545          "flatPath": "projects/{project}/regions/{region}/commitments/{commitment}",
60546          "httpMethod": "GET",
60547          "parameters": {
60548            "commitment": {
60549              "description": "Name of the commitment to return.",
60550              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
60551              "location": "path",
60552              "required": true,
60553              "type": "string"
60554            },
60555            "project": {
60556              "description": "Project ID for this request.",
60557              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60558              "location": "path",
60559              "required": true,
60560              "type": "string"
60561            },
60562            "region": {
60563              "description": "Name of the region for this request.",
60564              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60565              "location": "path",
60566              "required": true,
60567              "type": "string"
60568            }
60569          },
60570          "parameterOrder": [
60571            "project",
60572            "region",
60573            "commitment"
60574          ],
60575          "response": {
60576            "$ref": "Commitment"
60577          },
60578          "scopes": [
60579            "https://www.googleapis.com/auth/cloud-platform",
60580            "https://www.googleapis.com/auth/compute",
60581            "https://www.googleapis.com/auth/compute.readonly"
60582          ],
60583          "description": "Returns the specified commitment resource."
60584        },
60585        "insert": {
60586          "id": "compute.regionCommitments.insert",
60587          "path": "projects/{project}/regions/{region}/commitments",
60588          "flatPath": "projects/{project}/regions/{region}/commitments",
60589          "httpMethod": "POST",
60590          "parameters": {
60591            "project": {
60592              "description": "Project ID for this request.",
60593              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60594              "location": "path",
60595              "required": true,
60596              "type": "string"
60597            },
60598            "region": {
60599              "description": "Name of the region for this request.",
60600              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60601              "location": "path",
60602              "required": true,
60603              "type": "string"
60604            },
60605            "requestId": {
60606              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
60607              "location": "query",
60608              "type": "string"
60609            }
60610          },
60611          "parameterOrder": [
60612            "project",
60613            "region"
60614          ],
60615          "request": {
60616            "$ref": "Commitment"
60617          },
60618          "response": {
60619            "$ref": "Operation"
60620          },
60621          "scopes": [
60622            "https://www.googleapis.com/auth/cloud-platform",
60623            "https://www.googleapis.com/auth/compute"
60624          ],
60625          "description": "Creates a commitment in the specified project using the data included in the request."
60626        },
60627        "update": {
60628          "id": "compute.regionCommitments.update",
60629          "path": "projects/{project}/regions/{region}/commitments/{commitment}",
60630          "flatPath": "projects/{project}/regions/{region}/commitments/{commitment}",
60631          "httpMethod": "PATCH",
60632          "parameters": {
60633            "commitment": {
60634              "description": "Name of the commitment for which auto renew is being updated.",
60635              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
60636              "location": "path",
60637              "required": true,
60638              "type": "string"
60639            },
60640            "paths": {
60641              "location": "query",
60642              "repeated": true,
60643              "type": "string"
60644            },
60645            "project": {
60646              "description": "Project ID for this request.",
60647              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60648              "location": "path",
60649              "required": true,
60650              "type": "string"
60651            },
60652            "region": {
60653              "description": "Name of the region for this request.",
60654              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60655              "location": "path",
60656              "required": true,
60657              "type": "string"
60658            },
60659            "requestId": {
60660              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
60661              "location": "query",
60662              "type": "string"
60663            },
60664            "updateMask": {
60665              "description": "update_mask indicates fields to be updated as part of this request.",
60666              "location": "query",
60667              "type": "string",
60668              "format": "google-fieldmask"
60669            }
60670          },
60671          "parameterOrder": [
60672            "project",
60673            "region",
60674            "commitment"
60675          ],
60676          "request": {
60677            "$ref": "Commitment"
60678          },
60679          "response": {
60680            "$ref": "Operation"
60681          },
60682          "scopes": [
60683            "https://www.googleapis.com/auth/cloud-platform",
60684            "https://www.googleapis.com/auth/compute"
60685          ],
60686          "description": "Updates the specified commitment with the data included in the request. Update is performed only on selected fields included as part of update-mask. Only the following fields can be modified: auto_renew."
60687        }
60688      }
60689    },
60690    "diskTypes": {
60691      "methods": {
60692        "list": {
60693          "id": "compute.diskTypes.list",
60694          "path": "projects/{project}/zones/{zone}/diskTypes",
60695          "flatPath": "projects/{project}/zones/{zone}/diskTypes",
60696          "httpMethod": "GET",
60697          "parameters": {
60698            "filter": {
60699              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
60700              "location": "query",
60701              "type": "string"
60702            },
60703            "maxResults": {
60704              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
60705              "default": "500",
60706              "minimum": "0",
60707              "location": "query",
60708              "type": "integer",
60709              "format": "uint32"
60710            },
60711            "orderBy": {
60712              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
60713              "location": "query",
60714              "type": "string"
60715            },
60716            "pageToken": {
60717              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
60718              "location": "query",
60719              "type": "string"
60720            },
60721            "project": {
60722              "description": "Project ID for this request.",
60723              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60724              "location": "path",
60725              "required": true,
60726              "type": "string"
60727            },
60728            "returnPartialSuccess": {
60729              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
60730              "location": "query",
60731              "type": "boolean"
60732            },
60733            "zone": {
60734              "description": "The name of the zone for this request.",
60735              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60736              "location": "path",
60737              "required": true,
60738              "type": "string"
60739            }
60740          },
60741          "parameterOrder": [
60742            "project",
60743            "zone"
60744          ],
60745          "response": {
60746            "$ref": "DiskTypeList"
60747          },
60748          "scopes": [
60749            "https://www.googleapis.com/auth/cloud-platform",
60750            "https://www.googleapis.com/auth/compute",
60751            "https://www.googleapis.com/auth/compute.readonly"
60752          ],
60753          "description": "Retrieves a list of disk types available to the specified project."
60754        },
60755        "aggregatedList": {
60756          "id": "compute.diskTypes.aggregatedList",
60757          "path": "projects/{project}/aggregated/diskTypes",
60758          "flatPath": "projects/{project}/aggregated/diskTypes",
60759          "httpMethod": "GET",
60760          "parameters": {
60761            "filter": {
60762              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
60763              "location": "query",
60764              "type": "string"
60765            },
60766            "includeAllScopes": {
60767              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
60768              "location": "query",
60769              "type": "boolean"
60770            },
60771            "maxResults": {
60772              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
60773              "default": "500",
60774              "minimum": "0",
60775              "location": "query",
60776              "type": "integer",
60777              "format": "uint32"
60778            },
60779            "orderBy": {
60780              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
60781              "location": "query",
60782              "type": "string"
60783            },
60784            "pageToken": {
60785              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
60786              "location": "query",
60787              "type": "string"
60788            },
60789            "project": {
60790              "description": "Project ID for this request.",
60791              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60792              "location": "path",
60793              "required": true,
60794              "type": "string"
60795            },
60796            "returnPartialSuccess": {
60797              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
60798              "location": "query",
60799              "type": "boolean"
60800            },
60801            "serviceProjectNumber": {
60802              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
60803              "location": "query",
60804              "type": "string",
60805              "format": "int64"
60806            }
60807          },
60808          "parameterOrder": [
60809            "project"
60810          ],
60811          "response": {
60812            "$ref": "DiskTypeAggregatedList"
60813          },
60814          "scopes": [
60815            "https://www.googleapis.com/auth/cloud-platform",
60816            "https://www.googleapis.com/auth/compute",
60817            "https://www.googleapis.com/auth/compute.readonly"
60818          ],
60819          "description": "Retrieves an aggregated list of disk types. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
60820        },
60821        "get": {
60822          "id": "compute.diskTypes.get",
60823          "path": "projects/{project}/zones/{zone}/diskTypes/{diskType}",
60824          "flatPath": "projects/{project}/zones/{zone}/diskTypes/{diskType}",
60825          "httpMethod": "GET",
60826          "parameters": {
60827            "diskType": {
60828              "description": "Name of the disk type to return.",
60829              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
60830              "location": "path",
60831              "required": true,
60832              "type": "string"
60833            },
60834            "project": {
60835              "description": "Project ID for this request.",
60836              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60837              "location": "path",
60838              "required": true,
60839              "type": "string"
60840            },
60841            "zone": {
60842              "description": "The name of the zone for this request.",
60843              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60844              "location": "path",
60845              "required": true,
60846              "type": "string"
60847            }
60848          },
60849          "parameterOrder": [
60850            "project",
60851            "zone",
60852            "diskType"
60853          ],
60854          "response": {
60855            "$ref": "DiskType"
60856          },
60857          "scopes": [
60858            "https://www.googleapis.com/auth/cloud-platform",
60859            "https://www.googleapis.com/auth/compute",
60860            "https://www.googleapis.com/auth/compute.readonly"
60861          ],
60862          "description": "Returns the specified disk type."
60863        }
60864      }
60865    },
60866    "regionDiskTypes": {
60867      "methods": {
60868        "list": {
60869          "id": "compute.regionDiskTypes.list",
60870          "path": "projects/{project}/regions/{region}/diskTypes",
60871          "flatPath": "projects/{project}/regions/{region}/diskTypes",
60872          "httpMethod": "GET",
60873          "parameters": {
60874            "filter": {
60875              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
60876              "location": "query",
60877              "type": "string"
60878            },
60879            "maxResults": {
60880              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
60881              "default": "500",
60882              "minimum": "0",
60883              "location": "query",
60884              "type": "integer",
60885              "format": "uint32"
60886            },
60887            "orderBy": {
60888              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
60889              "location": "query",
60890              "type": "string"
60891            },
60892            "pageToken": {
60893              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
60894              "location": "query",
60895              "type": "string"
60896            },
60897            "project": {
60898              "description": "Project ID for this request.",
60899              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60900              "location": "path",
60901              "required": true,
60902              "type": "string"
60903            },
60904            "region": {
60905              "description": "The name of the region for this request.",
60906              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60907              "location": "path",
60908              "required": true,
60909              "type": "string"
60910            },
60911            "returnPartialSuccess": {
60912              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
60913              "location": "query",
60914              "type": "boolean"
60915            }
60916          },
60917          "parameterOrder": [
60918            "project",
60919            "region"
60920          ],
60921          "response": {
60922            "$ref": "RegionDiskTypeList"
60923          },
60924          "scopes": [
60925            "https://www.googleapis.com/auth/cloud-platform",
60926            "https://www.googleapis.com/auth/compute",
60927            "https://www.googleapis.com/auth/compute.readonly"
60928          ],
60929          "description": "Retrieves a list of regional disk types available to the specified project."
60930        },
60931        "get": {
60932          "id": "compute.regionDiskTypes.get",
60933          "path": "projects/{project}/regions/{region}/diskTypes/{diskType}",
60934          "flatPath": "projects/{project}/regions/{region}/diskTypes/{diskType}",
60935          "httpMethod": "GET",
60936          "parameters": {
60937            "diskType": {
60938              "description": "Name of the disk type to return.",
60939              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
60940              "location": "path",
60941              "required": true,
60942              "type": "string"
60943            },
60944            "project": {
60945              "description": "Project ID for this request.",
60946              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60947              "location": "path",
60948              "required": true,
60949              "type": "string"
60950            },
60951            "region": {
60952              "description": "The name of the region for this request.",
60953              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
60954              "location": "path",
60955              "required": true,
60956              "type": "string"
60957            }
60958          },
60959          "parameterOrder": [
60960            "project",
60961            "region",
60962            "diskType"
60963          ],
60964          "response": {
60965            "$ref": "DiskType"
60966          },
60967          "scopes": [
60968            "https://www.googleapis.com/auth/cloud-platform",
60969            "https://www.googleapis.com/auth/compute",
60970            "https://www.googleapis.com/auth/compute.readonly"
60971          ],
60972          "description": "Returns the specified regional disk type."
60973        }
60974      }
60975    },
60976    "externalVpnGateways": {
60977      "methods": {
60978        "insert": {
60979          "id": "compute.externalVpnGateways.insert",
60980          "path": "projects/{project}/global/externalVpnGateways",
60981          "flatPath": "projects/{project}/global/externalVpnGateways",
60982          "httpMethod": "POST",
60983          "parameters": {
60984            "project": {
60985              "description": "Project ID for this request.",
60986              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
60987              "location": "path",
60988              "required": true,
60989              "type": "string"
60990            },
60991            "requestId": {
60992              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
60993              "location": "query",
60994              "type": "string"
60995            }
60996          },
60997          "parameterOrder": [
60998            "project"
60999          ],
61000          "request": {
61001            "$ref": "ExternalVpnGateway"
61002          },
61003          "response": {
61004            "$ref": "Operation"
61005          },
61006          "scopes": [
61007            "https://www.googleapis.com/auth/cloud-platform",
61008            "https://www.googleapis.com/auth/compute"
61009          ],
61010          "description": "Creates a ExternalVpnGateway in the specified project using the data included in the request."
61011        },
61012        "list": {
61013          "id": "compute.externalVpnGateways.list",
61014          "path": "projects/{project}/global/externalVpnGateways",
61015          "flatPath": "projects/{project}/global/externalVpnGateways",
61016          "httpMethod": "GET",
61017          "parameters": {
61018            "filter": {
61019              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
61020              "location": "query",
61021              "type": "string"
61022            },
61023            "maxResults": {
61024              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
61025              "default": "500",
61026              "minimum": "0",
61027              "location": "query",
61028              "type": "integer",
61029              "format": "uint32"
61030            },
61031            "orderBy": {
61032              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
61033              "location": "query",
61034              "type": "string"
61035            },
61036            "pageToken": {
61037              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
61038              "location": "query",
61039              "type": "string"
61040            },
61041            "project": {
61042              "description": "Project ID for this request.",
61043              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61044              "location": "path",
61045              "required": true,
61046              "type": "string"
61047            },
61048            "returnPartialSuccess": {
61049              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
61050              "location": "query",
61051              "type": "boolean"
61052            }
61053          },
61054          "parameterOrder": [
61055            "project"
61056          ],
61057          "response": {
61058            "$ref": "ExternalVpnGatewayList"
61059          },
61060          "scopes": [
61061            "https://www.googleapis.com/auth/cloud-platform",
61062            "https://www.googleapis.com/auth/compute",
61063            "https://www.googleapis.com/auth/compute.readonly"
61064          ],
61065          "description": "Retrieves the list of ExternalVpnGateway available to the specified project."
61066        },
61067        "get": {
61068          "id": "compute.externalVpnGateways.get",
61069          "path": "projects/{project}/global/externalVpnGateways/{externalVpnGateway}",
61070          "flatPath": "projects/{project}/global/externalVpnGateways/{externalVpnGateway}",
61071          "httpMethod": "GET",
61072          "parameters": {
61073            "externalVpnGateway": {
61074              "description": "Name of the externalVpnGateway to return.",
61075              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
61076              "location": "path",
61077              "required": true,
61078              "type": "string"
61079            },
61080            "project": {
61081              "description": "Project ID for this request.",
61082              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61083              "location": "path",
61084              "required": true,
61085              "type": "string"
61086            }
61087          },
61088          "parameterOrder": [
61089            "project",
61090            "externalVpnGateway"
61091          ],
61092          "response": {
61093            "$ref": "ExternalVpnGateway"
61094          },
61095          "scopes": [
61096            "https://www.googleapis.com/auth/cloud-platform",
61097            "https://www.googleapis.com/auth/compute",
61098            "https://www.googleapis.com/auth/compute.readonly"
61099          ],
61100          "description": "Returns the specified externalVpnGateway. Get a list of available externalVpnGateways by making a list() request."
61101        },
61102        "delete": {
61103          "id": "compute.externalVpnGateways.delete",
61104          "path": "projects/{project}/global/externalVpnGateways/{externalVpnGateway}",
61105          "flatPath": "projects/{project}/global/externalVpnGateways/{externalVpnGateway}",
61106          "httpMethod": "DELETE",
61107          "parameters": {
61108            "externalVpnGateway": {
61109              "description": "Name of the externalVpnGateways to delete.",
61110              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
61111              "location": "path",
61112              "required": true,
61113              "type": "string"
61114            },
61115            "project": {
61116              "description": "Project ID for this request.",
61117              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61118              "location": "path",
61119              "required": true,
61120              "type": "string"
61121            },
61122            "requestId": {
61123              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
61124              "location": "query",
61125              "type": "string"
61126            }
61127          },
61128          "parameterOrder": [
61129            "project",
61130            "externalVpnGateway"
61131          ],
61132          "response": {
61133            "$ref": "Operation"
61134          },
61135          "scopes": [
61136            "https://www.googleapis.com/auth/cloud-platform",
61137            "https://www.googleapis.com/auth/compute"
61138          ],
61139          "description": "Deletes the specified externalVpnGateway."
61140        },
61141        "testIamPermissions": {
61142          "id": "compute.externalVpnGateways.testIamPermissions",
61143          "path": "projects/{project}/global/externalVpnGateways/{resource}/testIamPermissions",
61144          "flatPath": "projects/{project}/global/externalVpnGateways/{resource}/testIamPermissions",
61145          "httpMethod": "POST",
61146          "parameters": {
61147            "project": {
61148              "description": "Project ID for this request.",
61149              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61150              "location": "path",
61151              "required": true,
61152              "type": "string"
61153            },
61154            "resource": {
61155              "description": "Name or id of the resource for this request.",
61156              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
61157              "location": "path",
61158              "required": true,
61159              "type": "string"
61160            }
61161          },
61162          "parameterOrder": [
61163            "project",
61164            "resource"
61165          ],
61166          "request": {
61167            "$ref": "TestPermissionsRequest"
61168          },
61169          "response": {
61170            "$ref": "TestPermissionsResponse"
61171          },
61172          "scopes": [
61173            "https://www.googleapis.com/auth/cloud-platform",
61174            "https://www.googleapis.com/auth/compute",
61175            "https://www.googleapis.com/auth/compute.readonly"
61176          ],
61177          "description": "Returns permissions that a caller has on the specified resource."
61178        },
61179        "setLabels": {
61180          "id": "compute.externalVpnGateways.setLabels",
61181          "path": "projects/{project}/global/externalVpnGateways/{resource}/setLabels",
61182          "flatPath": "projects/{project}/global/externalVpnGateways/{resource}/setLabels",
61183          "httpMethod": "POST",
61184          "parameters": {
61185            "project": {
61186              "description": "Project ID for this request.",
61187              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61188              "location": "path",
61189              "required": true,
61190              "type": "string"
61191            },
61192            "resource": {
61193              "description": "Name or id of the resource for this request.",
61194              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
61195              "location": "path",
61196              "required": true,
61197              "type": "string"
61198            }
61199          },
61200          "parameterOrder": [
61201            "project",
61202            "resource"
61203          ],
61204          "request": {
61205            "$ref": "GlobalSetLabelsRequest"
61206          },
61207          "response": {
61208            "$ref": "Operation"
61209          },
61210          "scopes": [
61211            "https://www.googleapis.com/auth/cloud-platform",
61212            "https://www.googleapis.com/auth/compute"
61213          ],
61214          "description": "Sets the labels on an ExternalVpnGateway. To learn more about labels, read the Labeling Resources documentation."
61215        }
61216      }
61217    },
61218    "globalForwardingRules": {
61219      "methods": {
61220        "list": {
61221          "id": "compute.globalForwardingRules.list",
61222          "path": "projects/{project}/global/forwardingRules",
61223          "flatPath": "projects/{project}/global/forwardingRules",
61224          "httpMethod": "GET",
61225          "parameters": {
61226            "filter": {
61227              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
61228              "location": "query",
61229              "type": "string"
61230            },
61231            "maxResults": {
61232              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
61233              "default": "500",
61234              "minimum": "0",
61235              "location": "query",
61236              "type": "integer",
61237              "format": "uint32"
61238            },
61239            "orderBy": {
61240              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
61241              "location": "query",
61242              "type": "string"
61243            },
61244            "pageToken": {
61245              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
61246              "location": "query",
61247              "type": "string"
61248            },
61249            "project": {
61250              "description": "Project ID for this request.",
61251              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61252              "location": "path",
61253              "required": true,
61254              "type": "string"
61255            },
61256            "returnPartialSuccess": {
61257              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
61258              "location": "query",
61259              "type": "boolean"
61260            }
61261          },
61262          "parameterOrder": [
61263            "project"
61264          ],
61265          "response": {
61266            "$ref": "ForwardingRuleList"
61267          },
61268          "scopes": [
61269            "https://www.googleapis.com/auth/cloud-platform",
61270            "https://www.googleapis.com/auth/compute",
61271            "https://www.googleapis.com/auth/compute.readonly"
61272          ],
61273          "description": "Retrieves a list of GlobalForwardingRule resources available to the specified project."
61274        },
61275        "get": {
61276          "id": "compute.globalForwardingRules.get",
61277          "path": "projects/{project}/global/forwardingRules/{forwardingRule}",
61278          "flatPath": "projects/{project}/global/forwardingRules/{forwardingRule}",
61279          "httpMethod": "GET",
61280          "parameters": {
61281            "forwardingRule": {
61282              "description": "Name of the ForwardingRule resource to return.",
61283              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
61284              "location": "path",
61285              "required": true,
61286              "type": "string"
61287            },
61288            "project": {
61289              "description": "Project ID for this request.",
61290              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61291              "location": "path",
61292              "required": true,
61293              "type": "string"
61294            }
61295          },
61296          "parameterOrder": [
61297            "project",
61298            "forwardingRule"
61299          ],
61300          "response": {
61301            "$ref": "ForwardingRule"
61302          },
61303          "scopes": [
61304            "https://www.googleapis.com/auth/cloud-platform",
61305            "https://www.googleapis.com/auth/compute",
61306            "https://www.googleapis.com/auth/compute.readonly"
61307          ],
61308          "description": "Returns the specified GlobalForwardingRule resource. Gets a list of available forwarding rules by making a list() request."
61309        },
61310        "insert": {
61311          "id": "compute.globalForwardingRules.insert",
61312          "path": "projects/{project}/global/forwardingRules",
61313          "flatPath": "projects/{project}/global/forwardingRules",
61314          "httpMethod": "POST",
61315          "parameters": {
61316            "project": {
61317              "description": "Project ID for this request.",
61318              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61319              "location": "path",
61320              "required": true,
61321              "type": "string"
61322            },
61323            "requestId": {
61324              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
61325              "location": "query",
61326              "type": "string"
61327            }
61328          },
61329          "parameterOrder": [
61330            "project"
61331          ],
61332          "request": {
61333            "$ref": "ForwardingRule"
61334          },
61335          "response": {
61336            "$ref": "Operation"
61337          },
61338          "scopes": [
61339            "https://www.googleapis.com/auth/cloud-platform",
61340            "https://www.googleapis.com/auth/compute"
61341          ],
61342          "description": "Creates a GlobalForwardingRule resource in the specified project using the data included in the request."
61343        },
61344        "delete": {
61345          "id": "compute.globalForwardingRules.delete",
61346          "path": "projects/{project}/global/forwardingRules/{forwardingRule}",
61347          "flatPath": "projects/{project}/global/forwardingRules/{forwardingRule}",
61348          "httpMethod": "DELETE",
61349          "parameters": {
61350            "forwardingRule": {
61351              "description": "Name of the ForwardingRule resource to delete.",
61352              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
61353              "location": "path",
61354              "required": true,
61355              "type": "string"
61356            },
61357            "project": {
61358              "description": "Project ID for this request.",
61359              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61360              "location": "path",
61361              "required": true,
61362              "type": "string"
61363            },
61364            "requestId": {
61365              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
61366              "location": "query",
61367              "type": "string"
61368            }
61369          },
61370          "parameterOrder": [
61371            "project",
61372            "forwardingRule"
61373          ],
61374          "response": {
61375            "$ref": "Operation"
61376          },
61377          "scopes": [
61378            "https://www.googleapis.com/auth/cloud-platform",
61379            "https://www.googleapis.com/auth/compute"
61380          ],
61381          "description": "Deletes the specified GlobalForwardingRule resource."
61382        },
61383        "setTarget": {
61384          "id": "compute.globalForwardingRules.setTarget",
61385          "path": "projects/{project}/global/forwardingRules/{forwardingRule}/setTarget",
61386          "flatPath": "projects/{project}/global/forwardingRules/{forwardingRule}/setTarget",
61387          "httpMethod": "POST",
61388          "parameters": {
61389            "forwardingRule": {
61390              "description": "Name of the ForwardingRule resource in which target is to be set.",
61391              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
61392              "location": "path",
61393              "required": true,
61394              "type": "string"
61395            },
61396            "project": {
61397              "description": "Project ID for this request.",
61398              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61399              "location": "path",
61400              "required": true,
61401              "type": "string"
61402            },
61403            "requestId": {
61404              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
61405              "location": "query",
61406              "type": "string"
61407            }
61408          },
61409          "parameterOrder": [
61410            "project",
61411            "forwardingRule"
61412          ],
61413          "request": {
61414            "$ref": "TargetReference"
61415          },
61416          "response": {
61417            "$ref": "Operation"
61418          },
61419          "scopes": [
61420            "https://www.googleapis.com/auth/cloud-platform",
61421            "https://www.googleapis.com/auth/compute"
61422          ],
61423          "description": "Changes target URL for the GlobalForwardingRule resource. The new target should be of the same type as the old target."
61424        },
61425        "patch": {
61426          "id": "compute.globalForwardingRules.patch",
61427          "path": "projects/{project}/global/forwardingRules/{forwardingRule}",
61428          "flatPath": "projects/{project}/global/forwardingRules/{forwardingRule}",
61429          "httpMethod": "PATCH",
61430          "parameters": {
61431            "forwardingRule": {
61432              "description": "Name of the ForwardingRule resource to patch.",
61433              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
61434              "location": "path",
61435              "required": true,
61436              "type": "string"
61437            },
61438            "project": {
61439              "description": "Project ID for this request.",
61440              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61441              "location": "path",
61442              "required": true,
61443              "type": "string"
61444            },
61445            "requestId": {
61446              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
61447              "location": "query",
61448              "type": "string"
61449            }
61450          },
61451          "parameterOrder": [
61452            "project",
61453            "forwardingRule"
61454          ],
61455          "request": {
61456            "$ref": "ForwardingRule"
61457          },
61458          "response": {
61459            "$ref": "Operation"
61460          },
61461          "scopes": [
61462            "https://www.googleapis.com/auth/cloud-platform",
61463            "https://www.googleapis.com/auth/compute"
61464          ],
61465          "description": "Updates the specified forwarding rule with the data included in the request. This method supports PATCH semantics and uses the JSON merge patch format and processing rules. Currently, you can only patch the network_tier field."
61466        },
61467        "setLabels": {
61468          "id": "compute.globalForwardingRules.setLabels",
61469          "path": "projects/{project}/global/forwardingRules/{resource}/setLabels",
61470          "flatPath": "projects/{project}/global/forwardingRules/{resource}/setLabels",
61471          "httpMethod": "POST",
61472          "parameters": {
61473            "project": {
61474              "description": "Project ID for this request.",
61475              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61476              "location": "path",
61477              "required": true,
61478              "type": "string"
61479            },
61480            "resource": {
61481              "description": "Name or id of the resource for this request.",
61482              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
61483              "location": "path",
61484              "required": true,
61485              "type": "string"
61486            }
61487          },
61488          "parameterOrder": [
61489            "project",
61490            "resource"
61491          ],
61492          "request": {
61493            "$ref": "GlobalSetLabelsRequest"
61494          },
61495          "response": {
61496            "$ref": "Operation"
61497          },
61498          "scopes": [
61499            "https://www.googleapis.com/auth/cloud-platform",
61500            "https://www.googleapis.com/auth/compute"
61501          ],
61502          "description": "Sets the labels on the specified resource. To learn more about labels, read the Labeling resources documentation."
61503        }
61504      }
61505    },
61506    "forwardingRules": {
61507      "methods": {
61508        "list": {
61509          "id": "compute.forwardingRules.list",
61510          "path": "projects/{project}/regions/{region}/forwardingRules",
61511          "flatPath": "projects/{project}/regions/{region}/forwardingRules",
61512          "httpMethod": "GET",
61513          "parameters": {
61514            "filter": {
61515              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
61516              "location": "query",
61517              "type": "string"
61518            },
61519            "maxResults": {
61520              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
61521              "default": "500",
61522              "minimum": "0",
61523              "location": "query",
61524              "type": "integer",
61525              "format": "uint32"
61526            },
61527            "orderBy": {
61528              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
61529              "location": "query",
61530              "type": "string"
61531            },
61532            "pageToken": {
61533              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
61534              "location": "query",
61535              "type": "string"
61536            },
61537            "project": {
61538              "description": "Project ID for this request.",
61539              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61540              "location": "path",
61541              "required": true,
61542              "type": "string"
61543            },
61544            "region": {
61545              "description": "Name of the region scoping this request.",
61546              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
61547              "location": "path",
61548              "required": true,
61549              "type": "string"
61550            },
61551            "returnPartialSuccess": {
61552              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
61553              "location": "query",
61554              "type": "boolean"
61555            }
61556          },
61557          "parameterOrder": [
61558            "project",
61559            "region"
61560          ],
61561          "response": {
61562            "$ref": "ForwardingRuleList"
61563          },
61564          "scopes": [
61565            "https://www.googleapis.com/auth/cloud-platform",
61566            "https://www.googleapis.com/auth/compute",
61567            "https://www.googleapis.com/auth/compute.readonly"
61568          ],
61569          "description": "Retrieves a list of ForwardingRule resources available to the specified project and region."
61570        },
61571        "aggregatedList": {
61572          "id": "compute.forwardingRules.aggregatedList",
61573          "path": "projects/{project}/aggregated/forwardingRules",
61574          "flatPath": "projects/{project}/aggregated/forwardingRules",
61575          "httpMethod": "GET",
61576          "parameters": {
61577            "filter": {
61578              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
61579              "location": "query",
61580              "type": "string"
61581            },
61582            "includeAllScopes": {
61583              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
61584              "location": "query",
61585              "type": "boolean"
61586            },
61587            "maxResults": {
61588              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
61589              "default": "500",
61590              "minimum": "0",
61591              "location": "query",
61592              "type": "integer",
61593              "format": "uint32"
61594            },
61595            "orderBy": {
61596              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
61597              "location": "query",
61598              "type": "string"
61599            },
61600            "pageToken": {
61601              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
61602              "location": "query",
61603              "type": "string"
61604            },
61605            "project": {
61606              "description": "Project ID for this request.",
61607              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61608              "location": "path",
61609              "required": true,
61610              "type": "string"
61611            },
61612            "returnPartialSuccess": {
61613              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
61614              "location": "query",
61615              "type": "boolean"
61616            },
61617            "serviceProjectNumber": {
61618              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
61619              "location": "query",
61620              "type": "string",
61621              "format": "int64"
61622            }
61623          },
61624          "parameterOrder": [
61625            "project"
61626          ],
61627          "response": {
61628            "$ref": "ForwardingRuleAggregatedList"
61629          },
61630          "scopes": [
61631            "https://www.googleapis.com/auth/cloud-platform",
61632            "https://www.googleapis.com/auth/compute",
61633            "https://www.googleapis.com/auth/compute.readonly"
61634          ],
61635          "description": "Retrieves an aggregated list of forwarding rules. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
61636        },
61637        "get": {
61638          "id": "compute.forwardingRules.get",
61639          "path": "projects/{project}/regions/{region}/forwardingRules/{forwardingRule}",
61640          "flatPath": "projects/{project}/regions/{region}/forwardingRules/{forwardingRule}",
61641          "httpMethod": "GET",
61642          "parameters": {
61643            "forwardingRule": {
61644              "description": "Name of the ForwardingRule resource to return.",
61645              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
61646              "location": "path",
61647              "required": true,
61648              "type": "string"
61649            },
61650            "project": {
61651              "description": "Project ID for this request.",
61652              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61653              "location": "path",
61654              "required": true,
61655              "type": "string"
61656            },
61657            "region": {
61658              "description": "Name of the region scoping this request.",
61659              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
61660              "location": "path",
61661              "required": true,
61662              "type": "string"
61663            }
61664          },
61665          "parameterOrder": [
61666            "project",
61667            "region",
61668            "forwardingRule"
61669          ],
61670          "response": {
61671            "$ref": "ForwardingRule"
61672          },
61673          "scopes": [
61674            "https://www.googleapis.com/auth/cloud-platform",
61675            "https://www.googleapis.com/auth/compute",
61676            "https://www.googleapis.com/auth/compute.readonly"
61677          ],
61678          "description": "Returns the specified ForwardingRule resource."
61679        },
61680        "insert": {
61681          "id": "compute.forwardingRules.insert",
61682          "path": "projects/{project}/regions/{region}/forwardingRules",
61683          "flatPath": "projects/{project}/regions/{region}/forwardingRules",
61684          "httpMethod": "POST",
61685          "parameters": {
61686            "project": {
61687              "description": "Project ID for this request.",
61688              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61689              "location": "path",
61690              "required": true,
61691              "type": "string"
61692            },
61693            "region": {
61694              "description": "Name of the region scoping this request.",
61695              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
61696              "location": "path",
61697              "required": true,
61698              "type": "string"
61699            },
61700            "requestId": {
61701              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
61702              "location": "query",
61703              "type": "string"
61704            }
61705          },
61706          "parameterOrder": [
61707            "project",
61708            "region"
61709          ],
61710          "request": {
61711            "$ref": "ForwardingRule"
61712          },
61713          "response": {
61714            "$ref": "Operation"
61715          },
61716          "scopes": [
61717            "https://www.googleapis.com/auth/cloud-platform",
61718            "https://www.googleapis.com/auth/compute"
61719          ],
61720          "description": "Creates a ForwardingRule resource in the specified project and region using the data included in the request."
61721        },
61722        "delete": {
61723          "id": "compute.forwardingRules.delete",
61724          "path": "projects/{project}/regions/{region}/forwardingRules/{forwardingRule}",
61725          "flatPath": "projects/{project}/regions/{region}/forwardingRules/{forwardingRule}",
61726          "httpMethod": "DELETE",
61727          "parameters": {
61728            "forwardingRule": {
61729              "description": "Name of the ForwardingRule resource to delete.",
61730              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
61731              "location": "path",
61732              "required": true,
61733              "type": "string"
61734            },
61735            "project": {
61736              "description": "Project ID for this request.",
61737              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61738              "location": "path",
61739              "required": true,
61740              "type": "string"
61741            },
61742            "region": {
61743              "description": "Name of the region scoping this request.",
61744              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
61745              "location": "path",
61746              "required": true,
61747              "type": "string"
61748            },
61749            "requestId": {
61750              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
61751              "location": "query",
61752              "type": "string"
61753            }
61754          },
61755          "parameterOrder": [
61756            "project",
61757            "region",
61758            "forwardingRule"
61759          ],
61760          "response": {
61761            "$ref": "Operation"
61762          },
61763          "scopes": [
61764            "https://www.googleapis.com/auth/cloud-platform",
61765            "https://www.googleapis.com/auth/compute"
61766          ],
61767          "description": "Deletes the specified ForwardingRule resource."
61768        },
61769        "setTarget": {
61770          "id": "compute.forwardingRules.setTarget",
61771          "path": "projects/{project}/regions/{region}/forwardingRules/{forwardingRule}/setTarget",
61772          "flatPath": "projects/{project}/regions/{region}/forwardingRules/{forwardingRule}/setTarget",
61773          "httpMethod": "POST",
61774          "parameters": {
61775            "forwardingRule": {
61776              "description": "Name of the ForwardingRule resource in which target is to be set.",
61777              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
61778              "location": "path",
61779              "required": true,
61780              "type": "string"
61781            },
61782            "project": {
61783              "description": "Project ID for this request.",
61784              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61785              "location": "path",
61786              "required": true,
61787              "type": "string"
61788            },
61789            "region": {
61790              "description": "Name of the region scoping this request.",
61791              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
61792              "location": "path",
61793              "required": true,
61794              "type": "string"
61795            },
61796            "requestId": {
61797              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
61798              "location": "query",
61799              "type": "string"
61800            }
61801          },
61802          "parameterOrder": [
61803            "project",
61804            "region",
61805            "forwardingRule"
61806          ],
61807          "request": {
61808            "$ref": "TargetReference"
61809          },
61810          "response": {
61811            "$ref": "Operation"
61812          },
61813          "scopes": [
61814            "https://www.googleapis.com/auth/cloud-platform",
61815            "https://www.googleapis.com/auth/compute"
61816          ],
61817          "description": "Changes target URL for forwarding rule. The new target should be of the same type as the old target."
61818        },
61819        "patch": {
61820          "id": "compute.forwardingRules.patch",
61821          "path": "projects/{project}/regions/{region}/forwardingRules/{forwardingRule}",
61822          "flatPath": "projects/{project}/regions/{region}/forwardingRules/{forwardingRule}",
61823          "httpMethod": "PATCH",
61824          "parameters": {
61825            "forwardingRule": {
61826              "description": "Name of the ForwardingRule resource to patch.",
61827              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
61828              "location": "path",
61829              "required": true,
61830              "type": "string"
61831            },
61832            "project": {
61833              "description": "Project ID for this request.",
61834              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61835              "location": "path",
61836              "required": true,
61837              "type": "string"
61838            },
61839            "region": {
61840              "description": "Name of the region scoping this request.",
61841              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
61842              "location": "path",
61843              "required": true,
61844              "type": "string"
61845            },
61846            "requestId": {
61847              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
61848              "location": "query",
61849              "type": "string"
61850            }
61851          },
61852          "parameterOrder": [
61853            "project",
61854            "region",
61855            "forwardingRule"
61856          ],
61857          "request": {
61858            "$ref": "ForwardingRule"
61859          },
61860          "response": {
61861            "$ref": "Operation"
61862          },
61863          "scopes": [
61864            "https://www.googleapis.com/auth/cloud-platform",
61865            "https://www.googleapis.com/auth/compute"
61866          ],
61867          "description": "Updates the specified forwarding rule with the data included in the request. This method supports PATCH semantics and uses the JSON merge patch format and processing rules. Currently, you can only patch the network_tier field."
61868        },
61869        "setLabels": {
61870          "id": "compute.forwardingRules.setLabels",
61871          "path": "projects/{project}/regions/{region}/forwardingRules/{resource}/setLabels",
61872          "flatPath": "projects/{project}/regions/{region}/forwardingRules/{resource}/setLabels",
61873          "httpMethod": "POST",
61874          "parameters": {
61875            "project": {
61876              "description": "Project ID for this request.",
61877              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61878              "location": "path",
61879              "required": true,
61880              "type": "string"
61881            },
61882            "region": {
61883              "description": "The region for this request.",
61884              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
61885              "location": "path",
61886              "required": true,
61887              "type": "string"
61888            },
61889            "requestId": {
61890              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
61891              "location": "query",
61892              "type": "string"
61893            },
61894            "resource": {
61895              "description": "Name or id of the resource for this request.",
61896              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
61897              "location": "path",
61898              "required": true,
61899              "type": "string"
61900            }
61901          },
61902          "parameterOrder": [
61903            "project",
61904            "region",
61905            "resource"
61906          ],
61907          "request": {
61908            "$ref": "RegionSetLabelsRequest"
61909          },
61910          "response": {
61911            "$ref": "Operation"
61912          },
61913          "scopes": [
61914            "https://www.googleapis.com/auth/cloud-platform",
61915            "https://www.googleapis.com/auth/compute"
61916          ],
61917          "description": "Sets the labels on the specified resource. To learn more about labels, read the Labeling Resources documentation."
61918        }
61919      }
61920    },
61921    "regionHealthCheckServices": {
61922      "methods": {
61923        "list": {
61924          "id": "compute.regionHealthCheckServices.list",
61925          "path": "projects/{project}/regions/{region}/healthCheckServices",
61926          "flatPath": "projects/{project}/regions/{region}/healthCheckServices",
61927          "httpMethod": "GET",
61928          "parameters": {
61929            "filter": {
61930              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
61931              "location": "query",
61932              "type": "string"
61933            },
61934            "maxResults": {
61935              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
61936              "default": "500",
61937              "minimum": "0",
61938              "location": "query",
61939              "type": "integer",
61940              "format": "uint32"
61941            },
61942            "orderBy": {
61943              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
61944              "location": "query",
61945              "type": "string"
61946            },
61947            "pageToken": {
61948              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
61949              "location": "query",
61950              "type": "string"
61951            },
61952            "project": {
61953              "description": "Project ID for this request.",
61954              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
61955              "location": "path",
61956              "required": true,
61957              "type": "string"
61958            },
61959            "region": {
61960              "description": "Name of the region scoping this request.",
61961              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
61962              "location": "path",
61963              "required": true,
61964              "type": "string"
61965            },
61966            "returnPartialSuccess": {
61967              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
61968              "location": "query",
61969              "type": "boolean"
61970            }
61971          },
61972          "parameterOrder": [
61973            "project",
61974            "region"
61975          ],
61976          "response": {
61977            "$ref": "HealthCheckServicesList"
61978          },
61979          "scopes": [
61980            "https://www.googleapis.com/auth/cloud-platform",
61981            "https://www.googleapis.com/auth/compute",
61982            "https://www.googleapis.com/auth/compute.readonly"
61983          ],
61984          "description": "Lists all the HealthCheckService resources that have been configured for the specified project in the given region."
61985        },
61986        "get": {
61987          "id": "compute.regionHealthCheckServices.get",
61988          "path": "projects/{project}/regions/{region}/healthCheckServices/{healthCheckService}",
61989          "flatPath": "projects/{project}/regions/{region}/healthCheckServices/{healthCheckService}",
61990          "httpMethod": "GET",
61991          "parameters": {
61992            "healthCheckService": {
61993              "description": "Name of the HealthCheckService to update. The name must be 1-63 characters long, and comply with RFC1035.",
61994              "location": "path",
61995              "required": true,
61996              "type": "string"
61997            },
61998            "project": {
61999              "description": "Project ID for this request.",
62000              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62001              "location": "path",
62002              "required": true,
62003              "type": "string"
62004            },
62005            "region": {
62006              "description": "Name of the region scoping this request.",
62007              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
62008              "location": "path",
62009              "required": true,
62010              "type": "string"
62011            }
62012          },
62013          "parameterOrder": [
62014            "project",
62015            "region",
62016            "healthCheckService"
62017          ],
62018          "response": {
62019            "$ref": "HealthCheckService"
62020          },
62021          "scopes": [
62022            "https://www.googleapis.com/auth/cloud-platform",
62023            "https://www.googleapis.com/auth/compute",
62024            "https://www.googleapis.com/auth/compute.readonly"
62025          ],
62026          "description": "Returns the specified regional HealthCheckService resource."
62027        },
62028        "insert": {
62029          "id": "compute.regionHealthCheckServices.insert",
62030          "path": "projects/{project}/regions/{region}/healthCheckServices",
62031          "flatPath": "projects/{project}/regions/{region}/healthCheckServices",
62032          "httpMethod": "POST",
62033          "parameters": {
62034            "project": {
62035              "description": "Project ID for this request.",
62036              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62037              "location": "path",
62038              "required": true,
62039              "type": "string"
62040            },
62041            "region": {
62042              "description": "Name of the region scoping this request.",
62043              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
62044              "location": "path",
62045              "required": true,
62046              "type": "string"
62047            },
62048            "requestId": {
62049              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
62050              "location": "query",
62051              "type": "string"
62052            }
62053          },
62054          "parameterOrder": [
62055            "project",
62056            "region"
62057          ],
62058          "request": {
62059            "$ref": "HealthCheckService"
62060          },
62061          "response": {
62062            "$ref": "Operation"
62063          },
62064          "scopes": [
62065            "https://www.googleapis.com/auth/cloud-platform",
62066            "https://www.googleapis.com/auth/compute"
62067          ],
62068          "description": "Creates a regional HealthCheckService resource in the specified project and region using the data included in the request."
62069        },
62070        "delete": {
62071          "id": "compute.regionHealthCheckServices.delete",
62072          "path": "projects/{project}/regions/{region}/healthCheckServices/{healthCheckService}",
62073          "flatPath": "projects/{project}/regions/{region}/healthCheckServices/{healthCheckService}",
62074          "httpMethod": "DELETE",
62075          "parameters": {
62076            "healthCheckService": {
62077              "description": "Name of the HealthCheckService to delete. The name must be 1-63 characters long, and comply with RFC1035.",
62078              "location": "path",
62079              "required": true,
62080              "type": "string"
62081            },
62082            "project": {
62083              "description": "Project ID for this request.",
62084              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62085              "location": "path",
62086              "required": true,
62087              "type": "string"
62088            },
62089            "region": {
62090              "description": "Name of the region scoping this request.",
62091              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
62092              "location": "path",
62093              "required": true,
62094              "type": "string"
62095            },
62096            "requestId": {
62097              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
62098              "location": "query",
62099              "type": "string"
62100            }
62101          },
62102          "parameterOrder": [
62103            "project",
62104            "region",
62105            "healthCheckService"
62106          ],
62107          "response": {
62108            "$ref": "Operation"
62109          },
62110          "scopes": [
62111            "https://www.googleapis.com/auth/cloud-platform",
62112            "https://www.googleapis.com/auth/compute"
62113          ],
62114          "description": "Deletes the specified regional HealthCheckService."
62115        },
62116        "patch": {
62117          "id": "compute.regionHealthCheckServices.patch",
62118          "path": "projects/{project}/regions/{region}/healthCheckServices/{healthCheckService}",
62119          "flatPath": "projects/{project}/regions/{region}/healthCheckServices/{healthCheckService}",
62120          "httpMethod": "PATCH",
62121          "parameters": {
62122            "healthCheckService": {
62123              "description": "Name of the HealthCheckService to update. The name must be 1-63 characters long, and comply with RFC1035.",
62124              "location": "path",
62125              "required": true,
62126              "type": "string"
62127            },
62128            "project": {
62129              "description": "Project ID for this request.",
62130              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62131              "location": "path",
62132              "required": true,
62133              "type": "string"
62134            },
62135            "region": {
62136              "description": "Name of the region scoping this request.",
62137              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
62138              "location": "path",
62139              "required": true,
62140              "type": "string"
62141            },
62142            "requestId": {
62143              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
62144              "location": "query",
62145              "type": "string"
62146            }
62147          },
62148          "parameterOrder": [
62149            "project",
62150            "region",
62151            "healthCheckService"
62152          ],
62153          "request": {
62154            "$ref": "HealthCheckService"
62155          },
62156          "response": {
62157            "$ref": "Operation"
62158          },
62159          "scopes": [
62160            "https://www.googleapis.com/auth/cloud-platform",
62161            "https://www.googleapis.com/auth/compute"
62162          ],
62163          "description": "Updates the specified regional HealthCheckService resource with the data included in the request. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
62164        }
62165      }
62166    },
62167    "healthChecks": {
62168      "methods": {
62169        "list": {
62170          "id": "compute.healthChecks.list",
62171          "path": "projects/{project}/global/healthChecks",
62172          "flatPath": "projects/{project}/global/healthChecks",
62173          "httpMethod": "GET",
62174          "parameters": {
62175            "filter": {
62176              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
62177              "location": "query",
62178              "type": "string"
62179            },
62180            "maxResults": {
62181              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
62182              "default": "500",
62183              "minimum": "0",
62184              "location": "query",
62185              "type": "integer",
62186              "format": "uint32"
62187            },
62188            "orderBy": {
62189              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
62190              "location": "query",
62191              "type": "string"
62192            },
62193            "pageToken": {
62194              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
62195              "location": "query",
62196              "type": "string"
62197            },
62198            "project": {
62199              "description": "Project ID for this request.",
62200              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62201              "location": "path",
62202              "required": true,
62203              "type": "string"
62204            },
62205            "returnPartialSuccess": {
62206              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
62207              "location": "query",
62208              "type": "boolean"
62209            }
62210          },
62211          "parameterOrder": [
62212            "project"
62213          ],
62214          "response": {
62215            "$ref": "HealthCheckList"
62216          },
62217          "scopes": [
62218            "https://www.googleapis.com/auth/cloud-platform",
62219            "https://www.googleapis.com/auth/compute",
62220            "https://www.googleapis.com/auth/compute.readonly"
62221          ],
62222          "description": "Retrieves the list of HealthCheck resources available to the specified project."
62223        },
62224        "aggregatedList": {
62225          "id": "compute.healthChecks.aggregatedList",
62226          "path": "projects/{project}/aggregated/healthChecks",
62227          "flatPath": "projects/{project}/aggregated/healthChecks",
62228          "httpMethod": "GET",
62229          "parameters": {
62230            "filter": {
62231              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
62232              "location": "query",
62233              "type": "string"
62234            },
62235            "includeAllScopes": {
62236              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
62237              "location": "query",
62238              "type": "boolean"
62239            },
62240            "maxResults": {
62241              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
62242              "default": "500",
62243              "minimum": "0",
62244              "location": "query",
62245              "type": "integer",
62246              "format": "uint32"
62247            },
62248            "orderBy": {
62249              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
62250              "location": "query",
62251              "type": "string"
62252            },
62253            "pageToken": {
62254              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
62255              "location": "query",
62256              "type": "string"
62257            },
62258            "project": {
62259              "description": "Name of the project scoping this request.",
62260              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62261              "location": "path",
62262              "required": true,
62263              "type": "string"
62264            },
62265            "returnPartialSuccess": {
62266              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
62267              "location": "query",
62268              "type": "boolean"
62269            },
62270            "serviceProjectNumber": {
62271              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
62272              "location": "query",
62273              "type": "string",
62274              "format": "int64"
62275            }
62276          },
62277          "parameterOrder": [
62278            "project"
62279          ],
62280          "response": {
62281            "$ref": "HealthChecksAggregatedList"
62282          },
62283          "scopes": [
62284            "https://www.googleapis.com/auth/cloud-platform",
62285            "https://www.googleapis.com/auth/compute",
62286            "https://www.googleapis.com/auth/compute.readonly"
62287          ],
62288          "description": "Retrieves the list of all HealthCheck resources, regional and global, available to the specified project. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
62289        },
62290        "get": {
62291          "id": "compute.healthChecks.get",
62292          "path": "projects/{project}/global/healthChecks/{healthCheck}",
62293          "flatPath": "projects/{project}/global/healthChecks/{healthCheck}",
62294          "httpMethod": "GET",
62295          "parameters": {
62296            "healthCheck": {
62297              "description": "Name of the HealthCheck resource to return.",
62298              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
62299              "location": "path",
62300              "required": true,
62301              "type": "string"
62302            },
62303            "project": {
62304              "description": "Project ID for this request.",
62305              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62306              "location": "path",
62307              "required": true,
62308              "type": "string"
62309            }
62310          },
62311          "parameterOrder": [
62312            "project",
62313            "healthCheck"
62314          ],
62315          "response": {
62316            "$ref": "HealthCheck"
62317          },
62318          "scopes": [
62319            "https://www.googleapis.com/auth/cloud-platform",
62320            "https://www.googleapis.com/auth/compute",
62321            "https://www.googleapis.com/auth/compute.readonly"
62322          ],
62323          "description": "Returns the specified HealthCheck resource."
62324        },
62325        "insert": {
62326          "id": "compute.healthChecks.insert",
62327          "path": "projects/{project}/global/healthChecks",
62328          "flatPath": "projects/{project}/global/healthChecks",
62329          "httpMethod": "POST",
62330          "parameters": {
62331            "project": {
62332              "description": "Project ID for this request.",
62333              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62334              "location": "path",
62335              "required": true,
62336              "type": "string"
62337            },
62338            "requestId": {
62339              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
62340              "location": "query",
62341              "type": "string"
62342            }
62343          },
62344          "parameterOrder": [
62345            "project"
62346          ],
62347          "request": {
62348            "$ref": "HealthCheck"
62349          },
62350          "response": {
62351            "$ref": "Operation"
62352          },
62353          "scopes": [
62354            "https://www.googleapis.com/auth/cloud-platform",
62355            "https://www.googleapis.com/auth/compute"
62356          ],
62357          "description": "Creates a HealthCheck resource in the specified project using the data included in the request."
62358        },
62359        "delete": {
62360          "id": "compute.healthChecks.delete",
62361          "path": "projects/{project}/global/healthChecks/{healthCheck}",
62362          "flatPath": "projects/{project}/global/healthChecks/{healthCheck}",
62363          "httpMethod": "DELETE",
62364          "parameters": {
62365            "healthCheck": {
62366              "description": "Name of the HealthCheck resource to delete.",
62367              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
62368              "location": "path",
62369              "required": true,
62370              "type": "string"
62371            },
62372            "project": {
62373              "description": "Project ID for this request.",
62374              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62375              "location": "path",
62376              "required": true,
62377              "type": "string"
62378            },
62379            "requestId": {
62380              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
62381              "location": "query",
62382              "type": "string"
62383            }
62384          },
62385          "parameterOrder": [
62386            "project",
62387            "healthCheck"
62388          ],
62389          "response": {
62390            "$ref": "Operation"
62391          },
62392          "scopes": [
62393            "https://www.googleapis.com/auth/cloud-platform",
62394            "https://www.googleapis.com/auth/compute"
62395          ],
62396          "description": "Deletes the specified HealthCheck resource."
62397        },
62398        "update": {
62399          "id": "compute.healthChecks.update",
62400          "path": "projects/{project}/global/healthChecks/{healthCheck}",
62401          "flatPath": "projects/{project}/global/healthChecks/{healthCheck}",
62402          "httpMethod": "PUT",
62403          "parameters": {
62404            "healthCheck": {
62405              "description": "Name of the HealthCheck resource to update.",
62406              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
62407              "location": "path",
62408              "required": true,
62409              "type": "string"
62410            },
62411            "project": {
62412              "description": "Project ID for this request.",
62413              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62414              "location": "path",
62415              "required": true,
62416              "type": "string"
62417            },
62418            "requestId": {
62419              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
62420              "location": "query",
62421              "type": "string"
62422            }
62423          },
62424          "parameterOrder": [
62425            "project",
62426            "healthCheck"
62427          ],
62428          "request": {
62429            "$ref": "HealthCheck"
62430          },
62431          "response": {
62432            "$ref": "Operation"
62433          },
62434          "scopes": [
62435            "https://www.googleapis.com/auth/cloud-platform",
62436            "https://www.googleapis.com/auth/compute"
62437          ],
62438          "description": "Updates a HealthCheck resource in the specified project using the data included in the request."
62439        },
62440        "patch": {
62441          "id": "compute.healthChecks.patch",
62442          "path": "projects/{project}/global/healthChecks/{healthCheck}",
62443          "flatPath": "projects/{project}/global/healthChecks/{healthCheck}",
62444          "httpMethod": "PATCH",
62445          "parameters": {
62446            "healthCheck": {
62447              "description": "Name of the HealthCheck resource to patch.",
62448              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
62449              "location": "path",
62450              "required": true,
62451              "type": "string"
62452            },
62453            "project": {
62454              "description": "Project ID for this request.",
62455              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62456              "location": "path",
62457              "required": true,
62458              "type": "string"
62459            },
62460            "requestId": {
62461              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
62462              "location": "query",
62463              "type": "string"
62464            }
62465          },
62466          "parameterOrder": [
62467            "project",
62468            "healthCheck"
62469          ],
62470          "request": {
62471            "$ref": "HealthCheck"
62472          },
62473          "response": {
62474            "$ref": "Operation"
62475          },
62476          "scopes": [
62477            "https://www.googleapis.com/auth/cloud-platform",
62478            "https://www.googleapis.com/auth/compute"
62479          ],
62480          "description": "Updates a HealthCheck resource in the specified project using the data included in the request. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
62481        }
62482      }
62483    },
62484    "regionHealthChecks": {
62485      "methods": {
62486        "list": {
62487          "id": "compute.regionHealthChecks.list",
62488          "path": "projects/{project}/regions/{region}/healthChecks",
62489          "flatPath": "projects/{project}/regions/{region}/healthChecks",
62490          "httpMethod": "GET",
62491          "parameters": {
62492            "filter": {
62493              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
62494              "location": "query",
62495              "type": "string"
62496            },
62497            "maxResults": {
62498              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
62499              "default": "500",
62500              "minimum": "0",
62501              "location": "query",
62502              "type": "integer",
62503              "format": "uint32"
62504            },
62505            "orderBy": {
62506              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
62507              "location": "query",
62508              "type": "string"
62509            },
62510            "pageToken": {
62511              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
62512              "location": "query",
62513              "type": "string"
62514            },
62515            "project": {
62516              "description": "Project ID for this request.",
62517              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62518              "location": "path",
62519              "required": true,
62520              "type": "string"
62521            },
62522            "region": {
62523              "description": "Name of the region scoping this request.",
62524              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
62525              "location": "path",
62526              "required": true,
62527              "type": "string"
62528            },
62529            "returnPartialSuccess": {
62530              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
62531              "location": "query",
62532              "type": "boolean"
62533            }
62534          },
62535          "parameterOrder": [
62536            "project",
62537            "region"
62538          ],
62539          "response": {
62540            "$ref": "HealthCheckList"
62541          },
62542          "scopes": [
62543            "https://www.googleapis.com/auth/cloud-platform",
62544            "https://www.googleapis.com/auth/compute",
62545            "https://www.googleapis.com/auth/compute.readonly"
62546          ],
62547          "description": "Retrieves the list of HealthCheck resources available to the specified project."
62548        },
62549        "get": {
62550          "id": "compute.regionHealthChecks.get",
62551          "path": "projects/{project}/regions/{region}/healthChecks/{healthCheck}",
62552          "flatPath": "projects/{project}/regions/{region}/healthChecks/{healthCheck}",
62553          "httpMethod": "GET",
62554          "parameters": {
62555            "healthCheck": {
62556              "description": "Name of the HealthCheck resource to return.",
62557              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
62558              "location": "path",
62559              "required": true,
62560              "type": "string"
62561            },
62562            "project": {
62563              "description": "Project ID for this request.",
62564              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62565              "location": "path",
62566              "required": true,
62567              "type": "string"
62568            },
62569            "region": {
62570              "description": "Name of the region scoping this request.",
62571              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
62572              "location": "path",
62573              "required": true,
62574              "type": "string"
62575            }
62576          },
62577          "parameterOrder": [
62578            "project",
62579            "region",
62580            "healthCheck"
62581          ],
62582          "response": {
62583            "$ref": "HealthCheck"
62584          },
62585          "scopes": [
62586            "https://www.googleapis.com/auth/cloud-platform",
62587            "https://www.googleapis.com/auth/compute",
62588            "https://www.googleapis.com/auth/compute.readonly"
62589          ],
62590          "description": "Returns the specified HealthCheck resource."
62591        },
62592        "insert": {
62593          "id": "compute.regionHealthChecks.insert",
62594          "path": "projects/{project}/regions/{region}/healthChecks",
62595          "flatPath": "projects/{project}/regions/{region}/healthChecks",
62596          "httpMethod": "POST",
62597          "parameters": {
62598            "project": {
62599              "description": "Project ID for this request.",
62600              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62601              "location": "path",
62602              "required": true,
62603              "type": "string"
62604            },
62605            "region": {
62606              "description": "Name of the region scoping this request.",
62607              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
62608              "location": "path",
62609              "required": true,
62610              "type": "string"
62611            },
62612            "requestId": {
62613              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
62614              "location": "query",
62615              "type": "string"
62616            }
62617          },
62618          "parameterOrder": [
62619            "project",
62620            "region"
62621          ],
62622          "request": {
62623            "$ref": "HealthCheck"
62624          },
62625          "response": {
62626            "$ref": "Operation"
62627          },
62628          "scopes": [
62629            "https://www.googleapis.com/auth/cloud-platform",
62630            "https://www.googleapis.com/auth/compute"
62631          ],
62632          "description": "Creates a HealthCheck resource in the specified project using the data included in the request."
62633        },
62634        "delete": {
62635          "id": "compute.regionHealthChecks.delete",
62636          "path": "projects/{project}/regions/{region}/healthChecks/{healthCheck}",
62637          "flatPath": "projects/{project}/regions/{region}/healthChecks/{healthCheck}",
62638          "httpMethod": "DELETE",
62639          "parameters": {
62640            "healthCheck": {
62641              "description": "Name of the HealthCheck resource to delete.",
62642              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
62643              "location": "path",
62644              "required": true,
62645              "type": "string"
62646            },
62647            "project": {
62648              "description": "Project ID for this request.",
62649              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62650              "location": "path",
62651              "required": true,
62652              "type": "string"
62653            },
62654            "region": {
62655              "description": "Name of the region scoping this request.",
62656              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
62657              "location": "path",
62658              "required": true,
62659              "type": "string"
62660            },
62661            "requestId": {
62662              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
62663              "location": "query",
62664              "type": "string"
62665            }
62666          },
62667          "parameterOrder": [
62668            "project",
62669            "region",
62670            "healthCheck"
62671          ],
62672          "response": {
62673            "$ref": "Operation"
62674          },
62675          "scopes": [
62676            "https://www.googleapis.com/auth/cloud-platform",
62677            "https://www.googleapis.com/auth/compute"
62678          ],
62679          "description": "Deletes the specified HealthCheck resource."
62680        },
62681        "update": {
62682          "id": "compute.regionHealthChecks.update",
62683          "path": "projects/{project}/regions/{region}/healthChecks/{healthCheck}",
62684          "flatPath": "projects/{project}/regions/{region}/healthChecks/{healthCheck}",
62685          "httpMethod": "PUT",
62686          "parameters": {
62687            "healthCheck": {
62688              "description": "Name of the HealthCheck resource to update.",
62689              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
62690              "location": "path",
62691              "required": true,
62692              "type": "string"
62693            },
62694            "project": {
62695              "description": "Project ID for this request.",
62696              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62697              "location": "path",
62698              "required": true,
62699              "type": "string"
62700            },
62701            "region": {
62702              "description": "Name of the region scoping this request.",
62703              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
62704              "location": "path",
62705              "required": true,
62706              "type": "string"
62707            },
62708            "requestId": {
62709              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
62710              "location": "query",
62711              "type": "string"
62712            }
62713          },
62714          "parameterOrder": [
62715            "project",
62716            "region",
62717            "healthCheck"
62718          ],
62719          "request": {
62720            "$ref": "HealthCheck"
62721          },
62722          "response": {
62723            "$ref": "Operation"
62724          },
62725          "scopes": [
62726            "https://www.googleapis.com/auth/cloud-platform",
62727            "https://www.googleapis.com/auth/compute"
62728          ],
62729          "description": "Updates a HealthCheck resource in the specified project using the data included in the request."
62730        },
62731        "patch": {
62732          "id": "compute.regionHealthChecks.patch",
62733          "path": "projects/{project}/regions/{region}/healthChecks/{healthCheck}",
62734          "flatPath": "projects/{project}/regions/{region}/healthChecks/{healthCheck}",
62735          "httpMethod": "PATCH",
62736          "parameters": {
62737            "healthCheck": {
62738              "description": "Name of the HealthCheck resource to patch.",
62739              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
62740              "location": "path",
62741              "required": true,
62742              "type": "string"
62743            },
62744            "project": {
62745              "description": "Project ID for this request.",
62746              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62747              "location": "path",
62748              "required": true,
62749              "type": "string"
62750            },
62751            "region": {
62752              "description": "Name of the region scoping this request.",
62753              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
62754              "location": "path",
62755              "required": true,
62756              "type": "string"
62757            },
62758            "requestId": {
62759              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
62760              "location": "query",
62761              "type": "string"
62762            }
62763          },
62764          "parameterOrder": [
62765            "project",
62766            "region",
62767            "healthCheck"
62768          ],
62769          "request": {
62770            "$ref": "HealthCheck"
62771          },
62772          "response": {
62773            "$ref": "Operation"
62774          },
62775          "scopes": [
62776            "https://www.googleapis.com/auth/cloud-platform",
62777            "https://www.googleapis.com/auth/compute"
62778          ],
62779          "description": "Updates a HealthCheck resource in the specified project using the data included in the request. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
62780        }
62781      }
62782    },
62783    "httpHealthChecks": {
62784      "methods": {
62785        "list": {
62786          "id": "compute.httpHealthChecks.list",
62787          "path": "projects/{project}/global/httpHealthChecks",
62788          "flatPath": "projects/{project}/global/httpHealthChecks",
62789          "httpMethod": "GET",
62790          "parameters": {
62791            "filter": {
62792              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
62793              "location": "query",
62794              "type": "string"
62795            },
62796            "maxResults": {
62797              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
62798              "default": "500",
62799              "minimum": "0",
62800              "location": "query",
62801              "type": "integer",
62802              "format": "uint32"
62803            },
62804            "orderBy": {
62805              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
62806              "location": "query",
62807              "type": "string"
62808            },
62809            "pageToken": {
62810              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
62811              "location": "query",
62812              "type": "string"
62813            },
62814            "project": {
62815              "description": "Project ID for this request.",
62816              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62817              "location": "path",
62818              "required": true,
62819              "type": "string"
62820            },
62821            "returnPartialSuccess": {
62822              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
62823              "location": "query",
62824              "type": "boolean"
62825            }
62826          },
62827          "parameterOrder": [
62828            "project"
62829          ],
62830          "response": {
62831            "$ref": "HttpHealthCheckList"
62832          },
62833          "scopes": [
62834            "https://www.googleapis.com/auth/cloud-platform",
62835            "https://www.googleapis.com/auth/compute",
62836            "https://www.googleapis.com/auth/compute.readonly"
62837          ],
62838          "description": "Retrieves the list of HttpHealthCheck resources available to the specified project."
62839        },
62840        "get": {
62841          "id": "compute.httpHealthChecks.get",
62842          "path": "projects/{project}/global/httpHealthChecks/{httpHealthCheck}",
62843          "flatPath": "projects/{project}/global/httpHealthChecks/{httpHealthCheck}",
62844          "httpMethod": "GET",
62845          "parameters": {
62846            "httpHealthCheck": {
62847              "description": "Name of the HttpHealthCheck resource to return.",
62848              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
62849              "location": "path",
62850              "required": true,
62851              "type": "string"
62852            },
62853            "project": {
62854              "description": "Project ID for this request.",
62855              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62856              "location": "path",
62857              "required": true,
62858              "type": "string"
62859            }
62860          },
62861          "parameterOrder": [
62862            "project",
62863            "httpHealthCheck"
62864          ],
62865          "response": {
62866            "$ref": "HttpHealthCheck"
62867          },
62868          "scopes": [
62869            "https://www.googleapis.com/auth/cloud-platform",
62870            "https://www.googleapis.com/auth/compute",
62871            "https://www.googleapis.com/auth/compute.readonly"
62872          ],
62873          "description": "Returns the specified HttpHealthCheck resource."
62874        },
62875        "insert": {
62876          "id": "compute.httpHealthChecks.insert",
62877          "path": "projects/{project}/global/httpHealthChecks",
62878          "flatPath": "projects/{project}/global/httpHealthChecks",
62879          "httpMethod": "POST",
62880          "parameters": {
62881            "project": {
62882              "description": "Project ID for this request.",
62883              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62884              "location": "path",
62885              "required": true,
62886              "type": "string"
62887            },
62888            "requestId": {
62889              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
62890              "location": "query",
62891              "type": "string"
62892            }
62893          },
62894          "parameterOrder": [
62895            "project"
62896          ],
62897          "request": {
62898            "$ref": "HttpHealthCheck"
62899          },
62900          "response": {
62901            "$ref": "Operation"
62902          },
62903          "scopes": [
62904            "https://www.googleapis.com/auth/cloud-platform",
62905            "https://www.googleapis.com/auth/compute"
62906          ],
62907          "description": "Creates a HttpHealthCheck resource in the specified project using the data included in the request."
62908        },
62909        "delete": {
62910          "id": "compute.httpHealthChecks.delete",
62911          "path": "projects/{project}/global/httpHealthChecks/{httpHealthCheck}",
62912          "flatPath": "projects/{project}/global/httpHealthChecks/{httpHealthCheck}",
62913          "httpMethod": "DELETE",
62914          "parameters": {
62915            "httpHealthCheck": {
62916              "description": "Name of the HttpHealthCheck resource to delete.",
62917              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
62918              "location": "path",
62919              "required": true,
62920              "type": "string"
62921            },
62922            "project": {
62923              "description": "Project ID for this request.",
62924              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62925              "location": "path",
62926              "required": true,
62927              "type": "string"
62928            },
62929            "requestId": {
62930              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
62931              "location": "query",
62932              "type": "string"
62933            }
62934          },
62935          "parameterOrder": [
62936            "project",
62937            "httpHealthCheck"
62938          ],
62939          "response": {
62940            "$ref": "Operation"
62941          },
62942          "scopes": [
62943            "https://www.googleapis.com/auth/cloud-platform",
62944            "https://www.googleapis.com/auth/compute"
62945          ],
62946          "description": "Deletes the specified HttpHealthCheck resource."
62947        },
62948        "update": {
62949          "id": "compute.httpHealthChecks.update",
62950          "path": "projects/{project}/global/httpHealthChecks/{httpHealthCheck}",
62951          "flatPath": "projects/{project}/global/httpHealthChecks/{httpHealthCheck}",
62952          "httpMethod": "PUT",
62953          "parameters": {
62954            "httpHealthCheck": {
62955              "description": "Name of the HttpHealthCheck resource to update.",
62956              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
62957              "location": "path",
62958              "required": true,
62959              "type": "string"
62960            },
62961            "project": {
62962              "description": "Project ID for this request.",
62963              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
62964              "location": "path",
62965              "required": true,
62966              "type": "string"
62967            },
62968            "requestId": {
62969              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
62970              "location": "query",
62971              "type": "string"
62972            }
62973          },
62974          "parameterOrder": [
62975            "project",
62976            "httpHealthCheck"
62977          ],
62978          "request": {
62979            "$ref": "HttpHealthCheck"
62980          },
62981          "response": {
62982            "$ref": "Operation"
62983          },
62984          "scopes": [
62985            "https://www.googleapis.com/auth/cloud-platform",
62986            "https://www.googleapis.com/auth/compute"
62987          ],
62988          "description": "Updates a HttpHealthCheck resource in the specified project using the data included in the request."
62989        },
62990        "patch": {
62991          "id": "compute.httpHealthChecks.patch",
62992          "path": "projects/{project}/global/httpHealthChecks/{httpHealthCheck}",
62993          "flatPath": "projects/{project}/global/httpHealthChecks/{httpHealthCheck}",
62994          "httpMethod": "PATCH",
62995          "parameters": {
62996            "httpHealthCheck": {
62997              "description": "Name of the HttpHealthCheck resource to patch.",
62998              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
62999              "location": "path",
63000              "required": true,
63001              "type": "string"
63002            },
63003            "project": {
63004              "description": "Project ID for this request.",
63005              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63006              "location": "path",
63007              "required": true,
63008              "type": "string"
63009            },
63010            "requestId": {
63011              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
63012              "location": "query",
63013              "type": "string"
63014            }
63015          },
63016          "parameterOrder": [
63017            "project",
63018            "httpHealthCheck"
63019          ],
63020          "request": {
63021            "$ref": "HttpHealthCheck"
63022          },
63023          "response": {
63024            "$ref": "Operation"
63025          },
63026          "scopes": [
63027            "https://www.googleapis.com/auth/cloud-platform",
63028            "https://www.googleapis.com/auth/compute"
63029          ],
63030          "description": "Updates a HttpHealthCheck resource in the specified project using the data included in the request. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
63031        }
63032      }
63033    },
63034    "httpsHealthChecks": {
63035      "methods": {
63036        "list": {
63037          "id": "compute.httpsHealthChecks.list",
63038          "path": "projects/{project}/global/httpsHealthChecks",
63039          "flatPath": "projects/{project}/global/httpsHealthChecks",
63040          "httpMethod": "GET",
63041          "parameters": {
63042            "filter": {
63043              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
63044              "location": "query",
63045              "type": "string"
63046            },
63047            "maxResults": {
63048              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
63049              "default": "500",
63050              "minimum": "0",
63051              "location": "query",
63052              "type": "integer",
63053              "format": "uint32"
63054            },
63055            "orderBy": {
63056              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
63057              "location": "query",
63058              "type": "string"
63059            },
63060            "pageToken": {
63061              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
63062              "location": "query",
63063              "type": "string"
63064            },
63065            "project": {
63066              "description": "Project ID for this request.",
63067              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63068              "location": "path",
63069              "required": true,
63070              "type": "string"
63071            },
63072            "returnPartialSuccess": {
63073              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
63074              "location": "query",
63075              "type": "boolean"
63076            }
63077          },
63078          "parameterOrder": [
63079            "project"
63080          ],
63081          "response": {
63082            "$ref": "HttpsHealthCheckList"
63083          },
63084          "scopes": [
63085            "https://www.googleapis.com/auth/cloud-platform",
63086            "https://www.googleapis.com/auth/compute",
63087            "https://www.googleapis.com/auth/compute.readonly"
63088          ],
63089          "description": "Retrieves the list of HttpsHealthCheck resources available to the specified project."
63090        },
63091        "get": {
63092          "id": "compute.httpsHealthChecks.get",
63093          "path": "projects/{project}/global/httpsHealthChecks/{httpsHealthCheck}",
63094          "flatPath": "projects/{project}/global/httpsHealthChecks/{httpsHealthCheck}",
63095          "httpMethod": "GET",
63096          "parameters": {
63097            "httpsHealthCheck": {
63098              "description": "Name of the HttpsHealthCheck resource to return.",
63099              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
63100              "location": "path",
63101              "required": true,
63102              "type": "string"
63103            },
63104            "project": {
63105              "description": "Project ID for this request.",
63106              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63107              "location": "path",
63108              "required": true,
63109              "type": "string"
63110            }
63111          },
63112          "parameterOrder": [
63113            "project",
63114            "httpsHealthCheck"
63115          ],
63116          "response": {
63117            "$ref": "HttpsHealthCheck"
63118          },
63119          "scopes": [
63120            "https://www.googleapis.com/auth/cloud-platform",
63121            "https://www.googleapis.com/auth/compute",
63122            "https://www.googleapis.com/auth/compute.readonly"
63123          ],
63124          "description": "Returns the specified HttpsHealthCheck resource."
63125        },
63126        "insert": {
63127          "id": "compute.httpsHealthChecks.insert",
63128          "path": "projects/{project}/global/httpsHealthChecks",
63129          "flatPath": "projects/{project}/global/httpsHealthChecks",
63130          "httpMethod": "POST",
63131          "parameters": {
63132            "project": {
63133              "description": "Project ID for this request.",
63134              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63135              "location": "path",
63136              "required": true,
63137              "type": "string"
63138            },
63139            "requestId": {
63140              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
63141              "location": "query",
63142              "type": "string"
63143            }
63144          },
63145          "parameterOrder": [
63146            "project"
63147          ],
63148          "request": {
63149            "$ref": "HttpsHealthCheck"
63150          },
63151          "response": {
63152            "$ref": "Operation"
63153          },
63154          "scopes": [
63155            "https://www.googleapis.com/auth/cloud-platform",
63156            "https://www.googleapis.com/auth/compute"
63157          ],
63158          "description": "Creates a HttpsHealthCheck resource in the specified project using the data included in the request."
63159        },
63160        "delete": {
63161          "id": "compute.httpsHealthChecks.delete",
63162          "path": "projects/{project}/global/httpsHealthChecks/{httpsHealthCheck}",
63163          "flatPath": "projects/{project}/global/httpsHealthChecks/{httpsHealthCheck}",
63164          "httpMethod": "DELETE",
63165          "parameters": {
63166            "httpsHealthCheck": {
63167              "description": "Name of the HttpsHealthCheck resource to delete.",
63168              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
63169              "location": "path",
63170              "required": true,
63171              "type": "string"
63172            },
63173            "project": {
63174              "description": "Project ID for this request.",
63175              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63176              "location": "path",
63177              "required": true,
63178              "type": "string"
63179            },
63180            "requestId": {
63181              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
63182              "location": "query",
63183              "type": "string"
63184            }
63185          },
63186          "parameterOrder": [
63187            "project",
63188            "httpsHealthCheck"
63189          ],
63190          "response": {
63191            "$ref": "Operation"
63192          },
63193          "scopes": [
63194            "https://www.googleapis.com/auth/cloud-platform",
63195            "https://www.googleapis.com/auth/compute"
63196          ],
63197          "description": "Deletes the specified HttpsHealthCheck resource."
63198        },
63199        "update": {
63200          "id": "compute.httpsHealthChecks.update",
63201          "path": "projects/{project}/global/httpsHealthChecks/{httpsHealthCheck}",
63202          "flatPath": "projects/{project}/global/httpsHealthChecks/{httpsHealthCheck}",
63203          "httpMethod": "PUT",
63204          "parameters": {
63205            "httpsHealthCheck": {
63206              "description": "Name of the HttpsHealthCheck resource to update.",
63207              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
63208              "location": "path",
63209              "required": true,
63210              "type": "string"
63211            },
63212            "project": {
63213              "description": "Project ID for this request.",
63214              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63215              "location": "path",
63216              "required": true,
63217              "type": "string"
63218            },
63219            "requestId": {
63220              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
63221              "location": "query",
63222              "type": "string"
63223            }
63224          },
63225          "parameterOrder": [
63226            "project",
63227            "httpsHealthCheck"
63228          ],
63229          "request": {
63230            "$ref": "HttpsHealthCheck"
63231          },
63232          "response": {
63233            "$ref": "Operation"
63234          },
63235          "scopes": [
63236            "https://www.googleapis.com/auth/cloud-platform",
63237            "https://www.googleapis.com/auth/compute"
63238          ],
63239          "description": "Updates a HttpsHealthCheck resource in the specified project using the data included in the request."
63240        },
63241        "patch": {
63242          "id": "compute.httpsHealthChecks.patch",
63243          "path": "projects/{project}/global/httpsHealthChecks/{httpsHealthCheck}",
63244          "flatPath": "projects/{project}/global/httpsHealthChecks/{httpsHealthCheck}",
63245          "httpMethod": "PATCH",
63246          "parameters": {
63247            "httpsHealthCheck": {
63248              "description": "Name of the HttpsHealthCheck resource to patch.",
63249              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
63250              "location": "path",
63251              "required": true,
63252              "type": "string"
63253            },
63254            "project": {
63255              "description": "Project ID for this request.",
63256              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63257              "location": "path",
63258              "required": true,
63259              "type": "string"
63260            },
63261            "requestId": {
63262              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
63263              "location": "query",
63264              "type": "string"
63265            }
63266          },
63267          "parameterOrder": [
63268            "project",
63269            "httpsHealthCheck"
63270          ],
63271          "request": {
63272            "$ref": "HttpsHealthCheck"
63273          },
63274          "response": {
63275            "$ref": "Operation"
63276          },
63277          "scopes": [
63278            "https://www.googleapis.com/auth/cloud-platform",
63279            "https://www.googleapis.com/auth/compute"
63280          ],
63281          "description": "Updates a HttpsHealthCheck resource in the specified project using the data included in the request. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
63282        }
63283      }
63284    },
63285    "instanceTemplates": {
63286      "methods": {
63287        "list": {
63288          "id": "compute.instanceTemplates.list",
63289          "path": "projects/{project}/global/instanceTemplates",
63290          "flatPath": "projects/{project}/global/instanceTemplates",
63291          "httpMethod": "GET",
63292          "parameters": {
63293            "filter": {
63294              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
63295              "location": "query",
63296              "type": "string"
63297            },
63298            "maxResults": {
63299              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
63300              "default": "500",
63301              "minimum": "0",
63302              "location": "query",
63303              "type": "integer",
63304              "format": "uint32"
63305            },
63306            "orderBy": {
63307              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
63308              "location": "query",
63309              "type": "string"
63310            },
63311            "pageToken": {
63312              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
63313              "location": "query",
63314              "type": "string"
63315            },
63316            "project": {
63317              "description": "Project ID for this request.",
63318              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63319              "location": "path",
63320              "required": true,
63321              "type": "string"
63322            },
63323            "returnPartialSuccess": {
63324              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
63325              "location": "query",
63326              "type": "boolean"
63327            }
63328          },
63329          "parameterOrder": [
63330            "project"
63331          ],
63332          "response": {
63333            "$ref": "InstanceTemplateList"
63334          },
63335          "scopes": [
63336            "https://www.googleapis.com/auth/cloud-platform",
63337            "https://www.googleapis.com/auth/compute",
63338            "https://www.googleapis.com/auth/compute.readonly"
63339          ],
63340          "description": "Retrieves a list of instance templates that are contained within the specified project."
63341        },
63342        "get": {
63343          "id": "compute.instanceTemplates.get",
63344          "path": "projects/{project}/global/instanceTemplates/{instanceTemplate}",
63345          "flatPath": "projects/{project}/global/instanceTemplates/{instanceTemplate}",
63346          "httpMethod": "GET",
63347          "parameters": {
63348            "instanceTemplate": {
63349              "description": "The name of the instance template.",
63350              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
63351              "location": "path",
63352              "required": true,
63353              "type": "string"
63354            },
63355            "project": {
63356              "description": "Project ID for this request.",
63357              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63358              "location": "path",
63359              "required": true,
63360              "type": "string"
63361            }
63362          },
63363          "parameterOrder": [
63364            "project",
63365            "instanceTemplate"
63366          ],
63367          "response": {
63368            "$ref": "InstanceTemplate"
63369          },
63370          "scopes": [
63371            "https://www.googleapis.com/auth/cloud-platform",
63372            "https://www.googleapis.com/auth/compute",
63373            "https://www.googleapis.com/auth/compute.readonly"
63374          ],
63375          "description": "Returns the specified instance template."
63376        },
63377        "insert": {
63378          "id": "compute.instanceTemplates.insert",
63379          "path": "projects/{project}/global/instanceTemplates",
63380          "flatPath": "projects/{project}/global/instanceTemplates",
63381          "httpMethod": "POST",
63382          "parameters": {
63383            "project": {
63384              "description": "Project ID for this request.",
63385              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63386              "location": "path",
63387              "required": true,
63388              "type": "string"
63389            },
63390            "requestId": {
63391              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
63392              "location": "query",
63393              "type": "string"
63394            }
63395          },
63396          "parameterOrder": [
63397            "project"
63398          ],
63399          "request": {
63400            "$ref": "InstanceTemplate"
63401          },
63402          "response": {
63403            "$ref": "Operation"
63404          },
63405          "scopes": [
63406            "https://www.googleapis.com/auth/cloud-platform",
63407            "https://www.googleapis.com/auth/compute"
63408          ],
63409          "description": "Creates an instance template in the specified project using the data that is included in the request. If you are creating a new template to update an existing instance group, your new instance template must use the same network or, if applicable, the same subnetwork as the original template."
63410        },
63411        "delete": {
63412          "id": "compute.instanceTemplates.delete",
63413          "path": "projects/{project}/global/instanceTemplates/{instanceTemplate}",
63414          "flatPath": "projects/{project}/global/instanceTemplates/{instanceTemplate}",
63415          "httpMethod": "DELETE",
63416          "parameters": {
63417            "instanceTemplate": {
63418              "description": "The name of the instance template to delete.",
63419              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
63420              "location": "path",
63421              "required": true,
63422              "type": "string"
63423            },
63424            "project": {
63425              "description": "Project ID for this request.",
63426              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63427              "location": "path",
63428              "required": true,
63429              "type": "string"
63430            },
63431            "requestId": {
63432              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
63433              "location": "query",
63434              "type": "string"
63435            }
63436          },
63437          "parameterOrder": [
63438            "project",
63439            "instanceTemplate"
63440          ],
63441          "response": {
63442            "$ref": "Operation"
63443          },
63444          "scopes": [
63445            "https://www.googleapis.com/auth/cloud-platform",
63446            "https://www.googleapis.com/auth/compute"
63447          ],
63448          "description": "Deletes the specified instance template. Deleting an instance template is permanent and cannot be undone. It is not possible to delete templates that are already in use by a managed instance group."
63449        },
63450        "aggregatedList": {
63451          "id": "compute.instanceTemplates.aggregatedList",
63452          "path": "projects/{project}/aggregated/instanceTemplates",
63453          "flatPath": "projects/{project}/aggregated/instanceTemplates",
63454          "httpMethod": "GET",
63455          "parameters": {
63456            "filter": {
63457              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
63458              "location": "query",
63459              "type": "string"
63460            },
63461            "includeAllScopes": {
63462              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
63463              "location": "query",
63464              "type": "boolean"
63465            },
63466            "maxResults": {
63467              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
63468              "default": "500",
63469              "minimum": "0",
63470              "location": "query",
63471              "type": "integer",
63472              "format": "uint32"
63473            },
63474            "orderBy": {
63475              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
63476              "location": "query",
63477              "type": "string"
63478            },
63479            "pageToken": {
63480              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
63481              "location": "query",
63482              "type": "string"
63483            },
63484            "project": {
63485              "description": "Name of the project scoping this request.",
63486              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63487              "location": "path",
63488              "required": true,
63489              "type": "string"
63490            },
63491            "returnPartialSuccess": {
63492              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
63493              "location": "query",
63494              "type": "boolean"
63495            },
63496            "serviceProjectNumber": {
63497              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
63498              "location": "query",
63499              "type": "string",
63500              "format": "int64"
63501            }
63502          },
63503          "parameterOrder": [
63504            "project"
63505          ],
63506          "response": {
63507            "$ref": "InstanceTemplateAggregatedList"
63508          },
63509          "scopes": [
63510            "https://www.googleapis.com/auth/cloud-platform",
63511            "https://www.googleapis.com/auth/compute",
63512            "https://www.googleapis.com/auth/compute.readonly"
63513          ],
63514          "description": "Retrieves the list of all InstanceTemplates resources, regional and global, available to the specified project. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
63515        },
63516        "getIamPolicy": {
63517          "id": "compute.instanceTemplates.getIamPolicy",
63518          "path": "projects/{project}/global/instanceTemplates/{resource}/getIamPolicy",
63519          "flatPath": "projects/{project}/global/instanceTemplates/{resource}/getIamPolicy",
63520          "httpMethod": "GET",
63521          "parameters": {
63522            "optionsRequestedPolicyVersion": {
63523              "description": "Requested IAM Policy version.",
63524              "location": "query",
63525              "type": "integer",
63526              "format": "int32"
63527            },
63528            "project": {
63529              "description": "Project ID for this request.",
63530              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63531              "location": "path",
63532              "required": true,
63533              "type": "string"
63534            },
63535            "resource": {
63536              "description": "Name or id of the resource for this request.",
63537              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
63538              "location": "path",
63539              "required": true,
63540              "type": "string"
63541            }
63542          },
63543          "parameterOrder": [
63544            "project",
63545            "resource"
63546          ],
63547          "response": {
63548            "$ref": "Policy"
63549          },
63550          "scopes": [
63551            "https://www.googleapis.com/auth/cloud-platform",
63552            "https://www.googleapis.com/auth/compute",
63553            "https://www.googleapis.com/auth/compute.readonly"
63554          ],
63555          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
63556        },
63557        "setIamPolicy": {
63558          "id": "compute.instanceTemplates.setIamPolicy",
63559          "path": "projects/{project}/global/instanceTemplates/{resource}/setIamPolicy",
63560          "flatPath": "projects/{project}/global/instanceTemplates/{resource}/setIamPolicy",
63561          "httpMethod": "POST",
63562          "parameters": {
63563            "project": {
63564              "description": "Project ID for this request.",
63565              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63566              "location": "path",
63567              "required": true,
63568              "type": "string"
63569            },
63570            "resource": {
63571              "description": "Name or id of the resource for this request.",
63572              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
63573              "location": "path",
63574              "required": true,
63575              "type": "string"
63576            }
63577          },
63578          "parameterOrder": [
63579            "project",
63580            "resource"
63581          ],
63582          "request": {
63583            "$ref": "GlobalSetPolicyRequest"
63584          },
63585          "response": {
63586            "$ref": "Policy"
63587          },
63588          "scopes": [
63589            "https://www.googleapis.com/auth/cloud-platform",
63590            "https://www.googleapis.com/auth/compute"
63591          ],
63592          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
63593        },
63594        "testIamPermissions": {
63595          "id": "compute.instanceTemplates.testIamPermissions",
63596          "path": "projects/{project}/global/instanceTemplates/{resource}/testIamPermissions",
63597          "flatPath": "projects/{project}/global/instanceTemplates/{resource}/testIamPermissions",
63598          "httpMethod": "POST",
63599          "parameters": {
63600            "project": {
63601              "description": "Project ID for this request.",
63602              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63603              "location": "path",
63604              "required": true,
63605              "type": "string"
63606            },
63607            "resource": {
63608              "description": "Name or id of the resource for this request.",
63609              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
63610              "location": "path",
63611              "required": true,
63612              "type": "string"
63613            }
63614          },
63615          "parameterOrder": [
63616            "project",
63617            "resource"
63618          ],
63619          "request": {
63620            "$ref": "TestPermissionsRequest"
63621          },
63622          "response": {
63623            "$ref": "TestPermissionsResponse"
63624          },
63625          "scopes": [
63626            "https://www.googleapis.com/auth/cloud-platform",
63627            "https://www.googleapis.com/auth/compute",
63628            "https://www.googleapis.com/auth/compute.readonly"
63629          ],
63630          "description": "Returns permissions that a caller has on the specified resource."
63631        }
63632      }
63633    },
63634    "regionInstanceTemplates": {
63635      "methods": {
63636        "list": {
63637          "id": "compute.regionInstanceTemplates.list",
63638          "path": "projects/{project}/regions/{region}/instanceTemplates",
63639          "flatPath": "projects/{project}/regions/{region}/instanceTemplates",
63640          "httpMethod": "GET",
63641          "parameters": {
63642            "filter": {
63643              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
63644              "location": "query",
63645              "type": "string"
63646            },
63647            "maxResults": {
63648              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
63649              "default": "500",
63650              "minimum": "0",
63651              "location": "query",
63652              "type": "integer",
63653              "format": "uint32"
63654            },
63655            "orderBy": {
63656              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
63657              "location": "query",
63658              "type": "string"
63659            },
63660            "pageToken": {
63661              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
63662              "location": "query",
63663              "type": "string"
63664            },
63665            "project": {
63666              "description": "Project ID for this request.",
63667              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63668              "location": "path",
63669              "required": true,
63670              "type": "string"
63671            },
63672            "region": {
63673              "description": "The name of the regions for this request.",
63674              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
63675              "location": "path",
63676              "required": true,
63677              "type": "string"
63678            },
63679            "returnPartialSuccess": {
63680              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
63681              "location": "query",
63682              "type": "boolean"
63683            }
63684          },
63685          "parameterOrder": [
63686            "project",
63687            "region"
63688          ],
63689          "response": {
63690            "$ref": "InstanceTemplateList"
63691          },
63692          "scopes": [
63693            "https://www.googleapis.com/auth/cloud-platform",
63694            "https://www.googleapis.com/auth/compute",
63695            "https://www.googleapis.com/auth/compute.readonly"
63696          ],
63697          "description": "Retrieves a list of instance templates that are contained within the specified project and region."
63698        },
63699        "get": {
63700          "id": "compute.regionInstanceTemplates.get",
63701          "path": "projects/{project}/regions/{region}/instanceTemplates/{instanceTemplate}",
63702          "flatPath": "projects/{project}/regions/{region}/instanceTemplates/{instanceTemplate}",
63703          "httpMethod": "GET",
63704          "parameters": {
63705            "instanceTemplate": {
63706              "description": "The name of the instance template.",
63707              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
63708              "location": "path",
63709              "required": true,
63710              "type": "string"
63711            },
63712            "project": {
63713              "description": "Project ID for this request.",
63714              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63715              "location": "path",
63716              "required": true,
63717              "type": "string"
63718            },
63719            "region": {
63720              "description": "The name of the region for this request.",
63721              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
63722              "location": "path",
63723              "required": true,
63724              "type": "string"
63725            }
63726          },
63727          "parameterOrder": [
63728            "project",
63729            "region",
63730            "instanceTemplate"
63731          ],
63732          "response": {
63733            "$ref": "InstanceTemplate"
63734          },
63735          "scopes": [
63736            "https://www.googleapis.com/auth/cloud-platform",
63737            "https://www.googleapis.com/auth/compute",
63738            "https://www.googleapis.com/auth/compute.readonly"
63739          ],
63740          "description": "Returns the specified instance template."
63741        },
63742        "insert": {
63743          "id": "compute.regionInstanceTemplates.insert",
63744          "path": "projects/{project}/regions/{region}/instanceTemplates",
63745          "flatPath": "projects/{project}/regions/{region}/instanceTemplates",
63746          "httpMethod": "POST",
63747          "parameters": {
63748            "project": {
63749              "description": "Project ID for this request.",
63750              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63751              "location": "path",
63752              "required": true,
63753              "type": "string"
63754            },
63755            "region": {
63756              "description": "The name of the region for this request.",
63757              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
63758              "location": "path",
63759              "required": true,
63760              "type": "string"
63761            },
63762            "requestId": {
63763              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
63764              "location": "query",
63765              "type": "string"
63766            }
63767          },
63768          "parameterOrder": [
63769            "project",
63770            "region"
63771          ],
63772          "request": {
63773            "$ref": "InstanceTemplate"
63774          },
63775          "response": {
63776            "$ref": "Operation"
63777          },
63778          "scopes": [
63779            "https://www.googleapis.com/auth/cloud-platform",
63780            "https://www.googleapis.com/auth/compute"
63781          ],
63782          "description": "Creates an instance template in the specified project and region using the global instance template whose URL is included in the request."
63783        },
63784        "delete": {
63785          "id": "compute.regionInstanceTemplates.delete",
63786          "path": "projects/{project}/regions/{region}/instanceTemplates/{instanceTemplate}",
63787          "flatPath": "projects/{project}/regions/{region}/instanceTemplates/{instanceTemplate}",
63788          "httpMethod": "DELETE",
63789          "parameters": {
63790            "instanceTemplate": {
63791              "description": "The name of the instance template to delete.",
63792              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
63793              "location": "path",
63794              "required": true,
63795              "type": "string"
63796            },
63797            "project": {
63798              "description": "Project ID for this request.",
63799              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63800              "location": "path",
63801              "required": true,
63802              "type": "string"
63803            },
63804            "region": {
63805              "description": "The name of the region for this request.",
63806              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
63807              "location": "path",
63808              "required": true,
63809              "type": "string"
63810            },
63811            "requestId": {
63812              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
63813              "location": "query",
63814              "type": "string"
63815            }
63816          },
63817          "parameterOrder": [
63818            "project",
63819            "region",
63820            "instanceTemplate"
63821          ],
63822          "response": {
63823            "$ref": "Operation"
63824          },
63825          "scopes": [
63826            "https://www.googleapis.com/auth/cloud-platform",
63827            "https://www.googleapis.com/auth/compute"
63828          ],
63829          "description": "Deletes the specified instance template. Deleting an instance template is permanent and cannot be undone."
63830        }
63831      }
63832    },
63833    "instantSnapshots": {
63834      "methods": {
63835        "list": {
63836          "id": "compute.instantSnapshots.list",
63837          "path": "projects/{project}/zones/{zone}/instantSnapshots",
63838          "flatPath": "projects/{project}/zones/{zone}/instantSnapshots",
63839          "httpMethod": "GET",
63840          "parameters": {
63841            "filter": {
63842              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
63843              "location": "query",
63844              "type": "string"
63845            },
63846            "maxResults": {
63847              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
63848              "default": "500",
63849              "minimum": "0",
63850              "location": "query",
63851              "type": "integer",
63852              "format": "uint32"
63853            },
63854            "orderBy": {
63855              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
63856              "location": "query",
63857              "type": "string"
63858            },
63859            "pageToken": {
63860              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
63861              "location": "query",
63862              "type": "string"
63863            },
63864            "project": {
63865              "description": "Project ID for this request.",
63866              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63867              "location": "path",
63868              "required": true,
63869              "type": "string"
63870            },
63871            "returnPartialSuccess": {
63872              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
63873              "location": "query",
63874              "type": "boolean"
63875            },
63876            "zone": {
63877              "description": "The name of the zone for this request.",
63878              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
63879              "location": "path",
63880              "required": true,
63881              "type": "string"
63882            }
63883          },
63884          "parameterOrder": [
63885            "project",
63886            "zone"
63887          ],
63888          "response": {
63889            "$ref": "InstantSnapshotList"
63890          },
63891          "scopes": [
63892            "https://www.googleapis.com/auth/cloud-platform",
63893            "https://www.googleapis.com/auth/compute",
63894            "https://www.googleapis.com/auth/compute.readonly"
63895          ],
63896          "description": "Retrieves the list of InstantSnapshot resources contained within the specified zone."
63897        },
63898        "get": {
63899          "id": "compute.instantSnapshots.get",
63900          "path": "projects/{project}/zones/{zone}/instantSnapshots/{instantSnapshot}",
63901          "flatPath": "projects/{project}/zones/{zone}/instantSnapshots/{instantSnapshot}",
63902          "httpMethod": "GET",
63903          "parameters": {
63904            "instantSnapshot": {
63905              "description": "Name of the InstantSnapshot resource to return.",
63906              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
63907              "location": "path",
63908              "required": true,
63909              "type": "string"
63910            },
63911            "project": {
63912              "description": "Project ID for this request.",
63913              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63914              "location": "path",
63915              "required": true,
63916              "type": "string"
63917            },
63918            "zone": {
63919              "description": "The name of the zone for this request.",
63920              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
63921              "location": "path",
63922              "required": true,
63923              "type": "string"
63924            }
63925          },
63926          "parameterOrder": [
63927            "project",
63928            "zone",
63929            "instantSnapshot"
63930          ],
63931          "response": {
63932            "$ref": "InstantSnapshot"
63933          },
63934          "scopes": [
63935            "https://www.googleapis.com/auth/cloud-platform",
63936            "https://www.googleapis.com/auth/compute",
63937            "https://www.googleapis.com/auth/compute.readonly"
63938          ],
63939          "description": "Returns the specified InstantSnapshot resource in the specified zone."
63940        },
63941        "insert": {
63942          "id": "compute.instantSnapshots.insert",
63943          "path": "projects/{project}/zones/{zone}/instantSnapshots",
63944          "flatPath": "projects/{project}/zones/{zone}/instantSnapshots",
63945          "httpMethod": "POST",
63946          "parameters": {
63947            "project": {
63948              "description": "Project ID for this request.",
63949              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63950              "location": "path",
63951              "required": true,
63952              "type": "string"
63953            },
63954            "requestId": {
63955              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
63956              "location": "query",
63957              "type": "string"
63958            },
63959            "zone": {
63960              "description": "Name of the zone for this request.",
63961              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
63962              "location": "path",
63963              "required": true,
63964              "type": "string"
63965            }
63966          },
63967          "parameterOrder": [
63968            "project",
63969            "zone"
63970          ],
63971          "request": {
63972            "$ref": "InstantSnapshot"
63973          },
63974          "response": {
63975            "$ref": "Operation"
63976          },
63977          "scopes": [
63978            "https://www.googleapis.com/auth/cloud-platform",
63979            "https://www.googleapis.com/auth/compute"
63980          ],
63981          "description": "Creates an instant snapshot in the specified zone."
63982        },
63983        "setLabels": {
63984          "id": "compute.instantSnapshots.setLabels",
63985          "path": "projects/{project}/zones/{zone}/instantSnapshots/{resource}/setLabels",
63986          "flatPath": "projects/{project}/zones/{zone}/instantSnapshots/{resource}/setLabels",
63987          "httpMethod": "POST",
63988          "parameters": {
63989            "project": {
63990              "description": "Project ID for this request.",
63991              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
63992              "location": "path",
63993              "required": true,
63994              "type": "string"
63995            },
63996            "requestId": {
63997              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
63998              "location": "query",
63999              "type": "string"
64000            },
64001            "resource": {
64002              "description": "Name or id of the resource for this request.",
64003              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
64004              "location": "path",
64005              "required": true,
64006              "type": "string"
64007            },
64008            "zone": {
64009              "description": "The name of the zone for this request.",
64010              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64011              "location": "path",
64012              "required": true,
64013              "type": "string"
64014            }
64015          },
64016          "parameterOrder": [
64017            "project",
64018            "zone",
64019            "resource"
64020          ],
64021          "request": {
64022            "$ref": "ZoneSetLabelsRequest"
64023          },
64024          "response": {
64025            "$ref": "Operation"
64026          },
64027          "scopes": [
64028            "https://www.googleapis.com/auth/cloud-platform",
64029            "https://www.googleapis.com/auth/compute"
64030          ],
64031          "description": "Sets the labels on a instantSnapshot in the given zone. To learn more about labels, read the Labeling Resources documentation."
64032        },
64033        "delete": {
64034          "id": "compute.instantSnapshots.delete",
64035          "path": "projects/{project}/zones/{zone}/instantSnapshots/{instantSnapshot}",
64036          "flatPath": "projects/{project}/zones/{zone}/instantSnapshots/{instantSnapshot}",
64037          "httpMethod": "DELETE",
64038          "parameters": {
64039            "instantSnapshot": {
64040              "description": "Name of the InstantSnapshot resource to delete.",
64041              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
64042              "location": "path",
64043              "required": true,
64044              "type": "string"
64045            },
64046            "project": {
64047              "description": "Project ID for this request.",
64048              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64049              "location": "path",
64050              "required": true,
64051              "type": "string"
64052            },
64053            "requestId": {
64054              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
64055              "location": "query",
64056              "type": "string"
64057            },
64058            "zone": {
64059              "description": "The name of the zone for this request.",
64060              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64061              "location": "path",
64062              "required": true,
64063              "type": "string"
64064            }
64065          },
64066          "parameterOrder": [
64067            "project",
64068            "zone",
64069            "instantSnapshot"
64070          ],
64071          "response": {
64072            "$ref": "Operation"
64073          },
64074          "scopes": [
64075            "https://www.googleapis.com/auth/cloud-platform",
64076            "https://www.googleapis.com/auth/compute"
64077          ],
64078          "description": "Deletes the specified InstantSnapshot resource. Keep in mind that deleting a single instantSnapshot might not necessarily delete all the data on that instantSnapshot. If any data on the instantSnapshot that is marked for deletion is needed for subsequent instantSnapshots, the data will be moved to the next corresponding instantSnapshot. For more information, see Deleting instantSnapshots."
64079        },
64080        "getIamPolicy": {
64081          "id": "compute.instantSnapshots.getIamPolicy",
64082          "path": "projects/{project}/zones/{zone}/instantSnapshots/{resource}/getIamPolicy",
64083          "flatPath": "projects/{project}/zones/{zone}/instantSnapshots/{resource}/getIamPolicy",
64084          "httpMethod": "GET",
64085          "parameters": {
64086            "optionsRequestedPolicyVersion": {
64087              "description": "Requested IAM Policy version.",
64088              "location": "query",
64089              "type": "integer",
64090              "format": "int32"
64091            },
64092            "project": {
64093              "description": "Project ID for this request.",
64094              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64095              "location": "path",
64096              "required": true,
64097              "type": "string"
64098            },
64099            "resource": {
64100              "description": "Name or id of the resource for this request.",
64101              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
64102              "location": "path",
64103              "required": true,
64104              "type": "string"
64105            },
64106            "zone": {
64107              "description": "The name of the zone for this request.",
64108              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64109              "location": "path",
64110              "required": true,
64111              "type": "string"
64112            }
64113          },
64114          "parameterOrder": [
64115            "project",
64116            "zone",
64117            "resource"
64118          ],
64119          "response": {
64120            "$ref": "Policy"
64121          },
64122          "scopes": [
64123            "https://www.googleapis.com/auth/cloud-platform",
64124            "https://www.googleapis.com/auth/compute",
64125            "https://www.googleapis.com/auth/compute.readonly"
64126          ],
64127          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
64128        },
64129        "setIamPolicy": {
64130          "id": "compute.instantSnapshots.setIamPolicy",
64131          "path": "projects/{project}/zones/{zone}/instantSnapshots/{resource}/setIamPolicy",
64132          "flatPath": "projects/{project}/zones/{zone}/instantSnapshots/{resource}/setIamPolicy",
64133          "httpMethod": "POST",
64134          "parameters": {
64135            "project": {
64136              "description": "Project ID for this request.",
64137              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64138              "location": "path",
64139              "required": true,
64140              "type": "string"
64141            },
64142            "resource": {
64143              "description": "Name or id of the resource for this request.",
64144              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
64145              "location": "path",
64146              "required": true,
64147              "type": "string"
64148            },
64149            "zone": {
64150              "description": "The name of the zone for this request.",
64151              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64152              "location": "path",
64153              "required": true,
64154              "type": "string"
64155            }
64156          },
64157          "parameterOrder": [
64158            "project",
64159            "zone",
64160            "resource"
64161          ],
64162          "request": {
64163            "$ref": "ZoneSetPolicyRequest"
64164          },
64165          "response": {
64166            "$ref": "Policy"
64167          },
64168          "scopes": [
64169            "https://www.googleapis.com/auth/cloud-platform",
64170            "https://www.googleapis.com/auth/compute"
64171          ],
64172          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
64173        },
64174        "testIamPermissions": {
64175          "id": "compute.instantSnapshots.testIamPermissions",
64176          "path": "projects/{project}/zones/{zone}/instantSnapshots/{resource}/testIamPermissions",
64177          "flatPath": "projects/{project}/zones/{zone}/instantSnapshots/{resource}/testIamPermissions",
64178          "httpMethod": "POST",
64179          "parameters": {
64180            "project": {
64181              "description": "Project ID for this request.",
64182              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64183              "location": "path",
64184              "required": true,
64185              "type": "string"
64186            },
64187            "resource": {
64188              "description": "Name or id of the resource for this request.",
64189              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
64190              "location": "path",
64191              "required": true,
64192              "type": "string"
64193            },
64194            "zone": {
64195              "description": "The name of the zone for this request.",
64196              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64197              "location": "path",
64198              "required": true,
64199              "type": "string"
64200            }
64201          },
64202          "parameterOrder": [
64203            "project",
64204            "zone",
64205            "resource"
64206          ],
64207          "request": {
64208            "$ref": "TestPermissionsRequest"
64209          },
64210          "response": {
64211            "$ref": "TestPermissionsResponse"
64212          },
64213          "scopes": [
64214            "https://www.googleapis.com/auth/cloud-platform",
64215            "https://www.googleapis.com/auth/compute",
64216            "https://www.googleapis.com/auth/compute.readonly"
64217          ],
64218          "description": "Returns permissions that a caller has on the specified resource."
64219        },
64220        "aggregatedList": {
64221          "id": "compute.instantSnapshots.aggregatedList",
64222          "path": "projects/{project}/aggregated/instantSnapshots",
64223          "flatPath": "projects/{project}/aggregated/instantSnapshots",
64224          "httpMethod": "GET",
64225          "parameters": {
64226            "filter": {
64227              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
64228              "location": "query",
64229              "type": "string"
64230            },
64231            "includeAllScopes": {
64232              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
64233              "location": "query",
64234              "type": "boolean"
64235            },
64236            "maxResults": {
64237              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
64238              "default": "500",
64239              "minimum": "0",
64240              "location": "query",
64241              "type": "integer",
64242              "format": "uint32"
64243            },
64244            "orderBy": {
64245              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
64246              "location": "query",
64247              "type": "string"
64248            },
64249            "pageToken": {
64250              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
64251              "location": "query",
64252              "type": "string"
64253            },
64254            "project": {
64255              "description": "Project ID for this request.",
64256              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64257              "location": "path",
64258              "required": true,
64259              "type": "string"
64260            },
64261            "returnPartialSuccess": {
64262              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
64263              "location": "query",
64264              "type": "boolean"
64265            },
64266            "serviceProjectNumber": {
64267              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
64268              "location": "query",
64269              "type": "string",
64270              "format": "int64"
64271            }
64272          },
64273          "parameterOrder": [
64274            "project"
64275          ],
64276          "response": {
64277            "$ref": "InstantSnapshotAggregatedList"
64278          },
64279          "scopes": [
64280            "https://www.googleapis.com/auth/cloud-platform",
64281            "https://www.googleapis.com/auth/compute",
64282            "https://www.googleapis.com/auth/compute.readonly"
64283          ],
64284          "description": "Retrieves an aggregated list of instantSnapshots. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
64285        }
64286      }
64287    },
64288    "regionInstantSnapshots": {
64289      "methods": {
64290        "list": {
64291          "id": "compute.regionInstantSnapshots.list",
64292          "path": "projects/{project}/regions/{region}/instantSnapshots",
64293          "flatPath": "projects/{project}/regions/{region}/instantSnapshots",
64294          "httpMethod": "GET",
64295          "parameters": {
64296            "filter": {
64297              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
64298              "location": "query",
64299              "type": "string"
64300            },
64301            "maxResults": {
64302              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
64303              "default": "500",
64304              "minimum": "0",
64305              "location": "query",
64306              "type": "integer",
64307              "format": "uint32"
64308            },
64309            "orderBy": {
64310              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
64311              "location": "query",
64312              "type": "string"
64313            },
64314            "pageToken": {
64315              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
64316              "location": "query",
64317              "type": "string"
64318            },
64319            "project": {
64320              "description": "Project ID for this request.",
64321              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64322              "location": "path",
64323              "required": true,
64324              "type": "string"
64325            },
64326            "region": {
64327              "description": "The name of the region for this request.",
64328              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64329              "location": "path",
64330              "required": true,
64331              "type": "string"
64332            },
64333            "returnPartialSuccess": {
64334              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
64335              "location": "query",
64336              "type": "boolean"
64337            }
64338          },
64339          "parameterOrder": [
64340            "project",
64341            "region"
64342          ],
64343          "response": {
64344            "$ref": "InstantSnapshotList"
64345          },
64346          "scopes": [
64347            "https://www.googleapis.com/auth/cloud-platform",
64348            "https://www.googleapis.com/auth/compute",
64349            "https://www.googleapis.com/auth/compute.readonly"
64350          ],
64351          "description": "Retrieves the list of InstantSnapshot resources contained within the specified region."
64352        },
64353        "get": {
64354          "id": "compute.regionInstantSnapshots.get",
64355          "path": "projects/{project}/regions/{region}/instantSnapshots/{instantSnapshot}",
64356          "flatPath": "projects/{project}/regions/{region}/instantSnapshots/{instantSnapshot}",
64357          "httpMethod": "GET",
64358          "parameters": {
64359            "instantSnapshot": {
64360              "description": "Name of the InstantSnapshot resource to return.",
64361              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
64362              "location": "path",
64363              "required": true,
64364              "type": "string"
64365            },
64366            "project": {
64367              "description": "Project ID for this request.",
64368              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64369              "location": "path",
64370              "required": true,
64371              "type": "string"
64372            },
64373            "region": {
64374              "description": "The name of the region for this request.",
64375              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64376              "location": "path",
64377              "required": true,
64378              "type": "string"
64379            }
64380          },
64381          "parameterOrder": [
64382            "project",
64383            "region",
64384            "instantSnapshot"
64385          ],
64386          "response": {
64387            "$ref": "InstantSnapshot"
64388          },
64389          "scopes": [
64390            "https://www.googleapis.com/auth/cloud-platform",
64391            "https://www.googleapis.com/auth/compute",
64392            "https://www.googleapis.com/auth/compute.readonly"
64393          ],
64394          "description": "Returns the specified InstantSnapshot resource in the specified region."
64395        },
64396        "insert": {
64397          "id": "compute.regionInstantSnapshots.insert",
64398          "path": "projects/{project}/regions/{region}/instantSnapshots",
64399          "flatPath": "projects/{project}/regions/{region}/instantSnapshots",
64400          "httpMethod": "POST",
64401          "parameters": {
64402            "project": {
64403              "description": "Project ID for this request.",
64404              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64405              "location": "path",
64406              "required": true,
64407              "type": "string"
64408            },
64409            "region": {
64410              "description": "Name of the region for this request.",
64411              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64412              "location": "path",
64413              "required": true,
64414              "type": "string"
64415            },
64416            "requestId": {
64417              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
64418              "location": "query",
64419              "type": "string"
64420            }
64421          },
64422          "parameterOrder": [
64423            "project",
64424            "region"
64425          ],
64426          "request": {
64427            "$ref": "InstantSnapshot"
64428          },
64429          "response": {
64430            "$ref": "Operation"
64431          },
64432          "scopes": [
64433            "https://www.googleapis.com/auth/cloud-platform",
64434            "https://www.googleapis.com/auth/compute"
64435          ],
64436          "description": "Creates an instant snapshot in the specified region."
64437        },
64438        "setLabels": {
64439          "id": "compute.regionInstantSnapshots.setLabels",
64440          "path": "projects/{project}/regions/{region}/instantSnapshots/{resource}/setLabels",
64441          "flatPath": "projects/{project}/regions/{region}/instantSnapshots/{resource}/setLabels",
64442          "httpMethod": "POST",
64443          "parameters": {
64444            "project": {
64445              "description": "Project ID for this request.",
64446              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64447              "location": "path",
64448              "required": true,
64449              "type": "string"
64450            },
64451            "region": {
64452              "description": "The region for this request.",
64453              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64454              "location": "path",
64455              "required": true,
64456              "type": "string"
64457            },
64458            "requestId": {
64459              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
64460              "location": "query",
64461              "type": "string"
64462            },
64463            "resource": {
64464              "description": "Name or id of the resource for this request.",
64465              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
64466              "location": "path",
64467              "required": true,
64468              "type": "string"
64469            }
64470          },
64471          "parameterOrder": [
64472            "project",
64473            "region",
64474            "resource"
64475          ],
64476          "request": {
64477            "$ref": "RegionSetLabelsRequest"
64478          },
64479          "response": {
64480            "$ref": "Operation"
64481          },
64482          "scopes": [
64483            "https://www.googleapis.com/auth/cloud-platform",
64484            "https://www.googleapis.com/auth/compute"
64485          ],
64486          "description": "Sets the labels on a instantSnapshot in the given region. To learn more about labels, read the Labeling Resources documentation."
64487        },
64488        "delete": {
64489          "id": "compute.regionInstantSnapshots.delete",
64490          "path": "projects/{project}/regions/{region}/instantSnapshots/{instantSnapshot}",
64491          "flatPath": "projects/{project}/regions/{region}/instantSnapshots/{instantSnapshot}",
64492          "httpMethod": "DELETE",
64493          "parameters": {
64494            "instantSnapshot": {
64495              "description": "Name of the InstantSnapshot resource to delete.",
64496              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
64497              "location": "path",
64498              "required": true,
64499              "type": "string"
64500            },
64501            "project": {
64502              "description": "Project ID for this request.",
64503              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64504              "location": "path",
64505              "required": true,
64506              "type": "string"
64507            },
64508            "region": {
64509              "description": "The name of the region for this request.",
64510              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64511              "location": "path",
64512              "required": true,
64513              "type": "string"
64514            },
64515            "requestId": {
64516              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
64517              "location": "query",
64518              "type": "string"
64519            }
64520          },
64521          "parameterOrder": [
64522            "project",
64523            "region",
64524            "instantSnapshot"
64525          ],
64526          "response": {
64527            "$ref": "Operation"
64528          },
64529          "scopes": [
64530            "https://www.googleapis.com/auth/cloud-platform",
64531            "https://www.googleapis.com/auth/compute"
64532          ],
64533          "description": "Deletes the specified InstantSnapshot resource. Keep in mind that deleting a single instantSnapshot might not necessarily delete all the data on that instantSnapshot. If any data on the instantSnapshot that is marked for deletion is needed for subsequent instantSnapshots, the data will be moved to the next corresponding instantSnapshot. For more information, see Deleting instantSnapshots."
64534        },
64535        "getIamPolicy": {
64536          "id": "compute.regionInstantSnapshots.getIamPolicy",
64537          "path": "projects/{project}/regions/{region}/instantSnapshots/{resource}/getIamPolicy",
64538          "flatPath": "projects/{project}/regions/{region}/instantSnapshots/{resource}/getIamPolicy",
64539          "httpMethod": "GET",
64540          "parameters": {
64541            "optionsRequestedPolicyVersion": {
64542              "description": "Requested IAM Policy version.",
64543              "location": "query",
64544              "type": "integer",
64545              "format": "int32"
64546            },
64547            "project": {
64548              "description": "Project ID for this request.",
64549              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64550              "location": "path",
64551              "required": true,
64552              "type": "string"
64553            },
64554            "region": {
64555              "description": "The name of the region for this request.",
64556              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64557              "location": "path",
64558              "required": true,
64559              "type": "string"
64560            },
64561            "resource": {
64562              "description": "Name or id of the resource for this request.",
64563              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
64564              "location": "path",
64565              "required": true,
64566              "type": "string"
64567            }
64568          },
64569          "parameterOrder": [
64570            "project",
64571            "region",
64572            "resource"
64573          ],
64574          "response": {
64575            "$ref": "Policy"
64576          },
64577          "scopes": [
64578            "https://www.googleapis.com/auth/cloud-platform",
64579            "https://www.googleapis.com/auth/compute",
64580            "https://www.googleapis.com/auth/compute.readonly"
64581          ],
64582          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
64583        },
64584        "setIamPolicy": {
64585          "id": "compute.regionInstantSnapshots.setIamPolicy",
64586          "path": "projects/{project}/regions/{region}/instantSnapshots/{resource}/setIamPolicy",
64587          "flatPath": "projects/{project}/regions/{region}/instantSnapshots/{resource}/setIamPolicy",
64588          "httpMethod": "POST",
64589          "parameters": {
64590            "project": {
64591              "description": "Project ID for this request.",
64592              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64593              "location": "path",
64594              "required": true,
64595              "type": "string"
64596            },
64597            "region": {
64598              "description": "The name of the region for this request.",
64599              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64600              "location": "path",
64601              "required": true,
64602              "type": "string"
64603            },
64604            "resource": {
64605              "description": "Name or id of the resource for this request.",
64606              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
64607              "location": "path",
64608              "required": true,
64609              "type": "string"
64610            }
64611          },
64612          "parameterOrder": [
64613            "project",
64614            "region",
64615            "resource"
64616          ],
64617          "request": {
64618            "$ref": "RegionSetPolicyRequest"
64619          },
64620          "response": {
64621            "$ref": "Policy"
64622          },
64623          "scopes": [
64624            "https://www.googleapis.com/auth/cloud-platform",
64625            "https://www.googleapis.com/auth/compute"
64626          ],
64627          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
64628        },
64629        "testIamPermissions": {
64630          "id": "compute.regionInstantSnapshots.testIamPermissions",
64631          "path": "projects/{project}/regions/{region}/instantSnapshots/{resource}/testIamPermissions",
64632          "flatPath": "projects/{project}/regions/{region}/instantSnapshots/{resource}/testIamPermissions",
64633          "httpMethod": "POST",
64634          "parameters": {
64635            "project": {
64636              "description": "Project ID for this request.",
64637              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64638              "location": "path",
64639              "required": true,
64640              "type": "string"
64641            },
64642            "region": {
64643              "description": "The name of the region for this request.",
64644              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64645              "location": "path",
64646              "required": true,
64647              "type": "string"
64648            },
64649            "resource": {
64650              "description": "Name or id of the resource for this request.",
64651              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
64652              "location": "path",
64653              "required": true,
64654              "type": "string"
64655            }
64656          },
64657          "parameterOrder": [
64658            "project",
64659            "region",
64660            "resource"
64661          ],
64662          "request": {
64663            "$ref": "TestPermissionsRequest"
64664          },
64665          "response": {
64666            "$ref": "TestPermissionsResponse"
64667          },
64668          "scopes": [
64669            "https://www.googleapis.com/auth/cloud-platform",
64670            "https://www.googleapis.com/auth/compute",
64671            "https://www.googleapis.com/auth/compute.readonly"
64672          ],
64673          "description": "Returns permissions that a caller has on the specified resource."
64674        }
64675      }
64676    },
64677    "interconnectAttachments": {
64678      "methods": {
64679        "list": {
64680          "id": "compute.interconnectAttachments.list",
64681          "path": "projects/{project}/regions/{region}/interconnectAttachments",
64682          "flatPath": "projects/{project}/regions/{region}/interconnectAttachments",
64683          "httpMethod": "GET",
64684          "parameters": {
64685            "filter": {
64686              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
64687              "location": "query",
64688              "type": "string"
64689            },
64690            "maxResults": {
64691              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
64692              "default": "500",
64693              "minimum": "0",
64694              "location": "query",
64695              "type": "integer",
64696              "format": "uint32"
64697            },
64698            "orderBy": {
64699              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
64700              "location": "query",
64701              "type": "string"
64702            },
64703            "pageToken": {
64704              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
64705              "location": "query",
64706              "type": "string"
64707            },
64708            "project": {
64709              "description": "Project ID for this request.",
64710              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64711              "location": "path",
64712              "required": true,
64713              "type": "string"
64714            },
64715            "region": {
64716              "description": "Name of the region for this request.",
64717              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64718              "location": "path",
64719              "required": true,
64720              "type": "string"
64721            },
64722            "returnPartialSuccess": {
64723              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
64724              "location": "query",
64725              "type": "boolean"
64726            }
64727          },
64728          "parameterOrder": [
64729            "project",
64730            "region"
64731          ],
64732          "response": {
64733            "$ref": "InterconnectAttachmentList"
64734          },
64735          "scopes": [
64736            "https://www.googleapis.com/auth/cloud-platform",
64737            "https://www.googleapis.com/auth/compute",
64738            "https://www.googleapis.com/auth/compute.readonly"
64739          ],
64740          "description": "Retrieves the list of interconnect attachments contained within the specified region."
64741        },
64742        "aggregatedList": {
64743          "id": "compute.interconnectAttachments.aggregatedList",
64744          "path": "projects/{project}/aggregated/interconnectAttachments",
64745          "flatPath": "projects/{project}/aggregated/interconnectAttachments",
64746          "httpMethod": "GET",
64747          "parameters": {
64748            "filter": {
64749              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
64750              "location": "query",
64751              "type": "string"
64752            },
64753            "includeAllScopes": {
64754              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
64755              "location": "query",
64756              "type": "boolean"
64757            },
64758            "maxResults": {
64759              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
64760              "default": "500",
64761              "minimum": "0",
64762              "location": "query",
64763              "type": "integer",
64764              "format": "uint32"
64765            },
64766            "orderBy": {
64767              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
64768              "location": "query",
64769              "type": "string"
64770            },
64771            "pageToken": {
64772              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
64773              "location": "query",
64774              "type": "string"
64775            },
64776            "project": {
64777              "description": "Project ID for this request.",
64778              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64779              "location": "path",
64780              "required": true,
64781              "type": "string"
64782            },
64783            "returnPartialSuccess": {
64784              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
64785              "location": "query",
64786              "type": "boolean"
64787            },
64788            "serviceProjectNumber": {
64789              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
64790              "location": "query",
64791              "type": "string",
64792              "format": "int64"
64793            }
64794          },
64795          "parameterOrder": [
64796            "project"
64797          ],
64798          "response": {
64799            "$ref": "InterconnectAttachmentAggregatedList"
64800          },
64801          "scopes": [
64802            "https://www.googleapis.com/auth/cloud-platform",
64803            "https://www.googleapis.com/auth/compute",
64804            "https://www.googleapis.com/auth/compute.readonly"
64805          ],
64806          "description": "Retrieves an aggregated list of interconnect attachments. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
64807        },
64808        "get": {
64809          "id": "compute.interconnectAttachments.get",
64810          "path": "projects/{project}/regions/{region}/interconnectAttachments/{interconnectAttachment}",
64811          "flatPath": "projects/{project}/regions/{region}/interconnectAttachments/{interconnectAttachment}",
64812          "httpMethod": "GET",
64813          "parameters": {
64814            "interconnectAttachment": {
64815              "description": "Name of the interconnect attachment to return.",
64816              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
64817              "location": "path",
64818              "required": true,
64819              "type": "string"
64820            },
64821            "project": {
64822              "description": "Project ID for this request.",
64823              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64824              "location": "path",
64825              "required": true,
64826              "type": "string"
64827            },
64828            "region": {
64829              "description": "Name of the region for this request.",
64830              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64831              "location": "path",
64832              "required": true,
64833              "type": "string"
64834            }
64835          },
64836          "parameterOrder": [
64837            "project",
64838            "region",
64839            "interconnectAttachment"
64840          ],
64841          "response": {
64842            "$ref": "InterconnectAttachment"
64843          },
64844          "scopes": [
64845            "https://www.googleapis.com/auth/cloud-platform",
64846            "https://www.googleapis.com/auth/compute",
64847            "https://www.googleapis.com/auth/compute.readonly"
64848          ],
64849          "description": "Returns the specified interconnect attachment."
64850        },
64851        "insert": {
64852          "id": "compute.interconnectAttachments.insert",
64853          "path": "projects/{project}/regions/{region}/interconnectAttachments",
64854          "flatPath": "projects/{project}/regions/{region}/interconnectAttachments",
64855          "httpMethod": "POST",
64856          "parameters": {
64857            "project": {
64858              "description": "Project ID for this request.",
64859              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64860              "location": "path",
64861              "required": true,
64862              "type": "string"
64863            },
64864            "region": {
64865              "description": "Name of the region for this request.",
64866              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64867              "location": "path",
64868              "required": true,
64869              "type": "string"
64870            },
64871            "requestId": {
64872              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
64873              "location": "query",
64874              "type": "string"
64875            },
64876            "validateOnly": {
64877              "description": "If true, the request will not be committed.",
64878              "location": "query",
64879              "type": "boolean"
64880            }
64881          },
64882          "parameterOrder": [
64883            "project",
64884            "region"
64885          ],
64886          "request": {
64887            "$ref": "InterconnectAttachment"
64888          },
64889          "response": {
64890            "$ref": "Operation"
64891          },
64892          "scopes": [
64893            "https://www.googleapis.com/auth/cloud-platform",
64894            "https://www.googleapis.com/auth/compute"
64895          ],
64896          "description": "Creates an InterconnectAttachment in the specified project using the data included in the request."
64897        },
64898        "patch": {
64899          "id": "compute.interconnectAttachments.patch",
64900          "path": "projects/{project}/regions/{region}/interconnectAttachments/{interconnectAttachment}",
64901          "flatPath": "projects/{project}/regions/{region}/interconnectAttachments/{interconnectAttachment}",
64902          "httpMethod": "PATCH",
64903          "parameters": {
64904            "interconnectAttachment": {
64905              "description": "Name of the interconnect attachment to patch.",
64906              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
64907              "location": "path",
64908              "required": true,
64909              "type": "string"
64910            },
64911            "project": {
64912              "description": "Project ID for this request.",
64913              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64914              "location": "path",
64915              "required": true,
64916              "type": "string"
64917            },
64918            "region": {
64919              "description": "Name of the region scoping this request.",
64920              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64921              "location": "path",
64922              "required": true,
64923              "type": "string"
64924            },
64925            "requestId": {
64926              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
64927              "location": "query",
64928              "type": "string"
64929            }
64930          },
64931          "parameterOrder": [
64932            "project",
64933            "region",
64934            "interconnectAttachment"
64935          ],
64936          "request": {
64937            "$ref": "InterconnectAttachment"
64938          },
64939          "response": {
64940            "$ref": "Operation"
64941          },
64942          "scopes": [
64943            "https://www.googleapis.com/auth/cloud-platform",
64944            "https://www.googleapis.com/auth/compute"
64945          ],
64946          "description": "Updates the specified interconnect attachment with the data included in the request. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
64947        },
64948        "delete": {
64949          "id": "compute.interconnectAttachments.delete",
64950          "path": "projects/{project}/regions/{region}/interconnectAttachments/{interconnectAttachment}",
64951          "flatPath": "projects/{project}/regions/{region}/interconnectAttachments/{interconnectAttachment}",
64952          "httpMethod": "DELETE",
64953          "parameters": {
64954            "interconnectAttachment": {
64955              "description": "Name of the interconnect attachment to delete.",
64956              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
64957              "location": "path",
64958              "required": true,
64959              "type": "string"
64960            },
64961            "project": {
64962              "description": "Project ID for this request.",
64963              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
64964              "location": "path",
64965              "required": true,
64966              "type": "string"
64967            },
64968            "region": {
64969              "description": "Name of the region for this request.",
64970              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
64971              "location": "path",
64972              "required": true,
64973              "type": "string"
64974            },
64975            "requestId": {
64976              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
64977              "location": "query",
64978              "type": "string"
64979            }
64980          },
64981          "parameterOrder": [
64982            "project",
64983            "region",
64984            "interconnectAttachment"
64985          ],
64986          "response": {
64987            "$ref": "Operation"
64988          },
64989          "scopes": [
64990            "https://www.googleapis.com/auth/cloud-platform",
64991            "https://www.googleapis.com/auth/compute"
64992          ],
64993          "description": "Deletes the specified interconnect attachment."
64994        },
64995        "setLabels": {
64996          "id": "compute.interconnectAttachments.setLabels",
64997          "path": "projects/{project}/regions/{region}/interconnectAttachments/{resource}/setLabels",
64998          "flatPath": "projects/{project}/regions/{region}/interconnectAttachments/{resource}/setLabels",
64999          "httpMethod": "POST",
65000          "parameters": {
65001            "project": {
65002              "description": "Project ID for this request.",
65003              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65004              "location": "path",
65005              "required": true,
65006              "type": "string"
65007            },
65008            "region": {
65009              "description": "The region for this request.",
65010              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
65011              "location": "path",
65012              "required": true,
65013              "type": "string"
65014            },
65015            "requestId": {
65016              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
65017              "location": "query",
65018              "type": "string"
65019            },
65020            "resource": {
65021              "description": "Name or id of the resource for this request.",
65022              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
65023              "location": "path",
65024              "required": true,
65025              "type": "string"
65026            }
65027          },
65028          "parameterOrder": [
65029            "project",
65030            "region",
65031            "resource"
65032          ],
65033          "request": {
65034            "$ref": "RegionSetLabelsRequest"
65035          },
65036          "response": {
65037            "$ref": "Operation"
65038          },
65039          "scopes": [
65040            "https://www.googleapis.com/auth/cloud-platform",
65041            "https://www.googleapis.com/auth/compute"
65042          ],
65043          "description": "Sets the labels on an InterconnectAttachment. To learn more about labels, read the Labeling Resources documentation."
65044        }
65045      }
65046    },
65047    "interconnects": {
65048      "methods": {
65049        "insert": {
65050          "id": "compute.interconnects.insert",
65051          "path": "projects/{project}/global/interconnects",
65052          "flatPath": "projects/{project}/global/interconnects",
65053          "httpMethod": "POST",
65054          "parameters": {
65055            "project": {
65056              "description": "Project ID for this request.",
65057              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65058              "location": "path",
65059              "required": true,
65060              "type": "string"
65061            },
65062            "requestId": {
65063              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
65064              "location": "query",
65065              "type": "string"
65066            }
65067          },
65068          "parameterOrder": [
65069            "project"
65070          ],
65071          "request": {
65072            "$ref": "Interconnect"
65073          },
65074          "response": {
65075            "$ref": "Operation"
65076          },
65077          "scopes": [
65078            "https://www.googleapis.com/auth/cloud-platform",
65079            "https://www.googleapis.com/auth/compute"
65080          ],
65081          "description": "Creates an Interconnect in the specified project using the data included in the request."
65082        },
65083        "list": {
65084          "id": "compute.interconnects.list",
65085          "path": "projects/{project}/global/interconnects",
65086          "flatPath": "projects/{project}/global/interconnects",
65087          "httpMethod": "GET",
65088          "parameters": {
65089            "filter": {
65090              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
65091              "location": "query",
65092              "type": "string"
65093            },
65094            "maxResults": {
65095              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
65096              "default": "500",
65097              "minimum": "0",
65098              "location": "query",
65099              "type": "integer",
65100              "format": "uint32"
65101            },
65102            "orderBy": {
65103              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
65104              "location": "query",
65105              "type": "string"
65106            },
65107            "pageToken": {
65108              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
65109              "location": "query",
65110              "type": "string"
65111            },
65112            "project": {
65113              "description": "Project ID for this request.",
65114              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65115              "location": "path",
65116              "required": true,
65117              "type": "string"
65118            },
65119            "returnPartialSuccess": {
65120              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
65121              "location": "query",
65122              "type": "boolean"
65123            }
65124          },
65125          "parameterOrder": [
65126            "project"
65127          ],
65128          "response": {
65129            "$ref": "InterconnectList"
65130          },
65131          "scopes": [
65132            "https://www.googleapis.com/auth/cloud-platform",
65133            "https://www.googleapis.com/auth/compute",
65134            "https://www.googleapis.com/auth/compute.readonly"
65135          ],
65136          "description": "Retrieves the list of Interconnects available to the specified project."
65137        },
65138        "getDiagnostics": {
65139          "id": "compute.interconnects.getDiagnostics",
65140          "path": "projects/{project}/global/interconnects/{interconnect}/getDiagnostics",
65141          "flatPath": "projects/{project}/global/interconnects/{interconnect}/getDiagnostics",
65142          "httpMethod": "GET",
65143          "parameters": {
65144            "interconnect": {
65145              "description": "Name of the interconnect resource to query.",
65146              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
65147              "location": "path",
65148              "required": true,
65149              "type": "string"
65150            },
65151            "project": {
65152              "description": "Project ID for this request.",
65153              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65154              "location": "path",
65155              "required": true,
65156              "type": "string"
65157            }
65158          },
65159          "parameterOrder": [
65160            "project",
65161            "interconnect"
65162          ],
65163          "response": {
65164            "$ref": "InterconnectsGetDiagnosticsResponse"
65165          },
65166          "scopes": [
65167            "https://www.googleapis.com/auth/cloud-platform",
65168            "https://www.googleapis.com/auth/compute",
65169            "https://www.googleapis.com/auth/compute.readonly"
65170          ],
65171          "description": "Returns the interconnectDiagnostics for the specified Interconnect. In the event of a global outage, do not use this API to make decisions about where to redirect your network traffic. Unlike a VLAN attachment, which is regional, a Cloud Interconnect connection is a global resource. A global outage can prevent this API from functioning properly."
65172        },
65173        "getMacsecConfig": {
65174          "id": "compute.interconnects.getMacsecConfig",
65175          "path": "projects/{project}/global/interconnects/{interconnect}/getMacsecConfig",
65176          "flatPath": "projects/{project}/global/interconnects/{interconnect}/getMacsecConfig",
65177          "httpMethod": "GET",
65178          "parameters": {
65179            "interconnect": {
65180              "description": "Name of the interconnect resource to query.",
65181              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
65182              "location": "path",
65183              "required": true,
65184              "type": "string"
65185            },
65186            "project": {
65187              "description": "Project ID for this request.",
65188              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65189              "location": "path",
65190              "required": true,
65191              "type": "string"
65192            }
65193          },
65194          "parameterOrder": [
65195            "project",
65196            "interconnect"
65197          ],
65198          "response": {
65199            "$ref": "InterconnectsGetMacsecConfigResponse"
65200          },
65201          "scopes": [
65202            "https://www.googleapis.com/auth/cloud-platform",
65203            "https://www.googleapis.com/auth/compute",
65204            "https://www.googleapis.com/auth/compute.readonly"
65205          ],
65206          "description": "Returns the interconnectMacsecConfig for the specified Interconnect."
65207        },
65208        "get": {
65209          "id": "compute.interconnects.get",
65210          "path": "projects/{project}/global/interconnects/{interconnect}",
65211          "flatPath": "projects/{project}/global/interconnects/{interconnect}",
65212          "httpMethod": "GET",
65213          "parameters": {
65214            "interconnect": {
65215              "description": "Name of the interconnect to return.",
65216              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
65217              "location": "path",
65218              "required": true,
65219              "type": "string"
65220            },
65221            "project": {
65222              "description": "Project ID for this request.",
65223              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65224              "location": "path",
65225              "required": true,
65226              "type": "string"
65227            }
65228          },
65229          "parameterOrder": [
65230            "project",
65231            "interconnect"
65232          ],
65233          "response": {
65234            "$ref": "Interconnect"
65235          },
65236          "scopes": [
65237            "https://www.googleapis.com/auth/cloud-platform",
65238            "https://www.googleapis.com/auth/compute",
65239            "https://www.googleapis.com/auth/compute.readonly"
65240          ],
65241          "description": "Returns the specified Interconnect. Get a list of available Interconnects by making a list() request."
65242        },
65243        "delete": {
65244          "id": "compute.interconnects.delete",
65245          "path": "projects/{project}/global/interconnects/{interconnect}",
65246          "flatPath": "projects/{project}/global/interconnects/{interconnect}",
65247          "httpMethod": "DELETE",
65248          "parameters": {
65249            "interconnect": {
65250              "description": "Name of the interconnect to delete.",
65251              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
65252              "location": "path",
65253              "required": true,
65254              "type": "string"
65255            },
65256            "project": {
65257              "description": "Project ID for this request.",
65258              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65259              "location": "path",
65260              "required": true,
65261              "type": "string"
65262            },
65263            "requestId": {
65264              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
65265              "location": "query",
65266              "type": "string"
65267            }
65268          },
65269          "parameterOrder": [
65270            "project",
65271            "interconnect"
65272          ],
65273          "response": {
65274            "$ref": "Operation"
65275          },
65276          "scopes": [
65277            "https://www.googleapis.com/auth/cloud-platform",
65278            "https://www.googleapis.com/auth/compute"
65279          ],
65280          "description": "Deletes the specified Interconnect."
65281        },
65282        "patch": {
65283          "id": "compute.interconnects.patch",
65284          "path": "projects/{project}/global/interconnects/{interconnect}",
65285          "flatPath": "projects/{project}/global/interconnects/{interconnect}",
65286          "httpMethod": "PATCH",
65287          "parameters": {
65288            "interconnect": {
65289              "description": "Name of the interconnect to update.",
65290              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
65291              "location": "path",
65292              "required": true,
65293              "type": "string"
65294            },
65295            "project": {
65296              "description": "Project ID for this request.",
65297              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65298              "location": "path",
65299              "required": true,
65300              "type": "string"
65301            },
65302            "requestId": {
65303              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
65304              "location": "query",
65305              "type": "string"
65306            }
65307          },
65308          "parameterOrder": [
65309            "project",
65310            "interconnect"
65311          ],
65312          "request": {
65313            "$ref": "Interconnect"
65314          },
65315          "response": {
65316            "$ref": "Operation"
65317          },
65318          "scopes": [
65319            "https://www.googleapis.com/auth/cloud-platform",
65320            "https://www.googleapis.com/auth/compute"
65321          ],
65322          "description": "Updates the specified Interconnect with the data included in the request. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
65323        },
65324        "setLabels": {
65325          "id": "compute.interconnects.setLabels",
65326          "path": "projects/{project}/global/interconnects/{resource}/setLabels",
65327          "flatPath": "projects/{project}/global/interconnects/{resource}/setLabels",
65328          "httpMethod": "POST",
65329          "parameters": {
65330            "project": {
65331              "description": "Project ID for this request.",
65332              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65333              "location": "path",
65334              "required": true,
65335              "type": "string"
65336            },
65337            "resource": {
65338              "description": "Name or id of the resource for this request.",
65339              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
65340              "location": "path",
65341              "required": true,
65342              "type": "string"
65343            }
65344          },
65345          "parameterOrder": [
65346            "project",
65347            "resource"
65348          ],
65349          "request": {
65350            "$ref": "GlobalSetLabelsRequest"
65351          },
65352          "response": {
65353            "$ref": "Operation"
65354          },
65355          "scopes": [
65356            "https://www.googleapis.com/auth/cloud-platform",
65357            "https://www.googleapis.com/auth/compute"
65358          ],
65359          "description": "Sets the labels on an Interconnect. To learn more about labels, read the Labeling Resources documentation."
65360        }
65361      }
65362    },
65363    "interconnectLocations": {
65364      "methods": {
65365        "list": {
65366          "id": "compute.interconnectLocations.list",
65367          "path": "projects/{project}/global/interconnectLocations",
65368          "flatPath": "projects/{project}/global/interconnectLocations",
65369          "httpMethod": "GET",
65370          "parameters": {
65371            "filter": {
65372              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
65373              "location": "query",
65374              "type": "string"
65375            },
65376            "maxResults": {
65377              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
65378              "default": "500",
65379              "minimum": "0",
65380              "location": "query",
65381              "type": "integer",
65382              "format": "uint32"
65383            },
65384            "orderBy": {
65385              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
65386              "location": "query",
65387              "type": "string"
65388            },
65389            "pageToken": {
65390              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
65391              "location": "query",
65392              "type": "string"
65393            },
65394            "project": {
65395              "description": "Project ID for this request.",
65396              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65397              "location": "path",
65398              "required": true,
65399              "type": "string"
65400            },
65401            "returnPartialSuccess": {
65402              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
65403              "location": "query",
65404              "type": "boolean"
65405            }
65406          },
65407          "parameterOrder": [
65408            "project"
65409          ],
65410          "response": {
65411            "$ref": "InterconnectLocationList"
65412          },
65413          "scopes": [
65414            "https://www.googleapis.com/auth/cloud-platform",
65415            "https://www.googleapis.com/auth/compute",
65416            "https://www.googleapis.com/auth/compute.readonly"
65417          ],
65418          "description": "Retrieves the list of interconnect locations available to the specified project."
65419        },
65420        "get": {
65421          "id": "compute.interconnectLocations.get",
65422          "path": "projects/{project}/global/interconnectLocations/{interconnectLocation}",
65423          "flatPath": "projects/{project}/global/interconnectLocations/{interconnectLocation}",
65424          "httpMethod": "GET",
65425          "parameters": {
65426            "interconnectLocation": {
65427              "description": "Name of the interconnect location to return.",
65428              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
65429              "location": "path",
65430              "required": true,
65431              "type": "string"
65432            },
65433            "project": {
65434              "description": "Project ID for this request.",
65435              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65436              "location": "path",
65437              "required": true,
65438              "type": "string"
65439            }
65440          },
65441          "parameterOrder": [
65442            "project",
65443            "interconnectLocation"
65444          ],
65445          "response": {
65446            "$ref": "InterconnectLocation"
65447          },
65448          "scopes": [
65449            "https://www.googleapis.com/auth/cloud-platform",
65450            "https://www.googleapis.com/auth/compute",
65451            "https://www.googleapis.com/auth/compute.readonly"
65452          ],
65453          "description": "Returns the details for the specified interconnect location. Gets a list of available interconnect locations by making a list() request."
65454        }
65455      }
65456    },
65457    "interconnectRemoteLocations": {
65458      "methods": {
65459        "list": {
65460          "id": "compute.interconnectRemoteLocations.list",
65461          "path": "projects/{project}/global/interconnectRemoteLocations",
65462          "flatPath": "projects/{project}/global/interconnectRemoteLocations",
65463          "httpMethod": "GET",
65464          "parameters": {
65465            "filter": {
65466              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
65467              "location": "query",
65468              "type": "string"
65469            },
65470            "maxResults": {
65471              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
65472              "default": "500",
65473              "minimum": "0",
65474              "location": "query",
65475              "type": "integer",
65476              "format": "uint32"
65477            },
65478            "orderBy": {
65479              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
65480              "location": "query",
65481              "type": "string"
65482            },
65483            "pageToken": {
65484              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
65485              "location": "query",
65486              "type": "string"
65487            },
65488            "project": {
65489              "description": "Project ID for this request.",
65490              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65491              "location": "path",
65492              "required": true,
65493              "type": "string"
65494            },
65495            "returnPartialSuccess": {
65496              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
65497              "location": "query",
65498              "type": "boolean"
65499            }
65500          },
65501          "parameterOrder": [
65502            "project"
65503          ],
65504          "response": {
65505            "$ref": "InterconnectRemoteLocationList"
65506          },
65507          "scopes": [
65508            "https://www.googleapis.com/auth/cloud-platform",
65509            "https://www.googleapis.com/auth/compute",
65510            "https://www.googleapis.com/auth/compute.readonly"
65511          ],
65512          "description": "Retrieves the list of interconnect remote locations available to the specified project."
65513        },
65514        "get": {
65515          "id": "compute.interconnectRemoteLocations.get",
65516          "path": "projects/{project}/global/interconnectRemoteLocations/{interconnectRemoteLocation}",
65517          "flatPath": "projects/{project}/global/interconnectRemoteLocations/{interconnectRemoteLocation}",
65518          "httpMethod": "GET",
65519          "parameters": {
65520            "interconnectRemoteLocation": {
65521              "description": "Name of the interconnect remote location to return.",
65522              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
65523              "location": "path",
65524              "required": true,
65525              "type": "string"
65526            },
65527            "project": {
65528              "description": "Project ID for this request.",
65529              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65530              "location": "path",
65531              "required": true,
65532              "type": "string"
65533            }
65534          },
65535          "parameterOrder": [
65536            "project",
65537            "interconnectRemoteLocation"
65538          ],
65539          "response": {
65540            "$ref": "InterconnectRemoteLocation"
65541          },
65542          "scopes": [
65543            "https://www.googleapis.com/auth/cloud-platform",
65544            "https://www.googleapis.com/auth/compute",
65545            "https://www.googleapis.com/auth/compute.readonly"
65546          ],
65547          "description": "Returns the details for the specified interconnect remote location. Gets a list of available interconnect remote locations by making a list() request."
65548        }
65549      }
65550    },
65551    "licenseCodes": {
65552      "methods": {
65553        "get": {
65554          "id": "compute.licenseCodes.get",
65555          "path": "projects/{project}/global/licenseCodes/{licenseCode}",
65556          "flatPath": "projects/{project}/global/licenseCodes/{licenseCode}",
65557          "httpMethod": "GET",
65558          "parameters": {
65559            "licenseCode": {
65560              "description": "Number corresponding to the License code resource to return.",
65561              "pattern": "[0-9]{0,61}?",
65562              "location": "path",
65563              "required": true,
65564              "type": "string"
65565            },
65566            "project": {
65567              "description": "Project ID for this request.",
65568              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65569              "location": "path",
65570              "required": true,
65571              "type": "string"
65572            }
65573          },
65574          "parameterOrder": [
65575            "project",
65576            "licenseCode"
65577          ],
65578          "response": {
65579            "$ref": "LicenseCode"
65580          },
65581          "scopes": [
65582            "https://www.googleapis.com/auth/cloud-platform",
65583            "https://www.googleapis.com/auth/compute",
65584            "https://www.googleapis.com/auth/compute.readonly"
65585          ],
65586          "description": "Return a specified license code. License codes are mirrored across all projects that have permissions to read the License Code. *Caution* This resource is intended for use only by third-party partners who are creating Cloud Marketplace images. "
65587        },
65588        "testIamPermissions": {
65589          "id": "compute.licenseCodes.testIamPermissions",
65590          "path": "projects/{project}/global/licenseCodes/{resource}/testIamPermissions",
65591          "flatPath": "projects/{project}/global/licenseCodes/{resource}/testIamPermissions",
65592          "httpMethod": "POST",
65593          "parameters": {
65594            "project": {
65595              "description": "Project ID for this request.",
65596              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65597              "location": "path",
65598              "required": true,
65599              "type": "string"
65600            },
65601            "resource": {
65602              "description": "Name or id of the resource for this request.",
65603              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
65604              "location": "path",
65605              "required": true,
65606              "type": "string"
65607            }
65608          },
65609          "parameterOrder": [
65610            "project",
65611            "resource"
65612          ],
65613          "request": {
65614            "$ref": "TestPermissionsRequest"
65615          },
65616          "response": {
65617            "$ref": "TestPermissionsResponse"
65618          },
65619          "scopes": [
65620            "https://www.googleapis.com/auth/cloud-platform",
65621            "https://www.googleapis.com/auth/compute",
65622            "https://www.googleapis.com/auth/compute.readonly"
65623          ],
65624          "description": "Returns permissions that a caller has on the specified resource. *Caution* This resource is intended for use only by third-party partners who are creating Cloud Marketplace images. "
65625        }
65626      }
65627    },
65628    "licenses": {
65629      "methods": {
65630        "get": {
65631          "id": "compute.licenses.get",
65632          "path": "projects/{project}/global/licenses/{license}",
65633          "flatPath": "projects/{project}/global/licenses/{license}",
65634          "httpMethod": "GET",
65635          "parameters": {
65636            "license": {
65637              "description": "Name of the License resource to return.",
65638              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
65639              "location": "path",
65640              "required": true,
65641              "type": "string"
65642            },
65643            "project": {
65644              "description": "Project ID for this request.",
65645              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65646              "location": "path",
65647              "required": true,
65648              "type": "string"
65649            }
65650          },
65651          "parameterOrder": [
65652            "project",
65653            "license"
65654          ],
65655          "response": {
65656            "$ref": "License"
65657          },
65658          "scopes": [
65659            "https://www.googleapis.com/auth/cloud-platform",
65660            "https://www.googleapis.com/auth/compute",
65661            "https://www.googleapis.com/auth/compute.readonly"
65662          ],
65663          "description": "Returns the specified License resource. *Caution* This resource is intended for use only by third-party partners who are creating Cloud Marketplace images. "
65664        },
65665        "list": {
65666          "id": "compute.licenses.list",
65667          "path": "projects/{project}/global/licenses",
65668          "flatPath": "projects/{project}/global/licenses",
65669          "httpMethod": "GET",
65670          "parameters": {
65671            "filter": {
65672              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
65673              "location": "query",
65674              "type": "string"
65675            },
65676            "maxResults": {
65677              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
65678              "default": "500",
65679              "minimum": "0",
65680              "location": "query",
65681              "type": "integer",
65682              "format": "uint32"
65683            },
65684            "orderBy": {
65685              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
65686              "location": "query",
65687              "type": "string"
65688            },
65689            "pageToken": {
65690              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
65691              "location": "query",
65692              "type": "string"
65693            },
65694            "project": {
65695              "description": "Project ID for this request.",
65696              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65697              "location": "path",
65698              "required": true,
65699              "type": "string"
65700            },
65701            "returnPartialSuccess": {
65702              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
65703              "location": "query",
65704              "type": "boolean"
65705            }
65706          },
65707          "parameterOrder": [
65708            "project"
65709          ],
65710          "response": {
65711            "$ref": "LicensesListResponse"
65712          },
65713          "scopes": [
65714            "https://www.googleapis.com/auth/cloud-platform",
65715            "https://www.googleapis.com/auth/compute",
65716            "https://www.googleapis.com/auth/compute.readonly"
65717          ],
65718          "description": "Retrieves the list of licenses available in the specified project. This method does not get any licenses that belong to other projects, including licenses attached to publicly-available images, like Debian 9. If you want to get a list of publicly-available licenses, use this method to make a request to the respective image project, such as debian-cloud or windows-cloud. *Caution* This resource is intended for use only by third-party partners who are creating Cloud Marketplace images. "
65719        },
65720        "delete": {
65721          "id": "compute.licenses.delete",
65722          "path": "projects/{project}/global/licenses/{license}",
65723          "flatPath": "projects/{project}/global/licenses/{license}",
65724          "httpMethod": "DELETE",
65725          "parameters": {
65726            "license": {
65727              "description": "Name of the license resource to delete.",
65728              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
65729              "location": "path",
65730              "required": true,
65731              "type": "string"
65732            },
65733            "project": {
65734              "description": "Project ID for this request.",
65735              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65736              "location": "path",
65737              "required": true,
65738              "type": "string"
65739            },
65740            "requestId": {
65741              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
65742              "location": "query",
65743              "type": "string"
65744            }
65745          },
65746          "parameterOrder": [
65747            "project",
65748            "license"
65749          ],
65750          "response": {
65751            "$ref": "Operation"
65752          },
65753          "scopes": [
65754            "https://www.googleapis.com/auth/cloud-platform",
65755            "https://www.googleapis.com/auth/compute"
65756          ],
65757          "description": "Deletes the specified license. *Caution* This resource is intended for use only by third-party partners who are creating Cloud Marketplace images. "
65758        },
65759        "insert": {
65760          "id": "compute.licenses.insert",
65761          "path": "projects/{project}/global/licenses",
65762          "flatPath": "projects/{project}/global/licenses",
65763          "httpMethod": "POST",
65764          "parameters": {
65765            "project": {
65766              "description": "Project ID for this request.",
65767              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65768              "location": "path",
65769              "required": true,
65770              "type": "string"
65771            },
65772            "requestId": {
65773              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
65774              "location": "query",
65775              "type": "string"
65776            }
65777          },
65778          "parameterOrder": [
65779            "project"
65780          ],
65781          "request": {
65782            "$ref": "License"
65783          },
65784          "response": {
65785            "$ref": "Operation"
65786          },
65787          "scopes": [
65788            "https://www.googleapis.com/auth/cloud-platform",
65789            "https://www.googleapis.com/auth/compute",
65790            "https://www.googleapis.com/auth/devstorage.full_control",
65791            "https://www.googleapis.com/auth/devstorage.read_only",
65792            "https://www.googleapis.com/auth/devstorage.read_write"
65793          ],
65794          "description": "Create a License resource in the specified project. *Caution* This resource is intended for use only by third-party partners who are creating Cloud Marketplace images. "
65795        },
65796        "getIamPolicy": {
65797          "id": "compute.licenses.getIamPolicy",
65798          "path": "projects/{project}/global/licenses/{resource}/getIamPolicy",
65799          "flatPath": "projects/{project}/global/licenses/{resource}/getIamPolicy",
65800          "httpMethod": "GET",
65801          "parameters": {
65802            "optionsRequestedPolicyVersion": {
65803              "description": "Requested IAM Policy version.",
65804              "location": "query",
65805              "type": "integer",
65806              "format": "int32"
65807            },
65808            "project": {
65809              "description": "Project ID for this request.",
65810              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65811              "location": "path",
65812              "required": true,
65813              "type": "string"
65814            },
65815            "resource": {
65816              "description": "Name or id of the resource for this request.",
65817              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
65818              "location": "path",
65819              "required": true,
65820              "type": "string"
65821            }
65822          },
65823          "parameterOrder": [
65824            "project",
65825            "resource"
65826          ],
65827          "response": {
65828            "$ref": "Policy"
65829          },
65830          "scopes": [
65831            "https://www.googleapis.com/auth/cloud-platform",
65832            "https://www.googleapis.com/auth/compute",
65833            "https://www.googleapis.com/auth/compute.readonly"
65834          ],
65835          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists. *Caution* This resource is intended for use only by third-party partners who are creating Cloud Marketplace images. "
65836        },
65837        "setIamPolicy": {
65838          "id": "compute.licenses.setIamPolicy",
65839          "path": "projects/{project}/global/licenses/{resource}/setIamPolicy",
65840          "flatPath": "projects/{project}/global/licenses/{resource}/setIamPolicy",
65841          "httpMethod": "POST",
65842          "parameters": {
65843            "project": {
65844              "description": "Project ID for this request.",
65845              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65846              "location": "path",
65847              "required": true,
65848              "type": "string"
65849            },
65850            "resource": {
65851              "description": "Name or id of the resource for this request.",
65852              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
65853              "location": "path",
65854              "required": true,
65855              "type": "string"
65856            }
65857          },
65858          "parameterOrder": [
65859            "project",
65860            "resource"
65861          ],
65862          "request": {
65863            "$ref": "GlobalSetPolicyRequest"
65864          },
65865          "response": {
65866            "$ref": "Policy"
65867          },
65868          "scopes": [
65869            "https://www.googleapis.com/auth/cloud-platform",
65870            "https://www.googleapis.com/auth/compute"
65871          ],
65872          "description": "Sets the access control policy on the specified resource. Replaces any existing policy. *Caution* This resource is intended for use only by third-party partners who are creating Cloud Marketplace images. "
65873        },
65874        "testIamPermissions": {
65875          "id": "compute.licenses.testIamPermissions",
65876          "path": "projects/{project}/global/licenses/{resource}/testIamPermissions",
65877          "flatPath": "projects/{project}/global/licenses/{resource}/testIamPermissions",
65878          "httpMethod": "POST",
65879          "parameters": {
65880            "project": {
65881              "description": "Project ID for this request.",
65882              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65883              "location": "path",
65884              "required": true,
65885              "type": "string"
65886            },
65887            "resource": {
65888              "description": "Name or id of the resource for this request.",
65889              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
65890              "location": "path",
65891              "required": true,
65892              "type": "string"
65893            }
65894          },
65895          "parameterOrder": [
65896            "project",
65897            "resource"
65898          ],
65899          "request": {
65900            "$ref": "TestPermissionsRequest"
65901          },
65902          "response": {
65903            "$ref": "TestPermissionsResponse"
65904          },
65905          "scopes": [
65906            "https://www.googleapis.com/auth/cloud-platform",
65907            "https://www.googleapis.com/auth/compute",
65908            "https://www.googleapis.com/auth/compute.readonly"
65909          ],
65910          "description": "Returns permissions that a caller has on the specified resource. *Caution* This resource is intended for use only by third-party partners who are creating Cloud Marketplace images. "
65911        }
65912      }
65913    },
65914    "machineImages": {
65915      "methods": {
65916        "list": {
65917          "id": "compute.machineImages.list",
65918          "path": "projects/{project}/global/machineImages",
65919          "flatPath": "projects/{project}/global/machineImages",
65920          "httpMethod": "GET",
65921          "parameters": {
65922            "filter": {
65923              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
65924              "location": "query",
65925              "type": "string"
65926            },
65927            "maxResults": {
65928              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
65929              "default": "500",
65930              "minimum": "0",
65931              "location": "query",
65932              "type": "integer",
65933              "format": "uint32"
65934            },
65935            "orderBy": {
65936              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
65937              "location": "query",
65938              "type": "string"
65939            },
65940            "pageToken": {
65941              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
65942              "location": "query",
65943              "type": "string"
65944            },
65945            "project": {
65946              "description": "Project ID for this request.",
65947              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65948              "location": "path",
65949              "required": true,
65950              "type": "string"
65951            },
65952            "returnPartialSuccess": {
65953              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
65954              "location": "query",
65955              "type": "boolean"
65956            }
65957          },
65958          "parameterOrder": [
65959            "project"
65960          ],
65961          "response": {
65962            "$ref": "MachineImageList"
65963          },
65964          "scopes": [
65965            "https://www.googleapis.com/auth/cloud-platform",
65966            "https://www.googleapis.com/auth/compute",
65967            "https://www.googleapis.com/auth/compute.readonly"
65968          ],
65969          "description": "Retrieves a list of machine images that are contained within the specified project."
65970        },
65971        "get": {
65972          "id": "compute.machineImages.get",
65973          "path": "projects/{project}/global/machineImages/{machineImage}",
65974          "flatPath": "projects/{project}/global/machineImages/{machineImage}",
65975          "httpMethod": "GET",
65976          "parameters": {
65977            "machineImage": {
65978              "description": "The name of the machine image.",
65979              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
65980              "location": "path",
65981              "required": true,
65982              "type": "string"
65983            },
65984            "project": {
65985              "description": "Project ID for this request.",
65986              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
65987              "location": "path",
65988              "required": true,
65989              "type": "string"
65990            }
65991          },
65992          "parameterOrder": [
65993            "project",
65994            "machineImage"
65995          ],
65996          "response": {
65997            "$ref": "MachineImage"
65998          },
65999          "scopes": [
66000            "https://www.googleapis.com/auth/cloud-platform",
66001            "https://www.googleapis.com/auth/compute",
66002            "https://www.googleapis.com/auth/compute.readonly"
66003          ],
66004          "description": "Returns the specified machine image."
66005        },
66006        "insert": {
66007          "id": "compute.machineImages.insert",
66008          "path": "projects/{project}/global/machineImages",
66009          "flatPath": "projects/{project}/global/machineImages",
66010          "httpMethod": "POST",
66011          "parameters": {
66012            "project": {
66013              "description": "Project ID for this request.",
66014              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66015              "location": "path",
66016              "required": true,
66017              "type": "string"
66018            },
66019            "requestId": {
66020              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
66021              "location": "query",
66022              "type": "string"
66023            },
66024            "sourceInstance": {
66025              "description": "Required. Source instance that is used to create the machine image from.",
66026              "location": "query",
66027              "type": "string"
66028            }
66029          },
66030          "parameterOrder": [
66031            "project"
66032          ],
66033          "request": {
66034            "$ref": "MachineImage"
66035          },
66036          "response": {
66037            "$ref": "Operation"
66038          },
66039          "scopes": [
66040            "https://www.googleapis.com/auth/cloud-platform",
66041            "https://www.googleapis.com/auth/compute"
66042          ],
66043          "description": "Creates a machine image in the specified project using the data that is included in the request. If you are creating a new machine image to update an existing instance, your new machine image should use the same network or, if applicable, the same subnetwork as the original instance."
66044        },
66045        "delete": {
66046          "id": "compute.machineImages.delete",
66047          "path": "projects/{project}/global/machineImages/{machineImage}",
66048          "flatPath": "projects/{project}/global/machineImages/{machineImage}",
66049          "httpMethod": "DELETE",
66050          "parameters": {
66051            "machineImage": {
66052              "description": "The name of the machine image to delete.",
66053              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
66054              "location": "path",
66055              "required": true,
66056              "type": "string"
66057            },
66058            "project": {
66059              "description": "Project ID for this request.",
66060              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66061              "location": "path",
66062              "required": true,
66063              "type": "string"
66064            },
66065            "requestId": {
66066              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
66067              "location": "query",
66068              "type": "string"
66069            }
66070          },
66071          "parameterOrder": [
66072            "project",
66073            "machineImage"
66074          ],
66075          "response": {
66076            "$ref": "Operation"
66077          },
66078          "scopes": [
66079            "https://www.googleapis.com/auth/cloud-platform",
66080            "https://www.googleapis.com/auth/compute"
66081          ],
66082          "description": "Deletes the specified machine image. Deleting a machine image is permanent and cannot be undone."
66083        },
66084        "getIamPolicy": {
66085          "id": "compute.machineImages.getIamPolicy",
66086          "path": "projects/{project}/global/machineImages/{resource}/getIamPolicy",
66087          "flatPath": "projects/{project}/global/machineImages/{resource}/getIamPolicy",
66088          "httpMethod": "GET",
66089          "parameters": {
66090            "optionsRequestedPolicyVersion": {
66091              "description": "Requested IAM Policy version.",
66092              "location": "query",
66093              "type": "integer",
66094              "format": "int32"
66095            },
66096            "project": {
66097              "description": "Project ID for this request.",
66098              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66099              "location": "path",
66100              "required": true,
66101              "type": "string"
66102            },
66103            "resource": {
66104              "description": "Name or id of the resource for this request.",
66105              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
66106              "location": "path",
66107              "required": true,
66108              "type": "string"
66109            }
66110          },
66111          "parameterOrder": [
66112            "project",
66113            "resource"
66114          ],
66115          "response": {
66116            "$ref": "Policy"
66117          },
66118          "scopes": [
66119            "https://www.googleapis.com/auth/cloud-platform",
66120            "https://www.googleapis.com/auth/compute",
66121            "https://www.googleapis.com/auth/compute.readonly"
66122          ],
66123          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
66124        },
66125        "setIamPolicy": {
66126          "id": "compute.machineImages.setIamPolicy",
66127          "path": "projects/{project}/global/machineImages/{resource}/setIamPolicy",
66128          "flatPath": "projects/{project}/global/machineImages/{resource}/setIamPolicy",
66129          "httpMethod": "POST",
66130          "parameters": {
66131            "project": {
66132              "description": "Project ID for this request.",
66133              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66134              "location": "path",
66135              "required": true,
66136              "type": "string"
66137            },
66138            "resource": {
66139              "description": "Name or id of the resource for this request.",
66140              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
66141              "location": "path",
66142              "required": true,
66143              "type": "string"
66144            }
66145          },
66146          "parameterOrder": [
66147            "project",
66148            "resource"
66149          ],
66150          "request": {
66151            "$ref": "GlobalSetPolicyRequest"
66152          },
66153          "response": {
66154            "$ref": "Policy"
66155          },
66156          "scopes": [
66157            "https://www.googleapis.com/auth/cloud-platform",
66158            "https://www.googleapis.com/auth/compute"
66159          ],
66160          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
66161        },
66162        "testIamPermissions": {
66163          "id": "compute.machineImages.testIamPermissions",
66164          "path": "projects/{project}/global/machineImages/{resource}/testIamPermissions",
66165          "flatPath": "projects/{project}/global/machineImages/{resource}/testIamPermissions",
66166          "httpMethod": "POST",
66167          "parameters": {
66168            "project": {
66169              "description": "Project ID for this request.",
66170              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66171              "location": "path",
66172              "required": true,
66173              "type": "string"
66174            },
66175            "resource": {
66176              "description": "Name or id of the resource for this request.",
66177              "pattern": "[a-z](?:[-a-z0-9_]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
66178              "location": "path",
66179              "required": true,
66180              "type": "string"
66181            }
66182          },
66183          "parameterOrder": [
66184            "project",
66185            "resource"
66186          ],
66187          "request": {
66188            "$ref": "TestPermissionsRequest"
66189          },
66190          "response": {
66191            "$ref": "TestPermissionsResponse"
66192          },
66193          "scopes": [
66194            "https://www.googleapis.com/auth/cloud-platform",
66195            "https://www.googleapis.com/auth/compute",
66196            "https://www.googleapis.com/auth/compute.readonly"
66197          ],
66198          "description": "Returns permissions that a caller has on the specified resource."
66199        }
66200      }
66201    },
66202    "machineTypes": {
66203      "methods": {
66204        "list": {
66205          "id": "compute.machineTypes.list",
66206          "path": "projects/{project}/zones/{zone}/machineTypes",
66207          "flatPath": "projects/{project}/zones/{zone}/machineTypes",
66208          "httpMethod": "GET",
66209          "parameters": {
66210            "filter": {
66211              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
66212              "location": "query",
66213              "type": "string"
66214            },
66215            "maxResults": {
66216              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
66217              "default": "500",
66218              "minimum": "0",
66219              "location": "query",
66220              "type": "integer",
66221              "format": "uint32"
66222            },
66223            "orderBy": {
66224              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
66225              "location": "query",
66226              "type": "string"
66227            },
66228            "pageToken": {
66229              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
66230              "location": "query",
66231              "type": "string"
66232            },
66233            "project": {
66234              "description": "Project ID for this request.",
66235              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66236              "location": "path",
66237              "required": true,
66238              "type": "string"
66239            },
66240            "returnPartialSuccess": {
66241              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
66242              "location": "query",
66243              "type": "boolean"
66244            },
66245            "zone": {
66246              "description": "The name of the zone for this request.",
66247              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
66248              "location": "path",
66249              "required": true,
66250              "type": "string"
66251            }
66252          },
66253          "parameterOrder": [
66254            "project",
66255            "zone"
66256          ],
66257          "response": {
66258            "$ref": "MachineTypeList"
66259          },
66260          "scopes": [
66261            "https://www.googleapis.com/auth/cloud-platform",
66262            "https://www.googleapis.com/auth/compute",
66263            "https://www.googleapis.com/auth/compute.readonly"
66264          ],
66265          "description": "Retrieves a list of machine types available to the specified project."
66266        },
66267        "aggregatedList": {
66268          "id": "compute.machineTypes.aggregatedList",
66269          "path": "projects/{project}/aggregated/machineTypes",
66270          "flatPath": "projects/{project}/aggregated/machineTypes",
66271          "httpMethod": "GET",
66272          "parameters": {
66273            "filter": {
66274              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
66275              "location": "query",
66276              "type": "string"
66277            },
66278            "includeAllScopes": {
66279              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
66280              "location": "query",
66281              "type": "boolean"
66282            },
66283            "maxResults": {
66284              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
66285              "default": "500",
66286              "minimum": "0",
66287              "location": "query",
66288              "type": "integer",
66289              "format": "uint32"
66290            },
66291            "orderBy": {
66292              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
66293              "location": "query",
66294              "type": "string"
66295            },
66296            "pageToken": {
66297              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
66298              "location": "query",
66299              "type": "string"
66300            },
66301            "project": {
66302              "description": "Project ID for this request.",
66303              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66304              "location": "path",
66305              "required": true,
66306              "type": "string"
66307            },
66308            "returnPartialSuccess": {
66309              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
66310              "location": "query",
66311              "type": "boolean"
66312            },
66313            "serviceProjectNumber": {
66314              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
66315              "location": "query",
66316              "type": "string",
66317              "format": "int64"
66318            }
66319          },
66320          "parameterOrder": [
66321            "project"
66322          ],
66323          "response": {
66324            "$ref": "MachineTypeAggregatedList"
66325          },
66326          "scopes": [
66327            "https://www.googleapis.com/auth/cloud-platform",
66328            "https://www.googleapis.com/auth/compute",
66329            "https://www.googleapis.com/auth/compute.readonly"
66330          ],
66331          "description": "Retrieves an aggregated list of machine types. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
66332        },
66333        "get": {
66334          "id": "compute.machineTypes.get",
66335          "path": "projects/{project}/zones/{zone}/machineTypes/{machineType}",
66336          "flatPath": "projects/{project}/zones/{zone}/machineTypes/{machineType}",
66337          "httpMethod": "GET",
66338          "parameters": {
66339            "machineType": {
66340              "description": "Name of the machine type to return.",
66341              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
66342              "location": "path",
66343              "required": true,
66344              "type": "string"
66345            },
66346            "project": {
66347              "description": "Project ID for this request.",
66348              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66349              "location": "path",
66350              "required": true,
66351              "type": "string"
66352            },
66353            "zone": {
66354              "description": "The name of the zone for this request.",
66355              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
66356              "location": "path",
66357              "required": true,
66358              "type": "string"
66359            }
66360          },
66361          "parameterOrder": [
66362            "project",
66363            "zone",
66364            "machineType"
66365          ],
66366          "response": {
66367            "$ref": "MachineType"
66368          },
66369          "scopes": [
66370            "https://www.googleapis.com/auth/cloud-platform",
66371            "https://www.googleapis.com/auth/compute",
66372            "https://www.googleapis.com/auth/compute.readonly"
66373          ],
66374          "description": "Returns the specified machine type."
66375        }
66376      }
66377    },
66378    "networkAttachments": {
66379      "methods": {
66380        "aggregatedList": {
66381          "id": "compute.networkAttachments.aggregatedList",
66382          "path": "projects/{project}/aggregated/networkAttachments",
66383          "flatPath": "projects/{project}/aggregated/networkAttachments",
66384          "httpMethod": "GET",
66385          "parameters": {
66386            "filter": {
66387              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
66388              "location": "query",
66389              "type": "string"
66390            },
66391            "includeAllScopes": {
66392              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
66393              "location": "query",
66394              "type": "boolean"
66395            },
66396            "maxResults": {
66397              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
66398              "default": "500",
66399              "minimum": "0",
66400              "location": "query",
66401              "type": "integer",
66402              "format": "uint32"
66403            },
66404            "orderBy": {
66405              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
66406              "location": "query",
66407              "type": "string"
66408            },
66409            "pageToken": {
66410              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
66411              "location": "query",
66412              "type": "string"
66413            },
66414            "project": {
66415              "description": "Project ID for this request.",
66416              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66417              "location": "path",
66418              "required": true,
66419              "type": "string"
66420            },
66421            "returnPartialSuccess": {
66422              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
66423              "location": "query",
66424              "type": "boolean"
66425            },
66426            "serviceProjectNumber": {
66427              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
66428              "location": "query",
66429              "type": "string",
66430              "format": "int64"
66431            }
66432          },
66433          "parameterOrder": [
66434            "project"
66435          ],
66436          "response": {
66437            "$ref": "NetworkAttachmentAggregatedList"
66438          },
66439          "scopes": [
66440            "https://www.googleapis.com/auth/cloud-platform",
66441            "https://www.googleapis.com/auth/compute",
66442            "https://www.googleapis.com/auth/compute.readonly"
66443          ],
66444          "description": "Retrieves the list of all NetworkAttachment resources, regional and global, available to the specified project. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
66445        },
66446        "list": {
66447          "id": "compute.networkAttachments.list",
66448          "path": "projects/{project}/regions/{region}/networkAttachments",
66449          "flatPath": "projects/{project}/regions/{region}/networkAttachments",
66450          "httpMethod": "GET",
66451          "parameters": {
66452            "filter": {
66453              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
66454              "location": "query",
66455              "type": "string"
66456            },
66457            "maxResults": {
66458              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
66459              "default": "500",
66460              "minimum": "0",
66461              "location": "query",
66462              "type": "integer",
66463              "format": "uint32"
66464            },
66465            "orderBy": {
66466              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
66467              "location": "query",
66468              "type": "string"
66469            },
66470            "pageToken": {
66471              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
66472              "location": "query",
66473              "type": "string"
66474            },
66475            "project": {
66476              "description": "Project ID for this request.",
66477              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66478              "location": "path",
66479              "required": true,
66480              "type": "string"
66481            },
66482            "region": {
66483              "description": "Name of the region of this request.",
66484              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
66485              "location": "path",
66486              "required": true,
66487              "type": "string"
66488            },
66489            "returnPartialSuccess": {
66490              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
66491              "location": "query",
66492              "type": "boolean"
66493            }
66494          },
66495          "parameterOrder": [
66496            "project",
66497            "region"
66498          ],
66499          "response": {
66500            "$ref": "NetworkAttachmentList"
66501          },
66502          "scopes": [
66503            "https://www.googleapis.com/auth/cloud-platform",
66504            "https://www.googleapis.com/auth/compute",
66505            "https://www.googleapis.com/auth/compute.readonly"
66506          ],
66507          "description": "Lists the NetworkAttachments for a project in the given scope."
66508        },
66509        "get": {
66510          "id": "compute.networkAttachments.get",
66511          "path": "projects/{project}/regions/{region}/networkAttachments/{networkAttachment}",
66512          "flatPath": "projects/{project}/regions/{region}/networkAttachments/{networkAttachment}",
66513          "httpMethod": "GET",
66514          "parameters": {
66515            "networkAttachment": {
66516              "description": "Name of the NetworkAttachment resource to return.",
66517              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
66518              "location": "path",
66519              "required": true,
66520              "type": "string"
66521            },
66522            "project": {
66523              "description": "Project ID for this request.",
66524              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66525              "location": "path",
66526              "required": true,
66527              "type": "string"
66528            },
66529            "region": {
66530              "description": "Name of the region of this request.",
66531              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
66532              "location": "path",
66533              "required": true,
66534              "type": "string"
66535            }
66536          },
66537          "parameterOrder": [
66538            "project",
66539            "region",
66540            "networkAttachment"
66541          ],
66542          "response": {
66543            "$ref": "NetworkAttachment"
66544          },
66545          "scopes": [
66546            "https://www.googleapis.com/auth/cloud-platform",
66547            "https://www.googleapis.com/auth/compute",
66548            "https://www.googleapis.com/auth/compute.readonly"
66549          ],
66550          "description": "Returns the specified NetworkAttachment resource in the given scope."
66551        },
66552        "insert": {
66553          "id": "compute.networkAttachments.insert",
66554          "path": "projects/{project}/regions/{region}/networkAttachments",
66555          "flatPath": "projects/{project}/regions/{region}/networkAttachments",
66556          "httpMethod": "POST",
66557          "parameters": {
66558            "project": {
66559              "description": "Project ID for this request.",
66560              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66561              "location": "path",
66562              "required": true,
66563              "type": "string"
66564            },
66565            "region": {
66566              "description": "Name of the region of this request.",
66567              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
66568              "location": "path",
66569              "required": true,
66570              "type": "string"
66571            },
66572            "requestId": {
66573              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000). end_interface: MixerMutationRequestBuilder",
66574              "location": "query",
66575              "type": "string"
66576            }
66577          },
66578          "parameterOrder": [
66579            "project",
66580            "region"
66581          ],
66582          "request": {
66583            "$ref": "NetworkAttachment"
66584          },
66585          "response": {
66586            "$ref": "Operation"
66587          },
66588          "scopes": [
66589            "https://www.googleapis.com/auth/cloud-platform",
66590            "https://www.googleapis.com/auth/compute"
66591          ],
66592          "description": "Creates a NetworkAttachment in the specified project in the given scope using the parameters that are included in the request."
66593        },
66594        "delete": {
66595          "id": "compute.networkAttachments.delete",
66596          "path": "projects/{project}/regions/{region}/networkAttachments/{networkAttachment}",
66597          "flatPath": "projects/{project}/regions/{region}/networkAttachments/{networkAttachment}",
66598          "httpMethod": "DELETE",
66599          "parameters": {
66600            "networkAttachment": {
66601              "description": "Name of the NetworkAttachment resource to delete.",
66602              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
66603              "location": "path",
66604              "required": true,
66605              "type": "string"
66606            },
66607            "project": {
66608              "description": "Project ID for this request.",
66609              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66610              "location": "path",
66611              "required": true,
66612              "type": "string"
66613            },
66614            "region": {
66615              "description": "Name of the region of this request.",
66616              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
66617              "location": "path",
66618              "required": true,
66619              "type": "string"
66620            },
66621            "requestId": {
66622              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000). end_interface: MixerMutationRequestBuilder",
66623              "location": "query",
66624              "type": "string"
66625            }
66626          },
66627          "parameterOrder": [
66628            "project",
66629            "region",
66630            "networkAttachment"
66631          ],
66632          "response": {
66633            "$ref": "Operation"
66634          },
66635          "scopes": [
66636            "https://www.googleapis.com/auth/cloud-platform",
66637            "https://www.googleapis.com/auth/compute"
66638          ],
66639          "description": "Deletes the specified NetworkAttachment in the given scope"
66640        },
66641        "patch": {
66642          "id": "compute.networkAttachments.patch",
66643          "path": "projects/{project}/regions/{region}/networkAttachments/{networkAttachment}",
66644          "flatPath": "projects/{project}/regions/{region}/networkAttachments/{networkAttachment}",
66645          "httpMethod": "PATCH",
66646          "parameters": {
66647            "networkAttachment": {
66648              "description": "Name of the NetworkAttachment resource to patch.",
66649              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
66650              "location": "path",
66651              "required": true,
66652              "type": "string"
66653            },
66654            "project": {
66655              "description": "Project ID for this request.",
66656              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66657              "location": "path",
66658              "required": true,
66659              "type": "string"
66660            },
66661            "region": {
66662              "description": "Name of the region for this request.",
66663              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
66664              "location": "path",
66665              "required": true,
66666              "type": "string"
66667            },
66668            "requestId": {
66669              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000). end_interface: MixerMutationRequestBuilder",
66670              "location": "query",
66671              "type": "string"
66672            }
66673          },
66674          "parameterOrder": [
66675            "project",
66676            "region",
66677            "networkAttachment"
66678          ],
66679          "request": {
66680            "$ref": "NetworkAttachment"
66681          },
66682          "response": {
66683            "$ref": "Operation"
66684          },
66685          "scopes": [
66686            "https://www.googleapis.com/auth/cloud-platform",
66687            "https://www.googleapis.com/auth/compute"
66688          ],
66689          "description": "Patches the specified NetworkAttachment resource with the data included in the request. This method supports PATCH semantics and uses JSON merge patch format and processing rules."
66690        },
66691        "getIamPolicy": {
66692          "id": "compute.networkAttachments.getIamPolicy",
66693          "path": "projects/{project}/regions/{region}/networkAttachments/{resource}/getIamPolicy",
66694          "flatPath": "projects/{project}/regions/{region}/networkAttachments/{resource}/getIamPolicy",
66695          "httpMethod": "GET",
66696          "parameters": {
66697            "optionsRequestedPolicyVersion": {
66698              "description": "Requested IAM Policy version.",
66699              "location": "query",
66700              "type": "integer",
66701              "format": "int32"
66702            },
66703            "project": {
66704              "description": "Project ID for this request.",
66705              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66706              "location": "path",
66707              "required": true,
66708              "type": "string"
66709            },
66710            "region": {
66711              "description": "The name of the region for this request.",
66712              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
66713              "location": "path",
66714              "required": true,
66715              "type": "string"
66716            },
66717            "resource": {
66718              "description": "Name or id of the resource for this request.",
66719              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
66720              "location": "path",
66721              "required": true,
66722              "type": "string"
66723            }
66724          },
66725          "parameterOrder": [
66726            "project",
66727            "region",
66728            "resource"
66729          ],
66730          "response": {
66731            "$ref": "Policy"
66732          },
66733          "scopes": [
66734            "https://www.googleapis.com/auth/cloud-platform",
66735            "https://www.googleapis.com/auth/compute",
66736            "https://www.googleapis.com/auth/compute.readonly"
66737          ],
66738          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
66739        },
66740        "setIamPolicy": {
66741          "id": "compute.networkAttachments.setIamPolicy",
66742          "path": "projects/{project}/regions/{region}/networkAttachments/{resource}/setIamPolicy",
66743          "flatPath": "projects/{project}/regions/{region}/networkAttachments/{resource}/setIamPolicy",
66744          "httpMethod": "POST",
66745          "parameters": {
66746            "project": {
66747              "description": "Project ID for this request.",
66748              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66749              "location": "path",
66750              "required": true,
66751              "type": "string"
66752            },
66753            "region": {
66754              "description": "The name of the region for this request.",
66755              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
66756              "location": "path",
66757              "required": true,
66758              "type": "string"
66759            },
66760            "resource": {
66761              "description": "Name or id of the resource for this request.",
66762              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
66763              "location": "path",
66764              "required": true,
66765              "type": "string"
66766            }
66767          },
66768          "parameterOrder": [
66769            "project",
66770            "region",
66771            "resource"
66772          ],
66773          "request": {
66774            "$ref": "RegionSetPolicyRequest"
66775          },
66776          "response": {
66777            "$ref": "Policy"
66778          },
66779          "scopes": [
66780            "https://www.googleapis.com/auth/cloud-platform",
66781            "https://www.googleapis.com/auth/compute"
66782          ],
66783          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
66784        },
66785        "testIamPermissions": {
66786          "id": "compute.networkAttachments.testIamPermissions",
66787          "path": "projects/{project}/regions/{region}/networkAttachments/{resource}/testIamPermissions",
66788          "flatPath": "projects/{project}/regions/{region}/networkAttachments/{resource}/testIamPermissions",
66789          "httpMethod": "POST",
66790          "parameters": {
66791            "project": {
66792              "description": "Project ID for this request.",
66793              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66794              "location": "path",
66795              "required": true,
66796              "type": "string"
66797            },
66798            "region": {
66799              "description": "The name of the region for this request.",
66800              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
66801              "location": "path",
66802              "required": true,
66803              "type": "string"
66804            },
66805            "resource": {
66806              "description": "Name or id of the resource for this request.",
66807              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
66808              "location": "path",
66809              "required": true,
66810              "type": "string"
66811            }
66812          },
66813          "parameterOrder": [
66814            "project",
66815            "region",
66816            "resource"
66817          ],
66818          "request": {
66819            "$ref": "TestPermissionsRequest"
66820          },
66821          "response": {
66822            "$ref": "TestPermissionsResponse"
66823          },
66824          "scopes": [
66825            "https://www.googleapis.com/auth/cloud-platform",
66826            "https://www.googleapis.com/auth/compute",
66827            "https://www.googleapis.com/auth/compute.readonly"
66828          ],
66829          "description": "Returns permissions that a caller has on the specified resource."
66830        }
66831      }
66832    },
66833    "networkEdgeSecurityServices": {
66834      "methods": {
66835        "get": {
66836          "id": "compute.networkEdgeSecurityServices.get",
66837          "path": "projects/{project}/regions/{region}/networkEdgeSecurityServices/{networkEdgeSecurityService}",
66838          "flatPath": "projects/{project}/regions/{region}/networkEdgeSecurityServices/{networkEdgeSecurityService}",
66839          "httpMethod": "GET",
66840          "parameters": {
66841            "networkEdgeSecurityService": {
66842              "description": "Name of the network edge security service to get.",
66843              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
66844              "location": "path",
66845              "required": true,
66846              "type": "string"
66847            },
66848            "project": {
66849              "description": "Project ID for this request.",
66850              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66851              "location": "path",
66852              "required": true,
66853              "type": "string"
66854            },
66855            "region": {
66856              "description": "Name of the region scoping this request.",
66857              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
66858              "location": "path",
66859              "required": true,
66860              "type": "string"
66861            }
66862          },
66863          "parameterOrder": [
66864            "project",
66865            "region",
66866            "networkEdgeSecurityService"
66867          ],
66868          "response": {
66869            "$ref": "NetworkEdgeSecurityService"
66870          },
66871          "scopes": [
66872            "https://www.googleapis.com/auth/cloud-platform",
66873            "https://www.googleapis.com/auth/compute",
66874            "https://www.googleapis.com/auth/compute.readonly"
66875          ],
66876          "description": "Gets a specified NetworkEdgeSecurityService."
66877        },
66878        "insert": {
66879          "id": "compute.networkEdgeSecurityServices.insert",
66880          "path": "projects/{project}/regions/{region}/networkEdgeSecurityServices",
66881          "flatPath": "projects/{project}/regions/{region}/networkEdgeSecurityServices",
66882          "httpMethod": "POST",
66883          "parameters": {
66884            "project": {
66885              "description": "Project ID for this request.",
66886              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66887              "location": "path",
66888              "required": true,
66889              "type": "string"
66890            },
66891            "region": {
66892              "description": "Name of the region scoping this request.",
66893              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
66894              "location": "path",
66895              "required": true,
66896              "type": "string"
66897            },
66898            "requestId": {
66899              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
66900              "location": "query",
66901              "type": "string"
66902            },
66903            "validateOnly": {
66904              "description": "If true, the request will not be committed.",
66905              "location": "query",
66906              "type": "boolean"
66907            }
66908          },
66909          "parameterOrder": [
66910            "project",
66911            "region"
66912          ],
66913          "request": {
66914            "$ref": "NetworkEdgeSecurityService"
66915          },
66916          "response": {
66917            "$ref": "Operation"
66918          },
66919          "scopes": [
66920            "https://www.googleapis.com/auth/cloud-platform",
66921            "https://www.googleapis.com/auth/compute"
66922          ],
66923          "description": "Creates a new service in the specified project using the data included in the request."
66924        },
66925        "delete": {
66926          "id": "compute.networkEdgeSecurityServices.delete",
66927          "path": "projects/{project}/regions/{region}/networkEdgeSecurityServices/{networkEdgeSecurityService}",
66928          "flatPath": "projects/{project}/regions/{region}/networkEdgeSecurityServices/{networkEdgeSecurityService}",
66929          "httpMethod": "DELETE",
66930          "parameters": {
66931            "networkEdgeSecurityService": {
66932              "description": "Name of the network edge security service to delete.",
66933              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
66934              "location": "path",
66935              "required": true,
66936              "type": "string"
66937            },
66938            "project": {
66939              "description": "Project ID for this request.",
66940              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66941              "location": "path",
66942              "required": true,
66943              "type": "string"
66944            },
66945            "region": {
66946              "description": "Name of the region scoping this request.",
66947              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
66948              "location": "path",
66949              "required": true,
66950              "type": "string"
66951            },
66952            "requestId": {
66953              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
66954              "location": "query",
66955              "type": "string"
66956            }
66957          },
66958          "parameterOrder": [
66959            "project",
66960            "region",
66961            "networkEdgeSecurityService"
66962          ],
66963          "response": {
66964            "$ref": "Operation"
66965          },
66966          "scopes": [
66967            "https://www.googleapis.com/auth/cloud-platform",
66968            "https://www.googleapis.com/auth/compute"
66969          ],
66970          "description": "Deletes the specified service."
66971        },
66972        "patch": {
66973          "id": "compute.networkEdgeSecurityServices.patch",
66974          "path": "projects/{project}/regions/{region}/networkEdgeSecurityServices/{networkEdgeSecurityService}",
66975          "flatPath": "projects/{project}/regions/{region}/networkEdgeSecurityServices/{networkEdgeSecurityService}",
66976          "httpMethod": "PATCH",
66977          "parameters": {
66978            "networkEdgeSecurityService": {
66979              "description": "Name of the network edge security service to update.",
66980              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
66981              "location": "path",
66982              "required": true,
66983              "type": "string"
66984            },
66985            "paths": {
66986              "location": "query",
66987              "repeated": true,
66988              "type": "string"
66989            },
66990            "project": {
66991              "description": "Project ID for this request.",
66992              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
66993              "location": "path",
66994              "required": true,
66995              "type": "string"
66996            },
66997            "region": {
66998              "description": "Name of the region scoping this request.",
66999              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
67000              "location": "path",
67001              "required": true,
67002              "type": "string"
67003            },
67004            "requestId": {
67005              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
67006              "location": "query",
67007              "type": "string"
67008            },
67009            "updateMask": {
67010              "description": "Indicates fields to be updated as part of this request.",
67011              "location": "query",
67012              "type": "string",
67013              "format": "google-fieldmask"
67014            }
67015          },
67016          "parameterOrder": [
67017            "project",
67018            "region",
67019            "networkEdgeSecurityService"
67020          ],
67021          "request": {
67022            "$ref": "NetworkEdgeSecurityService"
67023          },
67024          "response": {
67025            "$ref": "Operation"
67026          },
67027          "scopes": [
67028            "https://www.googleapis.com/auth/cloud-platform",
67029            "https://www.googleapis.com/auth/compute"
67030          ],
67031          "description": "Patches the specified policy with the data included in the request."
67032        },
67033        "aggregatedList": {
67034          "id": "compute.networkEdgeSecurityServices.aggregatedList",
67035          "path": "projects/{project}/aggregated/networkEdgeSecurityServices",
67036          "flatPath": "projects/{project}/aggregated/networkEdgeSecurityServices",
67037          "httpMethod": "GET",
67038          "parameters": {
67039            "filter": {
67040              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
67041              "location": "query",
67042              "type": "string"
67043            },
67044            "includeAllScopes": {
67045              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
67046              "location": "query",
67047              "type": "boolean"
67048            },
67049            "maxResults": {
67050              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
67051              "default": "500",
67052              "minimum": "0",
67053              "location": "query",
67054              "type": "integer",
67055              "format": "uint32"
67056            },
67057            "orderBy": {
67058              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
67059              "location": "query",
67060              "type": "string"
67061            },
67062            "pageToken": {
67063              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
67064              "location": "query",
67065              "type": "string"
67066            },
67067            "project": {
67068              "description": "Name of the project scoping this request.",
67069              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67070              "location": "path",
67071              "required": true,
67072              "type": "string"
67073            },
67074            "returnPartialSuccess": {
67075              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
67076              "location": "query",
67077              "type": "boolean"
67078            },
67079            "serviceProjectNumber": {
67080              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
67081              "location": "query",
67082              "type": "string",
67083              "format": "int64"
67084            }
67085          },
67086          "parameterOrder": [
67087            "project"
67088          ],
67089          "response": {
67090            "$ref": "NetworkEdgeSecurityServiceAggregatedList"
67091          },
67092          "scopes": [
67093            "https://www.googleapis.com/auth/cloud-platform",
67094            "https://www.googleapis.com/auth/compute",
67095            "https://www.googleapis.com/auth/compute.readonly"
67096          ],
67097          "description": "Retrieves the list of all NetworkEdgeSecurityService resources available to the specified project. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
67098        }
67099      }
67100    },
67101    "networkEndpointGroups": {
67102      "methods": {
67103        "list": {
67104          "id": "compute.networkEndpointGroups.list",
67105          "path": "projects/{project}/zones/{zone}/networkEndpointGroups",
67106          "flatPath": "projects/{project}/zones/{zone}/networkEndpointGroups",
67107          "httpMethod": "GET",
67108          "parameters": {
67109            "filter": {
67110              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
67111              "location": "query",
67112              "type": "string"
67113            },
67114            "maxResults": {
67115              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
67116              "default": "500",
67117              "minimum": "0",
67118              "location": "query",
67119              "type": "integer",
67120              "format": "uint32"
67121            },
67122            "orderBy": {
67123              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
67124              "location": "query",
67125              "type": "string"
67126            },
67127            "pageToken": {
67128              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
67129              "location": "query",
67130              "type": "string"
67131            },
67132            "project": {
67133              "description": "Project ID for this request.",
67134              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67135              "location": "path",
67136              "required": true,
67137              "type": "string"
67138            },
67139            "returnPartialSuccess": {
67140              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
67141              "location": "query",
67142              "type": "boolean"
67143            },
67144            "zone": {
67145              "description": "The name of the zone where the network endpoint group is located. It should comply with RFC1035.",
67146              "location": "path",
67147              "required": true,
67148              "type": "string"
67149            }
67150          },
67151          "parameterOrder": [
67152            "project",
67153            "zone"
67154          ],
67155          "response": {
67156            "$ref": "NetworkEndpointGroupList"
67157          },
67158          "scopes": [
67159            "https://www.googleapis.com/auth/cloud-platform",
67160            "https://www.googleapis.com/auth/compute",
67161            "https://www.googleapis.com/auth/compute.readonly"
67162          ],
67163          "description": "Retrieves the list of network endpoint groups that are located in the specified project and zone."
67164        },
67165        "aggregatedList": {
67166          "id": "compute.networkEndpointGroups.aggregatedList",
67167          "path": "projects/{project}/aggregated/networkEndpointGroups",
67168          "flatPath": "projects/{project}/aggregated/networkEndpointGroups",
67169          "httpMethod": "GET",
67170          "parameters": {
67171            "filter": {
67172              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
67173              "location": "query",
67174              "type": "string"
67175            },
67176            "includeAllScopes": {
67177              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
67178              "location": "query",
67179              "type": "boolean"
67180            },
67181            "maxResults": {
67182              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
67183              "default": "500",
67184              "minimum": "0",
67185              "location": "query",
67186              "type": "integer",
67187              "format": "uint32"
67188            },
67189            "orderBy": {
67190              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
67191              "location": "query",
67192              "type": "string"
67193            },
67194            "pageToken": {
67195              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
67196              "location": "query",
67197              "type": "string"
67198            },
67199            "project": {
67200              "description": "Project ID for this request.",
67201              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67202              "location": "path",
67203              "required": true,
67204              "type": "string"
67205            },
67206            "returnPartialSuccess": {
67207              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
67208              "location": "query",
67209              "type": "boolean"
67210            },
67211            "serviceProjectNumber": {
67212              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
67213              "location": "query",
67214              "type": "string",
67215              "format": "int64"
67216            }
67217          },
67218          "parameterOrder": [
67219            "project"
67220          ],
67221          "response": {
67222            "$ref": "NetworkEndpointGroupAggregatedList"
67223          },
67224          "scopes": [
67225            "https://www.googleapis.com/auth/cloud-platform",
67226            "https://www.googleapis.com/auth/compute",
67227            "https://www.googleapis.com/auth/compute.readonly"
67228          ],
67229          "description": "Retrieves the list of network endpoint groups and sorts them by zone. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
67230        },
67231        "get": {
67232          "id": "compute.networkEndpointGroups.get",
67233          "path": "projects/{project}/zones/{zone}/networkEndpointGroups/{networkEndpointGroup}",
67234          "flatPath": "projects/{project}/zones/{zone}/networkEndpointGroups/{networkEndpointGroup}",
67235          "httpMethod": "GET",
67236          "parameters": {
67237            "networkEndpointGroup": {
67238              "description": "The name of the network endpoint group. It should comply with RFC1035.",
67239              "location": "path",
67240              "required": true,
67241              "type": "string"
67242            },
67243            "project": {
67244              "description": "Project ID for this request.",
67245              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67246              "location": "path",
67247              "required": true,
67248              "type": "string"
67249            },
67250            "zone": {
67251              "description": "The name of the zone where the network endpoint group is located. It should comply with RFC1035.",
67252              "location": "path",
67253              "required": true,
67254              "type": "string"
67255            }
67256          },
67257          "parameterOrder": [
67258            "project",
67259            "zone",
67260            "networkEndpointGroup"
67261          ],
67262          "response": {
67263            "$ref": "NetworkEndpointGroup"
67264          },
67265          "scopes": [
67266            "https://www.googleapis.com/auth/cloud-platform",
67267            "https://www.googleapis.com/auth/compute",
67268            "https://www.googleapis.com/auth/compute.readonly"
67269          ],
67270          "description": "Returns the specified network endpoint group."
67271        },
67272        "insert": {
67273          "id": "compute.networkEndpointGroups.insert",
67274          "path": "projects/{project}/zones/{zone}/networkEndpointGroups",
67275          "flatPath": "projects/{project}/zones/{zone}/networkEndpointGroups",
67276          "httpMethod": "POST",
67277          "parameters": {
67278            "project": {
67279              "description": "Project ID for this request.",
67280              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67281              "location": "path",
67282              "required": true,
67283              "type": "string"
67284            },
67285            "requestId": {
67286              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
67287              "location": "query",
67288              "type": "string"
67289            },
67290            "zone": {
67291              "description": "The name of the zone where you want to create the network endpoint group. It should comply with RFC1035.",
67292              "location": "path",
67293              "required": true,
67294              "type": "string"
67295            }
67296          },
67297          "parameterOrder": [
67298            "project",
67299            "zone"
67300          ],
67301          "request": {
67302            "$ref": "NetworkEndpointGroup"
67303          },
67304          "response": {
67305            "$ref": "Operation"
67306          },
67307          "scopes": [
67308            "https://www.googleapis.com/auth/cloud-platform",
67309            "https://www.googleapis.com/auth/compute"
67310          ],
67311          "description": "Creates a network endpoint group in the specified project using the parameters that are included in the request."
67312        },
67313        "delete": {
67314          "id": "compute.networkEndpointGroups.delete",
67315          "path": "projects/{project}/zones/{zone}/networkEndpointGroups/{networkEndpointGroup}",
67316          "flatPath": "projects/{project}/zones/{zone}/networkEndpointGroups/{networkEndpointGroup}",
67317          "httpMethod": "DELETE",
67318          "parameters": {
67319            "networkEndpointGroup": {
67320              "description": "The name of the network endpoint group to delete. It should comply with RFC1035.",
67321              "location": "path",
67322              "required": true,
67323              "type": "string"
67324            },
67325            "project": {
67326              "description": "Project ID for this request.",
67327              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67328              "location": "path",
67329              "required": true,
67330              "type": "string"
67331            },
67332            "requestId": {
67333              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
67334              "location": "query",
67335              "type": "string"
67336            },
67337            "zone": {
67338              "description": "The name of the zone where the network endpoint group is located. It should comply with RFC1035.",
67339              "location": "path",
67340              "required": true,
67341              "type": "string"
67342            }
67343          },
67344          "parameterOrder": [
67345            "project",
67346            "zone",
67347            "networkEndpointGroup"
67348          ],
67349          "response": {
67350            "$ref": "Operation"
67351          },
67352          "scopes": [
67353            "https://www.googleapis.com/auth/cloud-platform",
67354            "https://www.googleapis.com/auth/compute"
67355          ],
67356          "description": "Deletes the specified network endpoint group. The network endpoints in the NEG and the VM instances they belong to are not terminated when the NEG is deleted. Note that the NEG cannot be deleted if there are backend services referencing it."
67357        },
67358        "attachNetworkEndpoints": {
67359          "id": "compute.networkEndpointGroups.attachNetworkEndpoints",
67360          "path": "projects/{project}/zones/{zone}/networkEndpointGroups/{networkEndpointGroup}/attachNetworkEndpoints",
67361          "flatPath": "projects/{project}/zones/{zone}/networkEndpointGroups/{networkEndpointGroup}/attachNetworkEndpoints",
67362          "httpMethod": "POST",
67363          "parameters": {
67364            "networkEndpointGroup": {
67365              "description": "The name of the network endpoint group where you are attaching network endpoints to. It should comply with RFC1035.",
67366              "location": "path",
67367              "required": true,
67368              "type": "string"
67369            },
67370            "project": {
67371              "description": "Project ID for this request.",
67372              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67373              "location": "path",
67374              "required": true,
67375              "type": "string"
67376            },
67377            "requestId": {
67378              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
67379              "location": "query",
67380              "type": "string"
67381            },
67382            "zone": {
67383              "description": "The name of the zone where the network endpoint group is located. It should comply with RFC1035.",
67384              "location": "path",
67385              "required": true,
67386              "type": "string"
67387            }
67388          },
67389          "parameterOrder": [
67390            "project",
67391            "zone",
67392            "networkEndpointGroup"
67393          ],
67394          "request": {
67395            "$ref": "NetworkEndpointGroupsAttachEndpointsRequest"
67396          },
67397          "response": {
67398            "$ref": "Operation"
67399          },
67400          "scopes": [
67401            "https://www.googleapis.com/auth/cloud-platform",
67402            "https://www.googleapis.com/auth/compute"
67403          ],
67404          "description": "Attach a list of network endpoints to the specified network endpoint group."
67405        },
67406        "detachNetworkEndpoints": {
67407          "id": "compute.networkEndpointGroups.detachNetworkEndpoints",
67408          "path": "projects/{project}/zones/{zone}/networkEndpointGroups/{networkEndpointGroup}/detachNetworkEndpoints",
67409          "flatPath": "projects/{project}/zones/{zone}/networkEndpointGroups/{networkEndpointGroup}/detachNetworkEndpoints",
67410          "httpMethod": "POST",
67411          "parameters": {
67412            "networkEndpointGroup": {
67413              "description": "The name of the network endpoint group where you are removing network endpoints. It should comply with RFC1035.",
67414              "location": "path",
67415              "required": true,
67416              "type": "string"
67417            },
67418            "project": {
67419              "description": "Project ID for this request.",
67420              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67421              "location": "path",
67422              "required": true,
67423              "type": "string"
67424            },
67425            "requestId": {
67426              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
67427              "location": "query",
67428              "type": "string"
67429            },
67430            "zone": {
67431              "description": "The name of the zone where the network endpoint group is located. It should comply with RFC1035.",
67432              "location": "path",
67433              "required": true,
67434              "type": "string"
67435            }
67436          },
67437          "parameterOrder": [
67438            "project",
67439            "zone",
67440            "networkEndpointGroup"
67441          ],
67442          "request": {
67443            "$ref": "NetworkEndpointGroupsDetachEndpointsRequest"
67444          },
67445          "response": {
67446            "$ref": "Operation"
67447          },
67448          "scopes": [
67449            "https://www.googleapis.com/auth/cloud-platform",
67450            "https://www.googleapis.com/auth/compute"
67451          ],
67452          "description": "Detach a list of network endpoints from the specified network endpoint group."
67453        },
67454        "listNetworkEndpoints": {
67455          "id": "compute.networkEndpointGroups.listNetworkEndpoints",
67456          "path": "projects/{project}/zones/{zone}/networkEndpointGroups/{networkEndpointGroup}/listNetworkEndpoints",
67457          "flatPath": "projects/{project}/zones/{zone}/networkEndpointGroups/{networkEndpointGroup}/listNetworkEndpoints",
67458          "httpMethod": "POST",
67459          "parameters": {
67460            "filter": {
67461              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
67462              "location": "query",
67463              "type": "string"
67464            },
67465            "maxResults": {
67466              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
67467              "default": "500",
67468              "minimum": "0",
67469              "location": "query",
67470              "type": "integer",
67471              "format": "uint32"
67472            },
67473            "networkEndpointGroup": {
67474              "description": "The name of the network endpoint group from which you want to generate a list of included network endpoints. It should comply with RFC1035.",
67475              "location": "path",
67476              "required": true,
67477              "type": "string"
67478            },
67479            "orderBy": {
67480              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
67481              "location": "query",
67482              "type": "string"
67483            },
67484            "pageToken": {
67485              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
67486              "location": "query",
67487              "type": "string"
67488            },
67489            "project": {
67490              "description": "Project ID for this request.",
67491              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67492              "location": "path",
67493              "required": true,
67494              "type": "string"
67495            },
67496            "returnPartialSuccess": {
67497              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
67498              "location": "query",
67499              "type": "boolean"
67500            },
67501            "zone": {
67502              "description": "The name of the zone where the network endpoint group is located. It should comply with RFC1035.",
67503              "location": "path",
67504              "required": true,
67505              "type": "string"
67506            }
67507          },
67508          "parameterOrder": [
67509            "project",
67510            "zone",
67511            "networkEndpointGroup"
67512          ],
67513          "request": {
67514            "$ref": "NetworkEndpointGroupsListEndpointsRequest"
67515          },
67516          "response": {
67517            "$ref": "NetworkEndpointGroupsListNetworkEndpoints"
67518          },
67519          "scopes": [
67520            "https://www.googleapis.com/auth/cloud-platform",
67521            "https://www.googleapis.com/auth/compute",
67522            "https://www.googleapis.com/auth/compute.readonly"
67523          ],
67524          "description": "Lists the network endpoints in the specified network endpoint group."
67525        },
67526        "testIamPermissions": {
67527          "id": "compute.networkEndpointGroups.testIamPermissions",
67528          "path": "projects/{project}/zones/{zone}/networkEndpointGroups/{resource}/testIamPermissions",
67529          "flatPath": "projects/{project}/zones/{zone}/networkEndpointGroups/{resource}/testIamPermissions",
67530          "httpMethod": "POST",
67531          "parameters": {
67532            "project": {
67533              "description": "Project ID for this request.",
67534              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67535              "location": "path",
67536              "required": true,
67537              "type": "string"
67538            },
67539            "resource": {
67540              "description": "Name or id of the resource for this request.",
67541              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
67542              "location": "path",
67543              "required": true,
67544              "type": "string"
67545            },
67546            "zone": {
67547              "description": "The name of the zone for this request.",
67548              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
67549              "location": "path",
67550              "required": true,
67551              "type": "string"
67552            }
67553          },
67554          "parameterOrder": [
67555            "project",
67556            "zone",
67557            "resource"
67558          ],
67559          "request": {
67560            "$ref": "TestPermissionsRequest"
67561          },
67562          "response": {
67563            "$ref": "TestPermissionsResponse"
67564          },
67565          "scopes": [
67566            "https://www.googleapis.com/auth/cloud-platform",
67567            "https://www.googleapis.com/auth/compute",
67568            "https://www.googleapis.com/auth/compute.readonly"
67569          ],
67570          "description": "Returns permissions that a caller has on the specified resource."
67571        }
67572      }
67573    },
67574    "globalNetworkEndpointGroups": {
67575      "methods": {
67576        "list": {
67577          "id": "compute.globalNetworkEndpointGroups.list",
67578          "path": "projects/{project}/global/networkEndpointGroups",
67579          "flatPath": "projects/{project}/global/networkEndpointGroups",
67580          "httpMethod": "GET",
67581          "parameters": {
67582            "filter": {
67583              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
67584              "location": "query",
67585              "type": "string"
67586            },
67587            "maxResults": {
67588              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
67589              "default": "500",
67590              "minimum": "0",
67591              "location": "query",
67592              "type": "integer",
67593              "format": "uint32"
67594            },
67595            "orderBy": {
67596              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
67597              "location": "query",
67598              "type": "string"
67599            },
67600            "pageToken": {
67601              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
67602              "location": "query",
67603              "type": "string"
67604            },
67605            "project": {
67606              "description": "Project ID for this request.",
67607              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67608              "location": "path",
67609              "required": true,
67610              "type": "string"
67611            },
67612            "returnPartialSuccess": {
67613              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
67614              "location": "query",
67615              "type": "boolean"
67616            }
67617          },
67618          "parameterOrder": [
67619            "project"
67620          ],
67621          "response": {
67622            "$ref": "NetworkEndpointGroupList"
67623          },
67624          "scopes": [
67625            "https://www.googleapis.com/auth/cloud-platform",
67626            "https://www.googleapis.com/auth/compute",
67627            "https://www.googleapis.com/auth/compute.readonly"
67628          ],
67629          "description": "Retrieves the list of network endpoint groups that are located in the specified project."
67630        },
67631        "get": {
67632          "id": "compute.globalNetworkEndpointGroups.get",
67633          "path": "projects/{project}/global/networkEndpointGroups/{networkEndpointGroup}",
67634          "flatPath": "projects/{project}/global/networkEndpointGroups/{networkEndpointGroup}",
67635          "httpMethod": "GET",
67636          "parameters": {
67637            "networkEndpointGroup": {
67638              "description": "The name of the network endpoint group. It should comply with RFC1035.",
67639              "location": "path",
67640              "required": true,
67641              "type": "string"
67642            },
67643            "project": {
67644              "description": "Project ID for this request.",
67645              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67646              "location": "path",
67647              "required": true,
67648              "type": "string"
67649            }
67650          },
67651          "parameterOrder": [
67652            "project",
67653            "networkEndpointGroup"
67654          ],
67655          "response": {
67656            "$ref": "NetworkEndpointGroup"
67657          },
67658          "scopes": [
67659            "https://www.googleapis.com/auth/cloud-platform",
67660            "https://www.googleapis.com/auth/compute",
67661            "https://www.googleapis.com/auth/compute.readonly"
67662          ],
67663          "description": "Returns the specified network endpoint group."
67664        },
67665        "insert": {
67666          "id": "compute.globalNetworkEndpointGroups.insert",
67667          "path": "projects/{project}/global/networkEndpointGroups",
67668          "flatPath": "projects/{project}/global/networkEndpointGroups",
67669          "httpMethod": "POST",
67670          "parameters": {
67671            "project": {
67672              "description": "Project ID for this request.",
67673              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67674              "location": "path",
67675              "required": true,
67676              "type": "string"
67677            },
67678            "requestId": {
67679              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
67680              "location": "query",
67681              "type": "string"
67682            }
67683          },
67684          "parameterOrder": [
67685            "project"
67686          ],
67687          "request": {
67688            "$ref": "NetworkEndpointGroup"
67689          },
67690          "response": {
67691            "$ref": "Operation"
67692          },
67693          "scopes": [
67694            "https://www.googleapis.com/auth/cloud-platform",
67695            "https://www.googleapis.com/auth/compute"
67696          ],
67697          "description": "Creates a network endpoint group in the specified project using the parameters that are included in the request."
67698        },
67699        "delete": {
67700          "id": "compute.globalNetworkEndpointGroups.delete",
67701          "path": "projects/{project}/global/networkEndpointGroups/{networkEndpointGroup}",
67702          "flatPath": "projects/{project}/global/networkEndpointGroups/{networkEndpointGroup}",
67703          "httpMethod": "DELETE",
67704          "parameters": {
67705            "networkEndpointGroup": {
67706              "description": "The name of the network endpoint group to delete. It should comply with RFC1035.",
67707              "location": "path",
67708              "required": true,
67709              "type": "string"
67710            },
67711            "project": {
67712              "description": "Project ID for this request.",
67713              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67714              "location": "path",
67715              "required": true,
67716              "type": "string"
67717            },
67718            "requestId": {
67719              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
67720              "location": "query",
67721              "type": "string"
67722            }
67723          },
67724          "parameterOrder": [
67725            "project",
67726            "networkEndpointGroup"
67727          ],
67728          "response": {
67729            "$ref": "Operation"
67730          },
67731          "scopes": [
67732            "https://www.googleapis.com/auth/cloud-platform",
67733            "https://www.googleapis.com/auth/compute"
67734          ],
67735          "description": "Deletes the specified network endpoint group.Note that the NEG cannot be deleted if there are backend services referencing it."
67736        },
67737        "attachNetworkEndpoints": {
67738          "id": "compute.globalNetworkEndpointGroups.attachNetworkEndpoints",
67739          "path": "projects/{project}/global/networkEndpointGroups/{networkEndpointGroup}/attachNetworkEndpoints",
67740          "flatPath": "projects/{project}/global/networkEndpointGroups/{networkEndpointGroup}/attachNetworkEndpoints",
67741          "httpMethod": "POST",
67742          "parameters": {
67743            "networkEndpointGroup": {
67744              "description": "The name of the network endpoint group where you are attaching network endpoints to. It should comply with RFC1035.",
67745              "location": "path",
67746              "required": true,
67747              "type": "string"
67748            },
67749            "project": {
67750              "description": "Project ID for this request.",
67751              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67752              "location": "path",
67753              "required": true,
67754              "type": "string"
67755            },
67756            "requestId": {
67757              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
67758              "location": "query",
67759              "type": "string"
67760            }
67761          },
67762          "parameterOrder": [
67763            "project",
67764            "networkEndpointGroup"
67765          ],
67766          "request": {
67767            "$ref": "GlobalNetworkEndpointGroupsAttachEndpointsRequest"
67768          },
67769          "response": {
67770            "$ref": "Operation"
67771          },
67772          "scopes": [
67773            "https://www.googleapis.com/auth/cloud-platform",
67774            "https://www.googleapis.com/auth/compute"
67775          ],
67776          "description": "Attach a network endpoint to the specified network endpoint group."
67777        },
67778        "detachNetworkEndpoints": {
67779          "id": "compute.globalNetworkEndpointGroups.detachNetworkEndpoints",
67780          "path": "projects/{project}/global/networkEndpointGroups/{networkEndpointGroup}/detachNetworkEndpoints",
67781          "flatPath": "projects/{project}/global/networkEndpointGroups/{networkEndpointGroup}/detachNetworkEndpoints",
67782          "httpMethod": "POST",
67783          "parameters": {
67784            "networkEndpointGroup": {
67785              "description": "The name of the network endpoint group where you are removing network endpoints. It should comply with RFC1035.",
67786              "location": "path",
67787              "required": true,
67788              "type": "string"
67789            },
67790            "project": {
67791              "description": "Project ID for this request.",
67792              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67793              "location": "path",
67794              "required": true,
67795              "type": "string"
67796            },
67797            "requestId": {
67798              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
67799              "location": "query",
67800              "type": "string"
67801            }
67802          },
67803          "parameterOrder": [
67804            "project",
67805            "networkEndpointGroup"
67806          ],
67807          "request": {
67808            "$ref": "GlobalNetworkEndpointGroupsDetachEndpointsRequest"
67809          },
67810          "response": {
67811            "$ref": "Operation"
67812          },
67813          "scopes": [
67814            "https://www.googleapis.com/auth/cloud-platform",
67815            "https://www.googleapis.com/auth/compute"
67816          ],
67817          "description": "Detach the network endpoint from the specified network endpoint group."
67818        },
67819        "listNetworkEndpoints": {
67820          "id": "compute.globalNetworkEndpointGroups.listNetworkEndpoints",
67821          "path": "projects/{project}/global/networkEndpointGroups/{networkEndpointGroup}/listNetworkEndpoints",
67822          "flatPath": "projects/{project}/global/networkEndpointGroups/{networkEndpointGroup}/listNetworkEndpoints",
67823          "httpMethod": "POST",
67824          "parameters": {
67825            "filter": {
67826              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
67827              "location": "query",
67828              "type": "string"
67829            },
67830            "maxResults": {
67831              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
67832              "default": "500",
67833              "minimum": "0",
67834              "location": "query",
67835              "type": "integer",
67836              "format": "uint32"
67837            },
67838            "networkEndpointGroup": {
67839              "description": "The name of the network endpoint group from which you want to generate a list of included network endpoints. It should comply with RFC1035.",
67840              "location": "path",
67841              "required": true,
67842              "type": "string"
67843            },
67844            "orderBy": {
67845              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
67846              "location": "query",
67847              "type": "string"
67848            },
67849            "pageToken": {
67850              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
67851              "location": "query",
67852              "type": "string"
67853            },
67854            "project": {
67855              "description": "Project ID for this request.",
67856              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67857              "location": "path",
67858              "required": true,
67859              "type": "string"
67860            },
67861            "returnPartialSuccess": {
67862              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
67863              "location": "query",
67864              "type": "boolean"
67865            }
67866          },
67867          "parameterOrder": [
67868            "project",
67869            "networkEndpointGroup"
67870          ],
67871          "response": {
67872            "$ref": "NetworkEndpointGroupsListNetworkEndpoints"
67873          },
67874          "scopes": [
67875            "https://www.googleapis.com/auth/cloud-platform",
67876            "https://www.googleapis.com/auth/compute",
67877            "https://www.googleapis.com/auth/compute.readonly"
67878          ],
67879          "description": "Lists the network endpoints in the specified network endpoint group."
67880        }
67881      }
67882    },
67883    "regionNetworkEndpointGroups": {
67884      "methods": {
67885        "list": {
67886          "id": "compute.regionNetworkEndpointGroups.list",
67887          "path": "projects/{project}/regions/{region}/networkEndpointGroups",
67888          "flatPath": "projects/{project}/regions/{region}/networkEndpointGroups",
67889          "httpMethod": "GET",
67890          "parameters": {
67891            "filter": {
67892              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
67893              "location": "query",
67894              "type": "string"
67895            },
67896            "maxResults": {
67897              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
67898              "default": "500",
67899              "minimum": "0",
67900              "location": "query",
67901              "type": "integer",
67902              "format": "uint32"
67903            },
67904            "orderBy": {
67905              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
67906              "location": "query",
67907              "type": "string"
67908            },
67909            "pageToken": {
67910              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
67911              "location": "query",
67912              "type": "string"
67913            },
67914            "project": {
67915              "description": "Project ID for this request.",
67916              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67917              "location": "path",
67918              "required": true,
67919              "type": "string"
67920            },
67921            "region": {
67922              "description": "The name of the region where the network endpoint group is located. It should comply with RFC1035.",
67923              "location": "path",
67924              "required": true,
67925              "type": "string"
67926            },
67927            "returnPartialSuccess": {
67928              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
67929              "location": "query",
67930              "type": "boolean"
67931            }
67932          },
67933          "parameterOrder": [
67934            "project",
67935            "region"
67936          ],
67937          "response": {
67938            "$ref": "NetworkEndpointGroupList"
67939          },
67940          "scopes": [
67941            "https://www.googleapis.com/auth/cloud-platform",
67942            "https://www.googleapis.com/auth/compute",
67943            "https://www.googleapis.com/auth/compute.readonly"
67944          ],
67945          "description": "Retrieves the list of regional network endpoint groups available to the specified project in the given region."
67946        },
67947        "get": {
67948          "id": "compute.regionNetworkEndpointGroups.get",
67949          "path": "projects/{project}/regions/{region}/networkEndpointGroups/{networkEndpointGroup}",
67950          "flatPath": "projects/{project}/regions/{region}/networkEndpointGroups/{networkEndpointGroup}",
67951          "httpMethod": "GET",
67952          "parameters": {
67953            "networkEndpointGroup": {
67954              "description": "The name of the network endpoint group. It should comply with RFC1035.",
67955              "location": "path",
67956              "required": true,
67957              "type": "string"
67958            },
67959            "project": {
67960              "description": "Project ID for this request.",
67961              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67962              "location": "path",
67963              "required": true,
67964              "type": "string"
67965            },
67966            "region": {
67967              "description": "The name of the region where the network endpoint group is located. It should comply with RFC1035.",
67968              "location": "path",
67969              "required": true,
67970              "type": "string"
67971            }
67972          },
67973          "parameterOrder": [
67974            "project",
67975            "region",
67976            "networkEndpointGroup"
67977          ],
67978          "response": {
67979            "$ref": "NetworkEndpointGroup"
67980          },
67981          "scopes": [
67982            "https://www.googleapis.com/auth/cloud-platform",
67983            "https://www.googleapis.com/auth/compute",
67984            "https://www.googleapis.com/auth/compute.readonly"
67985          ],
67986          "description": "Returns the specified network endpoint group."
67987        },
67988        "insert": {
67989          "id": "compute.regionNetworkEndpointGroups.insert",
67990          "path": "projects/{project}/regions/{region}/networkEndpointGroups",
67991          "flatPath": "projects/{project}/regions/{region}/networkEndpointGroups",
67992          "httpMethod": "POST",
67993          "parameters": {
67994            "project": {
67995              "description": "Project ID for this request.",
67996              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
67997              "location": "path",
67998              "required": true,
67999              "type": "string"
68000            },
68001            "region": {
68002              "description": "The name of the region where you want to create the network endpoint group. It should comply with RFC1035.",
68003              "location": "path",
68004              "required": true,
68005              "type": "string"
68006            },
68007            "requestId": {
68008              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
68009              "location": "query",
68010              "type": "string"
68011            }
68012          },
68013          "parameterOrder": [
68014            "project",
68015            "region"
68016          ],
68017          "request": {
68018            "$ref": "NetworkEndpointGroup"
68019          },
68020          "response": {
68021            "$ref": "Operation"
68022          },
68023          "scopes": [
68024            "https://www.googleapis.com/auth/cloud-platform",
68025            "https://www.googleapis.com/auth/compute"
68026          ],
68027          "description": "Creates a network endpoint group in the specified project using the parameters that are included in the request."
68028        },
68029        "delete": {
68030          "id": "compute.regionNetworkEndpointGroups.delete",
68031          "path": "projects/{project}/regions/{region}/networkEndpointGroups/{networkEndpointGroup}",
68032          "flatPath": "projects/{project}/regions/{region}/networkEndpointGroups/{networkEndpointGroup}",
68033          "httpMethod": "DELETE",
68034          "parameters": {
68035            "networkEndpointGroup": {
68036              "description": "The name of the network endpoint group to delete. It should comply with RFC1035.",
68037              "location": "path",
68038              "required": true,
68039              "type": "string"
68040            },
68041            "project": {
68042              "description": "Project ID for this request.",
68043              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68044              "location": "path",
68045              "required": true,
68046              "type": "string"
68047            },
68048            "region": {
68049              "description": "The name of the region where the network endpoint group is located. It should comply with RFC1035.",
68050              "location": "path",
68051              "required": true,
68052              "type": "string"
68053            },
68054            "requestId": {
68055              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
68056              "location": "query",
68057              "type": "string"
68058            }
68059          },
68060          "parameterOrder": [
68061            "project",
68062            "region",
68063            "networkEndpointGroup"
68064          ],
68065          "response": {
68066            "$ref": "Operation"
68067          },
68068          "scopes": [
68069            "https://www.googleapis.com/auth/cloud-platform",
68070            "https://www.googleapis.com/auth/compute"
68071          ],
68072          "description": "Deletes the specified network endpoint group. Note that the NEG cannot be deleted if it is configured as a backend of a backend service."
68073        },
68074        "attachNetworkEndpoints": {
68075          "id": "compute.regionNetworkEndpointGroups.attachNetworkEndpoints",
68076          "path": "projects/{project}/regions/{region}/networkEndpointGroups/{networkEndpointGroup}/attachNetworkEndpoints",
68077          "flatPath": "projects/{project}/regions/{region}/networkEndpointGroups/{networkEndpointGroup}/attachNetworkEndpoints",
68078          "httpMethod": "POST",
68079          "parameters": {
68080            "networkEndpointGroup": {
68081              "description": "The name of the network endpoint group where you are attaching network endpoints to. It should comply with RFC1035.",
68082              "location": "path",
68083              "required": true,
68084              "type": "string"
68085            },
68086            "project": {
68087              "description": "Project ID for this request.",
68088              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68089              "location": "path",
68090              "required": true,
68091              "type": "string"
68092            },
68093            "region": {
68094              "description": "The name of the region where you want to create the network endpoint group. It should comply with RFC1035.",
68095              "location": "path",
68096              "required": true,
68097              "type": "string"
68098            },
68099            "requestId": {
68100              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
68101              "location": "query",
68102              "type": "string"
68103            }
68104          },
68105          "parameterOrder": [
68106            "project",
68107            "region",
68108            "networkEndpointGroup"
68109          ],
68110          "request": {
68111            "$ref": "RegionNetworkEndpointGroupsAttachEndpointsRequest"
68112          },
68113          "response": {
68114            "$ref": "Operation"
68115          },
68116          "scopes": [
68117            "https://www.googleapis.com/auth/cloud-platform",
68118            "https://www.googleapis.com/auth/compute"
68119          ],
68120          "description": "Attach a list of network endpoints to the specified network endpoint group."
68121        },
68122        "detachNetworkEndpoints": {
68123          "id": "compute.regionNetworkEndpointGroups.detachNetworkEndpoints",
68124          "path": "projects/{project}/regions/{region}/networkEndpointGroups/{networkEndpointGroup}/detachNetworkEndpoints",
68125          "flatPath": "projects/{project}/regions/{region}/networkEndpointGroups/{networkEndpointGroup}/detachNetworkEndpoints",
68126          "httpMethod": "POST",
68127          "parameters": {
68128            "networkEndpointGroup": {
68129              "description": "The name of the network endpoint group you are detaching network endpoints from. It should comply with RFC1035.",
68130              "location": "path",
68131              "required": true,
68132              "type": "string"
68133            },
68134            "project": {
68135              "description": "Project ID for this request.",
68136              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68137              "location": "path",
68138              "required": true,
68139              "type": "string"
68140            },
68141            "region": {
68142              "description": "The name of the region where the network endpoint group is located. It should comply with RFC1035.",
68143              "location": "path",
68144              "required": true,
68145              "type": "string"
68146            },
68147            "requestId": {
68148              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000). end_interface: MixerMutationRequestBuilder",
68149              "location": "query",
68150              "type": "string"
68151            }
68152          },
68153          "parameterOrder": [
68154            "project",
68155            "region",
68156            "networkEndpointGroup"
68157          ],
68158          "request": {
68159            "$ref": "RegionNetworkEndpointGroupsDetachEndpointsRequest"
68160          },
68161          "response": {
68162            "$ref": "Operation"
68163          },
68164          "scopes": [
68165            "https://www.googleapis.com/auth/cloud-platform",
68166            "https://www.googleapis.com/auth/compute"
68167          ],
68168          "description": "Detach the network endpoint from the specified network endpoint group."
68169        },
68170        "listNetworkEndpoints": {
68171          "id": "compute.regionNetworkEndpointGroups.listNetworkEndpoints",
68172          "path": "projects/{project}/regions/{region}/networkEndpointGroups/{networkEndpointGroup}/listNetworkEndpoints",
68173          "flatPath": "projects/{project}/regions/{region}/networkEndpointGroups/{networkEndpointGroup}/listNetworkEndpoints",
68174          "httpMethod": "POST",
68175          "parameters": {
68176            "filter": {
68177              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
68178              "location": "query",
68179              "type": "string"
68180            },
68181            "maxResults": {
68182              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
68183              "default": "500",
68184              "minimum": "0",
68185              "location": "query",
68186              "type": "integer",
68187              "format": "uint32"
68188            },
68189            "networkEndpointGroup": {
68190              "description": "The name of the network endpoint group from which you want to generate a list of included network endpoints. It should comply with RFC1035.",
68191              "location": "path",
68192              "required": true,
68193              "type": "string"
68194            },
68195            "orderBy": {
68196              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
68197              "location": "query",
68198              "type": "string"
68199            },
68200            "pageToken": {
68201              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
68202              "location": "query",
68203              "type": "string"
68204            },
68205            "project": {
68206              "description": "Project ID for this request.",
68207              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68208              "location": "path",
68209              "required": true,
68210              "type": "string"
68211            },
68212            "region": {
68213              "description": "The name of the region where the network endpoint group is located. It should comply with RFC1035.",
68214              "location": "path",
68215              "required": true,
68216              "type": "string"
68217            },
68218            "returnPartialSuccess": {
68219              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
68220              "location": "query",
68221              "type": "boolean"
68222            }
68223          },
68224          "parameterOrder": [
68225            "project",
68226            "region",
68227            "networkEndpointGroup"
68228          ],
68229          "response": {
68230            "$ref": "NetworkEndpointGroupsListNetworkEndpoints"
68231          },
68232          "scopes": [
68233            "https://www.googleapis.com/auth/cloud-platform",
68234            "https://www.googleapis.com/auth/compute",
68235            "https://www.googleapis.com/auth/compute.readonly"
68236          ],
68237          "description": "Lists the network endpoints in the specified network endpoint group."
68238        }
68239      }
68240    },
68241    "networks": {
68242      "methods": {
68243        "list": {
68244          "id": "compute.networks.list",
68245          "path": "projects/{project}/global/networks",
68246          "flatPath": "projects/{project}/global/networks",
68247          "httpMethod": "GET",
68248          "parameters": {
68249            "filter": {
68250              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
68251              "location": "query",
68252              "type": "string"
68253            },
68254            "maxResults": {
68255              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
68256              "default": "500",
68257              "minimum": "0",
68258              "location": "query",
68259              "type": "integer",
68260              "format": "uint32"
68261            },
68262            "orderBy": {
68263              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
68264              "location": "query",
68265              "type": "string"
68266            },
68267            "pageToken": {
68268              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
68269              "location": "query",
68270              "type": "string"
68271            },
68272            "project": {
68273              "description": "Project ID for this request.",
68274              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68275              "location": "path",
68276              "required": true,
68277              "type": "string"
68278            },
68279            "returnPartialSuccess": {
68280              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
68281              "location": "query",
68282              "type": "boolean"
68283            }
68284          },
68285          "parameterOrder": [
68286            "project"
68287          ],
68288          "response": {
68289            "$ref": "NetworkList"
68290          },
68291          "scopes": [
68292            "https://www.googleapis.com/auth/cloud-platform",
68293            "https://www.googleapis.com/auth/compute",
68294            "https://www.googleapis.com/auth/compute.readonly"
68295          ],
68296          "description": "Retrieves the list of networks available to the specified project."
68297        },
68298        "get": {
68299          "id": "compute.networks.get",
68300          "path": "projects/{project}/global/networks/{network}",
68301          "flatPath": "projects/{project}/global/networks/{network}",
68302          "httpMethod": "GET",
68303          "parameters": {
68304            "network": {
68305              "description": "Name of the network to return.",
68306              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
68307              "location": "path",
68308              "required": true,
68309              "type": "string"
68310            },
68311            "project": {
68312              "description": "Project ID for this request.",
68313              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68314              "location": "path",
68315              "required": true,
68316              "type": "string"
68317            }
68318          },
68319          "parameterOrder": [
68320            "project",
68321            "network"
68322          ],
68323          "response": {
68324            "$ref": "Network"
68325          },
68326          "scopes": [
68327            "https://www.googleapis.com/auth/cloud-platform",
68328            "https://www.googleapis.com/auth/compute",
68329            "https://www.googleapis.com/auth/compute.readonly"
68330          ],
68331          "description": "Returns the specified network."
68332        },
68333        "insert": {
68334          "id": "compute.networks.insert",
68335          "path": "projects/{project}/global/networks",
68336          "flatPath": "projects/{project}/global/networks",
68337          "httpMethod": "POST",
68338          "parameters": {
68339            "project": {
68340              "description": "Project ID for this request.",
68341              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68342              "location": "path",
68343              "required": true,
68344              "type": "string"
68345            },
68346            "requestId": {
68347              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
68348              "location": "query",
68349              "type": "string"
68350            }
68351          },
68352          "parameterOrder": [
68353            "project"
68354          ],
68355          "request": {
68356            "$ref": "Network"
68357          },
68358          "response": {
68359            "$ref": "Operation"
68360          },
68361          "scopes": [
68362            "https://www.googleapis.com/auth/cloud-platform",
68363            "https://www.googleapis.com/auth/compute"
68364          ],
68365          "description": "Creates a network in the specified project using the data included in the request."
68366        },
68367        "delete": {
68368          "id": "compute.networks.delete",
68369          "path": "projects/{project}/global/networks/{network}",
68370          "flatPath": "projects/{project}/global/networks/{network}",
68371          "httpMethod": "DELETE",
68372          "parameters": {
68373            "network": {
68374              "description": "Name of the network to delete.",
68375              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
68376              "location": "path",
68377              "required": true,
68378              "type": "string"
68379            },
68380            "project": {
68381              "description": "Project ID for this request.",
68382              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68383              "location": "path",
68384              "required": true,
68385              "type": "string"
68386            },
68387            "requestId": {
68388              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
68389              "location": "query",
68390              "type": "string"
68391            }
68392          },
68393          "parameterOrder": [
68394            "project",
68395            "network"
68396          ],
68397          "response": {
68398            "$ref": "Operation"
68399          },
68400          "scopes": [
68401            "https://www.googleapis.com/auth/cloud-platform",
68402            "https://www.googleapis.com/auth/compute"
68403          ],
68404          "description": "Deletes the specified network."
68405        },
68406        "patch": {
68407          "id": "compute.networks.patch",
68408          "path": "projects/{project}/global/networks/{network}",
68409          "flatPath": "projects/{project}/global/networks/{network}",
68410          "httpMethod": "PATCH",
68411          "parameters": {
68412            "network": {
68413              "description": "Name of the network to update.",
68414              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
68415              "location": "path",
68416              "required": true,
68417              "type": "string"
68418            },
68419            "project": {
68420              "description": "Project ID for this request.",
68421              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68422              "location": "path",
68423              "required": true,
68424              "type": "string"
68425            },
68426            "requestId": {
68427              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
68428              "location": "query",
68429              "type": "string"
68430            }
68431          },
68432          "parameterOrder": [
68433            "project",
68434            "network"
68435          ],
68436          "request": {
68437            "$ref": "Network"
68438          },
68439          "response": {
68440            "$ref": "Operation"
68441          },
68442          "scopes": [
68443            "https://www.googleapis.com/auth/cloud-platform",
68444            "https://www.googleapis.com/auth/compute"
68445          ],
68446          "description": "Patches the specified network with the data included in the request. Only the following fields can be modified: routingConfig.routingMode."
68447        },
68448        "updatePeering": {
68449          "id": "compute.networks.updatePeering",
68450          "path": "projects/{project}/global/networks/{network}/updatePeering",
68451          "flatPath": "projects/{project}/global/networks/{network}/updatePeering",
68452          "httpMethod": "PATCH",
68453          "parameters": {
68454            "network": {
68455              "description": "Name of the network resource which the updated peering is belonging to.",
68456              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
68457              "location": "path",
68458              "required": true,
68459              "type": "string"
68460            },
68461            "project": {
68462              "description": "Project ID for this request.",
68463              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68464              "location": "path",
68465              "required": true,
68466              "type": "string"
68467            },
68468            "requestId": {
68469              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
68470              "location": "query",
68471              "type": "string"
68472            }
68473          },
68474          "parameterOrder": [
68475            "project",
68476            "network"
68477          ],
68478          "request": {
68479            "$ref": "NetworksUpdatePeeringRequest"
68480          },
68481          "response": {
68482            "$ref": "Operation"
68483          },
68484          "scopes": [
68485            "https://www.googleapis.com/auth/cloud-platform",
68486            "https://www.googleapis.com/auth/compute"
68487          ],
68488          "description": "Updates the specified network peering with the data included in the request. You can only modify the NetworkPeering.export_custom_routes field and the NetworkPeering.import_custom_routes field."
68489        },
68490        "addPeering": {
68491          "id": "compute.networks.addPeering",
68492          "path": "projects/{project}/global/networks/{network}/addPeering",
68493          "flatPath": "projects/{project}/global/networks/{network}/addPeering",
68494          "httpMethod": "POST",
68495          "parameters": {
68496            "network": {
68497              "description": "Name of the network resource to add peering to.",
68498              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
68499              "location": "path",
68500              "required": true,
68501              "type": "string"
68502            },
68503            "project": {
68504              "description": "Project ID for this request.",
68505              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68506              "location": "path",
68507              "required": true,
68508              "type": "string"
68509            },
68510            "requestId": {
68511              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
68512              "location": "query",
68513              "type": "string"
68514            }
68515          },
68516          "parameterOrder": [
68517            "project",
68518            "network"
68519          ],
68520          "request": {
68521            "$ref": "NetworksAddPeeringRequest"
68522          },
68523          "response": {
68524            "$ref": "Operation"
68525          },
68526          "scopes": [
68527            "https://www.googleapis.com/auth/cloud-platform",
68528            "https://www.googleapis.com/auth/compute"
68529          ],
68530          "description": "Adds a peering to the specified network."
68531        },
68532        "removePeering": {
68533          "id": "compute.networks.removePeering",
68534          "path": "projects/{project}/global/networks/{network}/removePeering",
68535          "flatPath": "projects/{project}/global/networks/{network}/removePeering",
68536          "httpMethod": "POST",
68537          "parameters": {
68538            "network": {
68539              "description": "Name of the network resource to remove peering from.",
68540              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
68541              "location": "path",
68542              "required": true,
68543              "type": "string"
68544            },
68545            "project": {
68546              "description": "Project ID for this request.",
68547              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68548              "location": "path",
68549              "required": true,
68550              "type": "string"
68551            },
68552            "requestId": {
68553              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
68554              "location": "query",
68555              "type": "string"
68556            }
68557          },
68558          "parameterOrder": [
68559            "project",
68560            "network"
68561          ],
68562          "request": {
68563            "$ref": "NetworksRemovePeeringRequest"
68564          },
68565          "response": {
68566            "$ref": "Operation"
68567          },
68568          "scopes": [
68569            "https://www.googleapis.com/auth/cloud-platform",
68570            "https://www.googleapis.com/auth/compute"
68571          ],
68572          "description": "Removes a peering from the specified network."
68573        },
68574        "switchToCustomMode": {
68575          "id": "compute.networks.switchToCustomMode",
68576          "path": "projects/{project}/global/networks/{network}/switchToCustomMode",
68577          "flatPath": "projects/{project}/global/networks/{network}/switchToCustomMode",
68578          "httpMethod": "POST",
68579          "parameters": {
68580            "network": {
68581              "description": "Name of the network to be updated.",
68582              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
68583              "location": "path",
68584              "required": true,
68585              "type": "string"
68586            },
68587            "project": {
68588              "description": "Project ID for this request.",
68589              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68590              "location": "path",
68591              "required": true,
68592              "type": "string"
68593            },
68594            "requestId": {
68595              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
68596              "location": "query",
68597              "type": "string"
68598            }
68599          },
68600          "parameterOrder": [
68601            "project",
68602            "network"
68603          ],
68604          "response": {
68605            "$ref": "Operation"
68606          },
68607          "scopes": [
68608            "https://www.googleapis.com/auth/cloud-platform",
68609            "https://www.googleapis.com/auth/compute"
68610          ],
68611          "description": "Switches the network mode from auto subnet mode to custom subnet mode."
68612        },
68613        "getEffectiveFirewalls": {
68614          "id": "compute.networks.getEffectiveFirewalls",
68615          "path": "projects/{project}/global/networks/{network}/getEffectiveFirewalls",
68616          "flatPath": "projects/{project}/global/networks/{network}/getEffectiveFirewalls",
68617          "httpMethod": "GET",
68618          "parameters": {
68619            "network": {
68620              "description": "Name of the network for this request.",
68621              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
68622              "location": "path",
68623              "required": true,
68624              "type": "string"
68625            },
68626            "project": {
68627              "description": "Project ID for this request.",
68628              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68629              "location": "path",
68630              "required": true,
68631              "type": "string"
68632            }
68633          },
68634          "parameterOrder": [
68635            "project",
68636            "network"
68637          ],
68638          "response": {
68639            "$ref": "NetworksGetEffectiveFirewallsResponse"
68640          },
68641          "scopes": [
68642            "https://www.googleapis.com/auth/cloud-platform",
68643            "https://www.googleapis.com/auth/compute",
68644            "https://www.googleapis.com/auth/compute.readonly"
68645          ],
68646          "description": "Returns the effective firewalls on a given network."
68647        },
68648        "listPeeringRoutes": {
68649          "id": "compute.networks.listPeeringRoutes",
68650          "path": "projects/{project}/global/networks/{network}/listPeeringRoutes",
68651          "flatPath": "projects/{project}/global/networks/{network}/listPeeringRoutes",
68652          "httpMethod": "GET",
68653          "parameters": {
68654            "direction": {
68655              "description": "The direction of the exchanged routes.",
68656              "location": "query",
68657              "type": "string",
68658              "enumDescriptions": [
68659                "For routes exported from peer network.",
68660                "For routes exported from local network."
68661              ],
68662              "enum": [
68663                "INCOMING",
68664                "OUTGOING"
68665              ]
68666            },
68667            "filter": {
68668              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
68669              "location": "query",
68670              "type": "string"
68671            },
68672            "maxResults": {
68673              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
68674              "default": "500",
68675              "minimum": "0",
68676              "location": "query",
68677              "type": "integer",
68678              "format": "uint32"
68679            },
68680            "network": {
68681              "description": "Name of the network for this request.",
68682              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
68683              "location": "path",
68684              "required": true,
68685              "type": "string"
68686            },
68687            "orderBy": {
68688              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
68689              "location": "query",
68690              "type": "string"
68691            },
68692            "pageToken": {
68693              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
68694              "location": "query",
68695              "type": "string"
68696            },
68697            "peeringName": {
68698              "description": "The response will show routes exchanged over the given peering connection.",
68699              "location": "query",
68700              "type": "string"
68701            },
68702            "project": {
68703              "description": "Project ID for this request.",
68704              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68705              "location": "path",
68706              "required": true,
68707              "type": "string"
68708            },
68709            "region": {
68710              "description": "The region of the request. The response will include all subnet routes, static routes and dynamic routes in the region.",
68711              "location": "query",
68712              "type": "string"
68713            },
68714            "returnPartialSuccess": {
68715              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
68716              "location": "query",
68717              "type": "boolean"
68718            }
68719          },
68720          "parameterOrder": [
68721            "project",
68722            "network"
68723          ],
68724          "response": {
68725            "$ref": "ExchangedPeeringRoutesList"
68726          },
68727          "scopes": [
68728            "https://www.googleapis.com/auth/cloud-platform",
68729            "https://www.googleapis.com/auth/compute",
68730            "https://www.googleapis.com/auth/compute.readonly"
68731          ],
68732          "description": "Lists the peering routes exchanged over peering connection."
68733        }
68734      }
68735    },
68736    "nodeGroups": {
68737      "methods": {
68738        "list": {
68739          "id": "compute.nodeGroups.list",
68740          "path": "projects/{project}/zones/{zone}/nodeGroups",
68741          "flatPath": "projects/{project}/zones/{zone}/nodeGroups",
68742          "httpMethod": "GET",
68743          "parameters": {
68744            "filter": {
68745              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
68746              "location": "query",
68747              "type": "string"
68748            },
68749            "maxResults": {
68750              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
68751              "default": "500",
68752              "minimum": "0",
68753              "location": "query",
68754              "type": "integer",
68755              "format": "uint32"
68756            },
68757            "orderBy": {
68758              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
68759              "location": "query",
68760              "type": "string"
68761            },
68762            "pageToken": {
68763              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
68764              "location": "query",
68765              "type": "string"
68766            },
68767            "project": {
68768              "description": "Project ID for this request.",
68769              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68770              "location": "path",
68771              "required": true,
68772              "type": "string"
68773            },
68774            "returnPartialSuccess": {
68775              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
68776              "location": "query",
68777              "type": "boolean"
68778            },
68779            "zone": {
68780              "description": "The name of the zone for this request.",
68781              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
68782              "location": "path",
68783              "required": true,
68784              "type": "string"
68785            }
68786          },
68787          "parameterOrder": [
68788            "project",
68789            "zone"
68790          ],
68791          "response": {
68792            "$ref": "NodeGroupList"
68793          },
68794          "scopes": [
68795            "https://www.googleapis.com/auth/cloud-platform",
68796            "https://www.googleapis.com/auth/compute",
68797            "https://www.googleapis.com/auth/compute.readonly"
68798          ],
68799          "description": "Retrieves a list of node groups available to the specified project. Note: use nodeGroups.listNodes for more details about each group."
68800        },
68801        "aggregatedList": {
68802          "id": "compute.nodeGroups.aggregatedList",
68803          "path": "projects/{project}/aggregated/nodeGroups",
68804          "flatPath": "projects/{project}/aggregated/nodeGroups",
68805          "httpMethod": "GET",
68806          "parameters": {
68807            "filter": {
68808              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
68809              "location": "query",
68810              "type": "string"
68811            },
68812            "includeAllScopes": {
68813              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
68814              "location": "query",
68815              "type": "boolean"
68816            },
68817            "maxResults": {
68818              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
68819              "default": "500",
68820              "minimum": "0",
68821              "location": "query",
68822              "type": "integer",
68823              "format": "uint32"
68824            },
68825            "orderBy": {
68826              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
68827              "location": "query",
68828              "type": "string"
68829            },
68830            "pageToken": {
68831              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
68832              "location": "query",
68833              "type": "string"
68834            },
68835            "project": {
68836              "description": "Project ID for this request.",
68837              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68838              "location": "path",
68839              "required": true,
68840              "type": "string"
68841            },
68842            "returnPartialSuccess": {
68843              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
68844              "location": "query",
68845              "type": "boolean"
68846            },
68847            "serviceProjectNumber": {
68848              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
68849              "location": "query",
68850              "type": "string",
68851              "format": "int64"
68852            }
68853          },
68854          "parameterOrder": [
68855            "project"
68856          ],
68857          "response": {
68858            "$ref": "NodeGroupAggregatedList"
68859          },
68860          "scopes": [
68861            "https://www.googleapis.com/auth/cloud-platform",
68862            "https://www.googleapis.com/auth/compute",
68863            "https://www.googleapis.com/auth/compute.readonly"
68864          ],
68865          "description": "Retrieves an aggregated list of node groups. Note: use nodeGroups.listNodes for more details about each group. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
68866        },
68867        "get": {
68868          "id": "compute.nodeGroups.get",
68869          "path": "projects/{project}/zones/{zone}/nodeGroups/{nodeGroup}",
68870          "flatPath": "projects/{project}/zones/{zone}/nodeGroups/{nodeGroup}",
68871          "httpMethod": "GET",
68872          "parameters": {
68873            "nodeGroup": {
68874              "description": "Name of the node group to return.",
68875              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
68876              "location": "path",
68877              "required": true,
68878              "type": "string"
68879            },
68880            "project": {
68881              "description": "Project ID for this request.",
68882              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68883              "location": "path",
68884              "required": true,
68885              "type": "string"
68886            },
68887            "zone": {
68888              "description": "The name of the zone for this request.",
68889              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
68890              "location": "path",
68891              "required": true,
68892              "type": "string"
68893            }
68894          },
68895          "parameterOrder": [
68896            "project",
68897            "zone",
68898            "nodeGroup"
68899          ],
68900          "response": {
68901            "$ref": "NodeGroup"
68902          },
68903          "scopes": [
68904            "https://www.googleapis.com/auth/cloud-platform",
68905            "https://www.googleapis.com/auth/compute",
68906            "https://www.googleapis.com/auth/compute.readonly"
68907          ],
68908          "description": "Returns the specified NodeGroup. Get a list of available NodeGroups by making a list() request. Note: the \"nodes\" field should not be used. Use nodeGroups.listNodes instead."
68909        },
68910        "insert": {
68911          "id": "compute.nodeGroups.insert",
68912          "path": "projects/{project}/zones/{zone}/nodeGroups",
68913          "flatPath": "projects/{project}/zones/{zone}/nodeGroups",
68914          "httpMethod": "POST",
68915          "parameters": {
68916            "initialNodeCount": {
68917              "description": "Initial count of nodes in the node group.",
68918              "location": "query",
68919              "required": true,
68920              "type": "integer",
68921              "format": "int32"
68922            },
68923            "project": {
68924              "description": "Project ID for this request.",
68925              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68926              "location": "path",
68927              "required": true,
68928              "type": "string"
68929            },
68930            "requestId": {
68931              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
68932              "location": "query",
68933              "type": "string"
68934            },
68935            "zone": {
68936              "description": "The name of the zone for this request.",
68937              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
68938              "location": "path",
68939              "required": true,
68940              "type": "string"
68941            }
68942          },
68943          "parameterOrder": [
68944            "project",
68945            "zone",
68946            "initialNodeCount"
68947          ],
68948          "request": {
68949            "$ref": "NodeGroup"
68950          },
68951          "response": {
68952            "$ref": "Operation"
68953          },
68954          "scopes": [
68955            "https://www.googleapis.com/auth/cloud-platform",
68956            "https://www.googleapis.com/auth/compute"
68957          ],
68958          "description": "Creates a NodeGroup resource in the specified project using the data included in the request."
68959        },
68960        "delete": {
68961          "id": "compute.nodeGroups.delete",
68962          "path": "projects/{project}/zones/{zone}/nodeGroups/{nodeGroup}",
68963          "flatPath": "projects/{project}/zones/{zone}/nodeGroups/{nodeGroup}",
68964          "httpMethod": "DELETE",
68965          "parameters": {
68966            "nodeGroup": {
68967              "description": "Name of the NodeGroup resource to delete.",
68968              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
68969              "location": "path",
68970              "required": true,
68971              "type": "string"
68972            },
68973            "project": {
68974              "description": "Project ID for this request.",
68975              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
68976              "location": "path",
68977              "required": true,
68978              "type": "string"
68979            },
68980            "requestId": {
68981              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
68982              "location": "query",
68983              "type": "string"
68984            },
68985            "zone": {
68986              "description": "The name of the zone for this request.",
68987              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
68988              "location": "path",
68989              "required": true,
68990              "type": "string"
68991            }
68992          },
68993          "parameterOrder": [
68994            "project",
68995            "zone",
68996            "nodeGroup"
68997          ],
68998          "response": {
68999            "$ref": "Operation"
69000          },
69001          "scopes": [
69002            "https://www.googleapis.com/auth/cloud-platform",
69003            "https://www.googleapis.com/auth/compute"
69004          ],
69005          "description": "Deletes the specified NodeGroup resource."
69006        },
69007        "addNodes": {
69008          "id": "compute.nodeGroups.addNodes",
69009          "path": "projects/{project}/zones/{zone}/nodeGroups/{nodeGroup}/addNodes",
69010          "flatPath": "projects/{project}/zones/{zone}/nodeGroups/{nodeGroup}/addNodes",
69011          "httpMethod": "POST",
69012          "parameters": {
69013            "nodeGroup": {
69014              "description": "Name of the NodeGroup resource.",
69015              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
69016              "location": "path",
69017              "required": true,
69018              "type": "string"
69019            },
69020            "project": {
69021              "description": "Project ID for this request.",
69022              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69023              "location": "path",
69024              "required": true,
69025              "type": "string"
69026            },
69027            "requestId": {
69028              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
69029              "location": "query",
69030              "type": "string"
69031            },
69032            "zone": {
69033              "description": "The name of the zone for this request.",
69034              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69035              "location": "path",
69036              "required": true,
69037              "type": "string"
69038            }
69039          },
69040          "parameterOrder": [
69041            "project",
69042            "zone",
69043            "nodeGroup"
69044          ],
69045          "request": {
69046            "$ref": "NodeGroupsAddNodesRequest"
69047          },
69048          "response": {
69049            "$ref": "Operation"
69050          },
69051          "scopes": [
69052            "https://www.googleapis.com/auth/cloud-platform",
69053            "https://www.googleapis.com/auth/compute"
69054          ],
69055          "description": "Adds specified number of nodes to the node group."
69056        },
69057        "deleteNodes": {
69058          "id": "compute.nodeGroups.deleteNodes",
69059          "path": "projects/{project}/zones/{zone}/nodeGroups/{nodeGroup}/deleteNodes",
69060          "flatPath": "projects/{project}/zones/{zone}/nodeGroups/{nodeGroup}/deleteNodes",
69061          "httpMethod": "POST",
69062          "parameters": {
69063            "nodeGroup": {
69064              "description": "Name of the NodeGroup resource whose nodes will be deleted.",
69065              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
69066              "location": "path",
69067              "required": true,
69068              "type": "string"
69069            },
69070            "project": {
69071              "description": "Project ID for this request.",
69072              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69073              "location": "path",
69074              "required": true,
69075              "type": "string"
69076            },
69077            "requestId": {
69078              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
69079              "location": "query",
69080              "type": "string"
69081            },
69082            "zone": {
69083              "description": "The name of the zone for this request.",
69084              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69085              "location": "path",
69086              "required": true,
69087              "type": "string"
69088            }
69089          },
69090          "parameterOrder": [
69091            "project",
69092            "zone",
69093            "nodeGroup"
69094          ],
69095          "request": {
69096            "$ref": "NodeGroupsDeleteNodesRequest"
69097          },
69098          "response": {
69099            "$ref": "Operation"
69100          },
69101          "scopes": [
69102            "https://www.googleapis.com/auth/cloud-platform",
69103            "https://www.googleapis.com/auth/compute"
69104          ],
69105          "description": "Deletes specified nodes from the node group."
69106        },
69107        "listNodes": {
69108          "id": "compute.nodeGroups.listNodes",
69109          "path": "projects/{project}/zones/{zone}/nodeGroups/{nodeGroup}/listNodes",
69110          "flatPath": "projects/{project}/zones/{zone}/nodeGroups/{nodeGroup}/listNodes",
69111          "httpMethod": "POST",
69112          "parameters": {
69113            "filter": {
69114              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
69115              "location": "query",
69116              "type": "string"
69117            },
69118            "maxResults": {
69119              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
69120              "default": "500",
69121              "minimum": "0",
69122              "location": "query",
69123              "type": "integer",
69124              "format": "uint32"
69125            },
69126            "nodeGroup": {
69127              "description": "Name of the NodeGroup resource whose nodes you want to list.",
69128              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
69129              "location": "path",
69130              "required": true,
69131              "type": "string"
69132            },
69133            "orderBy": {
69134              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
69135              "location": "query",
69136              "type": "string"
69137            },
69138            "pageToken": {
69139              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
69140              "location": "query",
69141              "type": "string"
69142            },
69143            "project": {
69144              "description": "Project ID for this request.",
69145              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69146              "location": "path",
69147              "required": true,
69148              "type": "string"
69149            },
69150            "returnPartialSuccess": {
69151              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
69152              "location": "query",
69153              "type": "boolean"
69154            },
69155            "zone": {
69156              "description": "The name of the zone for this request.",
69157              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69158              "location": "path",
69159              "required": true,
69160              "type": "string"
69161            }
69162          },
69163          "parameterOrder": [
69164            "project",
69165            "zone",
69166            "nodeGroup"
69167          ],
69168          "response": {
69169            "$ref": "NodeGroupsListNodes"
69170          },
69171          "scopes": [
69172            "https://www.googleapis.com/auth/cloud-platform",
69173            "https://www.googleapis.com/auth/compute",
69174            "https://www.googleapis.com/auth/compute.readonly"
69175          ],
69176          "description": "Lists nodes in the node group."
69177        },
69178        "setNodeTemplate": {
69179          "id": "compute.nodeGroups.setNodeTemplate",
69180          "path": "projects/{project}/zones/{zone}/nodeGroups/{nodeGroup}/setNodeTemplate",
69181          "flatPath": "projects/{project}/zones/{zone}/nodeGroups/{nodeGroup}/setNodeTemplate",
69182          "httpMethod": "POST",
69183          "parameters": {
69184            "nodeGroup": {
69185              "description": "Name of the NodeGroup resource to update.",
69186              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
69187              "location": "path",
69188              "required": true,
69189              "type": "string"
69190            },
69191            "project": {
69192              "description": "Project ID for this request.",
69193              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69194              "location": "path",
69195              "required": true,
69196              "type": "string"
69197            },
69198            "requestId": {
69199              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
69200              "location": "query",
69201              "type": "string"
69202            },
69203            "zone": {
69204              "description": "The name of the zone for this request.",
69205              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69206              "location": "path",
69207              "required": true,
69208              "type": "string"
69209            }
69210          },
69211          "parameterOrder": [
69212            "project",
69213            "zone",
69214            "nodeGroup"
69215          ],
69216          "request": {
69217            "$ref": "NodeGroupsSetNodeTemplateRequest"
69218          },
69219          "response": {
69220            "$ref": "Operation"
69221          },
69222          "scopes": [
69223            "https://www.googleapis.com/auth/cloud-platform",
69224            "https://www.googleapis.com/auth/compute"
69225          ],
69226          "description": "Updates the node template of the node group."
69227        },
69228        "patch": {
69229          "id": "compute.nodeGroups.patch",
69230          "path": "projects/{project}/zones/{zone}/nodeGroups/{nodeGroup}",
69231          "flatPath": "projects/{project}/zones/{zone}/nodeGroups/{nodeGroup}",
69232          "httpMethod": "PATCH",
69233          "parameters": {
69234            "nodeGroup": {
69235              "description": "Name of the NodeGroup resource to update.",
69236              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
69237              "location": "path",
69238              "required": true,
69239              "type": "string"
69240            },
69241            "project": {
69242              "description": "Project ID for this request.",
69243              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69244              "location": "path",
69245              "required": true,
69246              "type": "string"
69247            },
69248            "requestId": {
69249              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
69250              "location": "query",
69251              "type": "string"
69252            },
69253            "zone": {
69254              "description": "The name of the zone for this request.",
69255              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69256              "location": "path",
69257              "required": true,
69258              "type": "string"
69259            }
69260          },
69261          "parameterOrder": [
69262            "project",
69263            "zone",
69264            "nodeGroup"
69265          ],
69266          "request": {
69267            "$ref": "NodeGroup"
69268          },
69269          "response": {
69270            "$ref": "Operation"
69271          },
69272          "scopes": [
69273            "https://www.googleapis.com/auth/cloud-platform",
69274            "https://www.googleapis.com/auth/compute"
69275          ],
69276          "description": "Updates the specified node group."
69277        },
69278        "simulateMaintenanceEvent": {
69279          "id": "compute.nodeGroups.simulateMaintenanceEvent",
69280          "path": "projects/{project}/zones/{zone}/nodeGroups/{nodeGroup}/simulateMaintenanceEvent",
69281          "flatPath": "projects/{project}/zones/{zone}/nodeGroups/{nodeGroup}/simulateMaintenanceEvent",
69282          "httpMethod": "POST",
69283          "parameters": {
69284            "nodeGroup": {
69285              "description": "Name of the NodeGroup resource whose nodes will go under maintenance simulation.",
69286              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
69287              "location": "path",
69288              "required": true,
69289              "type": "string"
69290            },
69291            "project": {
69292              "description": "Project ID for this request.",
69293              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69294              "location": "path",
69295              "required": true,
69296              "type": "string"
69297            },
69298            "requestId": {
69299              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
69300              "location": "query",
69301              "type": "string"
69302            },
69303            "zone": {
69304              "description": "The name of the zone for this request.",
69305              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69306              "location": "path",
69307              "required": true,
69308              "type": "string"
69309            }
69310          },
69311          "parameterOrder": [
69312            "project",
69313            "zone",
69314            "nodeGroup"
69315          ],
69316          "request": {
69317            "$ref": "NodeGroupsSimulateMaintenanceEventRequest"
69318          },
69319          "response": {
69320            "$ref": "Operation"
69321          },
69322          "scopes": [
69323            "https://www.googleapis.com/auth/cloud-platform",
69324            "https://www.googleapis.com/auth/compute"
69325          ],
69326          "description": "Simulates maintenance event on specified nodes from the node group."
69327        },
69328        "getIamPolicy": {
69329          "id": "compute.nodeGroups.getIamPolicy",
69330          "path": "projects/{project}/zones/{zone}/nodeGroups/{resource}/getIamPolicy",
69331          "flatPath": "projects/{project}/zones/{zone}/nodeGroups/{resource}/getIamPolicy",
69332          "httpMethod": "GET",
69333          "parameters": {
69334            "optionsRequestedPolicyVersion": {
69335              "description": "Requested IAM Policy version.",
69336              "location": "query",
69337              "type": "integer",
69338              "format": "int32"
69339            },
69340            "project": {
69341              "description": "Project ID for this request.",
69342              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69343              "location": "path",
69344              "required": true,
69345              "type": "string"
69346            },
69347            "resource": {
69348              "description": "Name or id of the resource for this request.",
69349              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
69350              "location": "path",
69351              "required": true,
69352              "type": "string"
69353            },
69354            "zone": {
69355              "description": "The name of the zone for this request.",
69356              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69357              "location": "path",
69358              "required": true,
69359              "type": "string"
69360            }
69361          },
69362          "parameterOrder": [
69363            "project",
69364            "zone",
69365            "resource"
69366          ],
69367          "response": {
69368            "$ref": "Policy"
69369          },
69370          "scopes": [
69371            "https://www.googleapis.com/auth/cloud-platform",
69372            "https://www.googleapis.com/auth/compute",
69373            "https://www.googleapis.com/auth/compute.readonly"
69374          ],
69375          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
69376        },
69377        "setIamPolicy": {
69378          "id": "compute.nodeGroups.setIamPolicy",
69379          "path": "projects/{project}/zones/{zone}/nodeGroups/{resource}/setIamPolicy",
69380          "flatPath": "projects/{project}/zones/{zone}/nodeGroups/{resource}/setIamPolicy",
69381          "httpMethod": "POST",
69382          "parameters": {
69383            "project": {
69384              "description": "Project ID for this request.",
69385              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69386              "location": "path",
69387              "required": true,
69388              "type": "string"
69389            },
69390            "resource": {
69391              "description": "Name or id of the resource for this request.",
69392              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
69393              "location": "path",
69394              "required": true,
69395              "type": "string"
69396            },
69397            "zone": {
69398              "description": "The name of the zone for this request.",
69399              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69400              "location": "path",
69401              "required": true,
69402              "type": "string"
69403            }
69404          },
69405          "parameterOrder": [
69406            "project",
69407            "zone",
69408            "resource"
69409          ],
69410          "request": {
69411            "$ref": "ZoneSetPolicyRequest"
69412          },
69413          "response": {
69414            "$ref": "Policy"
69415          },
69416          "scopes": [
69417            "https://www.googleapis.com/auth/cloud-platform",
69418            "https://www.googleapis.com/auth/compute"
69419          ],
69420          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
69421        },
69422        "testIamPermissions": {
69423          "id": "compute.nodeGroups.testIamPermissions",
69424          "path": "projects/{project}/zones/{zone}/nodeGroups/{resource}/testIamPermissions",
69425          "flatPath": "projects/{project}/zones/{zone}/nodeGroups/{resource}/testIamPermissions",
69426          "httpMethod": "POST",
69427          "parameters": {
69428            "project": {
69429              "description": "Project ID for this request.",
69430              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69431              "location": "path",
69432              "required": true,
69433              "type": "string"
69434            },
69435            "resource": {
69436              "description": "Name or id of the resource for this request.",
69437              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
69438              "location": "path",
69439              "required": true,
69440              "type": "string"
69441            },
69442            "zone": {
69443              "description": "The name of the zone for this request.",
69444              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69445              "location": "path",
69446              "required": true,
69447              "type": "string"
69448            }
69449          },
69450          "parameterOrder": [
69451            "project",
69452            "zone",
69453            "resource"
69454          ],
69455          "request": {
69456            "$ref": "TestPermissionsRequest"
69457          },
69458          "response": {
69459            "$ref": "TestPermissionsResponse"
69460          },
69461          "scopes": [
69462            "https://www.googleapis.com/auth/cloud-platform",
69463            "https://www.googleapis.com/auth/compute",
69464            "https://www.googleapis.com/auth/compute.readonly"
69465          ],
69466          "description": "Returns permissions that a caller has on the specified resource."
69467        }
69468      }
69469    },
69470    "nodeTemplates": {
69471      "methods": {
69472        "list": {
69473          "id": "compute.nodeTemplates.list",
69474          "path": "projects/{project}/regions/{region}/nodeTemplates",
69475          "flatPath": "projects/{project}/regions/{region}/nodeTemplates",
69476          "httpMethod": "GET",
69477          "parameters": {
69478            "filter": {
69479              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
69480              "location": "query",
69481              "type": "string"
69482            },
69483            "maxResults": {
69484              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
69485              "default": "500",
69486              "minimum": "0",
69487              "location": "query",
69488              "type": "integer",
69489              "format": "uint32"
69490            },
69491            "orderBy": {
69492              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
69493              "location": "query",
69494              "type": "string"
69495            },
69496            "pageToken": {
69497              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
69498              "location": "query",
69499              "type": "string"
69500            },
69501            "project": {
69502              "description": "Project ID for this request.",
69503              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69504              "location": "path",
69505              "required": true,
69506              "type": "string"
69507            },
69508            "region": {
69509              "description": "The name of the region for this request.",
69510              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69511              "location": "path",
69512              "required": true,
69513              "type": "string"
69514            },
69515            "returnPartialSuccess": {
69516              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
69517              "location": "query",
69518              "type": "boolean"
69519            }
69520          },
69521          "parameterOrder": [
69522            "project",
69523            "region"
69524          ],
69525          "response": {
69526            "$ref": "NodeTemplateList"
69527          },
69528          "scopes": [
69529            "https://www.googleapis.com/auth/cloud-platform",
69530            "https://www.googleapis.com/auth/compute",
69531            "https://www.googleapis.com/auth/compute.readonly"
69532          ],
69533          "description": "Retrieves a list of node templates available to the specified project."
69534        },
69535        "aggregatedList": {
69536          "id": "compute.nodeTemplates.aggregatedList",
69537          "path": "projects/{project}/aggregated/nodeTemplates",
69538          "flatPath": "projects/{project}/aggregated/nodeTemplates",
69539          "httpMethod": "GET",
69540          "parameters": {
69541            "filter": {
69542              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
69543              "location": "query",
69544              "type": "string"
69545            },
69546            "includeAllScopes": {
69547              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
69548              "location": "query",
69549              "type": "boolean"
69550            },
69551            "maxResults": {
69552              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
69553              "default": "500",
69554              "minimum": "0",
69555              "location": "query",
69556              "type": "integer",
69557              "format": "uint32"
69558            },
69559            "orderBy": {
69560              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
69561              "location": "query",
69562              "type": "string"
69563            },
69564            "pageToken": {
69565              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
69566              "location": "query",
69567              "type": "string"
69568            },
69569            "project": {
69570              "description": "Project ID for this request.",
69571              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69572              "location": "path",
69573              "required": true,
69574              "type": "string"
69575            },
69576            "returnPartialSuccess": {
69577              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
69578              "location": "query",
69579              "type": "boolean"
69580            },
69581            "serviceProjectNumber": {
69582              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
69583              "location": "query",
69584              "type": "string",
69585              "format": "int64"
69586            }
69587          },
69588          "parameterOrder": [
69589            "project"
69590          ],
69591          "response": {
69592            "$ref": "NodeTemplateAggregatedList"
69593          },
69594          "scopes": [
69595            "https://www.googleapis.com/auth/cloud-platform",
69596            "https://www.googleapis.com/auth/compute",
69597            "https://www.googleapis.com/auth/compute.readonly"
69598          ],
69599          "description": "Retrieves an aggregated list of node templates. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
69600        },
69601        "get": {
69602          "id": "compute.nodeTemplates.get",
69603          "path": "projects/{project}/regions/{region}/nodeTemplates/{nodeTemplate}",
69604          "flatPath": "projects/{project}/regions/{region}/nodeTemplates/{nodeTemplate}",
69605          "httpMethod": "GET",
69606          "parameters": {
69607            "nodeTemplate": {
69608              "description": "Name of the node template to return.",
69609              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
69610              "location": "path",
69611              "required": true,
69612              "type": "string"
69613            },
69614            "project": {
69615              "description": "Project ID for this request.",
69616              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69617              "location": "path",
69618              "required": true,
69619              "type": "string"
69620            },
69621            "region": {
69622              "description": "The name of the region for this request.",
69623              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69624              "location": "path",
69625              "required": true,
69626              "type": "string"
69627            }
69628          },
69629          "parameterOrder": [
69630            "project",
69631            "region",
69632            "nodeTemplate"
69633          ],
69634          "response": {
69635            "$ref": "NodeTemplate"
69636          },
69637          "scopes": [
69638            "https://www.googleapis.com/auth/cloud-platform",
69639            "https://www.googleapis.com/auth/compute",
69640            "https://www.googleapis.com/auth/compute.readonly"
69641          ],
69642          "description": "Returns the specified node template."
69643        },
69644        "insert": {
69645          "id": "compute.nodeTemplates.insert",
69646          "path": "projects/{project}/regions/{region}/nodeTemplates",
69647          "flatPath": "projects/{project}/regions/{region}/nodeTemplates",
69648          "httpMethod": "POST",
69649          "parameters": {
69650            "project": {
69651              "description": "Project ID for this request.",
69652              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69653              "location": "path",
69654              "required": true,
69655              "type": "string"
69656            },
69657            "region": {
69658              "description": "The name of the region for this request.",
69659              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69660              "location": "path",
69661              "required": true,
69662              "type": "string"
69663            },
69664            "requestId": {
69665              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
69666              "location": "query",
69667              "type": "string"
69668            }
69669          },
69670          "parameterOrder": [
69671            "project",
69672            "region"
69673          ],
69674          "request": {
69675            "$ref": "NodeTemplate"
69676          },
69677          "response": {
69678            "$ref": "Operation"
69679          },
69680          "scopes": [
69681            "https://www.googleapis.com/auth/cloud-platform",
69682            "https://www.googleapis.com/auth/compute"
69683          ],
69684          "description": "Creates a NodeTemplate resource in the specified project using the data included in the request."
69685        },
69686        "delete": {
69687          "id": "compute.nodeTemplates.delete",
69688          "path": "projects/{project}/regions/{region}/nodeTemplates/{nodeTemplate}",
69689          "flatPath": "projects/{project}/regions/{region}/nodeTemplates/{nodeTemplate}",
69690          "httpMethod": "DELETE",
69691          "parameters": {
69692            "nodeTemplate": {
69693              "description": "Name of the NodeTemplate resource to delete.",
69694              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
69695              "location": "path",
69696              "required": true,
69697              "type": "string"
69698            },
69699            "project": {
69700              "description": "Project ID for this request.",
69701              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69702              "location": "path",
69703              "required": true,
69704              "type": "string"
69705            },
69706            "region": {
69707              "description": "The name of the region for this request.",
69708              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69709              "location": "path",
69710              "required": true,
69711              "type": "string"
69712            },
69713            "requestId": {
69714              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
69715              "location": "query",
69716              "type": "string"
69717            }
69718          },
69719          "parameterOrder": [
69720            "project",
69721            "region",
69722            "nodeTemplate"
69723          ],
69724          "response": {
69725            "$ref": "Operation"
69726          },
69727          "scopes": [
69728            "https://www.googleapis.com/auth/cloud-platform",
69729            "https://www.googleapis.com/auth/compute"
69730          ],
69731          "description": "Deletes the specified NodeTemplate resource."
69732        },
69733        "getIamPolicy": {
69734          "id": "compute.nodeTemplates.getIamPolicy",
69735          "path": "projects/{project}/regions/{region}/nodeTemplates/{resource}/getIamPolicy",
69736          "flatPath": "projects/{project}/regions/{region}/nodeTemplates/{resource}/getIamPolicy",
69737          "httpMethod": "GET",
69738          "parameters": {
69739            "optionsRequestedPolicyVersion": {
69740              "description": "Requested IAM Policy version.",
69741              "location": "query",
69742              "type": "integer",
69743              "format": "int32"
69744            },
69745            "project": {
69746              "description": "Project ID for this request.",
69747              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69748              "location": "path",
69749              "required": true,
69750              "type": "string"
69751            },
69752            "region": {
69753              "description": "The name of the region for this request.",
69754              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69755              "location": "path",
69756              "required": true,
69757              "type": "string"
69758            },
69759            "resource": {
69760              "description": "Name or id of the resource for this request.",
69761              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
69762              "location": "path",
69763              "required": true,
69764              "type": "string"
69765            }
69766          },
69767          "parameterOrder": [
69768            "project",
69769            "region",
69770            "resource"
69771          ],
69772          "response": {
69773            "$ref": "Policy"
69774          },
69775          "scopes": [
69776            "https://www.googleapis.com/auth/cloud-platform",
69777            "https://www.googleapis.com/auth/compute",
69778            "https://www.googleapis.com/auth/compute.readonly"
69779          ],
69780          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
69781        },
69782        "setIamPolicy": {
69783          "id": "compute.nodeTemplates.setIamPolicy",
69784          "path": "projects/{project}/regions/{region}/nodeTemplates/{resource}/setIamPolicy",
69785          "flatPath": "projects/{project}/regions/{region}/nodeTemplates/{resource}/setIamPolicy",
69786          "httpMethod": "POST",
69787          "parameters": {
69788            "project": {
69789              "description": "Project ID for this request.",
69790              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69791              "location": "path",
69792              "required": true,
69793              "type": "string"
69794            },
69795            "region": {
69796              "description": "The name of the region for this request.",
69797              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69798              "location": "path",
69799              "required": true,
69800              "type": "string"
69801            },
69802            "resource": {
69803              "description": "Name or id of the resource for this request.",
69804              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
69805              "location": "path",
69806              "required": true,
69807              "type": "string"
69808            }
69809          },
69810          "parameterOrder": [
69811            "project",
69812            "region",
69813            "resource"
69814          ],
69815          "request": {
69816            "$ref": "RegionSetPolicyRequest"
69817          },
69818          "response": {
69819            "$ref": "Policy"
69820          },
69821          "scopes": [
69822            "https://www.googleapis.com/auth/cloud-platform",
69823            "https://www.googleapis.com/auth/compute"
69824          ],
69825          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
69826        },
69827        "testIamPermissions": {
69828          "id": "compute.nodeTemplates.testIamPermissions",
69829          "path": "projects/{project}/regions/{region}/nodeTemplates/{resource}/testIamPermissions",
69830          "flatPath": "projects/{project}/regions/{region}/nodeTemplates/{resource}/testIamPermissions",
69831          "httpMethod": "POST",
69832          "parameters": {
69833            "project": {
69834              "description": "Project ID for this request.",
69835              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69836              "location": "path",
69837              "required": true,
69838              "type": "string"
69839            },
69840            "region": {
69841              "description": "The name of the region for this request.",
69842              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69843              "location": "path",
69844              "required": true,
69845              "type": "string"
69846            },
69847            "resource": {
69848              "description": "Name or id of the resource for this request.",
69849              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
69850              "location": "path",
69851              "required": true,
69852              "type": "string"
69853            }
69854          },
69855          "parameterOrder": [
69856            "project",
69857            "region",
69858            "resource"
69859          ],
69860          "request": {
69861            "$ref": "TestPermissionsRequest"
69862          },
69863          "response": {
69864            "$ref": "TestPermissionsResponse"
69865          },
69866          "scopes": [
69867            "https://www.googleapis.com/auth/cloud-platform",
69868            "https://www.googleapis.com/auth/compute",
69869            "https://www.googleapis.com/auth/compute.readonly"
69870          ],
69871          "description": "Returns permissions that a caller has on the specified resource."
69872        }
69873      }
69874    },
69875    "nodeTypes": {
69876      "methods": {
69877        "list": {
69878          "id": "compute.nodeTypes.list",
69879          "path": "projects/{project}/zones/{zone}/nodeTypes",
69880          "flatPath": "projects/{project}/zones/{zone}/nodeTypes",
69881          "httpMethod": "GET",
69882          "parameters": {
69883            "filter": {
69884              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
69885              "location": "query",
69886              "type": "string"
69887            },
69888            "maxResults": {
69889              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
69890              "default": "500",
69891              "minimum": "0",
69892              "location": "query",
69893              "type": "integer",
69894              "format": "uint32"
69895            },
69896            "orderBy": {
69897              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
69898              "location": "query",
69899              "type": "string"
69900            },
69901            "pageToken": {
69902              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
69903              "location": "query",
69904              "type": "string"
69905            },
69906            "project": {
69907              "description": "Project ID for this request.",
69908              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69909              "location": "path",
69910              "required": true,
69911              "type": "string"
69912            },
69913            "returnPartialSuccess": {
69914              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
69915              "location": "query",
69916              "type": "boolean"
69917            },
69918            "zone": {
69919              "description": "The name of the zone for this request.",
69920              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
69921              "location": "path",
69922              "required": true,
69923              "type": "string"
69924            }
69925          },
69926          "parameterOrder": [
69927            "project",
69928            "zone"
69929          ],
69930          "response": {
69931            "$ref": "NodeTypeList"
69932          },
69933          "scopes": [
69934            "https://www.googleapis.com/auth/cloud-platform",
69935            "https://www.googleapis.com/auth/compute",
69936            "https://www.googleapis.com/auth/compute.readonly"
69937          ],
69938          "description": "Retrieves a list of node types available to the specified project."
69939        },
69940        "aggregatedList": {
69941          "id": "compute.nodeTypes.aggregatedList",
69942          "path": "projects/{project}/aggregated/nodeTypes",
69943          "flatPath": "projects/{project}/aggregated/nodeTypes",
69944          "httpMethod": "GET",
69945          "parameters": {
69946            "filter": {
69947              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
69948              "location": "query",
69949              "type": "string"
69950            },
69951            "includeAllScopes": {
69952              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
69953              "location": "query",
69954              "type": "boolean"
69955            },
69956            "maxResults": {
69957              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
69958              "default": "500",
69959              "minimum": "0",
69960              "location": "query",
69961              "type": "integer",
69962              "format": "uint32"
69963            },
69964            "orderBy": {
69965              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
69966              "location": "query",
69967              "type": "string"
69968            },
69969            "pageToken": {
69970              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
69971              "location": "query",
69972              "type": "string"
69973            },
69974            "project": {
69975              "description": "Project ID for this request.",
69976              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
69977              "location": "path",
69978              "required": true,
69979              "type": "string"
69980            },
69981            "returnPartialSuccess": {
69982              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
69983              "location": "query",
69984              "type": "boolean"
69985            },
69986            "serviceProjectNumber": {
69987              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
69988              "location": "query",
69989              "type": "string",
69990              "format": "int64"
69991            }
69992          },
69993          "parameterOrder": [
69994            "project"
69995          ],
69996          "response": {
69997            "$ref": "NodeTypeAggregatedList"
69998          },
69999          "scopes": [
70000            "https://www.googleapis.com/auth/cloud-platform",
70001            "https://www.googleapis.com/auth/compute",
70002            "https://www.googleapis.com/auth/compute.readonly"
70003          ],
70004          "description": "Retrieves an aggregated list of node types. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
70005        },
70006        "get": {
70007          "id": "compute.nodeTypes.get",
70008          "path": "projects/{project}/zones/{zone}/nodeTypes/{nodeType}",
70009          "flatPath": "projects/{project}/zones/{zone}/nodeTypes/{nodeType}",
70010          "httpMethod": "GET",
70011          "parameters": {
70012            "nodeType": {
70013              "description": "Name of the node type to return.",
70014              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
70015              "location": "path",
70016              "required": true,
70017              "type": "string"
70018            },
70019            "project": {
70020              "description": "Project ID for this request.",
70021              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70022              "location": "path",
70023              "required": true,
70024              "type": "string"
70025            },
70026            "zone": {
70027              "description": "The name of the zone for this request.",
70028              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
70029              "location": "path",
70030              "required": true,
70031              "type": "string"
70032            }
70033          },
70034          "parameterOrder": [
70035            "project",
70036            "zone",
70037            "nodeType"
70038          ],
70039          "response": {
70040            "$ref": "NodeType"
70041          },
70042          "scopes": [
70043            "https://www.googleapis.com/auth/cloud-platform",
70044            "https://www.googleapis.com/auth/compute",
70045            "https://www.googleapis.com/auth/compute.readonly"
70046          ],
70047          "description": "Returns the specified node type."
70048        }
70049      }
70050    },
70051    "regionNotificationEndpoints": {
70052      "methods": {
70053        "list": {
70054          "id": "compute.regionNotificationEndpoints.list",
70055          "path": "projects/{project}/regions/{region}/notificationEndpoints",
70056          "flatPath": "projects/{project}/regions/{region}/notificationEndpoints",
70057          "httpMethod": "GET",
70058          "parameters": {
70059            "filter": {
70060              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
70061              "location": "query",
70062              "type": "string"
70063            },
70064            "maxResults": {
70065              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
70066              "default": "500",
70067              "minimum": "0",
70068              "location": "query",
70069              "type": "integer",
70070              "format": "uint32"
70071            },
70072            "orderBy": {
70073              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
70074              "location": "query",
70075              "type": "string"
70076            },
70077            "pageToken": {
70078              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
70079              "location": "query",
70080              "type": "string"
70081            },
70082            "project": {
70083              "description": "Project ID for this request.",
70084              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70085              "location": "path",
70086              "required": true,
70087              "type": "string"
70088            },
70089            "region": {
70090              "description": "Name of the region scoping this request.",
70091              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
70092              "location": "path",
70093              "required": true,
70094              "type": "string"
70095            },
70096            "returnPartialSuccess": {
70097              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
70098              "location": "query",
70099              "type": "boolean"
70100            }
70101          },
70102          "parameterOrder": [
70103            "project",
70104            "region"
70105          ],
70106          "response": {
70107            "$ref": "NotificationEndpointList"
70108          },
70109          "scopes": [
70110            "https://www.googleapis.com/auth/cloud-platform",
70111            "https://www.googleapis.com/auth/compute",
70112            "https://www.googleapis.com/auth/compute.readonly"
70113          ],
70114          "description": "Lists the NotificationEndpoints for a project in the given region."
70115        },
70116        "get": {
70117          "id": "compute.regionNotificationEndpoints.get",
70118          "path": "projects/{project}/regions/{region}/notificationEndpoints/{notificationEndpoint}",
70119          "flatPath": "projects/{project}/regions/{region}/notificationEndpoints/{notificationEndpoint}",
70120          "httpMethod": "GET",
70121          "parameters": {
70122            "notificationEndpoint": {
70123              "description": "Name of the NotificationEndpoint resource to return.",
70124              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
70125              "location": "path",
70126              "required": true,
70127              "type": "string"
70128            },
70129            "project": {
70130              "description": "Project ID for this request.",
70131              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70132              "location": "path",
70133              "required": true,
70134              "type": "string"
70135            },
70136            "region": {
70137              "description": "Name of the region scoping this request.",
70138              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
70139              "location": "path",
70140              "required": true,
70141              "type": "string"
70142            }
70143          },
70144          "parameterOrder": [
70145            "project",
70146            "region",
70147            "notificationEndpoint"
70148          ],
70149          "response": {
70150            "$ref": "NotificationEndpoint"
70151          },
70152          "scopes": [
70153            "https://www.googleapis.com/auth/cloud-platform",
70154            "https://www.googleapis.com/auth/compute",
70155            "https://www.googleapis.com/auth/compute.readonly"
70156          ],
70157          "description": "Returns the specified NotificationEndpoint resource in the given region."
70158        },
70159        "insert": {
70160          "id": "compute.regionNotificationEndpoints.insert",
70161          "path": "projects/{project}/regions/{region}/notificationEndpoints",
70162          "flatPath": "projects/{project}/regions/{region}/notificationEndpoints",
70163          "httpMethod": "POST",
70164          "parameters": {
70165            "project": {
70166              "description": "Project ID for this request.",
70167              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70168              "location": "path",
70169              "required": true,
70170              "type": "string"
70171            },
70172            "region": {
70173              "description": "Name of the region scoping this request.",
70174              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
70175              "location": "path",
70176              "required": true,
70177              "type": "string"
70178            },
70179            "requestId": {
70180              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
70181              "location": "query",
70182              "type": "string"
70183            }
70184          },
70185          "parameterOrder": [
70186            "project",
70187            "region"
70188          ],
70189          "request": {
70190            "$ref": "NotificationEndpoint"
70191          },
70192          "response": {
70193            "$ref": "Operation"
70194          },
70195          "scopes": [
70196            "https://www.googleapis.com/auth/cloud-platform",
70197            "https://www.googleapis.com/auth/compute"
70198          ],
70199          "description": "Create a NotificationEndpoint in the specified project in the given region using the parameters that are included in the request."
70200        },
70201        "delete": {
70202          "id": "compute.regionNotificationEndpoints.delete",
70203          "path": "projects/{project}/regions/{region}/notificationEndpoints/{notificationEndpoint}",
70204          "flatPath": "projects/{project}/regions/{region}/notificationEndpoints/{notificationEndpoint}",
70205          "httpMethod": "DELETE",
70206          "parameters": {
70207            "notificationEndpoint": {
70208              "description": "Name of the NotificationEndpoint resource to delete.",
70209              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
70210              "location": "path",
70211              "required": true,
70212              "type": "string"
70213            },
70214            "project": {
70215              "description": "Project ID for this request.",
70216              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70217              "location": "path",
70218              "required": true,
70219              "type": "string"
70220            },
70221            "region": {
70222              "description": "Name of the region scoping this request.",
70223              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
70224              "location": "path",
70225              "required": true,
70226              "type": "string"
70227            },
70228            "requestId": {
70229              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
70230              "location": "query",
70231              "type": "string"
70232            }
70233          },
70234          "parameterOrder": [
70235            "project",
70236            "region",
70237            "notificationEndpoint"
70238          ],
70239          "response": {
70240            "$ref": "Operation"
70241          },
70242          "scopes": [
70243            "https://www.googleapis.com/auth/cloud-platform",
70244            "https://www.googleapis.com/auth/compute"
70245          ],
70246          "description": "Deletes the specified NotificationEndpoint in the given region"
70247        }
70248      }
70249    },
70250    "packetMirrorings": {
70251      "methods": {
70252        "get": {
70253          "id": "compute.packetMirrorings.get",
70254          "path": "projects/{project}/regions/{region}/packetMirrorings/{packetMirroring}",
70255          "flatPath": "projects/{project}/regions/{region}/packetMirrorings/{packetMirroring}",
70256          "httpMethod": "GET",
70257          "parameters": {
70258            "packetMirroring": {
70259              "description": "Name of the PacketMirroring resource to return.",
70260              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
70261              "location": "path",
70262              "required": true,
70263              "type": "string"
70264            },
70265            "project": {
70266              "description": "Project ID for this request.",
70267              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70268              "location": "path",
70269              "required": true,
70270              "type": "string"
70271            },
70272            "region": {
70273              "description": "Name of the region for this request.",
70274              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
70275              "location": "path",
70276              "required": true,
70277              "type": "string"
70278            }
70279          },
70280          "parameterOrder": [
70281            "project",
70282            "region",
70283            "packetMirroring"
70284          ],
70285          "response": {
70286            "$ref": "PacketMirroring"
70287          },
70288          "scopes": [
70289            "https://www.googleapis.com/auth/cloud-platform",
70290            "https://www.googleapis.com/auth/compute",
70291            "https://www.googleapis.com/auth/compute.readonly"
70292          ],
70293          "description": "Returns the specified PacketMirroring resource."
70294        },
70295        "insert": {
70296          "id": "compute.packetMirrorings.insert",
70297          "path": "projects/{project}/regions/{region}/packetMirrorings",
70298          "flatPath": "projects/{project}/regions/{region}/packetMirrorings",
70299          "httpMethod": "POST",
70300          "parameters": {
70301            "project": {
70302              "description": "Project ID for this request.",
70303              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70304              "location": "path",
70305              "required": true,
70306              "type": "string"
70307            },
70308            "region": {
70309              "description": "Name of the region for this request.",
70310              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
70311              "location": "path",
70312              "required": true,
70313              "type": "string"
70314            },
70315            "requestId": {
70316              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
70317              "location": "query",
70318              "type": "string"
70319            }
70320          },
70321          "parameterOrder": [
70322            "project",
70323            "region"
70324          ],
70325          "request": {
70326            "$ref": "PacketMirroring"
70327          },
70328          "response": {
70329            "$ref": "Operation"
70330          },
70331          "scopes": [
70332            "https://www.googleapis.com/auth/cloud-platform",
70333            "https://www.googleapis.com/auth/compute"
70334          ],
70335          "description": "Creates a PacketMirroring resource in the specified project and region using the data included in the request."
70336        },
70337        "patch": {
70338          "id": "compute.packetMirrorings.patch",
70339          "path": "projects/{project}/regions/{region}/packetMirrorings/{packetMirroring}",
70340          "flatPath": "projects/{project}/regions/{region}/packetMirrorings/{packetMirroring}",
70341          "httpMethod": "PATCH",
70342          "parameters": {
70343            "packetMirroring": {
70344              "description": "Name of the PacketMirroring resource to patch.",
70345              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
70346              "location": "path",
70347              "required": true,
70348              "type": "string"
70349            },
70350            "project": {
70351              "description": "Project ID for this request.",
70352              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70353              "location": "path",
70354              "required": true,
70355              "type": "string"
70356            },
70357            "region": {
70358              "description": "Name of the region for this request.",
70359              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
70360              "location": "path",
70361              "required": true,
70362              "type": "string"
70363            },
70364            "requestId": {
70365              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
70366              "location": "query",
70367              "type": "string"
70368            }
70369          },
70370          "parameterOrder": [
70371            "project",
70372            "region",
70373            "packetMirroring"
70374          ],
70375          "request": {
70376            "$ref": "PacketMirroring"
70377          },
70378          "response": {
70379            "$ref": "Operation"
70380          },
70381          "scopes": [
70382            "https://www.googleapis.com/auth/cloud-platform",
70383            "https://www.googleapis.com/auth/compute"
70384          ],
70385          "description": "Patches the specified PacketMirroring resource with the data included in the request. This method supports PATCH semantics and uses JSON merge patch format and processing rules."
70386        },
70387        "delete": {
70388          "id": "compute.packetMirrorings.delete",
70389          "path": "projects/{project}/regions/{region}/packetMirrorings/{packetMirroring}",
70390          "flatPath": "projects/{project}/regions/{region}/packetMirrorings/{packetMirroring}",
70391          "httpMethod": "DELETE",
70392          "parameters": {
70393            "packetMirroring": {
70394              "description": "Name of the PacketMirroring resource to delete.",
70395              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
70396              "location": "path",
70397              "required": true,
70398              "type": "string"
70399            },
70400            "project": {
70401              "description": "Project ID for this request.",
70402              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70403              "location": "path",
70404              "required": true,
70405              "type": "string"
70406            },
70407            "region": {
70408              "description": "Name of the region for this request.",
70409              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
70410              "location": "path",
70411              "required": true,
70412              "type": "string"
70413            },
70414            "requestId": {
70415              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
70416              "location": "query",
70417              "type": "string"
70418            }
70419          },
70420          "parameterOrder": [
70421            "project",
70422            "region",
70423            "packetMirroring"
70424          ],
70425          "response": {
70426            "$ref": "Operation"
70427          },
70428          "scopes": [
70429            "https://www.googleapis.com/auth/cloud-platform",
70430            "https://www.googleapis.com/auth/compute"
70431          ],
70432          "description": "Deletes the specified PacketMirroring resource."
70433        },
70434        "list": {
70435          "id": "compute.packetMirrorings.list",
70436          "path": "projects/{project}/regions/{region}/packetMirrorings",
70437          "flatPath": "projects/{project}/regions/{region}/packetMirrorings",
70438          "httpMethod": "GET",
70439          "parameters": {
70440            "filter": {
70441              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
70442              "location": "query",
70443              "type": "string"
70444            },
70445            "maxResults": {
70446              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
70447              "default": "500",
70448              "minimum": "0",
70449              "location": "query",
70450              "type": "integer",
70451              "format": "uint32"
70452            },
70453            "orderBy": {
70454              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
70455              "location": "query",
70456              "type": "string"
70457            },
70458            "pageToken": {
70459              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
70460              "location": "query",
70461              "type": "string"
70462            },
70463            "project": {
70464              "description": "Project ID for this request.",
70465              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70466              "location": "path",
70467              "required": true,
70468              "type": "string"
70469            },
70470            "region": {
70471              "description": "Name of the region for this request.",
70472              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
70473              "location": "path",
70474              "required": true,
70475              "type": "string"
70476            },
70477            "returnPartialSuccess": {
70478              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
70479              "location": "query",
70480              "type": "boolean"
70481            }
70482          },
70483          "parameterOrder": [
70484            "project",
70485            "region"
70486          ],
70487          "response": {
70488            "$ref": "PacketMirroringList"
70489          },
70490          "scopes": [
70491            "https://www.googleapis.com/auth/cloud-platform",
70492            "https://www.googleapis.com/auth/compute",
70493            "https://www.googleapis.com/auth/compute.readonly"
70494          ],
70495          "description": "Retrieves a list of PacketMirroring resources available to the specified project and region."
70496        },
70497        "aggregatedList": {
70498          "id": "compute.packetMirrorings.aggregatedList",
70499          "path": "projects/{project}/aggregated/packetMirrorings",
70500          "flatPath": "projects/{project}/aggregated/packetMirrorings",
70501          "httpMethod": "GET",
70502          "parameters": {
70503            "filter": {
70504              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
70505              "location": "query",
70506              "type": "string"
70507            },
70508            "includeAllScopes": {
70509              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
70510              "location": "query",
70511              "type": "boolean"
70512            },
70513            "maxResults": {
70514              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
70515              "default": "500",
70516              "minimum": "0",
70517              "location": "query",
70518              "type": "integer",
70519              "format": "uint32"
70520            },
70521            "orderBy": {
70522              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
70523              "location": "query",
70524              "type": "string"
70525            },
70526            "pageToken": {
70527              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
70528              "location": "query",
70529              "type": "string"
70530            },
70531            "project": {
70532              "description": "Project ID for this request.",
70533              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70534              "location": "path",
70535              "required": true,
70536              "type": "string"
70537            },
70538            "returnPartialSuccess": {
70539              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
70540              "location": "query",
70541              "type": "boolean"
70542            },
70543            "serviceProjectNumber": {
70544              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
70545              "location": "query",
70546              "type": "string",
70547              "format": "int64"
70548            }
70549          },
70550          "parameterOrder": [
70551            "project"
70552          ],
70553          "response": {
70554            "$ref": "PacketMirroringAggregatedList"
70555          },
70556          "scopes": [
70557            "https://www.googleapis.com/auth/cloud-platform",
70558            "https://www.googleapis.com/auth/compute",
70559            "https://www.googleapis.com/auth/compute.readonly"
70560          ],
70561          "description": "Retrieves an aggregated list of packetMirrorings. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
70562        },
70563        "testIamPermissions": {
70564          "id": "compute.packetMirrorings.testIamPermissions",
70565          "path": "projects/{project}/regions/{region}/packetMirrorings/{resource}/testIamPermissions",
70566          "flatPath": "projects/{project}/regions/{region}/packetMirrorings/{resource}/testIamPermissions",
70567          "httpMethod": "POST",
70568          "parameters": {
70569            "project": {
70570              "description": "Project ID for this request.",
70571              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70572              "location": "path",
70573              "required": true,
70574              "type": "string"
70575            },
70576            "region": {
70577              "description": "The name of the region for this request.",
70578              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
70579              "location": "path",
70580              "required": true,
70581              "type": "string"
70582            },
70583            "resource": {
70584              "description": "Name or id of the resource for this request.",
70585              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
70586              "location": "path",
70587              "required": true,
70588              "type": "string"
70589            }
70590          },
70591          "parameterOrder": [
70592            "project",
70593            "region",
70594            "resource"
70595          ],
70596          "request": {
70597            "$ref": "TestPermissionsRequest"
70598          },
70599          "response": {
70600            "$ref": "TestPermissionsResponse"
70601          },
70602          "scopes": [
70603            "https://www.googleapis.com/auth/cloud-platform",
70604            "https://www.googleapis.com/auth/compute",
70605            "https://www.googleapis.com/auth/compute.readonly"
70606          ],
70607          "description": "Returns permissions that a caller has on the specified resource."
70608        }
70609      }
70610    },
70611    "projects": {
70612      "methods": {
70613        "get": {
70614          "id": "compute.projects.get",
70615          "path": "projects/{project}",
70616          "flatPath": "projects/{project}",
70617          "httpMethod": "GET",
70618          "parameters": {
70619            "project": {
70620              "description": "Project ID for this request.",
70621              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70622              "location": "path",
70623              "required": true,
70624              "type": "string"
70625            }
70626          },
70627          "parameterOrder": [
70628            "project"
70629          ],
70630          "response": {
70631            "$ref": "Project"
70632          },
70633          "scopes": [
70634            "https://www.googleapis.com/auth/cloud-platform",
70635            "https://www.googleapis.com/auth/compute",
70636            "https://www.googleapis.com/auth/compute.readonly"
70637          ],
70638          "description": "Returns the specified Project resource. To decrease latency for this method, you can optionally omit any unneeded information from the response by using a field mask. This practice is especially recommended for unused quota information (the `quotas` field). To exclude one or more fields, set your request's `fields` query parameter to only include the fields you need. For example, to only include the `id` and `selfLink` fields, add the query parameter `?fields=id,selfLink` to your request."
70639        },
70640        "setCommonInstanceMetadata": {
70641          "id": "compute.projects.setCommonInstanceMetadata",
70642          "path": "projects/{project}/setCommonInstanceMetadata",
70643          "flatPath": "projects/{project}/setCommonInstanceMetadata",
70644          "httpMethod": "POST",
70645          "parameters": {
70646            "project": {
70647              "description": "Project ID for this request.",
70648              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70649              "location": "path",
70650              "required": true,
70651              "type": "string"
70652            },
70653            "requestId": {
70654              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
70655              "location": "query",
70656              "type": "string"
70657            }
70658          },
70659          "parameterOrder": [
70660            "project"
70661          ],
70662          "request": {
70663            "$ref": "Metadata"
70664          },
70665          "response": {
70666            "$ref": "Operation"
70667          },
70668          "scopes": [
70669            "https://www.googleapis.com/auth/cloud-platform",
70670            "https://www.googleapis.com/auth/compute"
70671          ],
70672          "description": "Sets metadata common to all instances within the specified project using the data included in the request."
70673        },
70674        "setUsageExportBucket": {
70675          "id": "compute.projects.setUsageExportBucket",
70676          "path": "projects/{project}/setUsageExportBucket",
70677          "flatPath": "projects/{project}/setUsageExportBucket",
70678          "httpMethod": "POST",
70679          "parameters": {
70680            "project": {
70681              "description": "Project ID for this request.",
70682              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70683              "location": "path",
70684              "required": true,
70685              "type": "string"
70686            },
70687            "requestId": {
70688              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
70689              "location": "query",
70690              "type": "string"
70691            }
70692          },
70693          "parameterOrder": [
70694            "project"
70695          ],
70696          "request": {
70697            "$ref": "UsageExportLocation"
70698          },
70699          "response": {
70700            "$ref": "Operation"
70701          },
70702          "scopes": [
70703            "https://www.googleapis.com/auth/cloud-platform",
70704            "https://www.googleapis.com/auth/compute",
70705            "https://www.googleapis.com/auth/devstorage.full_control",
70706            "https://www.googleapis.com/auth/devstorage.read_only",
70707            "https://www.googleapis.com/auth/devstorage.read_write"
70708          ],
70709          "description": "Enables the usage export feature and sets the usage export bucket where reports are stored. If you provide an empty request body using this method, the usage export feature will be disabled."
70710        },
70711        "moveInstance": {
70712          "id": "compute.projects.moveInstance",
70713          "path": "projects/{project}/moveInstance",
70714          "flatPath": "projects/{project}/moveInstance",
70715          "httpMethod": "POST",
70716          "parameters": {
70717            "project": {
70718              "description": "Project ID for this request.",
70719              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70720              "location": "path",
70721              "required": true,
70722              "type": "string"
70723            },
70724            "requestId": {
70725              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
70726              "location": "query",
70727              "type": "string"
70728            }
70729          },
70730          "parameterOrder": [
70731            "project"
70732          ],
70733          "request": {
70734            "$ref": "InstanceMoveRequest"
70735          },
70736          "response": {
70737            "$ref": "Operation"
70738          },
70739          "scopes": [
70740            "https://www.googleapis.com/auth/cloud-platform",
70741            "https://www.googleapis.com/auth/compute"
70742          ],
70743          "deprecated": true,
70744          "description": "Moves an instance and its attached persistent disks from one zone to another. *Note*: Moving VMs or disks by using this method might cause unexpected behavior. For more information, see the [known issue](/compute/docs/troubleshooting/known-issues#moving_vms_or_disks_using_the_moveinstance_api_or_the_causes_unexpected_behavior). [Deprecated] This method is deprecated. See [moving instance across zones](/compute/docs/instances/moving-instance-across-zones) instead."
70745        },
70746        "moveDisk": {
70747          "id": "compute.projects.moveDisk",
70748          "path": "projects/{project}/moveDisk",
70749          "flatPath": "projects/{project}/moveDisk",
70750          "httpMethod": "POST",
70751          "parameters": {
70752            "project": {
70753              "description": "Project ID for this request.",
70754              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70755              "location": "path",
70756              "required": true,
70757              "type": "string"
70758            },
70759            "requestId": {
70760              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
70761              "location": "query",
70762              "type": "string"
70763            }
70764          },
70765          "parameterOrder": [
70766            "project"
70767          ],
70768          "request": {
70769            "$ref": "DiskMoveRequest"
70770          },
70771          "response": {
70772            "$ref": "Operation"
70773          },
70774          "scopes": [
70775            "https://www.googleapis.com/auth/cloud-platform",
70776            "https://www.googleapis.com/auth/compute"
70777          ],
70778          "description": "Moves a persistent disk from one zone to another."
70779        },
70780        "listXpnHosts": {
70781          "id": "compute.projects.listXpnHosts",
70782          "path": "projects/{project}/listXpnHosts",
70783          "flatPath": "projects/{project}/listXpnHosts",
70784          "httpMethod": "POST",
70785          "parameters": {
70786            "filter": {
70787              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
70788              "location": "query",
70789              "type": "string"
70790            },
70791            "maxResults": {
70792              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
70793              "default": "500",
70794              "minimum": "0",
70795              "location": "query",
70796              "type": "integer",
70797              "format": "uint32"
70798            },
70799            "orderBy": {
70800              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
70801              "location": "query",
70802              "type": "string"
70803            },
70804            "pageToken": {
70805              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
70806              "location": "query",
70807              "type": "string"
70808            },
70809            "project": {
70810              "description": "Project ID for this request.",
70811              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70812              "location": "path",
70813              "required": true,
70814              "type": "string"
70815            },
70816            "returnPartialSuccess": {
70817              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
70818              "location": "query",
70819              "type": "boolean"
70820            }
70821          },
70822          "parameterOrder": [
70823            "project"
70824          ],
70825          "request": {
70826            "$ref": "ProjectsListXpnHostsRequest"
70827          },
70828          "response": {
70829            "$ref": "XpnHostList"
70830          },
70831          "scopes": [
70832            "https://www.googleapis.com/auth/cloud-platform",
70833            "https://www.googleapis.com/auth/compute"
70834          ],
70835          "description": "Lists all shared VPC host projects visible to the user in an organization."
70836        },
70837        "enableXpnHost": {
70838          "id": "compute.projects.enableXpnHost",
70839          "path": "projects/{project}/enableXpnHost",
70840          "flatPath": "projects/{project}/enableXpnHost",
70841          "httpMethod": "POST",
70842          "parameters": {
70843            "project": {
70844              "description": "Project ID for this request.",
70845              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70846              "location": "path",
70847              "required": true,
70848              "type": "string"
70849            },
70850            "requestId": {
70851              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
70852              "location": "query",
70853              "type": "string"
70854            }
70855          },
70856          "parameterOrder": [
70857            "project"
70858          ],
70859          "response": {
70860            "$ref": "Operation"
70861          },
70862          "scopes": [
70863            "https://www.googleapis.com/auth/cloud-platform",
70864            "https://www.googleapis.com/auth/compute"
70865          ],
70866          "description": "Enable this project as a shared VPC host project."
70867        },
70868        "disableXpnHost": {
70869          "id": "compute.projects.disableXpnHost",
70870          "path": "projects/{project}/disableXpnHost",
70871          "flatPath": "projects/{project}/disableXpnHost",
70872          "httpMethod": "POST",
70873          "parameters": {
70874            "project": {
70875              "description": "Project ID for this request.",
70876              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70877              "location": "path",
70878              "required": true,
70879              "type": "string"
70880            },
70881            "requestId": {
70882              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
70883              "location": "query",
70884              "type": "string"
70885            }
70886          },
70887          "parameterOrder": [
70888            "project"
70889          ],
70890          "response": {
70891            "$ref": "Operation"
70892          },
70893          "scopes": [
70894            "https://www.googleapis.com/auth/cloud-platform",
70895            "https://www.googleapis.com/auth/compute"
70896          ],
70897          "description": "Disable this project as a shared VPC host project."
70898        },
70899        "enableXpnResource": {
70900          "id": "compute.projects.enableXpnResource",
70901          "path": "projects/{project}/enableXpnResource",
70902          "flatPath": "projects/{project}/enableXpnResource",
70903          "httpMethod": "POST",
70904          "parameters": {
70905            "project": {
70906              "description": "Project ID for this request.",
70907              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70908              "location": "path",
70909              "required": true,
70910              "type": "string"
70911            },
70912            "requestId": {
70913              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
70914              "location": "query",
70915              "type": "string"
70916            }
70917          },
70918          "parameterOrder": [
70919            "project"
70920          ],
70921          "request": {
70922            "$ref": "ProjectsEnableXpnResourceRequest"
70923          },
70924          "response": {
70925            "$ref": "Operation"
70926          },
70927          "scopes": [
70928            "https://www.googleapis.com/auth/cloud-platform",
70929            "https://www.googleapis.com/auth/compute"
70930          ],
70931          "description": "Enable service resource (a.k.a service project) for a host project, so that subnets in the host project can be used by instances in the service project."
70932        },
70933        "disableXpnResource": {
70934          "id": "compute.projects.disableXpnResource",
70935          "path": "projects/{project}/disableXpnResource",
70936          "flatPath": "projects/{project}/disableXpnResource",
70937          "httpMethod": "POST",
70938          "parameters": {
70939            "project": {
70940              "description": "Project ID for this request.",
70941              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70942              "location": "path",
70943              "required": true,
70944              "type": "string"
70945            },
70946            "requestId": {
70947              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
70948              "location": "query",
70949              "type": "string"
70950            }
70951          },
70952          "parameterOrder": [
70953            "project"
70954          ],
70955          "request": {
70956            "$ref": "ProjectsDisableXpnResourceRequest"
70957          },
70958          "response": {
70959            "$ref": "Operation"
70960          },
70961          "scopes": [
70962            "https://www.googleapis.com/auth/cloud-platform",
70963            "https://www.googleapis.com/auth/compute"
70964          ],
70965          "description": "Disable a service resource (also known as service project) associated with this host project."
70966        },
70967        "getXpnHost": {
70968          "id": "compute.projects.getXpnHost",
70969          "path": "projects/{project}/getXpnHost",
70970          "flatPath": "projects/{project}/getXpnHost",
70971          "httpMethod": "GET",
70972          "parameters": {
70973            "project": {
70974              "description": "Project ID for this request.",
70975              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
70976              "location": "path",
70977              "required": true,
70978              "type": "string"
70979            }
70980          },
70981          "parameterOrder": [
70982            "project"
70983          ],
70984          "response": {
70985            "$ref": "Project"
70986          },
70987          "scopes": [
70988            "https://www.googleapis.com/auth/cloud-platform",
70989            "https://www.googleapis.com/auth/compute"
70990          ],
70991          "description": "Gets the shared VPC host project that this project links to. May be empty if no link exists."
70992        },
70993        "getXpnResources": {
70994          "id": "compute.projects.getXpnResources",
70995          "path": "projects/{project}/getXpnResources",
70996          "flatPath": "projects/{project}/getXpnResources",
70997          "httpMethod": "GET",
70998          "parameters": {
70999            "filter": {
71000              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
71001              "location": "query",
71002              "type": "string"
71003            },
71004            "maxResults": {
71005              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
71006              "default": "500",
71007              "minimum": "0",
71008              "location": "query",
71009              "type": "integer",
71010              "format": "uint32"
71011            },
71012            "orderBy": {
71013              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
71014              "location": "query",
71015              "type": "string"
71016            },
71017            "pageToken": {
71018              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
71019              "location": "query",
71020              "type": "string"
71021            },
71022            "project": {
71023              "description": "Project ID for this request.",
71024              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71025              "location": "path",
71026              "required": true,
71027              "type": "string"
71028            },
71029            "returnPartialSuccess": {
71030              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
71031              "location": "query",
71032              "type": "boolean"
71033            }
71034          },
71035          "parameterOrder": [
71036            "project"
71037          ],
71038          "response": {
71039            "$ref": "ProjectsGetXpnResources"
71040          },
71041          "scopes": [
71042            "https://www.googleapis.com/auth/cloud-platform",
71043            "https://www.googleapis.com/auth/compute"
71044          ],
71045          "description": "Gets service resources (a.k.a service project) associated with this host project."
71046        },
71047        "setDefaultNetworkTier": {
71048          "id": "compute.projects.setDefaultNetworkTier",
71049          "path": "projects/{project}/setDefaultNetworkTier",
71050          "flatPath": "projects/{project}/setDefaultNetworkTier",
71051          "httpMethod": "POST",
71052          "parameters": {
71053            "project": {
71054              "description": "Project ID for this request.",
71055              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71056              "location": "path",
71057              "required": true,
71058              "type": "string"
71059            },
71060            "requestId": {
71061              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
71062              "location": "query",
71063              "type": "string"
71064            }
71065          },
71066          "parameterOrder": [
71067            "project"
71068          ],
71069          "request": {
71070            "$ref": "ProjectsSetDefaultNetworkTierRequest"
71071          },
71072          "response": {
71073            "$ref": "Operation"
71074          },
71075          "scopes": [
71076            "https://www.googleapis.com/auth/cloud-platform",
71077            "https://www.googleapis.com/auth/compute"
71078          ],
71079          "description": "Sets the default network tier of the project. The default network tier is used when an address/forwardingRule/instance is created without specifying the network tier field."
71080        },
71081        "setCloudArmorTier": {
71082          "id": "compute.projects.setCloudArmorTier",
71083          "path": "projects/{project}/setCloudArmorTier",
71084          "flatPath": "projects/{project}/setCloudArmorTier",
71085          "httpMethod": "POST",
71086          "parameters": {
71087            "project": {
71088              "description": "Project ID for this request.",
71089              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71090              "location": "path",
71091              "required": true,
71092              "type": "string"
71093            },
71094            "requestId": {
71095              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
71096              "location": "query",
71097              "type": "string"
71098            }
71099          },
71100          "parameterOrder": [
71101            "project"
71102          ],
71103          "request": {
71104            "$ref": "ProjectsSetCloudArmorTierRequest"
71105          },
71106          "response": {
71107            "$ref": "Operation"
71108          },
71109          "scopes": [
71110            "https://www.googleapis.com/auth/cloud-platform",
71111            "https://www.googleapis.com/auth/compute"
71112          ],
71113          "description": "Sets the Cloud Armor tier of the project. To set ENTERPRISE or above the billing account of the project must be subscribed to Cloud Armor Enterprise. See Subscribing to Cloud Armor Enterprise for more information."
71114        }
71115      }
71116    },
71117    "publicAdvertisedPrefixes": {
71118      "methods": {
71119        "list": {
71120          "id": "compute.publicAdvertisedPrefixes.list",
71121          "path": "projects/{project}/global/publicAdvertisedPrefixes",
71122          "flatPath": "projects/{project}/global/publicAdvertisedPrefixes",
71123          "httpMethod": "GET",
71124          "parameters": {
71125            "filter": {
71126              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
71127              "location": "query",
71128              "type": "string"
71129            },
71130            "maxResults": {
71131              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
71132              "default": "500",
71133              "minimum": "0",
71134              "location": "query",
71135              "type": "integer",
71136              "format": "uint32"
71137            },
71138            "orderBy": {
71139              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
71140              "location": "query",
71141              "type": "string"
71142            },
71143            "pageToken": {
71144              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
71145              "location": "query",
71146              "type": "string"
71147            },
71148            "project": {
71149              "description": "Project ID for this request.",
71150              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71151              "location": "path",
71152              "required": true,
71153              "type": "string"
71154            },
71155            "returnPartialSuccess": {
71156              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
71157              "location": "query",
71158              "type": "boolean"
71159            }
71160          },
71161          "parameterOrder": [
71162            "project"
71163          ],
71164          "response": {
71165            "$ref": "PublicAdvertisedPrefixList"
71166          },
71167          "scopes": [
71168            "https://www.googleapis.com/auth/cloud-platform",
71169            "https://www.googleapis.com/auth/compute",
71170            "https://www.googleapis.com/auth/compute.readonly"
71171          ],
71172          "description": "Lists the PublicAdvertisedPrefixes for a project."
71173        },
71174        "get": {
71175          "id": "compute.publicAdvertisedPrefixes.get",
71176          "path": "projects/{project}/global/publicAdvertisedPrefixes/{publicAdvertisedPrefix}",
71177          "flatPath": "projects/{project}/global/publicAdvertisedPrefixes/{publicAdvertisedPrefix}",
71178          "httpMethod": "GET",
71179          "parameters": {
71180            "project": {
71181              "description": "Project ID for this request.",
71182              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71183              "location": "path",
71184              "required": true,
71185              "type": "string"
71186            },
71187            "publicAdvertisedPrefix": {
71188              "description": "Name of the PublicAdvertisedPrefix resource to return.",
71189              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
71190              "location": "path",
71191              "required": true,
71192              "type": "string"
71193            }
71194          },
71195          "parameterOrder": [
71196            "project",
71197            "publicAdvertisedPrefix"
71198          ],
71199          "response": {
71200            "$ref": "PublicAdvertisedPrefix"
71201          },
71202          "scopes": [
71203            "https://www.googleapis.com/auth/cloud-platform",
71204            "https://www.googleapis.com/auth/compute",
71205            "https://www.googleapis.com/auth/compute.readonly"
71206          ],
71207          "description": "Returns the specified PublicAdvertisedPrefix resource."
71208        },
71209        "insert": {
71210          "id": "compute.publicAdvertisedPrefixes.insert",
71211          "path": "projects/{project}/global/publicAdvertisedPrefixes",
71212          "flatPath": "projects/{project}/global/publicAdvertisedPrefixes",
71213          "httpMethod": "POST",
71214          "parameters": {
71215            "project": {
71216              "description": "Project ID for this request.",
71217              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71218              "location": "path",
71219              "required": true,
71220              "type": "string"
71221            },
71222            "requestId": {
71223              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
71224              "location": "query",
71225              "type": "string"
71226            }
71227          },
71228          "parameterOrder": [
71229            "project"
71230          ],
71231          "request": {
71232            "$ref": "PublicAdvertisedPrefix"
71233          },
71234          "response": {
71235            "$ref": "Operation"
71236          },
71237          "scopes": [
71238            "https://www.googleapis.com/auth/cloud-platform",
71239            "https://www.googleapis.com/auth/compute"
71240          ],
71241          "description": "Creates a PublicAdvertisedPrefix in the specified project using the parameters that are included in the request."
71242        },
71243        "delete": {
71244          "id": "compute.publicAdvertisedPrefixes.delete",
71245          "path": "projects/{project}/global/publicAdvertisedPrefixes/{publicAdvertisedPrefix}",
71246          "flatPath": "projects/{project}/global/publicAdvertisedPrefixes/{publicAdvertisedPrefix}",
71247          "httpMethod": "DELETE",
71248          "parameters": {
71249            "project": {
71250              "description": "Project ID for this request.",
71251              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71252              "location": "path",
71253              "required": true,
71254              "type": "string"
71255            },
71256            "publicAdvertisedPrefix": {
71257              "description": "Name of the PublicAdvertisedPrefix resource to delete.",
71258              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
71259              "location": "path",
71260              "required": true,
71261              "type": "string"
71262            },
71263            "requestId": {
71264              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
71265              "location": "query",
71266              "type": "string"
71267            }
71268          },
71269          "parameterOrder": [
71270            "project",
71271            "publicAdvertisedPrefix"
71272          ],
71273          "response": {
71274            "$ref": "Operation"
71275          },
71276          "scopes": [
71277            "https://www.googleapis.com/auth/cloud-platform",
71278            "https://www.googleapis.com/auth/compute"
71279          ],
71280          "description": "Deletes the specified PublicAdvertisedPrefix"
71281        },
71282        "patch": {
71283          "id": "compute.publicAdvertisedPrefixes.patch",
71284          "path": "projects/{project}/global/publicAdvertisedPrefixes/{publicAdvertisedPrefix}",
71285          "flatPath": "projects/{project}/global/publicAdvertisedPrefixes/{publicAdvertisedPrefix}",
71286          "httpMethod": "PATCH",
71287          "parameters": {
71288            "project": {
71289              "description": "Project ID for this request.",
71290              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71291              "location": "path",
71292              "required": true,
71293              "type": "string"
71294            },
71295            "publicAdvertisedPrefix": {
71296              "description": "Name of the PublicAdvertisedPrefix resource to patch.",
71297              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
71298              "location": "path",
71299              "required": true,
71300              "type": "string"
71301            },
71302            "requestId": {
71303              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
71304              "location": "query",
71305              "type": "string"
71306            }
71307          },
71308          "parameterOrder": [
71309            "project",
71310            "publicAdvertisedPrefix"
71311          ],
71312          "request": {
71313            "$ref": "PublicAdvertisedPrefix"
71314          },
71315          "response": {
71316            "$ref": "Operation"
71317          },
71318          "scopes": [
71319            "https://www.googleapis.com/auth/cloud-platform",
71320            "https://www.googleapis.com/auth/compute"
71321          ],
71322          "description": "Patches the specified Router resource with the data included in the request. This method supports PATCH semantics and uses JSON merge patch format and processing rules."
71323        },
71324        "announce": {
71325          "id": "compute.publicAdvertisedPrefixes.announce",
71326          "path": "projects/{project}/global/publicAdvertisedPrefixes/{publicAdvertisedPrefix}/announce",
71327          "flatPath": "projects/{project}/global/publicAdvertisedPrefixes/{publicAdvertisedPrefix}/announce",
71328          "httpMethod": "POST",
71329          "parameters": {
71330            "project": {
71331              "description": "Project ID for this request.",
71332              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71333              "location": "path",
71334              "required": true,
71335              "type": "string"
71336            },
71337            "publicAdvertisedPrefix": {
71338              "description": "The name of the public advertised prefix. It should comply with RFC1035.",
71339              "location": "path",
71340              "required": true,
71341              "type": "string"
71342            },
71343            "requestId": {
71344              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
71345              "location": "query",
71346              "type": "string"
71347            }
71348          },
71349          "parameterOrder": [
71350            "project",
71351            "publicAdvertisedPrefix"
71352          ],
71353          "response": {
71354            "$ref": "Operation"
71355          },
71356          "scopes": [
71357            "https://www.googleapis.com/auth/cloud-platform",
71358            "https://www.googleapis.com/auth/compute"
71359          ],
71360          "description": "Announces the specified PublicAdvertisedPrefix"
71361        },
71362        "withdraw": {
71363          "id": "compute.publicAdvertisedPrefixes.withdraw",
71364          "path": "projects/{project}/global/publicAdvertisedPrefixes/{publicAdvertisedPrefix}/withdraw",
71365          "flatPath": "projects/{project}/global/publicAdvertisedPrefixes/{publicAdvertisedPrefix}/withdraw",
71366          "httpMethod": "POST",
71367          "parameters": {
71368            "project": {
71369              "description": "Project ID for this request.",
71370              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71371              "location": "path",
71372              "required": true,
71373              "type": "string"
71374            },
71375            "publicAdvertisedPrefix": {
71376              "description": "The name of the public advertised prefix. It should comply with RFC1035.",
71377              "location": "path",
71378              "required": true,
71379              "type": "string"
71380            },
71381            "requestId": {
71382              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
71383              "location": "query",
71384              "type": "string"
71385            }
71386          },
71387          "parameterOrder": [
71388            "project",
71389            "publicAdvertisedPrefix"
71390          ],
71391          "response": {
71392            "$ref": "Operation"
71393          },
71394          "scopes": [
71395            "https://www.googleapis.com/auth/cloud-platform",
71396            "https://www.googleapis.com/auth/compute"
71397          ],
71398          "description": "Withdraws the specified PublicAdvertisedPrefix"
71399        }
71400      }
71401    },
71402    "globalPublicDelegatedPrefixes": {
71403      "methods": {
71404        "list": {
71405          "id": "compute.globalPublicDelegatedPrefixes.list",
71406          "path": "projects/{project}/global/publicDelegatedPrefixes",
71407          "flatPath": "projects/{project}/global/publicDelegatedPrefixes",
71408          "httpMethod": "GET",
71409          "parameters": {
71410            "filter": {
71411              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
71412              "location": "query",
71413              "type": "string"
71414            },
71415            "maxResults": {
71416              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
71417              "default": "500",
71418              "minimum": "0",
71419              "location": "query",
71420              "type": "integer",
71421              "format": "uint32"
71422            },
71423            "orderBy": {
71424              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
71425              "location": "query",
71426              "type": "string"
71427            },
71428            "pageToken": {
71429              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
71430              "location": "query",
71431              "type": "string"
71432            },
71433            "project": {
71434              "description": "Project ID for this request.",
71435              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71436              "location": "path",
71437              "required": true,
71438              "type": "string"
71439            },
71440            "returnPartialSuccess": {
71441              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
71442              "location": "query",
71443              "type": "boolean"
71444            }
71445          },
71446          "parameterOrder": [
71447            "project"
71448          ],
71449          "response": {
71450            "$ref": "PublicDelegatedPrefixList"
71451          },
71452          "scopes": [
71453            "https://www.googleapis.com/auth/cloud-platform",
71454            "https://www.googleapis.com/auth/compute",
71455            "https://www.googleapis.com/auth/compute.readonly"
71456          ],
71457          "description": "Lists the global PublicDelegatedPrefixes for a project."
71458        },
71459        "get": {
71460          "id": "compute.globalPublicDelegatedPrefixes.get",
71461          "path": "projects/{project}/global/publicDelegatedPrefixes/{publicDelegatedPrefix}",
71462          "flatPath": "projects/{project}/global/publicDelegatedPrefixes/{publicDelegatedPrefix}",
71463          "httpMethod": "GET",
71464          "parameters": {
71465            "project": {
71466              "description": "Project ID for this request.",
71467              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71468              "location": "path",
71469              "required": true,
71470              "type": "string"
71471            },
71472            "publicDelegatedPrefix": {
71473              "description": "Name of the PublicDelegatedPrefix resource to return.",
71474              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
71475              "location": "path",
71476              "required": true,
71477              "type": "string"
71478            }
71479          },
71480          "parameterOrder": [
71481            "project",
71482            "publicDelegatedPrefix"
71483          ],
71484          "response": {
71485            "$ref": "PublicDelegatedPrefix"
71486          },
71487          "scopes": [
71488            "https://www.googleapis.com/auth/cloud-platform",
71489            "https://www.googleapis.com/auth/compute",
71490            "https://www.googleapis.com/auth/compute.readonly"
71491          ],
71492          "description": "Returns the specified global PublicDelegatedPrefix resource."
71493        },
71494        "insert": {
71495          "id": "compute.globalPublicDelegatedPrefixes.insert",
71496          "path": "projects/{project}/global/publicDelegatedPrefixes",
71497          "flatPath": "projects/{project}/global/publicDelegatedPrefixes",
71498          "httpMethod": "POST",
71499          "parameters": {
71500            "project": {
71501              "description": "Project ID for this request.",
71502              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71503              "location": "path",
71504              "required": true,
71505              "type": "string"
71506            },
71507            "requestId": {
71508              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
71509              "location": "query",
71510              "type": "string"
71511            }
71512          },
71513          "parameterOrder": [
71514            "project"
71515          ],
71516          "request": {
71517            "$ref": "PublicDelegatedPrefix"
71518          },
71519          "response": {
71520            "$ref": "Operation"
71521          },
71522          "scopes": [
71523            "https://www.googleapis.com/auth/cloud-platform",
71524            "https://www.googleapis.com/auth/compute"
71525          ],
71526          "description": "Creates a global PublicDelegatedPrefix in the specified project using the parameters that are included in the request."
71527        },
71528        "delete": {
71529          "id": "compute.globalPublicDelegatedPrefixes.delete",
71530          "path": "projects/{project}/global/publicDelegatedPrefixes/{publicDelegatedPrefix}",
71531          "flatPath": "projects/{project}/global/publicDelegatedPrefixes/{publicDelegatedPrefix}",
71532          "httpMethod": "DELETE",
71533          "parameters": {
71534            "project": {
71535              "description": "Project ID for this request.",
71536              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71537              "location": "path",
71538              "required": true,
71539              "type": "string"
71540            },
71541            "publicDelegatedPrefix": {
71542              "description": "Name of the PublicDelegatedPrefix resource to delete.",
71543              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
71544              "location": "path",
71545              "required": true,
71546              "type": "string"
71547            },
71548            "requestId": {
71549              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
71550              "location": "query",
71551              "type": "string"
71552            }
71553          },
71554          "parameterOrder": [
71555            "project",
71556            "publicDelegatedPrefix"
71557          ],
71558          "response": {
71559            "$ref": "Operation"
71560          },
71561          "scopes": [
71562            "https://www.googleapis.com/auth/cloud-platform",
71563            "https://www.googleapis.com/auth/compute"
71564          ],
71565          "description": "Deletes the specified global PublicDelegatedPrefix."
71566        },
71567        "patch": {
71568          "id": "compute.globalPublicDelegatedPrefixes.patch",
71569          "path": "projects/{project}/global/publicDelegatedPrefixes/{publicDelegatedPrefix}",
71570          "flatPath": "projects/{project}/global/publicDelegatedPrefixes/{publicDelegatedPrefix}",
71571          "httpMethod": "PATCH",
71572          "parameters": {
71573            "project": {
71574              "description": "Project ID for this request.",
71575              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71576              "location": "path",
71577              "required": true,
71578              "type": "string"
71579            },
71580            "publicDelegatedPrefix": {
71581              "description": "Name of the PublicDelegatedPrefix resource to patch.",
71582              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
71583              "location": "path",
71584              "required": true,
71585              "type": "string"
71586            },
71587            "requestId": {
71588              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
71589              "location": "query",
71590              "type": "string"
71591            }
71592          },
71593          "parameterOrder": [
71594            "project",
71595            "publicDelegatedPrefix"
71596          ],
71597          "request": {
71598            "$ref": "PublicDelegatedPrefix"
71599          },
71600          "response": {
71601            "$ref": "Operation"
71602          },
71603          "scopes": [
71604            "https://www.googleapis.com/auth/cloud-platform",
71605            "https://www.googleapis.com/auth/compute"
71606          ],
71607          "description": "Patches the specified global PublicDelegatedPrefix resource with the data included in the request. This method supports PATCH semantics and uses JSON merge patch format and processing rules."
71608        }
71609      }
71610    },
71611    "publicDelegatedPrefixes": {
71612      "methods": {
71613        "list": {
71614          "id": "compute.publicDelegatedPrefixes.list",
71615          "path": "projects/{project}/regions/{region}/publicDelegatedPrefixes",
71616          "flatPath": "projects/{project}/regions/{region}/publicDelegatedPrefixes",
71617          "httpMethod": "GET",
71618          "parameters": {
71619            "filter": {
71620              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
71621              "location": "query",
71622              "type": "string"
71623            },
71624            "maxResults": {
71625              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
71626              "default": "500",
71627              "minimum": "0",
71628              "location": "query",
71629              "type": "integer",
71630              "format": "uint32"
71631            },
71632            "orderBy": {
71633              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
71634              "location": "query",
71635              "type": "string"
71636            },
71637            "pageToken": {
71638              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
71639              "location": "query",
71640              "type": "string"
71641            },
71642            "project": {
71643              "description": "Project ID for this request.",
71644              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71645              "location": "path",
71646              "required": true,
71647              "type": "string"
71648            },
71649            "region": {
71650              "description": "Name of the region of this request.",
71651              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
71652              "location": "path",
71653              "required": true,
71654              "type": "string"
71655            },
71656            "returnPartialSuccess": {
71657              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
71658              "location": "query",
71659              "type": "boolean"
71660            }
71661          },
71662          "parameterOrder": [
71663            "project",
71664            "region"
71665          ],
71666          "response": {
71667            "$ref": "PublicDelegatedPrefixList"
71668          },
71669          "scopes": [
71670            "https://www.googleapis.com/auth/cloud-platform",
71671            "https://www.googleapis.com/auth/compute",
71672            "https://www.googleapis.com/auth/compute.readonly"
71673          ],
71674          "description": "Lists the PublicDelegatedPrefixes for a project in the given region."
71675        },
71676        "get": {
71677          "id": "compute.publicDelegatedPrefixes.get",
71678          "path": "projects/{project}/regions/{region}/publicDelegatedPrefixes/{publicDelegatedPrefix}",
71679          "flatPath": "projects/{project}/regions/{region}/publicDelegatedPrefixes/{publicDelegatedPrefix}",
71680          "httpMethod": "GET",
71681          "parameters": {
71682            "project": {
71683              "description": "Project ID for this request.",
71684              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71685              "location": "path",
71686              "required": true,
71687              "type": "string"
71688            },
71689            "publicDelegatedPrefix": {
71690              "description": "Name of the PublicDelegatedPrefix resource to return.",
71691              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
71692              "location": "path",
71693              "required": true,
71694              "type": "string"
71695            },
71696            "region": {
71697              "description": "Name of the region of this request.",
71698              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
71699              "location": "path",
71700              "required": true,
71701              "type": "string"
71702            }
71703          },
71704          "parameterOrder": [
71705            "project",
71706            "region",
71707            "publicDelegatedPrefix"
71708          ],
71709          "response": {
71710            "$ref": "PublicDelegatedPrefix"
71711          },
71712          "scopes": [
71713            "https://www.googleapis.com/auth/cloud-platform",
71714            "https://www.googleapis.com/auth/compute",
71715            "https://www.googleapis.com/auth/compute.readonly"
71716          ],
71717          "description": "Returns the specified PublicDelegatedPrefix resource in the given region."
71718        },
71719        "insert": {
71720          "id": "compute.publicDelegatedPrefixes.insert",
71721          "path": "projects/{project}/regions/{region}/publicDelegatedPrefixes",
71722          "flatPath": "projects/{project}/regions/{region}/publicDelegatedPrefixes",
71723          "httpMethod": "POST",
71724          "parameters": {
71725            "project": {
71726              "description": "Project ID for this request.",
71727              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71728              "location": "path",
71729              "required": true,
71730              "type": "string"
71731            },
71732            "region": {
71733              "description": "Name of the region of this request.",
71734              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
71735              "location": "path",
71736              "required": true,
71737              "type": "string"
71738            },
71739            "requestId": {
71740              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
71741              "location": "query",
71742              "type": "string"
71743            }
71744          },
71745          "parameterOrder": [
71746            "project",
71747            "region"
71748          ],
71749          "request": {
71750            "$ref": "PublicDelegatedPrefix"
71751          },
71752          "response": {
71753            "$ref": "Operation"
71754          },
71755          "scopes": [
71756            "https://www.googleapis.com/auth/cloud-platform",
71757            "https://www.googleapis.com/auth/compute"
71758          ],
71759          "description": "Creates a PublicDelegatedPrefix in the specified project in the given region using the parameters that are included in the request."
71760        },
71761        "delete": {
71762          "id": "compute.publicDelegatedPrefixes.delete",
71763          "path": "projects/{project}/regions/{region}/publicDelegatedPrefixes/{publicDelegatedPrefix}",
71764          "flatPath": "projects/{project}/regions/{region}/publicDelegatedPrefixes/{publicDelegatedPrefix}",
71765          "httpMethod": "DELETE",
71766          "parameters": {
71767            "project": {
71768              "description": "Project ID for this request.",
71769              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71770              "location": "path",
71771              "required": true,
71772              "type": "string"
71773            },
71774            "publicDelegatedPrefix": {
71775              "description": "Name of the PublicDelegatedPrefix resource to delete.",
71776              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
71777              "location": "path",
71778              "required": true,
71779              "type": "string"
71780            },
71781            "region": {
71782              "description": "Name of the region of this request.",
71783              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
71784              "location": "path",
71785              "required": true,
71786              "type": "string"
71787            },
71788            "requestId": {
71789              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
71790              "location": "query",
71791              "type": "string"
71792            }
71793          },
71794          "parameterOrder": [
71795            "project",
71796            "region",
71797            "publicDelegatedPrefix"
71798          ],
71799          "response": {
71800            "$ref": "Operation"
71801          },
71802          "scopes": [
71803            "https://www.googleapis.com/auth/cloud-platform",
71804            "https://www.googleapis.com/auth/compute"
71805          ],
71806          "description": "Deletes the specified PublicDelegatedPrefix in the given region."
71807        },
71808        "patch": {
71809          "id": "compute.publicDelegatedPrefixes.patch",
71810          "path": "projects/{project}/regions/{region}/publicDelegatedPrefixes/{publicDelegatedPrefix}",
71811          "flatPath": "projects/{project}/regions/{region}/publicDelegatedPrefixes/{publicDelegatedPrefix}",
71812          "httpMethod": "PATCH",
71813          "parameters": {
71814            "project": {
71815              "description": "Project ID for this request.",
71816              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71817              "location": "path",
71818              "required": true,
71819              "type": "string"
71820            },
71821            "publicDelegatedPrefix": {
71822              "description": "Name of the PublicDelegatedPrefix resource to patch.",
71823              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
71824              "location": "path",
71825              "required": true,
71826              "type": "string"
71827            },
71828            "region": {
71829              "description": "Name of the region for this request.",
71830              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
71831              "location": "path",
71832              "required": true,
71833              "type": "string"
71834            },
71835            "requestId": {
71836              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
71837              "location": "query",
71838              "type": "string"
71839            }
71840          },
71841          "parameterOrder": [
71842            "project",
71843            "region",
71844            "publicDelegatedPrefix"
71845          ],
71846          "request": {
71847            "$ref": "PublicDelegatedPrefix"
71848          },
71849          "response": {
71850            "$ref": "Operation"
71851          },
71852          "scopes": [
71853            "https://www.googleapis.com/auth/cloud-platform",
71854            "https://www.googleapis.com/auth/compute"
71855          ],
71856          "description": "Patches the specified PublicDelegatedPrefix resource with the data included in the request. This method supports PATCH semantics and uses JSON merge patch format and processing rules."
71857        },
71858        "announce": {
71859          "id": "compute.publicDelegatedPrefixes.announce",
71860          "path": "projects/{project}/regions/{region}/publicDelegatedPrefixes/{publicDelegatedPrefix}/announce",
71861          "flatPath": "projects/{project}/regions/{region}/publicDelegatedPrefixes/{publicDelegatedPrefix}/announce",
71862          "httpMethod": "POST",
71863          "parameters": {
71864            "project": {
71865              "description": "Project ID for this request.",
71866              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71867              "location": "path",
71868              "required": true,
71869              "type": "string"
71870            },
71871            "publicDelegatedPrefix": {
71872              "description": "The name of the public delegated prefix. It should comply with RFC1035.",
71873              "location": "path",
71874              "required": true,
71875              "type": "string"
71876            },
71877            "region": {
71878              "description": "The name of the region where the public delegated prefix is located. It should comply with RFC1035.",
71879              "location": "path",
71880              "required": true,
71881              "type": "string"
71882            },
71883            "requestId": {
71884              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
71885              "location": "query",
71886              "type": "string"
71887            }
71888          },
71889          "parameterOrder": [
71890            "project",
71891            "region",
71892            "publicDelegatedPrefix"
71893          ],
71894          "response": {
71895            "$ref": "Operation"
71896          },
71897          "scopes": [
71898            "https://www.googleapis.com/auth/cloud-platform",
71899            "https://www.googleapis.com/auth/compute"
71900          ],
71901          "description": "Announces the specified PublicDelegatedPrefix in the given region."
71902        },
71903        "withdraw": {
71904          "id": "compute.publicDelegatedPrefixes.withdraw",
71905          "path": "projects/{project}/regions/{region}/publicDelegatedPrefixes/{publicDelegatedPrefix}/withdraw",
71906          "flatPath": "projects/{project}/regions/{region}/publicDelegatedPrefixes/{publicDelegatedPrefix}/withdraw",
71907          "httpMethod": "POST",
71908          "parameters": {
71909            "project": {
71910              "description": "Project ID for this request.",
71911              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71912              "location": "path",
71913              "required": true,
71914              "type": "string"
71915            },
71916            "publicDelegatedPrefix": {
71917              "description": "The name of the public delegated prefix. It should comply with RFC1035.",
71918              "location": "path",
71919              "required": true,
71920              "type": "string"
71921            },
71922            "region": {
71923              "description": "The name of the region where the public delegated prefix is located. It should comply with RFC1035.",
71924              "location": "path",
71925              "required": true,
71926              "type": "string"
71927            },
71928            "requestId": {
71929              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
71930              "location": "query",
71931              "type": "string"
71932            }
71933          },
71934          "parameterOrder": [
71935            "project",
71936            "region",
71937            "publicDelegatedPrefix"
71938          ],
71939          "response": {
71940            "$ref": "Operation"
71941          },
71942          "scopes": [
71943            "https://www.googleapis.com/auth/cloud-platform",
71944            "https://www.googleapis.com/auth/compute"
71945          ],
71946          "description": "Withdraws the specified PublicDelegatedPrefix in the given region."
71947        },
71948        "aggregatedList": {
71949          "id": "compute.publicDelegatedPrefixes.aggregatedList",
71950          "path": "projects/{project}/aggregated/publicDelegatedPrefixes",
71951          "flatPath": "projects/{project}/aggregated/publicDelegatedPrefixes",
71952          "httpMethod": "GET",
71953          "parameters": {
71954            "filter": {
71955              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
71956              "location": "query",
71957              "type": "string"
71958            },
71959            "includeAllScopes": {
71960              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
71961              "location": "query",
71962              "type": "boolean"
71963            },
71964            "maxResults": {
71965              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
71966              "default": "500",
71967              "minimum": "0",
71968              "location": "query",
71969              "type": "integer",
71970              "format": "uint32"
71971            },
71972            "orderBy": {
71973              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
71974              "location": "query",
71975              "type": "string"
71976            },
71977            "pageToken": {
71978              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
71979              "location": "query",
71980              "type": "string"
71981            },
71982            "project": {
71983              "description": "Name of the project scoping this request.",
71984              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
71985              "location": "path",
71986              "required": true,
71987              "type": "string"
71988            },
71989            "returnPartialSuccess": {
71990              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
71991              "location": "query",
71992              "type": "boolean"
71993            },
71994            "serviceProjectNumber": {
71995              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
71996              "location": "query",
71997              "type": "string",
71998              "format": "int64"
71999            }
72000          },
72001          "parameterOrder": [
72002            "project"
72003          ],
72004          "response": {
72005            "$ref": "PublicDelegatedPrefixAggregatedList"
72006          },
72007          "scopes": [
72008            "https://www.googleapis.com/auth/cloud-platform",
72009            "https://www.googleapis.com/auth/compute",
72010            "https://www.googleapis.com/auth/compute.readonly"
72011          ],
72012          "description": "Lists all PublicDelegatedPrefix resources owned by the specific project across all scopes. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
72013        }
72014      }
72015    },
72016    "regions": {
72017      "methods": {
72018        "list": {
72019          "id": "compute.regions.list",
72020          "path": "projects/{project}/regions",
72021          "flatPath": "projects/{project}/regions",
72022          "httpMethod": "GET",
72023          "parameters": {
72024            "filter": {
72025              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
72026              "location": "query",
72027              "type": "string"
72028            },
72029            "maxResults": {
72030              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
72031              "default": "500",
72032              "minimum": "0",
72033              "location": "query",
72034              "type": "integer",
72035              "format": "uint32"
72036            },
72037            "orderBy": {
72038              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
72039              "location": "query",
72040              "type": "string"
72041            },
72042            "pageToken": {
72043              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
72044              "location": "query",
72045              "type": "string"
72046            },
72047            "project": {
72048              "description": "Project ID for this request.",
72049              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72050              "location": "path",
72051              "required": true,
72052              "type": "string"
72053            },
72054            "returnPartialSuccess": {
72055              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
72056              "location": "query",
72057              "type": "boolean"
72058            }
72059          },
72060          "parameterOrder": [
72061            "project"
72062          ],
72063          "response": {
72064            "$ref": "RegionList"
72065          },
72066          "scopes": [
72067            "https://www.googleapis.com/auth/cloud-platform",
72068            "https://www.googleapis.com/auth/compute",
72069            "https://www.googleapis.com/auth/compute.readonly"
72070          ],
72071          "description": "Retrieves the list of region resources available to the specified project. To decrease latency for this method, you can optionally omit any unneeded information from the response by using a field mask. This practice is especially recommended for unused quota information (the `items.quotas` field). To exclude one or more fields, set your request's `fields` query parameter to only include the fields you need. For example, to only include the `id` and `selfLink` fields, add the query parameter `?fields=id,selfLink` to your request."
72072        },
72073        "get": {
72074          "id": "compute.regions.get",
72075          "path": "projects/{project}/regions/{region}",
72076          "flatPath": "projects/{project}/regions/{region}",
72077          "httpMethod": "GET",
72078          "parameters": {
72079            "project": {
72080              "description": "Project ID for this request.",
72081              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72082              "location": "path",
72083              "required": true,
72084              "type": "string"
72085            },
72086            "region": {
72087              "description": "Name of the region resource to return.",
72088              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
72089              "location": "path",
72090              "required": true,
72091              "type": "string"
72092            }
72093          },
72094          "parameterOrder": [
72095            "project",
72096            "region"
72097          ],
72098          "response": {
72099            "$ref": "Region"
72100          },
72101          "scopes": [
72102            "https://www.googleapis.com/auth/cloud-platform",
72103            "https://www.googleapis.com/auth/compute",
72104            "https://www.googleapis.com/auth/compute.readonly"
72105          ],
72106          "description": "Returns the specified Region resource. To decrease latency for this method, you can optionally omit any unneeded information from the response by using a field mask. This practice is especially recommended for unused quota information (the `quotas` field). To exclude one or more fields, set your request's `fields` query parameter to only include the fields you need. For example, to only include the `id` and `selfLink` fields, add the query parameter `?fields=id,selfLink` to your request."
72107        }
72108      }
72109    },
72110    "resourcePolicies": {
72111      "methods": {
72112        "list": {
72113          "id": "compute.resourcePolicies.list",
72114          "path": "projects/{project}/regions/{region}/resourcePolicies",
72115          "flatPath": "projects/{project}/regions/{region}/resourcePolicies",
72116          "httpMethod": "GET",
72117          "parameters": {
72118            "filter": {
72119              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
72120              "location": "query",
72121              "type": "string"
72122            },
72123            "maxResults": {
72124              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
72125              "default": "500",
72126              "minimum": "0",
72127              "location": "query",
72128              "type": "integer",
72129              "format": "uint32"
72130            },
72131            "orderBy": {
72132              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
72133              "location": "query",
72134              "type": "string"
72135            },
72136            "pageToken": {
72137              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
72138              "location": "query",
72139              "type": "string"
72140            },
72141            "project": {
72142              "description": "Project ID for this request.",
72143              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72144              "location": "path",
72145              "required": true,
72146              "type": "string"
72147            },
72148            "region": {
72149              "description": "Name of the region for this request.",
72150              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
72151              "location": "path",
72152              "required": true,
72153              "type": "string"
72154            },
72155            "returnPartialSuccess": {
72156              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
72157              "location": "query",
72158              "type": "boolean"
72159            }
72160          },
72161          "parameterOrder": [
72162            "project",
72163            "region"
72164          ],
72165          "response": {
72166            "$ref": "ResourcePolicyList"
72167          },
72168          "scopes": [
72169            "https://www.googleapis.com/auth/cloud-platform",
72170            "https://www.googleapis.com/auth/compute",
72171            "https://www.googleapis.com/auth/compute.readonly"
72172          ],
72173          "description": "A list all the resource policies that have been configured for the specified project in specified region."
72174        },
72175        "aggregatedList": {
72176          "id": "compute.resourcePolicies.aggregatedList",
72177          "path": "projects/{project}/aggregated/resourcePolicies",
72178          "flatPath": "projects/{project}/aggregated/resourcePolicies",
72179          "httpMethod": "GET",
72180          "parameters": {
72181            "filter": {
72182              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
72183              "location": "query",
72184              "type": "string"
72185            },
72186            "includeAllScopes": {
72187              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
72188              "location": "query",
72189              "type": "boolean"
72190            },
72191            "maxResults": {
72192              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
72193              "default": "500",
72194              "minimum": "0",
72195              "location": "query",
72196              "type": "integer",
72197              "format": "uint32"
72198            },
72199            "orderBy": {
72200              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
72201              "location": "query",
72202              "type": "string"
72203            },
72204            "pageToken": {
72205              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
72206              "location": "query",
72207              "type": "string"
72208            },
72209            "project": {
72210              "description": "Project ID for this request.",
72211              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72212              "location": "path",
72213              "required": true,
72214              "type": "string"
72215            },
72216            "returnPartialSuccess": {
72217              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
72218              "location": "query",
72219              "type": "boolean"
72220            },
72221            "serviceProjectNumber": {
72222              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
72223              "location": "query",
72224              "type": "string",
72225              "format": "int64"
72226            }
72227          },
72228          "parameterOrder": [
72229            "project"
72230          ],
72231          "response": {
72232            "$ref": "ResourcePolicyAggregatedList"
72233          },
72234          "scopes": [
72235            "https://www.googleapis.com/auth/cloud-platform",
72236            "https://www.googleapis.com/auth/compute",
72237            "https://www.googleapis.com/auth/compute.readonly"
72238          ],
72239          "description": "Retrieves an aggregated list of resource policies. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
72240        },
72241        "get": {
72242          "id": "compute.resourcePolicies.get",
72243          "path": "projects/{project}/regions/{region}/resourcePolicies/{resourcePolicy}",
72244          "flatPath": "projects/{project}/regions/{region}/resourcePolicies/{resourcePolicy}",
72245          "httpMethod": "GET",
72246          "parameters": {
72247            "project": {
72248              "description": "Project ID for this request.",
72249              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72250              "location": "path",
72251              "required": true,
72252              "type": "string"
72253            },
72254            "region": {
72255              "description": "Name of the region for this request.",
72256              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
72257              "location": "path",
72258              "required": true,
72259              "type": "string"
72260            },
72261            "resourcePolicy": {
72262              "description": "Name of the resource policy to retrieve.",
72263              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
72264              "location": "path",
72265              "required": true,
72266              "type": "string"
72267            }
72268          },
72269          "parameterOrder": [
72270            "project",
72271            "region",
72272            "resourcePolicy"
72273          ],
72274          "response": {
72275            "$ref": "ResourcePolicy"
72276          },
72277          "scopes": [
72278            "https://www.googleapis.com/auth/cloud-platform",
72279            "https://www.googleapis.com/auth/compute",
72280            "https://www.googleapis.com/auth/compute.readonly"
72281          ],
72282          "description": "Retrieves all information of the specified resource policy."
72283        },
72284        "insert": {
72285          "id": "compute.resourcePolicies.insert",
72286          "path": "projects/{project}/regions/{region}/resourcePolicies",
72287          "flatPath": "projects/{project}/regions/{region}/resourcePolicies",
72288          "httpMethod": "POST",
72289          "parameters": {
72290            "project": {
72291              "description": "Project ID for this request.",
72292              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72293              "location": "path",
72294              "required": true,
72295              "type": "string"
72296            },
72297            "region": {
72298              "description": "Name of the region for this request.",
72299              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
72300              "location": "path",
72301              "required": true,
72302              "type": "string"
72303            },
72304            "requestId": {
72305              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
72306              "location": "query",
72307              "type": "string"
72308            }
72309          },
72310          "parameterOrder": [
72311            "project",
72312            "region"
72313          ],
72314          "request": {
72315            "$ref": "ResourcePolicy"
72316          },
72317          "response": {
72318            "$ref": "Operation"
72319          },
72320          "scopes": [
72321            "https://www.googleapis.com/auth/cloud-platform",
72322            "https://www.googleapis.com/auth/compute"
72323          ],
72324          "description": "Creates a new resource policy."
72325        },
72326        "delete": {
72327          "id": "compute.resourcePolicies.delete",
72328          "path": "projects/{project}/regions/{region}/resourcePolicies/{resourcePolicy}",
72329          "flatPath": "projects/{project}/regions/{region}/resourcePolicies/{resourcePolicy}",
72330          "httpMethod": "DELETE",
72331          "parameters": {
72332            "project": {
72333              "description": "Project ID for this request.",
72334              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72335              "location": "path",
72336              "required": true,
72337              "type": "string"
72338            },
72339            "region": {
72340              "description": "Name of the region for this request.",
72341              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
72342              "location": "path",
72343              "required": true,
72344              "type": "string"
72345            },
72346            "requestId": {
72347              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
72348              "location": "query",
72349              "type": "string"
72350            },
72351            "resourcePolicy": {
72352              "description": "Name of the resource policy to delete.",
72353              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
72354              "location": "path",
72355              "required": true,
72356              "type": "string"
72357            }
72358          },
72359          "parameterOrder": [
72360            "project",
72361            "region",
72362            "resourcePolicy"
72363          ],
72364          "response": {
72365            "$ref": "Operation"
72366          },
72367          "scopes": [
72368            "https://www.googleapis.com/auth/cloud-platform",
72369            "https://www.googleapis.com/auth/compute"
72370          ],
72371          "description": "Deletes the specified resource policy."
72372        },
72373        "patch": {
72374          "id": "compute.resourcePolicies.patch",
72375          "path": "projects/{project}/regions/{region}/resourcePolicies/{resourcePolicy}",
72376          "flatPath": "projects/{project}/regions/{region}/resourcePolicies/{resourcePolicy}",
72377          "httpMethod": "PATCH",
72378          "parameters": {
72379            "project": {
72380              "description": "Project ID for this request.",
72381              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72382              "location": "path",
72383              "required": true,
72384              "type": "string"
72385            },
72386            "region": {
72387              "description": "Name of the region for this request.",
72388              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
72389              "location": "path",
72390              "required": true,
72391              "type": "string"
72392            },
72393            "requestId": {
72394              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
72395              "location": "query",
72396              "type": "string"
72397            },
72398            "resourcePolicy": {
72399              "description": "Id of the resource policy to patch.",
72400              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
72401              "location": "path",
72402              "required": true,
72403              "type": "string"
72404            },
72405            "updateMask": {
72406              "description": "update_mask indicates fields to be updated as part of this request.",
72407              "location": "query",
72408              "type": "string",
72409              "format": "google-fieldmask"
72410            }
72411          },
72412          "parameterOrder": [
72413            "project",
72414            "region",
72415            "resourcePolicy"
72416          ],
72417          "request": {
72418            "$ref": "ResourcePolicy"
72419          },
72420          "response": {
72421            "$ref": "Operation"
72422          },
72423          "scopes": [
72424            "https://www.googleapis.com/auth/cloud-platform",
72425            "https://www.googleapis.com/auth/compute"
72426          ],
72427          "description": "Modify the specified resource policy."
72428        },
72429        "getIamPolicy": {
72430          "id": "compute.resourcePolicies.getIamPolicy",
72431          "path": "projects/{project}/regions/{region}/resourcePolicies/{resource}/getIamPolicy",
72432          "flatPath": "projects/{project}/regions/{region}/resourcePolicies/{resource}/getIamPolicy",
72433          "httpMethod": "GET",
72434          "parameters": {
72435            "optionsRequestedPolicyVersion": {
72436              "description": "Requested IAM Policy version.",
72437              "location": "query",
72438              "type": "integer",
72439              "format": "int32"
72440            },
72441            "project": {
72442              "description": "Project ID for this request.",
72443              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72444              "location": "path",
72445              "required": true,
72446              "type": "string"
72447            },
72448            "region": {
72449              "description": "The name of the region for this request.",
72450              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
72451              "location": "path",
72452              "required": true,
72453              "type": "string"
72454            },
72455            "resource": {
72456              "description": "Name or id of the resource for this request.",
72457              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
72458              "location": "path",
72459              "required": true,
72460              "type": "string"
72461            }
72462          },
72463          "parameterOrder": [
72464            "project",
72465            "region",
72466            "resource"
72467          ],
72468          "response": {
72469            "$ref": "Policy"
72470          },
72471          "scopes": [
72472            "https://www.googleapis.com/auth/cloud-platform",
72473            "https://www.googleapis.com/auth/compute",
72474            "https://www.googleapis.com/auth/compute.readonly"
72475          ],
72476          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
72477        },
72478        "setIamPolicy": {
72479          "id": "compute.resourcePolicies.setIamPolicy",
72480          "path": "projects/{project}/regions/{region}/resourcePolicies/{resource}/setIamPolicy",
72481          "flatPath": "projects/{project}/regions/{region}/resourcePolicies/{resource}/setIamPolicy",
72482          "httpMethod": "POST",
72483          "parameters": {
72484            "project": {
72485              "description": "Project ID for this request.",
72486              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72487              "location": "path",
72488              "required": true,
72489              "type": "string"
72490            },
72491            "region": {
72492              "description": "The name of the region for this request.",
72493              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
72494              "location": "path",
72495              "required": true,
72496              "type": "string"
72497            },
72498            "resource": {
72499              "description": "Name or id of the resource for this request.",
72500              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
72501              "location": "path",
72502              "required": true,
72503              "type": "string"
72504            }
72505          },
72506          "parameterOrder": [
72507            "project",
72508            "region",
72509            "resource"
72510          ],
72511          "request": {
72512            "$ref": "RegionSetPolicyRequest"
72513          },
72514          "response": {
72515            "$ref": "Policy"
72516          },
72517          "scopes": [
72518            "https://www.googleapis.com/auth/cloud-platform",
72519            "https://www.googleapis.com/auth/compute"
72520          ],
72521          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
72522        },
72523        "testIamPermissions": {
72524          "id": "compute.resourcePolicies.testIamPermissions",
72525          "path": "projects/{project}/regions/{region}/resourcePolicies/{resource}/testIamPermissions",
72526          "flatPath": "projects/{project}/regions/{region}/resourcePolicies/{resource}/testIamPermissions",
72527          "httpMethod": "POST",
72528          "parameters": {
72529            "project": {
72530              "description": "Project ID for this request.",
72531              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72532              "location": "path",
72533              "required": true,
72534              "type": "string"
72535            },
72536            "region": {
72537              "description": "The name of the region for this request.",
72538              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
72539              "location": "path",
72540              "required": true,
72541              "type": "string"
72542            },
72543            "resource": {
72544              "description": "Name or id of the resource for this request.",
72545              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
72546              "location": "path",
72547              "required": true,
72548              "type": "string"
72549            }
72550          },
72551          "parameterOrder": [
72552            "project",
72553            "region",
72554            "resource"
72555          ],
72556          "request": {
72557            "$ref": "TestPermissionsRequest"
72558          },
72559          "response": {
72560            "$ref": "TestPermissionsResponse"
72561          },
72562          "scopes": [
72563            "https://www.googleapis.com/auth/cloud-platform",
72564            "https://www.googleapis.com/auth/compute",
72565            "https://www.googleapis.com/auth/compute.readonly"
72566          ],
72567          "description": "Returns permissions that a caller has on the specified resource."
72568        }
72569      }
72570    },
72571    "routes": {
72572      "methods": {
72573        "list": {
72574          "id": "compute.routes.list",
72575          "path": "projects/{project}/global/routes",
72576          "flatPath": "projects/{project}/global/routes",
72577          "httpMethod": "GET",
72578          "parameters": {
72579            "filter": {
72580              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
72581              "location": "query",
72582              "type": "string"
72583            },
72584            "maxResults": {
72585              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
72586              "default": "500",
72587              "minimum": "0",
72588              "location": "query",
72589              "type": "integer",
72590              "format": "uint32"
72591            },
72592            "orderBy": {
72593              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
72594              "location": "query",
72595              "type": "string"
72596            },
72597            "pageToken": {
72598              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
72599              "location": "query",
72600              "type": "string"
72601            },
72602            "project": {
72603              "description": "Project ID for this request.",
72604              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72605              "location": "path",
72606              "required": true,
72607              "type": "string"
72608            },
72609            "returnPartialSuccess": {
72610              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
72611              "location": "query",
72612              "type": "boolean"
72613            }
72614          },
72615          "parameterOrder": [
72616            "project"
72617          ],
72618          "response": {
72619            "$ref": "RouteList"
72620          },
72621          "scopes": [
72622            "https://www.googleapis.com/auth/cloud-platform",
72623            "https://www.googleapis.com/auth/compute",
72624            "https://www.googleapis.com/auth/compute.readonly"
72625          ],
72626          "description": "Retrieves the list of Route resources available to the specified project."
72627        },
72628        "get": {
72629          "id": "compute.routes.get",
72630          "path": "projects/{project}/global/routes/{route}",
72631          "flatPath": "projects/{project}/global/routes/{route}",
72632          "httpMethod": "GET",
72633          "parameters": {
72634            "project": {
72635              "description": "Project ID for this request.",
72636              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72637              "location": "path",
72638              "required": true,
72639              "type": "string"
72640            },
72641            "route": {
72642              "description": "Name of the Route resource to return.",
72643              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
72644              "location": "path",
72645              "required": true,
72646              "type": "string"
72647            }
72648          },
72649          "parameterOrder": [
72650            "project",
72651            "route"
72652          ],
72653          "response": {
72654            "$ref": "Route"
72655          },
72656          "scopes": [
72657            "https://www.googleapis.com/auth/cloud-platform",
72658            "https://www.googleapis.com/auth/compute",
72659            "https://www.googleapis.com/auth/compute.readonly"
72660          ],
72661          "description": "Returns the specified Route resource."
72662        },
72663        "insert": {
72664          "id": "compute.routes.insert",
72665          "path": "projects/{project}/global/routes",
72666          "flatPath": "projects/{project}/global/routes",
72667          "httpMethod": "POST",
72668          "parameters": {
72669            "project": {
72670              "description": "Project ID for this request.",
72671              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72672              "location": "path",
72673              "required": true,
72674              "type": "string"
72675            },
72676            "requestId": {
72677              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
72678              "location": "query",
72679              "type": "string"
72680            }
72681          },
72682          "parameterOrder": [
72683            "project"
72684          ],
72685          "request": {
72686            "$ref": "Route"
72687          },
72688          "response": {
72689            "$ref": "Operation"
72690          },
72691          "scopes": [
72692            "https://www.googleapis.com/auth/cloud-platform",
72693            "https://www.googleapis.com/auth/compute"
72694          ],
72695          "description": "Creates a Route resource in the specified project using the data included in the request."
72696        },
72697        "delete": {
72698          "id": "compute.routes.delete",
72699          "path": "projects/{project}/global/routes/{route}",
72700          "flatPath": "projects/{project}/global/routes/{route}",
72701          "httpMethod": "DELETE",
72702          "parameters": {
72703            "project": {
72704              "description": "Project ID for this request.",
72705              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72706              "location": "path",
72707              "required": true,
72708              "type": "string"
72709            },
72710            "requestId": {
72711              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
72712              "location": "query",
72713              "type": "string"
72714            },
72715            "route": {
72716              "description": "Name of the Route resource to delete.",
72717              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
72718              "location": "path",
72719              "required": true,
72720              "type": "string"
72721            }
72722          },
72723          "parameterOrder": [
72724            "project",
72725            "route"
72726          ],
72727          "response": {
72728            "$ref": "Operation"
72729          },
72730          "scopes": [
72731            "https://www.googleapis.com/auth/cloud-platform",
72732            "https://www.googleapis.com/auth/compute"
72733          ],
72734          "description": "Deletes the specified Route resource."
72735        }
72736      }
72737    },
72738    "routers": {
72739      "methods": {
72740        "get": {
72741          "id": "compute.routers.get",
72742          "path": "projects/{project}/regions/{region}/routers/{router}",
72743          "flatPath": "projects/{project}/regions/{region}/routers/{router}",
72744          "httpMethod": "GET",
72745          "parameters": {
72746            "project": {
72747              "description": "Project ID for this request.",
72748              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72749              "location": "path",
72750              "required": true,
72751              "type": "string"
72752            },
72753            "region": {
72754              "description": "Name of the region for this request.",
72755              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
72756              "location": "path",
72757              "required": true,
72758              "type": "string"
72759            },
72760            "router": {
72761              "description": "Name of the Router resource to return.",
72762              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
72763              "location": "path",
72764              "required": true,
72765              "type": "string"
72766            }
72767          },
72768          "parameterOrder": [
72769            "project",
72770            "region",
72771            "router"
72772          ],
72773          "response": {
72774            "$ref": "Router"
72775          },
72776          "scopes": [
72777            "https://www.googleapis.com/auth/cloud-platform",
72778            "https://www.googleapis.com/auth/compute",
72779            "https://www.googleapis.com/auth/compute.readonly"
72780          ],
72781          "description": "Returns the specified Router resource."
72782        },
72783        "insert": {
72784          "id": "compute.routers.insert",
72785          "path": "projects/{project}/regions/{region}/routers",
72786          "flatPath": "projects/{project}/regions/{region}/routers",
72787          "httpMethod": "POST",
72788          "parameters": {
72789            "project": {
72790              "description": "Project ID for this request.",
72791              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72792              "location": "path",
72793              "required": true,
72794              "type": "string"
72795            },
72796            "region": {
72797              "description": "Name of the region for this request.",
72798              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
72799              "location": "path",
72800              "required": true,
72801              "type": "string"
72802            },
72803            "requestId": {
72804              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
72805              "location": "query",
72806              "type": "string"
72807            }
72808          },
72809          "parameterOrder": [
72810            "project",
72811            "region"
72812          ],
72813          "request": {
72814            "$ref": "Router"
72815          },
72816          "response": {
72817            "$ref": "Operation"
72818          },
72819          "scopes": [
72820            "https://www.googleapis.com/auth/cloud-platform",
72821            "https://www.googleapis.com/auth/compute"
72822          ],
72823          "description": "Creates a Router resource in the specified project and region using the data included in the request."
72824        },
72825        "update": {
72826          "id": "compute.routers.update",
72827          "path": "projects/{project}/regions/{region}/routers/{router}",
72828          "flatPath": "projects/{project}/regions/{region}/routers/{router}",
72829          "httpMethod": "PUT",
72830          "parameters": {
72831            "project": {
72832              "description": "Project ID for this request.",
72833              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72834              "location": "path",
72835              "required": true,
72836              "type": "string"
72837            },
72838            "region": {
72839              "description": "Name of the region for this request.",
72840              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
72841              "location": "path",
72842              "required": true,
72843              "type": "string"
72844            },
72845            "requestId": {
72846              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
72847              "location": "query",
72848              "type": "string"
72849            },
72850            "router": {
72851              "description": "Name of the Router resource to update.",
72852              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
72853              "location": "path",
72854              "required": true,
72855              "type": "string"
72856            }
72857          },
72858          "parameterOrder": [
72859            "project",
72860            "region",
72861            "router"
72862          ],
72863          "request": {
72864            "$ref": "Router"
72865          },
72866          "response": {
72867            "$ref": "Operation"
72868          },
72869          "scopes": [
72870            "https://www.googleapis.com/auth/cloud-platform",
72871            "https://www.googleapis.com/auth/compute"
72872          ],
72873          "description": "Updates the specified Router resource with the data included in the request. This method conforms to PUT semantics, which requests that the state of the target resource be created or replaced with the state defined by the representation enclosed in the request message payload."
72874        },
72875        "patch": {
72876          "id": "compute.routers.patch",
72877          "path": "projects/{project}/regions/{region}/routers/{router}",
72878          "flatPath": "projects/{project}/regions/{region}/routers/{router}",
72879          "httpMethod": "PATCH",
72880          "parameters": {
72881            "project": {
72882              "description": "Project ID for this request.",
72883              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72884              "location": "path",
72885              "required": true,
72886              "type": "string"
72887            },
72888            "region": {
72889              "description": "Name of the region for this request.",
72890              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
72891              "location": "path",
72892              "required": true,
72893              "type": "string"
72894            },
72895            "requestId": {
72896              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
72897              "location": "query",
72898              "type": "string"
72899            },
72900            "router": {
72901              "description": "Name of the Router resource to patch.",
72902              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
72903              "location": "path",
72904              "required": true,
72905              "type": "string"
72906            }
72907          },
72908          "parameterOrder": [
72909            "project",
72910            "region",
72911            "router"
72912          ],
72913          "request": {
72914            "$ref": "Router"
72915          },
72916          "response": {
72917            "$ref": "Operation"
72918          },
72919          "scopes": [
72920            "https://www.googleapis.com/auth/cloud-platform",
72921            "https://www.googleapis.com/auth/compute"
72922          ],
72923          "description": "Patches the specified Router resource with the data included in the request. This method supports PATCH semantics and uses JSON merge patch format and processing rules."
72924        },
72925        "delete": {
72926          "id": "compute.routers.delete",
72927          "path": "projects/{project}/regions/{region}/routers/{router}",
72928          "flatPath": "projects/{project}/regions/{region}/routers/{router}",
72929          "httpMethod": "DELETE",
72930          "parameters": {
72931            "project": {
72932              "description": "Project ID for this request.",
72933              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
72934              "location": "path",
72935              "required": true,
72936              "type": "string"
72937            },
72938            "region": {
72939              "description": "Name of the region for this request.",
72940              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
72941              "location": "path",
72942              "required": true,
72943              "type": "string"
72944            },
72945            "requestId": {
72946              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
72947              "location": "query",
72948              "type": "string"
72949            },
72950            "router": {
72951              "description": "Name of the Router resource to delete.",
72952              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
72953              "location": "path",
72954              "required": true,
72955              "type": "string"
72956            }
72957          },
72958          "parameterOrder": [
72959            "project",
72960            "region",
72961            "router"
72962          ],
72963          "response": {
72964            "$ref": "Operation"
72965          },
72966          "scopes": [
72967            "https://www.googleapis.com/auth/cloud-platform",
72968            "https://www.googleapis.com/auth/compute"
72969          ],
72970          "description": "Deletes the specified Router resource."
72971        },
72972        "list": {
72973          "id": "compute.routers.list",
72974          "path": "projects/{project}/regions/{region}/routers",
72975          "flatPath": "projects/{project}/regions/{region}/routers",
72976          "httpMethod": "GET",
72977          "parameters": {
72978            "filter": {
72979              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
72980              "location": "query",
72981              "type": "string"
72982            },
72983            "maxResults": {
72984              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
72985              "default": "500",
72986              "minimum": "0",
72987              "location": "query",
72988              "type": "integer",
72989              "format": "uint32"
72990            },
72991            "orderBy": {
72992              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
72993              "location": "query",
72994              "type": "string"
72995            },
72996            "pageToken": {
72997              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
72998              "location": "query",
72999              "type": "string"
73000            },
73001            "project": {
73002              "description": "Project ID for this request.",
73003              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73004              "location": "path",
73005              "required": true,
73006              "type": "string"
73007            },
73008            "region": {
73009              "description": "Name of the region for this request.",
73010              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
73011              "location": "path",
73012              "required": true,
73013              "type": "string"
73014            },
73015            "returnPartialSuccess": {
73016              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
73017              "location": "query",
73018              "type": "boolean"
73019            }
73020          },
73021          "parameterOrder": [
73022            "project",
73023            "region"
73024          ],
73025          "response": {
73026            "$ref": "RouterList"
73027          },
73028          "scopes": [
73029            "https://www.googleapis.com/auth/cloud-platform",
73030            "https://www.googleapis.com/auth/compute",
73031            "https://www.googleapis.com/auth/compute.readonly"
73032          ],
73033          "description": "Retrieves a list of Router resources available to the specified project."
73034        },
73035        "aggregatedList": {
73036          "id": "compute.routers.aggregatedList",
73037          "path": "projects/{project}/aggregated/routers",
73038          "flatPath": "projects/{project}/aggregated/routers",
73039          "httpMethod": "GET",
73040          "parameters": {
73041            "filter": {
73042              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
73043              "location": "query",
73044              "type": "string"
73045            },
73046            "includeAllScopes": {
73047              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
73048              "location": "query",
73049              "type": "boolean"
73050            },
73051            "maxResults": {
73052              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
73053              "default": "500",
73054              "minimum": "0",
73055              "location": "query",
73056              "type": "integer",
73057              "format": "uint32"
73058            },
73059            "orderBy": {
73060              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
73061              "location": "query",
73062              "type": "string"
73063            },
73064            "pageToken": {
73065              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
73066              "location": "query",
73067              "type": "string"
73068            },
73069            "project": {
73070              "description": "Project ID for this request.",
73071              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73072              "location": "path",
73073              "required": true,
73074              "type": "string"
73075            },
73076            "returnPartialSuccess": {
73077              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
73078              "location": "query",
73079              "type": "boolean"
73080            },
73081            "serviceProjectNumber": {
73082              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
73083              "location": "query",
73084              "type": "string",
73085              "format": "int64"
73086            }
73087          },
73088          "parameterOrder": [
73089            "project"
73090          ],
73091          "response": {
73092            "$ref": "RouterAggregatedList"
73093          },
73094          "scopes": [
73095            "https://www.googleapis.com/auth/cloud-platform",
73096            "https://www.googleapis.com/auth/compute",
73097            "https://www.googleapis.com/auth/compute.readonly"
73098          ],
73099          "description": "Retrieves an aggregated list of routers. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
73100        },
73101        "getRouterStatus": {
73102          "id": "compute.routers.getRouterStatus",
73103          "path": "projects/{project}/regions/{region}/routers/{router}/getRouterStatus",
73104          "flatPath": "projects/{project}/regions/{region}/routers/{router}/getRouterStatus",
73105          "httpMethod": "GET",
73106          "parameters": {
73107            "project": {
73108              "description": "Project ID for this request.",
73109              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73110              "location": "path",
73111              "required": true,
73112              "type": "string"
73113            },
73114            "region": {
73115              "description": "Name of the region for this request.",
73116              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
73117              "location": "path",
73118              "required": true,
73119              "type": "string"
73120            },
73121            "router": {
73122              "description": "Name of the Router resource to query.",
73123              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
73124              "location": "path",
73125              "required": true,
73126              "type": "string"
73127            }
73128          },
73129          "parameterOrder": [
73130            "project",
73131            "region",
73132            "router"
73133          ],
73134          "response": {
73135            "$ref": "RouterStatusResponse"
73136          },
73137          "scopes": [
73138            "https://www.googleapis.com/auth/cloud-platform",
73139            "https://www.googleapis.com/auth/compute",
73140            "https://www.googleapis.com/auth/compute.readonly"
73141          ],
73142          "description": "Retrieves runtime information of the specified router."
73143        },
73144        "getNatMappingInfo": {
73145          "id": "compute.routers.getNatMappingInfo",
73146          "path": "projects/{project}/regions/{region}/routers/{router}/getNatMappingInfo",
73147          "flatPath": "projects/{project}/regions/{region}/routers/{router}/getNatMappingInfo",
73148          "httpMethod": "GET",
73149          "parameters": {
73150            "filter": {
73151              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
73152              "location": "query",
73153              "type": "string"
73154            },
73155            "maxResults": {
73156              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
73157              "default": "500",
73158              "minimum": "0",
73159              "location": "query",
73160              "type": "integer",
73161              "format": "uint32"
73162            },
73163            "natName": {
73164              "description": "Name of the nat service to filter the Nat Mapping information. If it is omitted, all nats for this router will be returned. Name should conform to RFC1035.",
73165              "location": "query",
73166              "type": "string"
73167            },
73168            "orderBy": {
73169              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
73170              "location": "query",
73171              "type": "string"
73172            },
73173            "pageToken": {
73174              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
73175              "location": "query",
73176              "type": "string"
73177            },
73178            "project": {
73179              "description": "Project ID for this request.",
73180              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73181              "location": "path",
73182              "required": true,
73183              "type": "string"
73184            },
73185            "region": {
73186              "description": "Name of the region for this request.",
73187              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
73188              "location": "path",
73189              "required": true,
73190              "type": "string"
73191            },
73192            "returnPartialSuccess": {
73193              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
73194              "location": "query",
73195              "type": "boolean"
73196            },
73197            "router": {
73198              "description": "Name of the Router resource to query for Nat Mapping information of VM endpoints.",
73199              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
73200              "location": "path",
73201              "required": true,
73202              "type": "string"
73203            }
73204          },
73205          "parameterOrder": [
73206            "project",
73207            "region",
73208            "router"
73209          ],
73210          "response": {
73211            "$ref": "VmEndpointNatMappingsList"
73212          },
73213          "scopes": [
73214            "https://www.googleapis.com/auth/cloud-platform",
73215            "https://www.googleapis.com/auth/compute",
73216            "https://www.googleapis.com/auth/compute.readonly"
73217          ],
73218          "description": "Retrieves runtime Nat mapping information of VM endpoints."
73219        },
73220        "getNatIpInfo": {
73221          "id": "compute.routers.getNatIpInfo",
73222          "path": "projects/{project}/regions/{region}/routers/{router}/getNatIpInfo",
73223          "flatPath": "projects/{project}/regions/{region}/routers/{router}/getNatIpInfo",
73224          "httpMethod": "GET",
73225          "parameters": {
73226            "natName": {
73227              "description": "Name of the nat service to filter the NAT IP information. If it is omitted, all nats for this router will be returned. Name should conform to RFC1035.",
73228              "location": "query",
73229              "type": "string"
73230            },
73231            "project": {
73232              "description": "Project ID for this request.",
73233              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73234              "location": "path",
73235              "required": true,
73236              "type": "string"
73237            },
73238            "region": {
73239              "description": "Name of the region for this request.",
73240              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
73241              "location": "path",
73242              "required": true,
73243              "type": "string"
73244            },
73245            "router": {
73246              "description": "Name of the Router resource to query for Nat IP information. The name should conform to RFC1035.",
73247              "location": "path",
73248              "required": true,
73249              "type": "string"
73250            }
73251          },
73252          "parameterOrder": [
73253            "project",
73254            "region",
73255            "router"
73256          ],
73257          "response": {
73258            "$ref": "NatIpInfoResponse"
73259          },
73260          "scopes": [
73261            "https://www.googleapis.com/auth/cloud-platform",
73262            "https://www.googleapis.com/auth/compute",
73263            "https://www.googleapis.com/auth/compute.readonly"
73264          ],
73265          "description": "Retrieves runtime NAT IP information."
73266        },
73267        "preview": {
73268          "id": "compute.routers.preview",
73269          "path": "projects/{project}/regions/{region}/routers/{router}/preview",
73270          "flatPath": "projects/{project}/regions/{region}/routers/{router}/preview",
73271          "httpMethod": "POST",
73272          "parameters": {
73273            "project": {
73274              "description": "Project ID for this request.",
73275              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73276              "location": "path",
73277              "required": true,
73278              "type": "string"
73279            },
73280            "region": {
73281              "description": "Name of the region for this request.",
73282              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
73283              "location": "path",
73284              "required": true,
73285              "type": "string"
73286            },
73287            "router": {
73288              "description": "Name of the Router resource to query.",
73289              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
73290              "location": "path",
73291              "required": true,
73292              "type": "string"
73293            }
73294          },
73295          "parameterOrder": [
73296            "project",
73297            "region",
73298            "router"
73299          ],
73300          "request": {
73301            "$ref": "Router"
73302          },
73303          "response": {
73304            "$ref": "RoutersPreviewResponse"
73305          },
73306          "scopes": [
73307            "https://www.googleapis.com/auth/cloud-platform",
73308            "https://www.googleapis.com/auth/compute",
73309            "https://www.googleapis.com/auth/compute.readonly"
73310          ],
73311          "description": "Preview fields auto-generated during router create and update operations. Calling this method does NOT create or update the router."
73312        }
73313      }
73314    },
73315    "serviceAttachments": {
73316      "methods": {
73317        "aggregatedList": {
73318          "id": "compute.serviceAttachments.aggregatedList",
73319          "path": "projects/{project}/aggregated/serviceAttachments",
73320          "flatPath": "projects/{project}/aggregated/serviceAttachments",
73321          "httpMethod": "GET",
73322          "parameters": {
73323            "filter": {
73324              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
73325              "location": "query",
73326              "type": "string"
73327            },
73328            "includeAllScopes": {
73329              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
73330              "location": "query",
73331              "type": "boolean"
73332            },
73333            "maxResults": {
73334              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
73335              "default": "500",
73336              "minimum": "0",
73337              "location": "query",
73338              "type": "integer",
73339              "format": "uint32"
73340            },
73341            "orderBy": {
73342              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
73343              "location": "query",
73344              "type": "string"
73345            },
73346            "pageToken": {
73347              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
73348              "location": "query",
73349              "type": "string"
73350            },
73351            "project": {
73352              "description": "Name of the project scoping this request.",
73353              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73354              "location": "path",
73355              "required": true,
73356              "type": "string"
73357            },
73358            "returnPartialSuccess": {
73359              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
73360              "location": "query",
73361              "type": "boolean"
73362            },
73363            "serviceProjectNumber": {
73364              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
73365              "location": "query",
73366              "type": "string",
73367              "format": "int64"
73368            }
73369          },
73370          "parameterOrder": [
73371            "project"
73372          ],
73373          "response": {
73374            "$ref": "ServiceAttachmentAggregatedList"
73375          },
73376          "scopes": [
73377            "https://www.googleapis.com/auth/cloud-platform",
73378            "https://www.googleapis.com/auth/compute",
73379            "https://www.googleapis.com/auth/compute.readonly"
73380          ],
73381          "description": "Retrieves the list of all ServiceAttachment resources, regional and global, available to the specified project. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
73382        },
73383        "list": {
73384          "id": "compute.serviceAttachments.list",
73385          "path": "projects/{project}/regions/{region}/serviceAttachments",
73386          "flatPath": "projects/{project}/regions/{region}/serviceAttachments",
73387          "httpMethod": "GET",
73388          "parameters": {
73389            "filter": {
73390              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
73391              "location": "query",
73392              "type": "string"
73393            },
73394            "maxResults": {
73395              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
73396              "default": "500",
73397              "minimum": "0",
73398              "location": "query",
73399              "type": "integer",
73400              "format": "uint32"
73401            },
73402            "orderBy": {
73403              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
73404              "location": "query",
73405              "type": "string"
73406            },
73407            "pageToken": {
73408              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
73409              "location": "query",
73410              "type": "string"
73411            },
73412            "project": {
73413              "description": "Project ID for this request.",
73414              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73415              "location": "path",
73416              "required": true,
73417              "type": "string"
73418            },
73419            "region": {
73420              "description": "Name of the region of this request.",
73421              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
73422              "location": "path",
73423              "required": true,
73424              "type": "string"
73425            },
73426            "returnPartialSuccess": {
73427              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
73428              "location": "query",
73429              "type": "boolean"
73430            }
73431          },
73432          "parameterOrder": [
73433            "project",
73434            "region"
73435          ],
73436          "response": {
73437            "$ref": "ServiceAttachmentList"
73438          },
73439          "scopes": [
73440            "https://www.googleapis.com/auth/cloud-platform",
73441            "https://www.googleapis.com/auth/compute",
73442            "https://www.googleapis.com/auth/compute.readonly"
73443          ],
73444          "description": "Lists the ServiceAttachments for a project in the given scope."
73445        },
73446        "get": {
73447          "id": "compute.serviceAttachments.get",
73448          "path": "projects/{project}/regions/{region}/serviceAttachments/{serviceAttachment}",
73449          "flatPath": "projects/{project}/regions/{region}/serviceAttachments/{serviceAttachment}",
73450          "httpMethod": "GET",
73451          "parameters": {
73452            "project": {
73453              "description": "Project ID for this request.",
73454              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73455              "location": "path",
73456              "required": true,
73457              "type": "string"
73458            },
73459            "region": {
73460              "description": "Name of the region of this request.",
73461              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
73462              "location": "path",
73463              "required": true,
73464              "type": "string"
73465            },
73466            "serviceAttachment": {
73467              "description": "Name of the ServiceAttachment resource to return.",
73468              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
73469              "location": "path",
73470              "required": true,
73471              "type": "string"
73472            }
73473          },
73474          "parameterOrder": [
73475            "project",
73476            "region",
73477            "serviceAttachment"
73478          ],
73479          "response": {
73480            "$ref": "ServiceAttachment"
73481          },
73482          "scopes": [
73483            "https://www.googleapis.com/auth/cloud-platform",
73484            "https://www.googleapis.com/auth/compute",
73485            "https://www.googleapis.com/auth/compute.readonly"
73486          ],
73487          "description": "Returns the specified ServiceAttachment resource in the given scope."
73488        },
73489        "insert": {
73490          "id": "compute.serviceAttachments.insert",
73491          "path": "projects/{project}/regions/{region}/serviceAttachments",
73492          "flatPath": "projects/{project}/regions/{region}/serviceAttachments",
73493          "httpMethod": "POST",
73494          "parameters": {
73495            "project": {
73496              "description": "Project ID for this request.",
73497              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73498              "location": "path",
73499              "required": true,
73500              "type": "string"
73501            },
73502            "region": {
73503              "description": "Name of the region of this request.",
73504              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
73505              "location": "path",
73506              "required": true,
73507              "type": "string"
73508            },
73509            "requestId": {
73510              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
73511              "location": "query",
73512              "type": "string"
73513            }
73514          },
73515          "parameterOrder": [
73516            "project",
73517            "region"
73518          ],
73519          "request": {
73520            "$ref": "ServiceAttachment"
73521          },
73522          "response": {
73523            "$ref": "Operation"
73524          },
73525          "scopes": [
73526            "https://www.googleapis.com/auth/cloud-platform",
73527            "https://www.googleapis.com/auth/compute"
73528          ],
73529          "description": "Creates a ServiceAttachment in the specified project in the given scope using the parameters that are included in the request."
73530        },
73531        "delete": {
73532          "id": "compute.serviceAttachments.delete",
73533          "path": "projects/{project}/regions/{region}/serviceAttachments/{serviceAttachment}",
73534          "flatPath": "projects/{project}/regions/{region}/serviceAttachments/{serviceAttachment}",
73535          "httpMethod": "DELETE",
73536          "parameters": {
73537            "project": {
73538              "description": "Project ID for this request.",
73539              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73540              "location": "path",
73541              "required": true,
73542              "type": "string"
73543            },
73544            "region": {
73545              "description": "Name of the region of this request.",
73546              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
73547              "location": "path",
73548              "required": true,
73549              "type": "string"
73550            },
73551            "requestId": {
73552              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
73553              "location": "query",
73554              "type": "string"
73555            },
73556            "serviceAttachment": {
73557              "description": "Name of the ServiceAttachment resource to delete.",
73558              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
73559              "location": "path",
73560              "required": true,
73561              "type": "string"
73562            }
73563          },
73564          "parameterOrder": [
73565            "project",
73566            "region",
73567            "serviceAttachment"
73568          ],
73569          "response": {
73570            "$ref": "Operation"
73571          },
73572          "scopes": [
73573            "https://www.googleapis.com/auth/cloud-platform",
73574            "https://www.googleapis.com/auth/compute"
73575          ],
73576          "description": "Deletes the specified ServiceAttachment in the given scope"
73577        },
73578        "patch": {
73579          "id": "compute.serviceAttachments.patch",
73580          "path": "projects/{project}/regions/{region}/serviceAttachments/{serviceAttachment}",
73581          "flatPath": "projects/{project}/regions/{region}/serviceAttachments/{serviceAttachment}",
73582          "httpMethod": "PATCH",
73583          "parameters": {
73584            "project": {
73585              "description": "Project ID for this request.",
73586              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73587              "location": "path",
73588              "required": true,
73589              "type": "string"
73590            },
73591            "region": {
73592              "description": "The region scoping this request and should conform to RFC1035.",
73593              "location": "path",
73594              "required": true,
73595              "type": "string"
73596            },
73597            "requestId": {
73598              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
73599              "location": "query",
73600              "type": "string"
73601            },
73602            "serviceAttachment": {
73603              "description": "The resource id of the ServiceAttachment to patch. It should conform to RFC1035 resource name or be a string form on an unsigned long number.",
73604              "location": "path",
73605              "required": true,
73606              "type": "string"
73607            }
73608          },
73609          "parameterOrder": [
73610            "project",
73611            "region",
73612            "serviceAttachment"
73613          ],
73614          "request": {
73615            "$ref": "ServiceAttachment"
73616          },
73617          "response": {
73618            "$ref": "Operation"
73619          },
73620          "scopes": [
73621            "https://www.googleapis.com/auth/cloud-platform",
73622            "https://www.googleapis.com/auth/compute"
73623          ],
73624          "description": "Patches the specified ServiceAttachment resource with the data included in the request. This method supports PATCH semantics and uses JSON merge patch format and processing rules."
73625        },
73626        "getIamPolicy": {
73627          "id": "compute.serviceAttachments.getIamPolicy",
73628          "path": "projects/{project}/regions/{region}/serviceAttachments/{resource}/getIamPolicy",
73629          "flatPath": "projects/{project}/regions/{region}/serviceAttachments/{resource}/getIamPolicy",
73630          "httpMethod": "GET",
73631          "parameters": {
73632            "optionsRequestedPolicyVersion": {
73633              "description": "Requested IAM Policy version.",
73634              "location": "query",
73635              "type": "integer",
73636              "format": "int32"
73637            },
73638            "project": {
73639              "description": "Project ID for this request.",
73640              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73641              "location": "path",
73642              "required": true,
73643              "type": "string"
73644            },
73645            "region": {
73646              "description": "The name of the region for this request.",
73647              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
73648              "location": "path",
73649              "required": true,
73650              "type": "string"
73651            },
73652            "resource": {
73653              "description": "Name or id of the resource for this request.",
73654              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
73655              "location": "path",
73656              "required": true,
73657              "type": "string"
73658            }
73659          },
73660          "parameterOrder": [
73661            "project",
73662            "region",
73663            "resource"
73664          ],
73665          "response": {
73666            "$ref": "Policy"
73667          },
73668          "scopes": [
73669            "https://www.googleapis.com/auth/cloud-platform",
73670            "https://www.googleapis.com/auth/compute",
73671            "https://www.googleapis.com/auth/compute.readonly"
73672          ],
73673          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
73674        },
73675        "setIamPolicy": {
73676          "id": "compute.serviceAttachments.setIamPolicy",
73677          "path": "projects/{project}/regions/{region}/serviceAttachments/{resource}/setIamPolicy",
73678          "flatPath": "projects/{project}/regions/{region}/serviceAttachments/{resource}/setIamPolicy",
73679          "httpMethod": "POST",
73680          "parameters": {
73681            "project": {
73682              "description": "Project ID for this request.",
73683              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73684              "location": "path",
73685              "required": true,
73686              "type": "string"
73687            },
73688            "region": {
73689              "description": "The name of the region for this request.",
73690              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
73691              "location": "path",
73692              "required": true,
73693              "type": "string"
73694            },
73695            "resource": {
73696              "description": "Name or id of the resource for this request.",
73697              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
73698              "location": "path",
73699              "required": true,
73700              "type": "string"
73701            }
73702          },
73703          "parameterOrder": [
73704            "project",
73705            "region",
73706            "resource"
73707          ],
73708          "request": {
73709            "$ref": "RegionSetPolicyRequest"
73710          },
73711          "response": {
73712            "$ref": "Policy"
73713          },
73714          "scopes": [
73715            "https://www.googleapis.com/auth/cloud-platform",
73716            "https://www.googleapis.com/auth/compute"
73717          ],
73718          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
73719        },
73720        "testIamPermissions": {
73721          "id": "compute.serviceAttachments.testIamPermissions",
73722          "path": "projects/{project}/regions/{region}/serviceAttachments/{resource}/testIamPermissions",
73723          "flatPath": "projects/{project}/regions/{region}/serviceAttachments/{resource}/testIamPermissions",
73724          "httpMethod": "POST",
73725          "parameters": {
73726            "project": {
73727              "description": "Project ID for this request.",
73728              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73729              "location": "path",
73730              "required": true,
73731              "type": "string"
73732            },
73733            "region": {
73734              "description": "The name of the region for this request.",
73735              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
73736              "location": "path",
73737              "required": true,
73738              "type": "string"
73739            },
73740            "resource": {
73741              "description": "Name or id of the resource for this request.",
73742              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
73743              "location": "path",
73744              "required": true,
73745              "type": "string"
73746            }
73747          },
73748          "parameterOrder": [
73749            "project",
73750            "region",
73751            "resource"
73752          ],
73753          "request": {
73754            "$ref": "TestPermissionsRequest"
73755          },
73756          "response": {
73757            "$ref": "TestPermissionsResponse"
73758          },
73759          "scopes": [
73760            "https://www.googleapis.com/auth/cloud-platform",
73761            "https://www.googleapis.com/auth/compute",
73762            "https://www.googleapis.com/auth/compute.readonly"
73763          ],
73764          "description": "Returns permissions that a caller has on the specified resource."
73765        }
73766      }
73767    },
73768    "snapshotSettings": {
73769      "methods": {
73770        "get": {
73771          "id": "compute.snapshotSettings.get",
73772          "path": "projects/{project}/global/snapshotSettings",
73773          "flatPath": "projects/{project}/global/snapshotSettings",
73774          "httpMethod": "GET",
73775          "parameters": {
73776            "project": {
73777              "description": "Project ID for this request.",
73778              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73779              "location": "path",
73780              "required": true,
73781              "type": "string"
73782            }
73783          },
73784          "parameterOrder": [
73785            "project"
73786          ],
73787          "response": {
73788            "$ref": "SnapshotSettings"
73789          },
73790          "scopes": [
73791            "https://www.googleapis.com/auth/cloud-platform",
73792            "https://www.googleapis.com/auth/compute",
73793            "https://www.googleapis.com/auth/compute.readonly"
73794          ],
73795          "description": "Get snapshot settings."
73796        },
73797        "patch": {
73798          "id": "compute.snapshotSettings.patch",
73799          "path": "projects/{project}/global/snapshotSettings",
73800          "flatPath": "projects/{project}/global/snapshotSettings",
73801          "httpMethod": "PATCH",
73802          "parameters": {
73803            "project": {
73804              "description": "Project ID for this request.",
73805              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73806              "location": "path",
73807              "required": true,
73808              "type": "string"
73809            },
73810            "requestId": {
73811              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
73812              "location": "query",
73813              "type": "string"
73814            },
73815            "updateMask": {
73816              "description": "update_mask indicates fields to be updated as part of this request.",
73817              "location": "query",
73818              "type": "string",
73819              "format": "google-fieldmask"
73820            }
73821          },
73822          "parameterOrder": [
73823            "project"
73824          ],
73825          "request": {
73826            "$ref": "SnapshotSettings"
73827          },
73828          "response": {
73829            "$ref": "Operation"
73830          },
73831          "scopes": [
73832            "https://www.googleapis.com/auth/cloud-platform",
73833            "https://www.googleapis.com/auth/compute"
73834          ],
73835          "description": "Patch snapshot settings."
73836        }
73837      }
73838    },
73839    "sslCertificates": {
73840      "methods": {
73841        "list": {
73842          "id": "compute.sslCertificates.list",
73843          "path": "projects/{project}/global/sslCertificates",
73844          "flatPath": "projects/{project}/global/sslCertificates",
73845          "httpMethod": "GET",
73846          "parameters": {
73847            "filter": {
73848              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
73849              "location": "query",
73850              "type": "string"
73851            },
73852            "maxResults": {
73853              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
73854              "default": "500",
73855              "minimum": "0",
73856              "location": "query",
73857              "type": "integer",
73858              "format": "uint32"
73859            },
73860            "orderBy": {
73861              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
73862              "location": "query",
73863              "type": "string"
73864            },
73865            "pageToken": {
73866              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
73867              "location": "query",
73868              "type": "string"
73869            },
73870            "project": {
73871              "description": "Project ID for this request.",
73872              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73873              "location": "path",
73874              "required": true,
73875              "type": "string"
73876            },
73877            "returnPartialSuccess": {
73878              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
73879              "location": "query",
73880              "type": "boolean"
73881            }
73882          },
73883          "parameterOrder": [
73884            "project"
73885          ],
73886          "response": {
73887            "$ref": "SslCertificateList"
73888          },
73889          "scopes": [
73890            "https://www.googleapis.com/auth/cloud-platform",
73891            "https://www.googleapis.com/auth/compute",
73892            "https://www.googleapis.com/auth/compute.readonly"
73893          ],
73894          "description": "Retrieves the list of SslCertificate resources available to the specified project."
73895        },
73896        "get": {
73897          "id": "compute.sslCertificates.get",
73898          "path": "projects/{project}/global/sslCertificates/{sslCertificate}",
73899          "flatPath": "projects/{project}/global/sslCertificates/{sslCertificate}",
73900          "httpMethod": "GET",
73901          "parameters": {
73902            "project": {
73903              "description": "Project ID for this request.",
73904              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73905              "location": "path",
73906              "required": true,
73907              "type": "string"
73908            },
73909            "sslCertificate": {
73910              "description": "Name of the SslCertificate resource to return.",
73911              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
73912              "location": "path",
73913              "required": true,
73914              "type": "string"
73915            }
73916          },
73917          "parameterOrder": [
73918            "project",
73919            "sslCertificate"
73920          ],
73921          "response": {
73922            "$ref": "SslCertificate"
73923          },
73924          "scopes": [
73925            "https://www.googleapis.com/auth/cloud-platform",
73926            "https://www.googleapis.com/auth/compute",
73927            "https://www.googleapis.com/auth/compute.readonly"
73928          ],
73929          "description": "Returns the specified SslCertificate resource."
73930        },
73931        "insert": {
73932          "id": "compute.sslCertificates.insert",
73933          "path": "projects/{project}/global/sslCertificates",
73934          "flatPath": "projects/{project}/global/sslCertificates",
73935          "httpMethod": "POST",
73936          "parameters": {
73937            "project": {
73938              "description": "Project ID for this request.",
73939              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73940              "location": "path",
73941              "required": true,
73942              "type": "string"
73943            },
73944            "requestId": {
73945              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
73946              "location": "query",
73947              "type": "string"
73948            }
73949          },
73950          "parameterOrder": [
73951            "project"
73952          ],
73953          "request": {
73954            "$ref": "SslCertificate"
73955          },
73956          "response": {
73957            "$ref": "Operation"
73958          },
73959          "scopes": [
73960            "https://www.googleapis.com/auth/cloud-platform",
73961            "https://www.googleapis.com/auth/compute"
73962          ],
73963          "description": "Creates a SslCertificate resource in the specified project using the data included in the request."
73964        },
73965        "delete": {
73966          "id": "compute.sslCertificates.delete",
73967          "path": "projects/{project}/global/sslCertificates/{sslCertificate}",
73968          "flatPath": "projects/{project}/global/sslCertificates/{sslCertificate}",
73969          "httpMethod": "DELETE",
73970          "parameters": {
73971            "project": {
73972              "description": "Project ID for this request.",
73973              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
73974              "location": "path",
73975              "required": true,
73976              "type": "string"
73977            },
73978            "requestId": {
73979              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
73980              "location": "query",
73981              "type": "string"
73982            },
73983            "sslCertificate": {
73984              "description": "Name of the SslCertificate resource to delete.",
73985              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
73986              "location": "path",
73987              "required": true,
73988              "type": "string"
73989            }
73990          },
73991          "parameterOrder": [
73992            "project",
73993            "sslCertificate"
73994          ],
73995          "response": {
73996            "$ref": "Operation"
73997          },
73998          "scopes": [
73999            "https://www.googleapis.com/auth/cloud-platform",
74000            "https://www.googleapis.com/auth/compute"
74001          ],
74002          "description": "Deletes the specified SslCertificate resource."
74003        },
74004        "aggregatedList": {
74005          "id": "compute.sslCertificates.aggregatedList",
74006          "path": "projects/{project}/aggregated/sslCertificates",
74007          "flatPath": "projects/{project}/aggregated/sslCertificates",
74008          "httpMethod": "GET",
74009          "parameters": {
74010            "filter": {
74011              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
74012              "location": "query",
74013              "type": "string"
74014            },
74015            "includeAllScopes": {
74016              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
74017              "location": "query",
74018              "type": "boolean"
74019            },
74020            "maxResults": {
74021              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
74022              "default": "500",
74023              "minimum": "0",
74024              "location": "query",
74025              "type": "integer",
74026              "format": "uint32"
74027            },
74028            "orderBy": {
74029              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
74030              "location": "query",
74031              "type": "string"
74032            },
74033            "pageToken": {
74034              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
74035              "location": "query",
74036              "type": "string"
74037            },
74038            "project": {
74039              "description": "Name of the project scoping this request.",
74040              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74041              "location": "path",
74042              "required": true,
74043              "type": "string"
74044            },
74045            "returnPartialSuccess": {
74046              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
74047              "location": "query",
74048              "type": "boolean"
74049            },
74050            "serviceProjectNumber": {
74051              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
74052              "location": "query",
74053              "type": "string",
74054              "format": "int64"
74055            }
74056          },
74057          "parameterOrder": [
74058            "project"
74059          ],
74060          "response": {
74061            "$ref": "SslCertificateAggregatedList"
74062          },
74063          "scopes": [
74064            "https://www.googleapis.com/auth/cloud-platform",
74065            "https://www.googleapis.com/auth/compute",
74066            "https://www.googleapis.com/auth/compute.readonly"
74067          ],
74068          "description": "Retrieves the list of all SslCertificate resources, regional and global, available to the specified project. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
74069        }
74070      }
74071    },
74072    "regionSslCertificates": {
74073      "methods": {
74074        "list": {
74075          "id": "compute.regionSslCertificates.list",
74076          "path": "projects/{project}/regions/{region}/sslCertificates",
74077          "flatPath": "projects/{project}/regions/{region}/sslCertificates",
74078          "httpMethod": "GET",
74079          "parameters": {
74080            "filter": {
74081              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
74082              "location": "query",
74083              "type": "string"
74084            },
74085            "maxResults": {
74086              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
74087              "default": "500",
74088              "minimum": "0",
74089              "location": "query",
74090              "type": "integer",
74091              "format": "uint32"
74092            },
74093            "orderBy": {
74094              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
74095              "location": "query",
74096              "type": "string"
74097            },
74098            "pageToken": {
74099              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
74100              "location": "query",
74101              "type": "string"
74102            },
74103            "project": {
74104              "description": "Project ID for this request.",
74105              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74106              "location": "path",
74107              "required": true,
74108              "type": "string"
74109            },
74110            "region": {
74111              "description": "Name of the region scoping this request.",
74112              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
74113              "location": "path",
74114              "required": true,
74115              "type": "string"
74116            },
74117            "returnPartialSuccess": {
74118              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
74119              "location": "query",
74120              "type": "boolean"
74121            }
74122          },
74123          "parameterOrder": [
74124            "project",
74125            "region"
74126          ],
74127          "response": {
74128            "$ref": "SslCertificateList"
74129          },
74130          "scopes": [
74131            "https://www.googleapis.com/auth/cloud-platform",
74132            "https://www.googleapis.com/auth/compute",
74133            "https://www.googleapis.com/auth/compute.readonly"
74134          ],
74135          "description": "Retrieves the list of SslCertificate resources available to the specified project in the specified region."
74136        },
74137        "get": {
74138          "id": "compute.regionSslCertificates.get",
74139          "path": "projects/{project}/regions/{region}/sslCertificates/{sslCertificate}",
74140          "flatPath": "projects/{project}/regions/{region}/sslCertificates/{sslCertificate}",
74141          "httpMethod": "GET",
74142          "parameters": {
74143            "project": {
74144              "description": "Project ID for this request.",
74145              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74146              "location": "path",
74147              "required": true,
74148              "type": "string"
74149            },
74150            "region": {
74151              "description": "Name of the region scoping this request.",
74152              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
74153              "location": "path",
74154              "required": true,
74155              "type": "string"
74156            },
74157            "sslCertificate": {
74158              "description": "Name of the SslCertificate resource to return.",
74159              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
74160              "location": "path",
74161              "required": true,
74162              "type": "string"
74163            }
74164          },
74165          "parameterOrder": [
74166            "project",
74167            "region",
74168            "sslCertificate"
74169          ],
74170          "response": {
74171            "$ref": "SslCertificate"
74172          },
74173          "scopes": [
74174            "https://www.googleapis.com/auth/cloud-platform",
74175            "https://www.googleapis.com/auth/compute",
74176            "https://www.googleapis.com/auth/compute.readonly"
74177          ],
74178          "description": "Returns the specified SslCertificate resource in the specified region. Get a list of available SSL certificates by making a list() request."
74179        },
74180        "insert": {
74181          "id": "compute.regionSslCertificates.insert",
74182          "path": "projects/{project}/regions/{region}/sslCertificates",
74183          "flatPath": "projects/{project}/regions/{region}/sslCertificates",
74184          "httpMethod": "POST",
74185          "parameters": {
74186            "project": {
74187              "description": "Project ID for this request.",
74188              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74189              "location": "path",
74190              "required": true,
74191              "type": "string"
74192            },
74193            "region": {
74194              "description": "Name of the region scoping this request.",
74195              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
74196              "location": "path",
74197              "required": true,
74198              "type": "string"
74199            },
74200            "requestId": {
74201              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
74202              "location": "query",
74203              "type": "string"
74204            }
74205          },
74206          "parameterOrder": [
74207            "project",
74208            "region"
74209          ],
74210          "request": {
74211            "$ref": "SslCertificate"
74212          },
74213          "response": {
74214            "$ref": "Operation"
74215          },
74216          "scopes": [
74217            "https://www.googleapis.com/auth/cloud-platform",
74218            "https://www.googleapis.com/auth/compute"
74219          ],
74220          "description": "Creates a SslCertificate resource in the specified project and region using the data included in the request"
74221        },
74222        "delete": {
74223          "id": "compute.regionSslCertificates.delete",
74224          "path": "projects/{project}/regions/{region}/sslCertificates/{sslCertificate}",
74225          "flatPath": "projects/{project}/regions/{region}/sslCertificates/{sslCertificate}",
74226          "httpMethod": "DELETE",
74227          "parameters": {
74228            "project": {
74229              "description": "Project ID for this request.",
74230              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74231              "location": "path",
74232              "required": true,
74233              "type": "string"
74234            },
74235            "region": {
74236              "description": "Name of the region scoping this request.",
74237              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
74238              "location": "path",
74239              "required": true,
74240              "type": "string"
74241            },
74242            "requestId": {
74243              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
74244              "location": "query",
74245              "type": "string"
74246            },
74247            "sslCertificate": {
74248              "description": "Name of the SslCertificate resource to delete.",
74249              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
74250              "location": "path",
74251              "required": true,
74252              "type": "string"
74253            }
74254          },
74255          "parameterOrder": [
74256            "project",
74257            "region",
74258            "sslCertificate"
74259          ],
74260          "response": {
74261            "$ref": "Operation"
74262          },
74263          "scopes": [
74264            "https://www.googleapis.com/auth/cloud-platform",
74265            "https://www.googleapis.com/auth/compute"
74266          ],
74267          "description": "Deletes the specified SslCertificate resource in the region."
74268        }
74269      }
74270    },
74271    "sslPolicies": {
74272      "methods": {
74273        "list": {
74274          "id": "compute.sslPolicies.list",
74275          "path": "projects/{project}/global/sslPolicies",
74276          "flatPath": "projects/{project}/global/sslPolicies",
74277          "httpMethod": "GET",
74278          "parameters": {
74279            "filter": {
74280              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
74281              "location": "query",
74282              "type": "string"
74283            },
74284            "maxResults": {
74285              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
74286              "default": "500",
74287              "minimum": "0",
74288              "location": "query",
74289              "type": "integer",
74290              "format": "uint32"
74291            },
74292            "orderBy": {
74293              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
74294              "location": "query",
74295              "type": "string"
74296            },
74297            "pageToken": {
74298              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
74299              "location": "query",
74300              "type": "string"
74301            },
74302            "project": {
74303              "description": "Project ID for this request.",
74304              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74305              "location": "path",
74306              "required": true,
74307              "type": "string"
74308            },
74309            "returnPartialSuccess": {
74310              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
74311              "location": "query",
74312              "type": "boolean"
74313            }
74314          },
74315          "parameterOrder": [
74316            "project"
74317          ],
74318          "response": {
74319            "$ref": "SslPoliciesList"
74320          },
74321          "scopes": [
74322            "https://www.googleapis.com/auth/cloud-platform",
74323            "https://www.googleapis.com/auth/compute",
74324            "https://www.googleapis.com/auth/compute.readonly"
74325          ],
74326          "description": "Lists all the SSL policies that have been configured for the specified project."
74327        },
74328        "get": {
74329          "id": "compute.sslPolicies.get",
74330          "path": "projects/{project}/global/sslPolicies/{sslPolicy}",
74331          "flatPath": "projects/{project}/global/sslPolicies/{sslPolicy}",
74332          "httpMethod": "GET",
74333          "parameters": {
74334            "project": {
74335              "description": "Project ID for this request.",
74336              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74337              "location": "path",
74338              "required": true,
74339              "type": "string"
74340            },
74341            "sslPolicy": {
74342              "description": "Name of the SSL policy to update. The name must be 1-63 characters long, and comply with RFC1035.",
74343              "location": "path",
74344              "required": true,
74345              "type": "string"
74346            }
74347          },
74348          "parameterOrder": [
74349            "project",
74350            "sslPolicy"
74351          ],
74352          "response": {
74353            "$ref": "SslPolicy"
74354          },
74355          "scopes": [
74356            "https://www.googleapis.com/auth/cloud-platform",
74357            "https://www.googleapis.com/auth/compute",
74358            "https://www.googleapis.com/auth/compute.readonly"
74359          ],
74360          "description": "Lists all of the ordered rules present in a single specified policy."
74361        },
74362        "insert": {
74363          "id": "compute.sslPolicies.insert",
74364          "path": "projects/{project}/global/sslPolicies",
74365          "flatPath": "projects/{project}/global/sslPolicies",
74366          "httpMethod": "POST",
74367          "parameters": {
74368            "project": {
74369              "description": "Project ID for this request.",
74370              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74371              "location": "path",
74372              "required": true,
74373              "type": "string"
74374            },
74375            "requestId": {
74376              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
74377              "location": "query",
74378              "type": "string"
74379            }
74380          },
74381          "parameterOrder": [
74382            "project"
74383          ],
74384          "request": {
74385            "$ref": "SslPolicy"
74386          },
74387          "response": {
74388            "$ref": "Operation"
74389          },
74390          "scopes": [
74391            "https://www.googleapis.com/auth/cloud-platform",
74392            "https://www.googleapis.com/auth/compute"
74393          ],
74394          "description": "Returns the specified SSL policy resource."
74395        },
74396        "delete": {
74397          "id": "compute.sslPolicies.delete",
74398          "path": "projects/{project}/global/sslPolicies/{sslPolicy}",
74399          "flatPath": "projects/{project}/global/sslPolicies/{sslPolicy}",
74400          "httpMethod": "DELETE",
74401          "parameters": {
74402            "project": {
74403              "description": "Project ID for this request.",
74404              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74405              "location": "path",
74406              "required": true,
74407              "type": "string"
74408            },
74409            "requestId": {
74410              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
74411              "location": "query",
74412              "type": "string"
74413            },
74414            "sslPolicy": {
74415              "description": "Name of the SSL policy to delete. The name must be 1-63 characters long, and comply with RFC1035.",
74416              "location": "path",
74417              "required": true,
74418              "type": "string"
74419            }
74420          },
74421          "parameterOrder": [
74422            "project",
74423            "sslPolicy"
74424          ],
74425          "response": {
74426            "$ref": "Operation"
74427          },
74428          "scopes": [
74429            "https://www.googleapis.com/auth/cloud-platform",
74430            "https://www.googleapis.com/auth/compute"
74431          ],
74432          "description": "Deletes the specified SSL policy. The SSL policy resource can be deleted only if it is not in use by any TargetHttpsProxy or TargetSslProxy resources."
74433        },
74434        "patch": {
74435          "id": "compute.sslPolicies.patch",
74436          "path": "projects/{project}/global/sslPolicies/{sslPolicy}",
74437          "flatPath": "projects/{project}/global/sslPolicies/{sslPolicy}",
74438          "httpMethod": "PATCH",
74439          "parameters": {
74440            "project": {
74441              "description": "Project ID for this request.",
74442              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74443              "location": "path",
74444              "required": true,
74445              "type": "string"
74446            },
74447            "requestId": {
74448              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
74449              "location": "query",
74450              "type": "string"
74451            },
74452            "sslPolicy": {
74453              "description": "Name of the SSL policy to update. The name must be 1-63 characters long, and comply with RFC1035.",
74454              "location": "path",
74455              "required": true,
74456              "type": "string"
74457            }
74458          },
74459          "parameterOrder": [
74460            "project",
74461            "sslPolicy"
74462          ],
74463          "request": {
74464            "$ref": "SslPolicy"
74465          },
74466          "response": {
74467            "$ref": "Operation"
74468          },
74469          "scopes": [
74470            "https://www.googleapis.com/auth/cloud-platform",
74471            "https://www.googleapis.com/auth/compute"
74472          ],
74473          "description": "Patches the specified SSL policy with the data included in the request."
74474        },
74475        "listAvailableFeatures": {
74476          "id": "compute.sslPolicies.listAvailableFeatures",
74477          "path": "projects/{project}/global/sslPolicies/listAvailableFeatures",
74478          "flatPath": "projects/{project}/global/sslPolicies/listAvailableFeatures",
74479          "httpMethod": "GET",
74480          "parameters": {
74481            "filter": {
74482              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
74483              "location": "query",
74484              "type": "string"
74485            },
74486            "maxResults": {
74487              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
74488              "default": "500",
74489              "minimum": "0",
74490              "location": "query",
74491              "type": "integer",
74492              "format": "uint32"
74493            },
74494            "orderBy": {
74495              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
74496              "location": "query",
74497              "type": "string"
74498            },
74499            "pageToken": {
74500              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
74501              "location": "query",
74502              "type": "string"
74503            },
74504            "project": {
74505              "description": "Project ID for this request.",
74506              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74507              "location": "path",
74508              "required": true,
74509              "type": "string"
74510            },
74511            "returnPartialSuccess": {
74512              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
74513              "location": "query",
74514              "type": "boolean"
74515            }
74516          },
74517          "parameterOrder": [
74518            "project"
74519          ],
74520          "response": {
74521            "$ref": "SslPoliciesListAvailableFeaturesResponse"
74522          },
74523          "scopes": [
74524            "https://www.googleapis.com/auth/cloud-platform",
74525            "https://www.googleapis.com/auth/compute",
74526            "https://www.googleapis.com/auth/compute.readonly"
74527          ],
74528          "description": "Lists all features that can be specified in the SSL policy when using custom profile."
74529        },
74530        "aggregatedList": {
74531          "id": "compute.sslPolicies.aggregatedList",
74532          "path": "projects/{project}/aggregated/sslPolicies",
74533          "flatPath": "projects/{project}/aggregated/sslPolicies",
74534          "httpMethod": "GET",
74535          "parameters": {
74536            "filter": {
74537              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
74538              "location": "query",
74539              "type": "string"
74540            },
74541            "includeAllScopes": {
74542              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
74543              "location": "query",
74544              "type": "boolean"
74545            },
74546            "maxResults": {
74547              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
74548              "default": "500",
74549              "minimum": "0",
74550              "location": "query",
74551              "type": "integer",
74552              "format": "uint32"
74553            },
74554            "orderBy": {
74555              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
74556              "location": "query",
74557              "type": "string"
74558            },
74559            "pageToken": {
74560              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
74561              "location": "query",
74562              "type": "string"
74563            },
74564            "project": {
74565              "description": "Name of the project scoping this request.",
74566              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74567              "location": "path",
74568              "required": true,
74569              "type": "string"
74570            },
74571            "returnPartialSuccess": {
74572              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
74573              "location": "query",
74574              "type": "boolean"
74575            },
74576            "serviceProjectNumber": {
74577              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
74578              "location": "query",
74579              "type": "string",
74580              "format": "int64"
74581            }
74582          },
74583          "parameterOrder": [
74584            "project"
74585          ],
74586          "response": {
74587            "$ref": "SslPoliciesAggregatedList"
74588          },
74589          "scopes": [
74590            "https://www.googleapis.com/auth/cloud-platform",
74591            "https://www.googleapis.com/auth/compute",
74592            "https://www.googleapis.com/auth/compute.readonly"
74593          ],
74594          "description": "Retrieves the list of all SslPolicy resources, regional and global, available to the specified project. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
74595        }
74596      }
74597    },
74598    "regionSslPolicies": {
74599      "methods": {
74600        "list": {
74601          "id": "compute.regionSslPolicies.list",
74602          "path": "projects/{project}/regions/{region}/sslPolicies",
74603          "flatPath": "projects/{project}/regions/{region}/sslPolicies",
74604          "httpMethod": "GET",
74605          "parameters": {
74606            "filter": {
74607              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
74608              "location": "query",
74609              "type": "string"
74610            },
74611            "maxResults": {
74612              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
74613              "default": "500",
74614              "minimum": "0",
74615              "location": "query",
74616              "type": "integer",
74617              "format": "uint32"
74618            },
74619            "orderBy": {
74620              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
74621              "location": "query",
74622              "type": "string"
74623            },
74624            "pageToken": {
74625              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
74626              "location": "query",
74627              "type": "string"
74628            },
74629            "project": {
74630              "description": "Project ID for this request.",
74631              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74632              "location": "path",
74633              "required": true,
74634              "type": "string"
74635            },
74636            "region": {
74637              "description": "Name of the region scoping this request.",
74638              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
74639              "location": "path",
74640              "required": true,
74641              "type": "string"
74642            },
74643            "returnPartialSuccess": {
74644              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
74645              "location": "query",
74646              "type": "boolean"
74647            }
74648          },
74649          "parameterOrder": [
74650            "project",
74651            "region"
74652          ],
74653          "response": {
74654            "$ref": "SslPoliciesList"
74655          },
74656          "scopes": [
74657            "https://www.googleapis.com/auth/cloud-platform",
74658            "https://www.googleapis.com/auth/compute",
74659            "https://www.googleapis.com/auth/compute.readonly"
74660          ],
74661          "description": "Lists all the SSL policies that have been configured for the specified project and region."
74662        },
74663        "get": {
74664          "id": "compute.regionSslPolicies.get",
74665          "path": "projects/{project}/regions/{region}/sslPolicies/{sslPolicy}",
74666          "flatPath": "projects/{project}/regions/{region}/sslPolicies/{sslPolicy}",
74667          "httpMethod": "GET",
74668          "parameters": {
74669            "project": {
74670              "description": "Project ID for this request.",
74671              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74672              "location": "path",
74673              "required": true,
74674              "type": "string"
74675            },
74676            "region": {
74677              "description": "Name of the region scoping this request.",
74678              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
74679              "location": "path",
74680              "required": true,
74681              "type": "string"
74682            },
74683            "sslPolicy": {
74684              "description": "Name of the SSL policy to update. The name must be 1-63 characters long, and comply with RFC1035.",
74685              "location": "path",
74686              "required": true,
74687              "type": "string"
74688            }
74689          },
74690          "parameterOrder": [
74691            "project",
74692            "region",
74693            "sslPolicy"
74694          ],
74695          "response": {
74696            "$ref": "SslPolicy"
74697          },
74698          "scopes": [
74699            "https://www.googleapis.com/auth/cloud-platform",
74700            "https://www.googleapis.com/auth/compute",
74701            "https://www.googleapis.com/auth/compute.readonly"
74702          ],
74703          "description": "Lists all of the ordered rules present in a single specified policy."
74704        },
74705        "insert": {
74706          "id": "compute.regionSslPolicies.insert",
74707          "path": "projects/{project}/regions/{region}/sslPolicies",
74708          "flatPath": "projects/{project}/regions/{region}/sslPolicies",
74709          "httpMethod": "POST",
74710          "parameters": {
74711            "project": {
74712              "description": "Project ID for this request.",
74713              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74714              "location": "path",
74715              "required": true,
74716              "type": "string"
74717            },
74718            "region": {
74719              "description": "Name of the region scoping this request.",
74720              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
74721              "location": "path",
74722              "required": true,
74723              "type": "string"
74724            },
74725            "requestId": {
74726              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
74727              "location": "query",
74728              "type": "string"
74729            }
74730          },
74731          "parameterOrder": [
74732            "project",
74733            "region"
74734          ],
74735          "request": {
74736            "$ref": "SslPolicy"
74737          },
74738          "response": {
74739            "$ref": "Operation"
74740          },
74741          "scopes": [
74742            "https://www.googleapis.com/auth/cloud-platform",
74743            "https://www.googleapis.com/auth/compute"
74744          ],
74745          "description": "Creates a new policy in the specified project and region using the data included in the request."
74746        },
74747        "delete": {
74748          "id": "compute.regionSslPolicies.delete",
74749          "path": "projects/{project}/regions/{region}/sslPolicies/{sslPolicy}",
74750          "flatPath": "projects/{project}/regions/{region}/sslPolicies/{sslPolicy}",
74751          "httpMethod": "DELETE",
74752          "parameters": {
74753            "project": {
74754              "description": "Project ID for this request.",
74755              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74756              "location": "path",
74757              "required": true,
74758              "type": "string"
74759            },
74760            "region": {
74761              "description": "Name of the region scoping this request.",
74762              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
74763              "location": "path",
74764              "required": true,
74765              "type": "string"
74766            },
74767            "requestId": {
74768              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
74769              "location": "query",
74770              "type": "string"
74771            },
74772            "sslPolicy": {
74773              "description": "Name of the SSL policy to delete. The name must be 1-63 characters long, and comply with RFC1035.",
74774              "location": "path",
74775              "required": true,
74776              "type": "string"
74777            }
74778          },
74779          "parameterOrder": [
74780            "project",
74781            "region",
74782            "sslPolicy"
74783          ],
74784          "response": {
74785            "$ref": "Operation"
74786          },
74787          "scopes": [
74788            "https://www.googleapis.com/auth/cloud-platform",
74789            "https://www.googleapis.com/auth/compute"
74790          ],
74791          "description": "Deletes the specified SSL policy. The SSL policy resource can be deleted only if it is not in use by any TargetHttpsProxy or TargetSslProxy resources."
74792        },
74793        "patch": {
74794          "id": "compute.regionSslPolicies.patch",
74795          "path": "projects/{project}/regions/{region}/sslPolicies/{sslPolicy}",
74796          "flatPath": "projects/{project}/regions/{region}/sslPolicies/{sslPolicy}",
74797          "httpMethod": "PATCH",
74798          "parameters": {
74799            "project": {
74800              "description": "Project ID for this request.",
74801              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74802              "location": "path",
74803              "required": true,
74804              "type": "string"
74805            },
74806            "region": {
74807              "description": "Name of the region scoping this request.",
74808              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
74809              "location": "path",
74810              "required": true,
74811              "type": "string"
74812            },
74813            "requestId": {
74814              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
74815              "location": "query",
74816              "type": "string"
74817            },
74818            "sslPolicy": {
74819              "description": "Name of the SSL policy to update. The name must be 1-63 characters long, and comply with RFC1035.",
74820              "location": "path",
74821              "required": true,
74822              "type": "string"
74823            }
74824          },
74825          "parameterOrder": [
74826            "project",
74827            "region",
74828            "sslPolicy"
74829          ],
74830          "request": {
74831            "$ref": "SslPolicy"
74832          },
74833          "response": {
74834            "$ref": "Operation"
74835          },
74836          "scopes": [
74837            "https://www.googleapis.com/auth/cloud-platform",
74838            "https://www.googleapis.com/auth/compute"
74839          ],
74840          "description": "Patches the specified SSL policy with the data included in the request."
74841        },
74842        "listAvailableFeatures": {
74843          "id": "compute.regionSslPolicies.listAvailableFeatures",
74844          "path": "projects/{project}/regions/{region}/sslPolicies/listAvailableFeatures",
74845          "flatPath": "projects/{project}/regions/{region}/sslPolicies/listAvailableFeatures",
74846          "httpMethod": "GET",
74847          "parameters": {
74848            "filter": {
74849              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
74850              "location": "query",
74851              "type": "string"
74852            },
74853            "maxResults": {
74854              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
74855              "default": "500",
74856              "minimum": "0",
74857              "location": "query",
74858              "type": "integer",
74859              "format": "uint32"
74860            },
74861            "orderBy": {
74862              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
74863              "location": "query",
74864              "type": "string"
74865            },
74866            "pageToken": {
74867              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
74868              "location": "query",
74869              "type": "string"
74870            },
74871            "project": {
74872              "description": "Project ID for this request.",
74873              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74874              "location": "path",
74875              "required": true,
74876              "type": "string"
74877            },
74878            "region": {
74879              "description": "Name of the region scoping this request.",
74880              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
74881              "location": "path",
74882              "required": true,
74883              "type": "string"
74884            },
74885            "returnPartialSuccess": {
74886              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
74887              "location": "query",
74888              "type": "boolean"
74889            }
74890          },
74891          "parameterOrder": [
74892            "project",
74893            "region"
74894          ],
74895          "response": {
74896            "$ref": "SslPoliciesListAvailableFeaturesResponse"
74897          },
74898          "scopes": [
74899            "https://www.googleapis.com/auth/cloud-platform",
74900            "https://www.googleapis.com/auth/compute",
74901            "https://www.googleapis.com/auth/compute.readonly"
74902          ],
74903          "description": "Lists all features that can be specified in the SSL policy when using custom profile."
74904        }
74905      }
74906    },
74907    "subnetworks": {
74908      "methods": {
74909        "list": {
74910          "id": "compute.subnetworks.list",
74911          "path": "projects/{project}/regions/{region}/subnetworks",
74912          "flatPath": "projects/{project}/regions/{region}/subnetworks",
74913          "httpMethod": "GET",
74914          "parameters": {
74915            "filter": {
74916              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
74917              "location": "query",
74918              "type": "string"
74919            },
74920            "maxResults": {
74921              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
74922              "default": "500",
74923              "minimum": "0",
74924              "location": "query",
74925              "type": "integer",
74926              "format": "uint32"
74927            },
74928            "orderBy": {
74929              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
74930              "location": "query",
74931              "type": "string"
74932            },
74933            "pageToken": {
74934              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
74935              "location": "query",
74936              "type": "string"
74937            },
74938            "project": {
74939              "description": "Project ID for this request.",
74940              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
74941              "location": "path",
74942              "required": true,
74943              "type": "string"
74944            },
74945            "region": {
74946              "description": "Name of the region scoping this request.",
74947              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
74948              "location": "path",
74949              "required": true,
74950              "type": "string"
74951            },
74952            "returnPartialSuccess": {
74953              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
74954              "location": "query",
74955              "type": "boolean"
74956            }
74957          },
74958          "parameterOrder": [
74959            "project",
74960            "region"
74961          ],
74962          "response": {
74963            "$ref": "SubnetworkList"
74964          },
74965          "scopes": [
74966            "https://www.googleapis.com/auth/cloud-platform",
74967            "https://www.googleapis.com/auth/compute",
74968            "https://www.googleapis.com/auth/compute.readonly"
74969          ],
74970          "description": "Retrieves a list of subnetworks available to the specified project."
74971        },
74972        "aggregatedList": {
74973          "id": "compute.subnetworks.aggregatedList",
74974          "path": "projects/{project}/aggregated/subnetworks",
74975          "flatPath": "projects/{project}/aggregated/subnetworks",
74976          "httpMethod": "GET",
74977          "parameters": {
74978            "filter": {
74979              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
74980              "location": "query",
74981              "type": "string"
74982            },
74983            "includeAllScopes": {
74984              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
74985              "location": "query",
74986              "type": "boolean"
74987            },
74988            "maxResults": {
74989              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
74990              "default": "500",
74991              "minimum": "0",
74992              "location": "query",
74993              "type": "integer",
74994              "format": "uint32"
74995            },
74996            "orderBy": {
74997              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
74998              "location": "query",
74999              "type": "string"
75000            },
75001            "pageToken": {
75002              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
75003              "location": "query",
75004              "type": "string"
75005            },
75006            "project": {
75007              "description": "Project ID for this request.",
75008              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75009              "location": "path",
75010              "required": true,
75011              "type": "string"
75012            },
75013            "returnPartialSuccess": {
75014              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
75015              "location": "query",
75016              "type": "boolean"
75017            },
75018            "serviceProjectNumber": {
75019              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
75020              "location": "query",
75021              "type": "string",
75022              "format": "int64"
75023            }
75024          },
75025          "parameterOrder": [
75026            "project"
75027          ],
75028          "response": {
75029            "$ref": "SubnetworkAggregatedList"
75030          },
75031          "scopes": [
75032            "https://www.googleapis.com/auth/cloud-platform",
75033            "https://www.googleapis.com/auth/compute",
75034            "https://www.googleapis.com/auth/compute.readonly"
75035          ],
75036          "description": "Retrieves an aggregated list of subnetworks. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
75037        },
75038        "listUsable": {
75039          "id": "compute.subnetworks.listUsable",
75040          "path": "projects/{project}/aggregated/subnetworks/listUsable",
75041          "flatPath": "projects/{project}/aggregated/subnetworks/listUsable",
75042          "httpMethod": "GET",
75043          "parameters": {
75044            "filter": {
75045              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
75046              "location": "query",
75047              "type": "string"
75048            },
75049            "maxResults": {
75050              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
75051              "default": "500",
75052              "minimum": "0",
75053              "location": "query",
75054              "type": "integer",
75055              "format": "uint32"
75056            },
75057            "orderBy": {
75058              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
75059              "location": "query",
75060              "type": "string"
75061            },
75062            "pageToken": {
75063              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
75064              "location": "query",
75065              "type": "string"
75066            },
75067            "project": {
75068              "description": "Project ID for this request.",
75069              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75070              "location": "path",
75071              "required": true,
75072              "type": "string"
75073            },
75074            "returnPartialSuccess": {
75075              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
75076              "location": "query",
75077              "type": "boolean"
75078            }
75079          },
75080          "parameterOrder": [
75081            "project"
75082          ],
75083          "response": {
75084            "$ref": "UsableSubnetworksAggregatedList"
75085          },
75086          "scopes": [
75087            "https://www.googleapis.com/auth/cloud-platform",
75088            "https://www.googleapis.com/auth/compute",
75089            "https://www.googleapis.com/auth/compute.readonly"
75090          ],
75091          "description": "Retrieves an aggregated list of all usable subnetworks in the project."
75092        },
75093        "get": {
75094          "id": "compute.subnetworks.get",
75095          "path": "projects/{project}/regions/{region}/subnetworks/{subnetwork}",
75096          "flatPath": "projects/{project}/regions/{region}/subnetworks/{subnetwork}",
75097          "httpMethod": "GET",
75098          "parameters": {
75099            "project": {
75100              "description": "Project ID for this request.",
75101              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75102              "location": "path",
75103              "required": true,
75104              "type": "string"
75105            },
75106            "region": {
75107              "description": "Name of the region scoping this request.",
75108              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
75109              "location": "path",
75110              "required": true,
75111              "type": "string"
75112            },
75113            "subnetwork": {
75114              "description": "Name of the Subnetwork resource to return.",
75115              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
75116              "location": "path",
75117              "required": true,
75118              "type": "string"
75119            }
75120          },
75121          "parameterOrder": [
75122            "project",
75123            "region",
75124            "subnetwork"
75125          ],
75126          "response": {
75127            "$ref": "Subnetwork"
75128          },
75129          "scopes": [
75130            "https://www.googleapis.com/auth/cloud-platform",
75131            "https://www.googleapis.com/auth/compute",
75132            "https://www.googleapis.com/auth/compute.readonly"
75133          ],
75134          "description": "Returns the specified subnetwork."
75135        },
75136        "insert": {
75137          "id": "compute.subnetworks.insert",
75138          "path": "projects/{project}/regions/{region}/subnetworks",
75139          "flatPath": "projects/{project}/regions/{region}/subnetworks",
75140          "httpMethod": "POST",
75141          "parameters": {
75142            "project": {
75143              "description": "Project ID for this request.",
75144              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75145              "location": "path",
75146              "required": true,
75147              "type": "string"
75148            },
75149            "region": {
75150              "description": "Name of the region scoping this request.",
75151              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
75152              "location": "path",
75153              "required": true,
75154              "type": "string"
75155            },
75156            "requestId": {
75157              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
75158              "location": "query",
75159              "type": "string"
75160            }
75161          },
75162          "parameterOrder": [
75163            "project",
75164            "region"
75165          ],
75166          "request": {
75167            "$ref": "Subnetwork"
75168          },
75169          "response": {
75170            "$ref": "Operation"
75171          },
75172          "scopes": [
75173            "https://www.googleapis.com/auth/cloud-platform",
75174            "https://www.googleapis.com/auth/compute"
75175          ],
75176          "description": "Creates a subnetwork in the specified project using the data included in the request."
75177        },
75178        "delete": {
75179          "id": "compute.subnetworks.delete",
75180          "path": "projects/{project}/regions/{region}/subnetworks/{subnetwork}",
75181          "flatPath": "projects/{project}/regions/{region}/subnetworks/{subnetwork}",
75182          "httpMethod": "DELETE",
75183          "parameters": {
75184            "project": {
75185              "description": "Project ID for this request.",
75186              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75187              "location": "path",
75188              "required": true,
75189              "type": "string"
75190            },
75191            "region": {
75192              "description": "Name of the region scoping this request.",
75193              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
75194              "location": "path",
75195              "required": true,
75196              "type": "string"
75197            },
75198            "requestId": {
75199              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
75200              "location": "query",
75201              "type": "string"
75202            },
75203            "subnetwork": {
75204              "description": "Name of the Subnetwork resource to delete.",
75205              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
75206              "location": "path",
75207              "required": true,
75208              "type": "string"
75209            }
75210          },
75211          "parameterOrder": [
75212            "project",
75213            "region",
75214            "subnetwork"
75215          ],
75216          "response": {
75217            "$ref": "Operation"
75218          },
75219          "scopes": [
75220            "https://www.googleapis.com/auth/cloud-platform",
75221            "https://www.googleapis.com/auth/compute"
75222          ],
75223          "description": "Deletes the specified subnetwork."
75224        },
75225        "expandIpCidrRange": {
75226          "id": "compute.subnetworks.expandIpCidrRange",
75227          "path": "projects/{project}/regions/{region}/subnetworks/{subnetwork}/expandIpCidrRange",
75228          "flatPath": "projects/{project}/regions/{region}/subnetworks/{subnetwork}/expandIpCidrRange",
75229          "httpMethod": "POST",
75230          "parameters": {
75231            "project": {
75232              "description": "Project ID for this request.",
75233              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75234              "location": "path",
75235              "required": true,
75236              "type": "string"
75237            },
75238            "region": {
75239              "description": "Name of the region scoping this request.",
75240              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
75241              "location": "path",
75242              "required": true,
75243              "type": "string"
75244            },
75245            "requestId": {
75246              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
75247              "location": "query",
75248              "type": "string"
75249            },
75250            "subnetwork": {
75251              "description": "Name of the Subnetwork resource to update.",
75252              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
75253              "location": "path",
75254              "required": true,
75255              "type": "string"
75256            }
75257          },
75258          "parameterOrder": [
75259            "project",
75260            "region",
75261            "subnetwork"
75262          ],
75263          "request": {
75264            "$ref": "SubnetworksExpandIpCidrRangeRequest"
75265          },
75266          "response": {
75267            "$ref": "Operation"
75268          },
75269          "scopes": [
75270            "https://www.googleapis.com/auth/cloud-platform",
75271            "https://www.googleapis.com/auth/compute"
75272          ],
75273          "description": "Expands the IP CIDR range of the subnetwork to a specified value."
75274        },
75275        "patch": {
75276          "id": "compute.subnetworks.patch",
75277          "path": "projects/{project}/regions/{region}/subnetworks/{subnetwork}",
75278          "flatPath": "projects/{project}/regions/{region}/subnetworks/{subnetwork}",
75279          "httpMethod": "PATCH",
75280          "parameters": {
75281            "drainTimeoutSeconds": {
75282              "description": "The drain timeout specifies the upper bound in seconds on the amount of time allowed to drain connections from the current ACTIVE subnetwork to the current BACKUP subnetwork. The drain timeout is only applicable when the following conditions are true: - the subnetwork being patched has purpose = INTERNAL_HTTPS_LOAD_BALANCER - the subnetwork being patched has role = BACKUP - the patch request is setting the role to ACTIVE. Note that after this patch operation the roles of the ACTIVE and BACKUP subnetworks will be swapped.",
75283              "location": "query",
75284              "type": "integer",
75285              "format": "int32"
75286            },
75287            "project": {
75288              "description": "Project ID for this request.",
75289              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75290              "location": "path",
75291              "required": true,
75292              "type": "string"
75293            },
75294            "region": {
75295              "description": "Name of the region scoping this request.",
75296              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
75297              "location": "path",
75298              "required": true,
75299              "type": "string"
75300            },
75301            "requestId": {
75302              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
75303              "location": "query",
75304              "type": "string"
75305            },
75306            "subnetwork": {
75307              "description": "Name of the Subnetwork resource to patch.",
75308              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
75309              "location": "path",
75310              "required": true,
75311              "type": "string"
75312            }
75313          },
75314          "parameterOrder": [
75315            "project",
75316            "region",
75317            "subnetwork"
75318          ],
75319          "request": {
75320            "$ref": "Subnetwork"
75321          },
75322          "response": {
75323            "$ref": "Operation"
75324          },
75325          "scopes": [
75326            "https://www.googleapis.com/auth/cloud-platform",
75327            "https://www.googleapis.com/auth/compute"
75328          ],
75329          "description": "Patches the specified subnetwork with the data included in the request. Only certain fields can be updated with a patch request as indicated in the field descriptions. You must specify the current fingerprint of the subnetwork resource being patched."
75330        },
75331        "getIamPolicy": {
75332          "id": "compute.subnetworks.getIamPolicy",
75333          "path": "projects/{project}/regions/{region}/subnetworks/{resource}/getIamPolicy",
75334          "flatPath": "projects/{project}/regions/{region}/subnetworks/{resource}/getIamPolicy",
75335          "httpMethod": "GET",
75336          "parameters": {
75337            "optionsRequestedPolicyVersion": {
75338              "description": "Requested IAM Policy version.",
75339              "location": "query",
75340              "type": "integer",
75341              "format": "int32"
75342            },
75343            "project": {
75344              "description": "Project ID for this request.",
75345              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75346              "location": "path",
75347              "required": true,
75348              "type": "string"
75349            },
75350            "region": {
75351              "description": "The name of the region for this request.",
75352              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
75353              "location": "path",
75354              "required": true,
75355              "type": "string"
75356            },
75357            "resource": {
75358              "description": "Name or id of the resource for this request.",
75359              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
75360              "location": "path",
75361              "required": true,
75362              "type": "string"
75363            }
75364          },
75365          "parameterOrder": [
75366            "project",
75367            "region",
75368            "resource"
75369          ],
75370          "response": {
75371            "$ref": "Policy"
75372          },
75373          "scopes": [
75374            "https://www.googleapis.com/auth/cloud-platform",
75375            "https://www.googleapis.com/auth/compute",
75376            "https://www.googleapis.com/auth/compute.readonly"
75377          ],
75378          "description": "Gets the access control policy for a resource. May be empty if no such policy or resource exists."
75379        },
75380        "setIamPolicy": {
75381          "id": "compute.subnetworks.setIamPolicy",
75382          "path": "projects/{project}/regions/{region}/subnetworks/{resource}/setIamPolicy",
75383          "flatPath": "projects/{project}/regions/{region}/subnetworks/{resource}/setIamPolicy",
75384          "httpMethod": "POST",
75385          "parameters": {
75386            "project": {
75387              "description": "Project ID for this request.",
75388              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75389              "location": "path",
75390              "required": true,
75391              "type": "string"
75392            },
75393            "region": {
75394              "description": "The name of the region for this request.",
75395              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
75396              "location": "path",
75397              "required": true,
75398              "type": "string"
75399            },
75400            "resource": {
75401              "description": "Name or id of the resource for this request.",
75402              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
75403              "location": "path",
75404              "required": true,
75405              "type": "string"
75406            }
75407          },
75408          "parameterOrder": [
75409            "project",
75410            "region",
75411            "resource"
75412          ],
75413          "request": {
75414            "$ref": "RegionSetPolicyRequest"
75415          },
75416          "response": {
75417            "$ref": "Policy"
75418          },
75419          "scopes": [
75420            "https://www.googleapis.com/auth/cloud-platform",
75421            "https://www.googleapis.com/auth/compute"
75422          ],
75423          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
75424        },
75425        "testIamPermissions": {
75426          "id": "compute.subnetworks.testIamPermissions",
75427          "path": "projects/{project}/regions/{region}/subnetworks/{resource}/testIamPermissions",
75428          "flatPath": "projects/{project}/regions/{region}/subnetworks/{resource}/testIamPermissions",
75429          "httpMethod": "POST",
75430          "parameters": {
75431            "project": {
75432              "description": "Project ID for this request.",
75433              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75434              "location": "path",
75435              "required": true,
75436              "type": "string"
75437            },
75438            "region": {
75439              "description": "The name of the region for this request.",
75440              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
75441              "location": "path",
75442              "required": true,
75443              "type": "string"
75444            },
75445            "resource": {
75446              "description": "Name or id of the resource for this request.",
75447              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
75448              "location": "path",
75449              "required": true,
75450              "type": "string"
75451            }
75452          },
75453          "parameterOrder": [
75454            "project",
75455            "region",
75456            "resource"
75457          ],
75458          "request": {
75459            "$ref": "TestPermissionsRequest"
75460          },
75461          "response": {
75462            "$ref": "TestPermissionsResponse"
75463          },
75464          "scopes": [
75465            "https://www.googleapis.com/auth/cloud-platform",
75466            "https://www.googleapis.com/auth/compute",
75467            "https://www.googleapis.com/auth/compute.readonly"
75468          ],
75469          "description": "Returns permissions that a caller has on the specified resource."
75470        },
75471        "setPrivateIpGoogleAccess": {
75472          "id": "compute.subnetworks.setPrivateIpGoogleAccess",
75473          "path": "projects/{project}/regions/{region}/subnetworks/{subnetwork}/setPrivateIpGoogleAccess",
75474          "flatPath": "projects/{project}/regions/{region}/subnetworks/{subnetwork}/setPrivateIpGoogleAccess",
75475          "httpMethod": "POST",
75476          "parameters": {
75477            "project": {
75478              "description": "Project ID for this request.",
75479              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75480              "location": "path",
75481              "required": true,
75482              "type": "string"
75483            },
75484            "region": {
75485              "description": "Name of the region scoping this request.",
75486              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
75487              "location": "path",
75488              "required": true,
75489              "type": "string"
75490            },
75491            "requestId": {
75492              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
75493              "location": "query",
75494              "type": "string"
75495            },
75496            "subnetwork": {
75497              "description": "Name of the Subnetwork resource.",
75498              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
75499              "location": "path",
75500              "required": true,
75501              "type": "string"
75502            }
75503          },
75504          "parameterOrder": [
75505            "project",
75506            "region",
75507            "subnetwork"
75508          ],
75509          "request": {
75510            "$ref": "SubnetworksSetPrivateIpGoogleAccessRequest"
75511          },
75512          "response": {
75513            "$ref": "Operation"
75514          },
75515          "scopes": [
75516            "https://www.googleapis.com/auth/cloud-platform",
75517            "https://www.googleapis.com/auth/compute"
75518          ],
75519          "description": "Set whether VMs in this subnet can access Google services without assigning external IP addresses through Private Google Access."
75520        }
75521      }
75522    },
75523    "targetGrpcProxies": {
75524      "methods": {
75525        "list": {
75526          "id": "compute.targetGrpcProxies.list",
75527          "path": "projects/{project}/global/targetGrpcProxies",
75528          "flatPath": "projects/{project}/global/targetGrpcProxies",
75529          "httpMethod": "GET",
75530          "parameters": {
75531            "filter": {
75532              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
75533              "location": "query",
75534              "type": "string"
75535            },
75536            "maxResults": {
75537              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
75538              "default": "500",
75539              "minimum": "0",
75540              "location": "query",
75541              "type": "integer",
75542              "format": "uint32"
75543            },
75544            "orderBy": {
75545              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
75546              "location": "query",
75547              "type": "string"
75548            },
75549            "pageToken": {
75550              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
75551              "location": "query",
75552              "type": "string"
75553            },
75554            "project": {
75555              "description": "Project ID for this request.",
75556              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75557              "location": "path",
75558              "required": true,
75559              "type": "string"
75560            },
75561            "returnPartialSuccess": {
75562              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
75563              "location": "query",
75564              "type": "boolean"
75565            }
75566          },
75567          "parameterOrder": [
75568            "project"
75569          ],
75570          "response": {
75571            "$ref": "TargetGrpcProxyList"
75572          },
75573          "scopes": [
75574            "https://www.googleapis.com/auth/cloud-platform",
75575            "https://www.googleapis.com/auth/compute",
75576            "https://www.googleapis.com/auth/compute.readonly"
75577          ],
75578          "description": "Lists the TargetGrpcProxies for a project in the given scope."
75579        },
75580        "get": {
75581          "id": "compute.targetGrpcProxies.get",
75582          "path": "projects/{project}/global/targetGrpcProxies/{targetGrpcProxy}",
75583          "flatPath": "projects/{project}/global/targetGrpcProxies/{targetGrpcProxy}",
75584          "httpMethod": "GET",
75585          "parameters": {
75586            "project": {
75587              "description": "Project ID for this request.",
75588              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75589              "location": "path",
75590              "required": true,
75591              "type": "string"
75592            },
75593            "targetGrpcProxy": {
75594              "description": "Name of the TargetGrpcProxy resource to return.",
75595              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
75596              "location": "path",
75597              "required": true,
75598              "type": "string"
75599            }
75600          },
75601          "parameterOrder": [
75602            "project",
75603            "targetGrpcProxy"
75604          ],
75605          "response": {
75606            "$ref": "TargetGrpcProxy"
75607          },
75608          "scopes": [
75609            "https://www.googleapis.com/auth/cloud-platform",
75610            "https://www.googleapis.com/auth/compute",
75611            "https://www.googleapis.com/auth/compute.readonly"
75612          ],
75613          "description": "Returns the specified TargetGrpcProxy resource in the given scope."
75614        },
75615        "insert": {
75616          "id": "compute.targetGrpcProxies.insert",
75617          "path": "projects/{project}/global/targetGrpcProxies",
75618          "flatPath": "projects/{project}/global/targetGrpcProxies",
75619          "httpMethod": "POST",
75620          "parameters": {
75621            "project": {
75622              "description": "Project ID for this request.",
75623              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75624              "location": "path",
75625              "required": true,
75626              "type": "string"
75627            },
75628            "requestId": {
75629              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
75630              "location": "query",
75631              "type": "string"
75632            }
75633          },
75634          "parameterOrder": [
75635            "project"
75636          ],
75637          "request": {
75638            "$ref": "TargetGrpcProxy"
75639          },
75640          "response": {
75641            "$ref": "Operation"
75642          },
75643          "scopes": [
75644            "https://www.googleapis.com/auth/cloud-platform",
75645            "https://www.googleapis.com/auth/compute"
75646          ],
75647          "description": "Creates a TargetGrpcProxy in the specified project in the given scope using the parameters that are included in the request."
75648        },
75649        "delete": {
75650          "id": "compute.targetGrpcProxies.delete",
75651          "path": "projects/{project}/global/targetGrpcProxies/{targetGrpcProxy}",
75652          "flatPath": "projects/{project}/global/targetGrpcProxies/{targetGrpcProxy}",
75653          "httpMethod": "DELETE",
75654          "parameters": {
75655            "project": {
75656              "description": "Project ID for this request.",
75657              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75658              "location": "path",
75659              "required": true,
75660              "type": "string"
75661            },
75662            "requestId": {
75663              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
75664              "location": "query",
75665              "type": "string"
75666            },
75667            "targetGrpcProxy": {
75668              "description": "Name of the TargetGrpcProxy resource to delete.",
75669              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
75670              "location": "path",
75671              "required": true,
75672              "type": "string"
75673            }
75674          },
75675          "parameterOrder": [
75676            "project",
75677            "targetGrpcProxy"
75678          ],
75679          "response": {
75680            "$ref": "Operation"
75681          },
75682          "scopes": [
75683            "https://www.googleapis.com/auth/cloud-platform",
75684            "https://www.googleapis.com/auth/compute"
75685          ],
75686          "description": "Deletes the specified TargetGrpcProxy in the given scope"
75687        },
75688        "patch": {
75689          "id": "compute.targetGrpcProxies.patch",
75690          "path": "projects/{project}/global/targetGrpcProxies/{targetGrpcProxy}",
75691          "flatPath": "projects/{project}/global/targetGrpcProxies/{targetGrpcProxy}",
75692          "httpMethod": "PATCH",
75693          "parameters": {
75694            "project": {
75695              "description": "Project ID for this request.",
75696              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75697              "location": "path",
75698              "required": true,
75699              "type": "string"
75700            },
75701            "requestId": {
75702              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
75703              "location": "query",
75704              "type": "string"
75705            },
75706            "targetGrpcProxy": {
75707              "description": "Name of the TargetGrpcProxy resource to patch.",
75708              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
75709              "location": "path",
75710              "required": true,
75711              "type": "string"
75712            }
75713          },
75714          "parameterOrder": [
75715            "project",
75716            "targetGrpcProxy"
75717          ],
75718          "request": {
75719            "$ref": "TargetGrpcProxy"
75720          },
75721          "response": {
75722            "$ref": "Operation"
75723          },
75724          "scopes": [
75725            "https://www.googleapis.com/auth/cloud-platform",
75726            "https://www.googleapis.com/auth/compute"
75727          ],
75728          "description": "Patches the specified TargetGrpcProxy resource with the data included in the request. This method supports PATCH semantics and uses JSON merge patch format and processing rules."
75729        }
75730      }
75731    },
75732    "targetHttpProxies": {
75733      "methods": {
75734        "list": {
75735          "id": "compute.targetHttpProxies.list",
75736          "path": "projects/{project}/global/targetHttpProxies",
75737          "flatPath": "projects/{project}/global/targetHttpProxies",
75738          "httpMethod": "GET",
75739          "parameters": {
75740            "filter": {
75741              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
75742              "location": "query",
75743              "type": "string"
75744            },
75745            "maxResults": {
75746              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
75747              "default": "500",
75748              "minimum": "0",
75749              "location": "query",
75750              "type": "integer",
75751              "format": "uint32"
75752            },
75753            "orderBy": {
75754              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
75755              "location": "query",
75756              "type": "string"
75757            },
75758            "pageToken": {
75759              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
75760              "location": "query",
75761              "type": "string"
75762            },
75763            "project": {
75764              "description": "Project ID for this request.",
75765              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75766              "location": "path",
75767              "required": true,
75768              "type": "string"
75769            },
75770            "returnPartialSuccess": {
75771              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
75772              "location": "query",
75773              "type": "boolean"
75774            }
75775          },
75776          "parameterOrder": [
75777            "project"
75778          ],
75779          "response": {
75780            "$ref": "TargetHttpProxyList"
75781          },
75782          "scopes": [
75783            "https://www.googleapis.com/auth/cloud-platform",
75784            "https://www.googleapis.com/auth/compute",
75785            "https://www.googleapis.com/auth/compute.readonly"
75786          ],
75787          "description": "Retrieves the list of TargetHttpProxy resources available to the specified project."
75788        },
75789        "get": {
75790          "id": "compute.targetHttpProxies.get",
75791          "path": "projects/{project}/global/targetHttpProxies/{targetHttpProxy}",
75792          "flatPath": "projects/{project}/global/targetHttpProxies/{targetHttpProxy}",
75793          "httpMethod": "GET",
75794          "parameters": {
75795            "project": {
75796              "description": "Project ID for this request.",
75797              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75798              "location": "path",
75799              "required": true,
75800              "type": "string"
75801            },
75802            "targetHttpProxy": {
75803              "description": "Name of the TargetHttpProxy resource to return.",
75804              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
75805              "location": "path",
75806              "required": true,
75807              "type": "string"
75808            }
75809          },
75810          "parameterOrder": [
75811            "project",
75812            "targetHttpProxy"
75813          ],
75814          "response": {
75815            "$ref": "TargetHttpProxy"
75816          },
75817          "scopes": [
75818            "https://www.googleapis.com/auth/cloud-platform",
75819            "https://www.googleapis.com/auth/compute",
75820            "https://www.googleapis.com/auth/compute.readonly"
75821          ],
75822          "description": "Returns the specified TargetHttpProxy resource."
75823        },
75824        "insert": {
75825          "id": "compute.targetHttpProxies.insert",
75826          "path": "projects/{project}/global/targetHttpProxies",
75827          "flatPath": "projects/{project}/global/targetHttpProxies",
75828          "httpMethod": "POST",
75829          "parameters": {
75830            "project": {
75831              "description": "Project ID for this request.",
75832              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75833              "location": "path",
75834              "required": true,
75835              "type": "string"
75836            },
75837            "requestId": {
75838              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
75839              "location": "query",
75840              "type": "string"
75841            }
75842          },
75843          "parameterOrder": [
75844            "project"
75845          ],
75846          "request": {
75847            "$ref": "TargetHttpProxy"
75848          },
75849          "response": {
75850            "$ref": "Operation"
75851          },
75852          "scopes": [
75853            "https://www.googleapis.com/auth/cloud-platform",
75854            "https://www.googleapis.com/auth/compute"
75855          ],
75856          "description": "Creates a TargetHttpProxy resource in the specified project using the data included in the request."
75857        },
75858        "delete": {
75859          "id": "compute.targetHttpProxies.delete",
75860          "path": "projects/{project}/global/targetHttpProxies/{targetHttpProxy}",
75861          "flatPath": "projects/{project}/global/targetHttpProxies/{targetHttpProxy}",
75862          "httpMethod": "DELETE",
75863          "parameters": {
75864            "project": {
75865              "description": "Project ID for this request.",
75866              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75867              "location": "path",
75868              "required": true,
75869              "type": "string"
75870            },
75871            "requestId": {
75872              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
75873              "location": "query",
75874              "type": "string"
75875            },
75876            "targetHttpProxy": {
75877              "description": "Name of the TargetHttpProxy resource to delete.",
75878              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
75879              "location": "path",
75880              "required": true,
75881              "type": "string"
75882            }
75883          },
75884          "parameterOrder": [
75885            "project",
75886            "targetHttpProxy"
75887          ],
75888          "response": {
75889            "$ref": "Operation"
75890          },
75891          "scopes": [
75892            "https://www.googleapis.com/auth/cloud-platform",
75893            "https://www.googleapis.com/auth/compute"
75894          ],
75895          "description": "Deletes the specified TargetHttpProxy resource."
75896        },
75897        "patch": {
75898          "id": "compute.targetHttpProxies.patch",
75899          "path": "projects/{project}/global/targetHttpProxies/{targetHttpProxy}",
75900          "flatPath": "projects/{project}/global/targetHttpProxies/{targetHttpProxy}",
75901          "httpMethod": "PATCH",
75902          "parameters": {
75903            "project": {
75904              "description": "Project ID for this request.",
75905              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75906              "location": "path",
75907              "required": true,
75908              "type": "string"
75909            },
75910            "requestId": {
75911              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
75912              "location": "query",
75913              "type": "string"
75914            },
75915            "targetHttpProxy": {
75916              "description": "Name of the TargetHttpProxy resource to patch.",
75917              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
75918              "location": "path",
75919              "required": true,
75920              "type": "string"
75921            }
75922          },
75923          "parameterOrder": [
75924            "project",
75925            "targetHttpProxy"
75926          ],
75927          "request": {
75928            "$ref": "TargetHttpProxy"
75929          },
75930          "response": {
75931            "$ref": "Operation"
75932          },
75933          "scopes": [
75934            "https://www.googleapis.com/auth/cloud-platform",
75935            "https://www.googleapis.com/auth/compute"
75936          ],
75937          "description": "Patches the specified TargetHttpProxy resource with the data included in the request. This method supports PATCH semantics and uses JSON merge patch format and processing rules."
75938        },
75939        "setUrlMap": {
75940          "id": "compute.targetHttpProxies.setUrlMap",
75941          "path": "projects/{project}/targetHttpProxies/{targetHttpProxy}/setUrlMap",
75942          "flatPath": "projects/{project}/targetHttpProxies/{targetHttpProxy}/setUrlMap",
75943          "httpMethod": "POST",
75944          "parameters": {
75945            "project": {
75946              "description": "Project ID for this request.",
75947              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
75948              "location": "path",
75949              "required": true,
75950              "type": "string"
75951            },
75952            "requestId": {
75953              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
75954              "location": "query",
75955              "type": "string"
75956            },
75957            "targetHttpProxy": {
75958              "description": "Name of the TargetHttpProxy to set a URL map for.",
75959              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
75960              "location": "path",
75961              "required": true,
75962              "type": "string"
75963            }
75964          },
75965          "parameterOrder": [
75966            "project",
75967            "targetHttpProxy"
75968          ],
75969          "request": {
75970            "$ref": "UrlMapReference"
75971          },
75972          "response": {
75973            "$ref": "Operation"
75974          },
75975          "scopes": [
75976            "https://www.googleapis.com/auth/cloud-platform",
75977            "https://www.googleapis.com/auth/compute"
75978          ],
75979          "description": "Changes the URL map for TargetHttpProxy."
75980        },
75981        "aggregatedList": {
75982          "id": "compute.targetHttpProxies.aggregatedList",
75983          "path": "projects/{project}/aggregated/targetHttpProxies",
75984          "flatPath": "projects/{project}/aggregated/targetHttpProxies",
75985          "httpMethod": "GET",
75986          "parameters": {
75987            "filter": {
75988              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
75989              "location": "query",
75990              "type": "string"
75991            },
75992            "includeAllScopes": {
75993              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
75994              "location": "query",
75995              "type": "boolean"
75996            },
75997            "maxResults": {
75998              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
75999              "default": "500",
76000              "minimum": "0",
76001              "location": "query",
76002              "type": "integer",
76003              "format": "uint32"
76004            },
76005            "orderBy": {
76006              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
76007              "location": "query",
76008              "type": "string"
76009            },
76010            "pageToken": {
76011              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
76012              "location": "query",
76013              "type": "string"
76014            },
76015            "project": {
76016              "description": "Name of the project scoping this request.",
76017              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76018              "location": "path",
76019              "required": true,
76020              "type": "string"
76021            },
76022            "returnPartialSuccess": {
76023              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
76024              "location": "query",
76025              "type": "boolean"
76026            },
76027            "serviceProjectNumber": {
76028              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
76029              "location": "query",
76030              "type": "string",
76031              "format": "int64"
76032            }
76033          },
76034          "parameterOrder": [
76035            "project"
76036          ],
76037          "response": {
76038            "$ref": "TargetHttpProxyAggregatedList"
76039          },
76040          "scopes": [
76041            "https://www.googleapis.com/auth/cloud-platform",
76042            "https://www.googleapis.com/auth/compute",
76043            "https://www.googleapis.com/auth/compute.readonly"
76044          ],
76045          "description": "Retrieves the list of all TargetHttpProxy resources, regional and global, available to the specified project. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
76046        }
76047      }
76048    },
76049    "regionTargetHttpProxies": {
76050      "methods": {
76051        "list": {
76052          "id": "compute.regionTargetHttpProxies.list",
76053          "path": "projects/{project}/regions/{region}/targetHttpProxies",
76054          "flatPath": "projects/{project}/regions/{region}/targetHttpProxies",
76055          "httpMethod": "GET",
76056          "parameters": {
76057            "filter": {
76058              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
76059              "location": "query",
76060              "type": "string"
76061            },
76062            "maxResults": {
76063              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
76064              "default": "500",
76065              "minimum": "0",
76066              "location": "query",
76067              "type": "integer",
76068              "format": "uint32"
76069            },
76070            "orderBy": {
76071              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
76072              "location": "query",
76073              "type": "string"
76074            },
76075            "pageToken": {
76076              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
76077              "location": "query",
76078              "type": "string"
76079            },
76080            "project": {
76081              "description": "Project ID for this request.",
76082              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76083              "location": "path",
76084              "required": true,
76085              "type": "string"
76086            },
76087            "region": {
76088              "description": "Name of the region scoping this request.",
76089              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
76090              "location": "path",
76091              "required": true,
76092              "type": "string"
76093            },
76094            "returnPartialSuccess": {
76095              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
76096              "location": "query",
76097              "type": "boolean"
76098            }
76099          },
76100          "parameterOrder": [
76101            "project",
76102            "region"
76103          ],
76104          "response": {
76105            "$ref": "TargetHttpProxyList"
76106          },
76107          "scopes": [
76108            "https://www.googleapis.com/auth/cloud-platform",
76109            "https://www.googleapis.com/auth/compute",
76110            "https://www.googleapis.com/auth/compute.readonly"
76111          ],
76112          "description": "Retrieves the list of TargetHttpProxy resources available to the specified project in the specified region."
76113        },
76114        "get": {
76115          "id": "compute.regionTargetHttpProxies.get",
76116          "path": "projects/{project}/regions/{region}/targetHttpProxies/{targetHttpProxy}",
76117          "flatPath": "projects/{project}/regions/{region}/targetHttpProxies/{targetHttpProxy}",
76118          "httpMethod": "GET",
76119          "parameters": {
76120            "project": {
76121              "description": "Project ID for this request.",
76122              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76123              "location": "path",
76124              "required": true,
76125              "type": "string"
76126            },
76127            "region": {
76128              "description": "Name of the region scoping this request.",
76129              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
76130              "location": "path",
76131              "required": true,
76132              "type": "string"
76133            },
76134            "targetHttpProxy": {
76135              "description": "Name of the TargetHttpProxy resource to return.",
76136              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
76137              "location": "path",
76138              "required": true,
76139              "type": "string"
76140            }
76141          },
76142          "parameterOrder": [
76143            "project",
76144            "region",
76145            "targetHttpProxy"
76146          ],
76147          "response": {
76148            "$ref": "TargetHttpProxy"
76149          },
76150          "scopes": [
76151            "https://www.googleapis.com/auth/cloud-platform",
76152            "https://www.googleapis.com/auth/compute",
76153            "https://www.googleapis.com/auth/compute.readonly"
76154          ],
76155          "description": "Returns the specified TargetHttpProxy resource in the specified region."
76156        },
76157        "insert": {
76158          "id": "compute.regionTargetHttpProxies.insert",
76159          "path": "projects/{project}/regions/{region}/targetHttpProxies",
76160          "flatPath": "projects/{project}/regions/{region}/targetHttpProxies",
76161          "httpMethod": "POST",
76162          "parameters": {
76163            "project": {
76164              "description": "Project ID for this request.",
76165              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76166              "location": "path",
76167              "required": true,
76168              "type": "string"
76169            },
76170            "region": {
76171              "description": "Name of the region scoping this request.",
76172              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
76173              "location": "path",
76174              "required": true,
76175              "type": "string"
76176            },
76177            "requestId": {
76178              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
76179              "location": "query",
76180              "type": "string"
76181            }
76182          },
76183          "parameterOrder": [
76184            "project",
76185            "region"
76186          ],
76187          "request": {
76188            "$ref": "TargetHttpProxy"
76189          },
76190          "response": {
76191            "$ref": "Operation"
76192          },
76193          "scopes": [
76194            "https://www.googleapis.com/auth/cloud-platform",
76195            "https://www.googleapis.com/auth/compute"
76196          ],
76197          "description": "Creates a TargetHttpProxy resource in the specified project and region using the data included in the request."
76198        },
76199        "delete": {
76200          "id": "compute.regionTargetHttpProxies.delete",
76201          "path": "projects/{project}/regions/{region}/targetHttpProxies/{targetHttpProxy}",
76202          "flatPath": "projects/{project}/regions/{region}/targetHttpProxies/{targetHttpProxy}",
76203          "httpMethod": "DELETE",
76204          "parameters": {
76205            "project": {
76206              "description": "Project ID for this request.",
76207              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76208              "location": "path",
76209              "required": true,
76210              "type": "string"
76211            },
76212            "region": {
76213              "description": "Name of the region scoping this request.",
76214              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
76215              "location": "path",
76216              "required": true,
76217              "type": "string"
76218            },
76219            "requestId": {
76220              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
76221              "location": "query",
76222              "type": "string"
76223            },
76224            "targetHttpProxy": {
76225              "description": "Name of the TargetHttpProxy resource to delete.",
76226              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
76227              "location": "path",
76228              "required": true,
76229              "type": "string"
76230            }
76231          },
76232          "parameterOrder": [
76233            "project",
76234            "region",
76235            "targetHttpProxy"
76236          ],
76237          "response": {
76238            "$ref": "Operation"
76239          },
76240          "scopes": [
76241            "https://www.googleapis.com/auth/cloud-platform",
76242            "https://www.googleapis.com/auth/compute"
76243          ],
76244          "description": "Deletes the specified TargetHttpProxy resource."
76245        },
76246        "setUrlMap": {
76247          "id": "compute.regionTargetHttpProxies.setUrlMap",
76248          "path": "projects/{project}/regions/{region}/targetHttpProxies/{targetHttpProxy}/setUrlMap",
76249          "flatPath": "projects/{project}/regions/{region}/targetHttpProxies/{targetHttpProxy}/setUrlMap",
76250          "httpMethod": "POST",
76251          "parameters": {
76252            "project": {
76253              "description": "Project ID for this request.",
76254              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76255              "location": "path",
76256              "required": true,
76257              "type": "string"
76258            },
76259            "region": {
76260              "description": "Name of the region scoping this request.",
76261              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
76262              "location": "path",
76263              "required": true,
76264              "type": "string"
76265            },
76266            "requestId": {
76267              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
76268              "location": "query",
76269              "type": "string"
76270            },
76271            "targetHttpProxy": {
76272              "description": "Name of the TargetHttpProxy to set a URL map for.",
76273              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
76274              "location": "path",
76275              "required": true,
76276              "type": "string"
76277            }
76278          },
76279          "parameterOrder": [
76280            "project",
76281            "region",
76282            "targetHttpProxy"
76283          ],
76284          "request": {
76285            "$ref": "UrlMapReference"
76286          },
76287          "response": {
76288            "$ref": "Operation"
76289          },
76290          "scopes": [
76291            "https://www.googleapis.com/auth/cloud-platform",
76292            "https://www.googleapis.com/auth/compute"
76293          ],
76294          "description": "Changes the URL map for TargetHttpProxy."
76295        }
76296      }
76297    },
76298    "targetHttpsProxies": {
76299      "methods": {
76300        "list": {
76301          "id": "compute.targetHttpsProxies.list",
76302          "path": "projects/{project}/global/targetHttpsProxies",
76303          "flatPath": "projects/{project}/global/targetHttpsProxies",
76304          "httpMethod": "GET",
76305          "parameters": {
76306            "filter": {
76307              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
76308              "location": "query",
76309              "type": "string"
76310            },
76311            "maxResults": {
76312              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
76313              "default": "500",
76314              "minimum": "0",
76315              "location": "query",
76316              "type": "integer",
76317              "format": "uint32"
76318            },
76319            "orderBy": {
76320              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
76321              "location": "query",
76322              "type": "string"
76323            },
76324            "pageToken": {
76325              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
76326              "location": "query",
76327              "type": "string"
76328            },
76329            "project": {
76330              "description": "Project ID for this request.",
76331              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76332              "location": "path",
76333              "required": true,
76334              "type": "string"
76335            },
76336            "returnPartialSuccess": {
76337              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
76338              "location": "query",
76339              "type": "boolean"
76340            }
76341          },
76342          "parameterOrder": [
76343            "project"
76344          ],
76345          "response": {
76346            "$ref": "TargetHttpsProxyList"
76347          },
76348          "scopes": [
76349            "https://www.googleapis.com/auth/cloud-platform",
76350            "https://www.googleapis.com/auth/compute",
76351            "https://www.googleapis.com/auth/compute.readonly"
76352          ],
76353          "description": "Retrieves the list of TargetHttpsProxy resources available to the specified project."
76354        },
76355        "aggregatedList": {
76356          "id": "compute.targetHttpsProxies.aggregatedList",
76357          "path": "projects/{project}/aggregated/targetHttpsProxies",
76358          "flatPath": "projects/{project}/aggregated/targetHttpsProxies",
76359          "httpMethod": "GET",
76360          "parameters": {
76361            "filter": {
76362              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
76363              "location": "query",
76364              "type": "string"
76365            },
76366            "includeAllScopes": {
76367              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
76368              "location": "query",
76369              "type": "boolean"
76370            },
76371            "maxResults": {
76372              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
76373              "default": "500",
76374              "minimum": "0",
76375              "location": "query",
76376              "type": "integer",
76377              "format": "uint32"
76378            },
76379            "orderBy": {
76380              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
76381              "location": "query",
76382              "type": "string"
76383            },
76384            "pageToken": {
76385              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
76386              "location": "query",
76387              "type": "string"
76388            },
76389            "project": {
76390              "description": "Name of the project scoping this request.",
76391              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76392              "location": "path",
76393              "required": true,
76394              "type": "string"
76395            },
76396            "returnPartialSuccess": {
76397              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
76398              "location": "query",
76399              "type": "boolean"
76400            },
76401            "serviceProjectNumber": {
76402              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
76403              "location": "query",
76404              "type": "string",
76405              "format": "int64"
76406            }
76407          },
76408          "parameterOrder": [
76409            "project"
76410          ],
76411          "response": {
76412            "$ref": "TargetHttpsProxyAggregatedList"
76413          },
76414          "scopes": [
76415            "https://www.googleapis.com/auth/cloud-platform",
76416            "https://www.googleapis.com/auth/compute",
76417            "https://www.googleapis.com/auth/compute.readonly"
76418          ],
76419          "description": "Retrieves the list of all TargetHttpsProxy resources, regional and global, available to the specified project. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
76420        },
76421        "get": {
76422          "id": "compute.targetHttpsProxies.get",
76423          "path": "projects/{project}/global/targetHttpsProxies/{targetHttpsProxy}",
76424          "flatPath": "projects/{project}/global/targetHttpsProxies/{targetHttpsProxy}",
76425          "httpMethod": "GET",
76426          "parameters": {
76427            "project": {
76428              "description": "Project ID for this request.",
76429              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76430              "location": "path",
76431              "required": true,
76432              "type": "string"
76433            },
76434            "targetHttpsProxy": {
76435              "description": "Name of the TargetHttpsProxy resource to return.",
76436              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
76437              "location": "path",
76438              "required": true,
76439              "type": "string"
76440            }
76441          },
76442          "parameterOrder": [
76443            "project",
76444            "targetHttpsProxy"
76445          ],
76446          "response": {
76447            "$ref": "TargetHttpsProxy"
76448          },
76449          "scopes": [
76450            "https://www.googleapis.com/auth/cloud-platform",
76451            "https://www.googleapis.com/auth/compute",
76452            "https://www.googleapis.com/auth/compute.readonly"
76453          ],
76454          "description": "Returns the specified TargetHttpsProxy resource."
76455        },
76456        "insert": {
76457          "id": "compute.targetHttpsProxies.insert",
76458          "path": "projects/{project}/global/targetHttpsProxies",
76459          "flatPath": "projects/{project}/global/targetHttpsProxies",
76460          "httpMethod": "POST",
76461          "parameters": {
76462            "project": {
76463              "description": "Project ID for this request.",
76464              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76465              "location": "path",
76466              "required": true,
76467              "type": "string"
76468            },
76469            "requestId": {
76470              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
76471              "location": "query",
76472              "type": "string"
76473            }
76474          },
76475          "parameterOrder": [
76476            "project"
76477          ],
76478          "request": {
76479            "$ref": "TargetHttpsProxy"
76480          },
76481          "response": {
76482            "$ref": "Operation"
76483          },
76484          "scopes": [
76485            "https://www.googleapis.com/auth/cloud-platform",
76486            "https://www.googleapis.com/auth/compute"
76487          ],
76488          "description": "Creates a TargetHttpsProxy resource in the specified project using the data included in the request."
76489        },
76490        "patch": {
76491          "id": "compute.targetHttpsProxies.patch",
76492          "path": "projects/{project}/global/targetHttpsProxies/{targetHttpsProxy}",
76493          "flatPath": "projects/{project}/global/targetHttpsProxies/{targetHttpsProxy}",
76494          "httpMethod": "PATCH",
76495          "parameters": {
76496            "project": {
76497              "description": "Project ID for this request.",
76498              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76499              "location": "path",
76500              "required": true,
76501              "type": "string"
76502            },
76503            "requestId": {
76504              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
76505              "location": "query",
76506              "type": "string"
76507            },
76508            "targetHttpsProxy": {
76509              "description": "Name of the TargetHttpsProxy resource to patch.",
76510              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
76511              "location": "path",
76512              "required": true,
76513              "type": "string"
76514            }
76515          },
76516          "parameterOrder": [
76517            "project",
76518            "targetHttpsProxy"
76519          ],
76520          "request": {
76521            "$ref": "TargetHttpsProxy"
76522          },
76523          "response": {
76524            "$ref": "Operation"
76525          },
76526          "scopes": [
76527            "https://www.googleapis.com/auth/cloud-platform",
76528            "https://www.googleapis.com/auth/compute"
76529          ],
76530          "description": "Patches the specified TargetHttpsProxy resource with the data included in the request. This method supports PATCH semantics and uses JSON merge patch format and processing rules."
76531        },
76532        "delete": {
76533          "id": "compute.targetHttpsProxies.delete",
76534          "path": "projects/{project}/global/targetHttpsProxies/{targetHttpsProxy}",
76535          "flatPath": "projects/{project}/global/targetHttpsProxies/{targetHttpsProxy}",
76536          "httpMethod": "DELETE",
76537          "parameters": {
76538            "project": {
76539              "description": "Project ID for this request.",
76540              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76541              "location": "path",
76542              "required": true,
76543              "type": "string"
76544            },
76545            "requestId": {
76546              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
76547              "location": "query",
76548              "type": "string"
76549            },
76550            "targetHttpsProxy": {
76551              "description": "Name of the TargetHttpsProxy resource to delete.",
76552              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
76553              "location": "path",
76554              "required": true,
76555              "type": "string"
76556            }
76557          },
76558          "parameterOrder": [
76559            "project",
76560            "targetHttpsProxy"
76561          ],
76562          "response": {
76563            "$ref": "Operation"
76564          },
76565          "scopes": [
76566            "https://www.googleapis.com/auth/cloud-platform",
76567            "https://www.googleapis.com/auth/compute"
76568          ],
76569          "description": "Deletes the specified TargetHttpsProxy resource."
76570        },
76571        "setUrlMap": {
76572          "id": "compute.targetHttpsProxies.setUrlMap",
76573          "path": "projects/{project}/targetHttpsProxies/{targetHttpsProxy}/setUrlMap",
76574          "flatPath": "projects/{project}/targetHttpsProxies/{targetHttpsProxy}/setUrlMap",
76575          "httpMethod": "POST",
76576          "parameters": {
76577            "project": {
76578              "description": "Project ID for this request.",
76579              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76580              "location": "path",
76581              "required": true,
76582              "type": "string"
76583            },
76584            "requestId": {
76585              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
76586              "location": "query",
76587              "type": "string"
76588            },
76589            "targetHttpsProxy": {
76590              "description": "Name of the TargetHttpsProxy resource whose URL map is to be set.",
76591              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
76592              "location": "path",
76593              "required": true,
76594              "type": "string"
76595            }
76596          },
76597          "parameterOrder": [
76598            "project",
76599            "targetHttpsProxy"
76600          ],
76601          "request": {
76602            "$ref": "UrlMapReference"
76603          },
76604          "response": {
76605            "$ref": "Operation"
76606          },
76607          "scopes": [
76608            "https://www.googleapis.com/auth/cloud-platform",
76609            "https://www.googleapis.com/auth/compute"
76610          ],
76611          "description": "Changes the URL map for TargetHttpsProxy."
76612        },
76613        "setSslCertificates": {
76614          "id": "compute.targetHttpsProxies.setSslCertificates",
76615          "path": "projects/{project}/targetHttpsProxies/{targetHttpsProxy}/setSslCertificates",
76616          "flatPath": "projects/{project}/targetHttpsProxies/{targetHttpsProxy}/setSslCertificates",
76617          "httpMethod": "POST",
76618          "parameters": {
76619            "project": {
76620              "description": "Project ID for this request.",
76621              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76622              "location": "path",
76623              "required": true,
76624              "type": "string"
76625            },
76626            "requestId": {
76627              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
76628              "location": "query",
76629              "type": "string"
76630            },
76631            "targetHttpsProxy": {
76632              "description": "Name of the TargetHttpsProxy resource to set an SslCertificates resource for.",
76633              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
76634              "location": "path",
76635              "required": true,
76636              "type": "string"
76637            }
76638          },
76639          "parameterOrder": [
76640            "project",
76641            "targetHttpsProxy"
76642          ],
76643          "request": {
76644            "$ref": "TargetHttpsProxiesSetSslCertificatesRequest"
76645          },
76646          "response": {
76647            "$ref": "Operation"
76648          },
76649          "scopes": [
76650            "https://www.googleapis.com/auth/cloud-platform",
76651            "https://www.googleapis.com/auth/compute"
76652          ],
76653          "description": "Replaces SslCertificates for TargetHttpsProxy."
76654        },
76655        "setCertificateMap": {
76656          "id": "compute.targetHttpsProxies.setCertificateMap",
76657          "path": "projects/{project}/global/targetHttpsProxies/{targetHttpsProxy}/setCertificateMap",
76658          "flatPath": "projects/{project}/global/targetHttpsProxies/{targetHttpsProxy}/setCertificateMap",
76659          "httpMethod": "POST",
76660          "parameters": {
76661            "project": {
76662              "description": "Project ID for this request.",
76663              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76664              "location": "path",
76665              "required": true,
76666              "type": "string"
76667            },
76668            "requestId": {
76669              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
76670              "location": "query",
76671              "type": "string"
76672            },
76673            "targetHttpsProxy": {
76674              "description": "Name of the TargetHttpsProxy resource whose CertificateMap is to be set. The name must be 1-63 characters long, and comply with RFC1035.",
76675              "location": "path",
76676              "required": true,
76677              "type": "string"
76678            }
76679          },
76680          "parameterOrder": [
76681            "project",
76682            "targetHttpsProxy"
76683          ],
76684          "request": {
76685            "$ref": "TargetHttpsProxiesSetCertificateMapRequest"
76686          },
76687          "response": {
76688            "$ref": "Operation"
76689          },
76690          "scopes": [
76691            "https://www.googleapis.com/auth/cloud-platform",
76692            "https://www.googleapis.com/auth/compute"
76693          ],
76694          "description": "Changes the Certificate Map for TargetHttpsProxy."
76695        },
76696        "setSslPolicy": {
76697          "id": "compute.targetHttpsProxies.setSslPolicy",
76698          "path": "projects/{project}/global/targetHttpsProxies/{targetHttpsProxy}/setSslPolicy",
76699          "flatPath": "projects/{project}/global/targetHttpsProxies/{targetHttpsProxy}/setSslPolicy",
76700          "httpMethod": "POST",
76701          "parameters": {
76702            "project": {
76703              "description": "Project ID for this request.",
76704              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76705              "location": "path",
76706              "required": true,
76707              "type": "string"
76708            },
76709            "requestId": {
76710              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
76711              "location": "query",
76712              "type": "string"
76713            },
76714            "targetHttpsProxy": {
76715              "description": "Name of the TargetHttpsProxy resource whose SSL policy is to be set. The name must be 1-63 characters long, and comply with RFC1035.",
76716              "location": "path",
76717              "required": true,
76718              "type": "string"
76719            }
76720          },
76721          "parameterOrder": [
76722            "project",
76723            "targetHttpsProxy"
76724          ],
76725          "request": {
76726            "$ref": "SslPolicyReference"
76727          },
76728          "response": {
76729            "$ref": "Operation"
76730          },
76731          "scopes": [
76732            "https://www.googleapis.com/auth/cloud-platform",
76733            "https://www.googleapis.com/auth/compute"
76734          ],
76735          "description": "Sets the SSL policy for TargetHttpsProxy. The SSL policy specifies the server-side support for SSL features. This affects connections between clients and the HTTPS proxy load balancer. They do not affect the connection between the load balancer and the backends."
76736        },
76737        "setQuicOverride": {
76738          "id": "compute.targetHttpsProxies.setQuicOverride",
76739          "path": "projects/{project}/global/targetHttpsProxies/{targetHttpsProxy}/setQuicOverride",
76740          "flatPath": "projects/{project}/global/targetHttpsProxies/{targetHttpsProxy}/setQuicOverride",
76741          "httpMethod": "POST",
76742          "parameters": {
76743            "project": {
76744              "description": "Project ID for this request.",
76745              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76746              "location": "path",
76747              "required": true,
76748              "type": "string"
76749            },
76750            "requestId": {
76751              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
76752              "location": "query",
76753              "type": "string"
76754            },
76755            "targetHttpsProxy": {
76756              "description": "Name of the TargetHttpsProxy resource to set the QUIC override policy for. The name should conform to RFC1035.",
76757              "location": "path",
76758              "required": true,
76759              "type": "string"
76760            }
76761          },
76762          "parameterOrder": [
76763            "project",
76764            "targetHttpsProxy"
76765          ],
76766          "request": {
76767            "$ref": "TargetHttpsProxiesSetQuicOverrideRequest"
76768          },
76769          "response": {
76770            "$ref": "Operation"
76771          },
76772          "scopes": [
76773            "https://www.googleapis.com/auth/cloud-platform",
76774            "https://www.googleapis.com/auth/compute"
76775          ],
76776          "description": "Sets the QUIC override policy for TargetHttpsProxy."
76777        }
76778      }
76779    },
76780    "regionTargetHttpsProxies": {
76781      "methods": {
76782        "list": {
76783          "id": "compute.regionTargetHttpsProxies.list",
76784          "path": "projects/{project}/regions/{region}/targetHttpsProxies",
76785          "flatPath": "projects/{project}/regions/{region}/targetHttpsProxies",
76786          "httpMethod": "GET",
76787          "parameters": {
76788            "filter": {
76789              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
76790              "location": "query",
76791              "type": "string"
76792            },
76793            "maxResults": {
76794              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
76795              "default": "500",
76796              "minimum": "0",
76797              "location": "query",
76798              "type": "integer",
76799              "format": "uint32"
76800            },
76801            "orderBy": {
76802              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
76803              "location": "query",
76804              "type": "string"
76805            },
76806            "pageToken": {
76807              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
76808              "location": "query",
76809              "type": "string"
76810            },
76811            "project": {
76812              "description": "Project ID for this request.",
76813              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76814              "location": "path",
76815              "required": true,
76816              "type": "string"
76817            },
76818            "region": {
76819              "description": "Name of the region scoping this request.",
76820              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
76821              "location": "path",
76822              "required": true,
76823              "type": "string"
76824            },
76825            "returnPartialSuccess": {
76826              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
76827              "location": "query",
76828              "type": "boolean"
76829            }
76830          },
76831          "parameterOrder": [
76832            "project",
76833            "region"
76834          ],
76835          "response": {
76836            "$ref": "TargetHttpsProxyList"
76837          },
76838          "scopes": [
76839            "https://www.googleapis.com/auth/cloud-platform",
76840            "https://www.googleapis.com/auth/compute",
76841            "https://www.googleapis.com/auth/compute.readonly"
76842          ],
76843          "description": "Retrieves the list of TargetHttpsProxy resources available to the specified project in the specified region."
76844        },
76845        "get": {
76846          "id": "compute.regionTargetHttpsProxies.get",
76847          "path": "projects/{project}/regions/{region}/targetHttpsProxies/{targetHttpsProxy}",
76848          "flatPath": "projects/{project}/regions/{region}/targetHttpsProxies/{targetHttpsProxy}",
76849          "httpMethod": "GET",
76850          "parameters": {
76851            "project": {
76852              "description": "Project ID for this request.",
76853              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76854              "location": "path",
76855              "required": true,
76856              "type": "string"
76857            },
76858            "region": {
76859              "description": "Name of the region scoping this request.",
76860              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
76861              "location": "path",
76862              "required": true,
76863              "type": "string"
76864            },
76865            "targetHttpsProxy": {
76866              "description": "Name of the TargetHttpsProxy resource to return.",
76867              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
76868              "location": "path",
76869              "required": true,
76870              "type": "string"
76871            }
76872          },
76873          "parameterOrder": [
76874            "project",
76875            "region",
76876            "targetHttpsProxy"
76877          ],
76878          "response": {
76879            "$ref": "TargetHttpsProxy"
76880          },
76881          "scopes": [
76882            "https://www.googleapis.com/auth/cloud-platform",
76883            "https://www.googleapis.com/auth/compute",
76884            "https://www.googleapis.com/auth/compute.readonly"
76885          ],
76886          "description": "Returns the specified TargetHttpsProxy resource in the specified region."
76887        },
76888        "insert": {
76889          "id": "compute.regionTargetHttpsProxies.insert",
76890          "path": "projects/{project}/regions/{region}/targetHttpsProxies",
76891          "flatPath": "projects/{project}/regions/{region}/targetHttpsProxies",
76892          "httpMethod": "POST",
76893          "parameters": {
76894            "project": {
76895              "description": "Project ID for this request.",
76896              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76897              "location": "path",
76898              "required": true,
76899              "type": "string"
76900            },
76901            "region": {
76902              "description": "Name of the region scoping this request.",
76903              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
76904              "location": "path",
76905              "required": true,
76906              "type": "string"
76907            },
76908            "requestId": {
76909              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
76910              "location": "query",
76911              "type": "string"
76912            }
76913          },
76914          "parameterOrder": [
76915            "project",
76916            "region"
76917          ],
76918          "request": {
76919            "$ref": "TargetHttpsProxy"
76920          },
76921          "response": {
76922            "$ref": "Operation"
76923          },
76924          "scopes": [
76925            "https://www.googleapis.com/auth/cloud-platform",
76926            "https://www.googleapis.com/auth/compute"
76927          ],
76928          "description": "Creates a TargetHttpsProxy resource in the specified project and region using the data included in the request."
76929        },
76930        "delete": {
76931          "id": "compute.regionTargetHttpsProxies.delete",
76932          "path": "projects/{project}/regions/{region}/targetHttpsProxies/{targetHttpsProxy}",
76933          "flatPath": "projects/{project}/regions/{region}/targetHttpsProxies/{targetHttpsProxy}",
76934          "httpMethod": "DELETE",
76935          "parameters": {
76936            "project": {
76937              "description": "Project ID for this request.",
76938              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76939              "location": "path",
76940              "required": true,
76941              "type": "string"
76942            },
76943            "region": {
76944              "description": "Name of the region scoping this request.",
76945              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
76946              "location": "path",
76947              "required": true,
76948              "type": "string"
76949            },
76950            "requestId": {
76951              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
76952              "location": "query",
76953              "type": "string"
76954            },
76955            "targetHttpsProxy": {
76956              "description": "Name of the TargetHttpsProxy resource to delete.",
76957              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
76958              "location": "path",
76959              "required": true,
76960              "type": "string"
76961            }
76962          },
76963          "parameterOrder": [
76964            "project",
76965            "region",
76966            "targetHttpsProxy"
76967          ],
76968          "response": {
76969            "$ref": "Operation"
76970          },
76971          "scopes": [
76972            "https://www.googleapis.com/auth/cloud-platform",
76973            "https://www.googleapis.com/auth/compute"
76974          ],
76975          "description": "Deletes the specified TargetHttpsProxy resource."
76976        },
76977        "patch": {
76978          "id": "compute.regionTargetHttpsProxies.patch",
76979          "path": "projects/{project}/regions/{region}/targetHttpsProxies/{targetHttpsProxy}",
76980          "flatPath": "projects/{project}/regions/{region}/targetHttpsProxies/{targetHttpsProxy}",
76981          "httpMethod": "PATCH",
76982          "parameters": {
76983            "project": {
76984              "description": "Project ID for this request.",
76985              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
76986              "location": "path",
76987              "required": true,
76988              "type": "string"
76989            },
76990            "region": {
76991              "description": "Name of the region for this request.",
76992              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
76993              "location": "path",
76994              "required": true,
76995              "type": "string"
76996            },
76997            "requestId": {
76998              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
76999              "location": "query",
77000              "type": "string"
77001            },
77002            "targetHttpsProxy": {
77003              "description": "Name of the TargetHttpsProxy resource to patch.",
77004              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
77005              "location": "path",
77006              "required": true,
77007              "type": "string"
77008            }
77009          },
77010          "parameterOrder": [
77011            "project",
77012            "region",
77013            "targetHttpsProxy"
77014          ],
77015          "request": {
77016            "$ref": "TargetHttpsProxy"
77017          },
77018          "response": {
77019            "$ref": "Operation"
77020          },
77021          "scopes": [
77022            "https://www.googleapis.com/auth/cloud-platform",
77023            "https://www.googleapis.com/auth/compute"
77024          ],
77025          "description": "Patches the specified regional TargetHttpsProxy resource with the data included in the request. This method supports PATCH semantics and uses JSON merge patch format and processing rules."
77026        },
77027        "setUrlMap": {
77028          "id": "compute.regionTargetHttpsProxies.setUrlMap",
77029          "path": "projects/{project}/regions/{region}/targetHttpsProxies/{targetHttpsProxy}/setUrlMap",
77030          "flatPath": "projects/{project}/regions/{region}/targetHttpsProxies/{targetHttpsProxy}/setUrlMap",
77031          "httpMethod": "POST",
77032          "parameters": {
77033            "project": {
77034              "description": "Project ID for this request.",
77035              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77036              "location": "path",
77037              "required": true,
77038              "type": "string"
77039            },
77040            "region": {
77041              "description": "Name of the region scoping this request.",
77042              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77043              "location": "path",
77044              "required": true,
77045              "type": "string"
77046            },
77047            "requestId": {
77048              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
77049              "location": "query",
77050              "type": "string"
77051            },
77052            "targetHttpsProxy": {
77053              "description": "Name of the TargetHttpsProxy to set a URL map for.",
77054              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
77055              "location": "path",
77056              "required": true,
77057              "type": "string"
77058            }
77059          },
77060          "parameterOrder": [
77061            "project",
77062            "region",
77063            "targetHttpsProxy"
77064          ],
77065          "request": {
77066            "$ref": "UrlMapReference"
77067          },
77068          "response": {
77069            "$ref": "Operation"
77070          },
77071          "scopes": [
77072            "https://www.googleapis.com/auth/cloud-platform",
77073            "https://www.googleapis.com/auth/compute"
77074          ],
77075          "description": "Changes the URL map for TargetHttpsProxy."
77076        },
77077        "setSslCertificates": {
77078          "id": "compute.regionTargetHttpsProxies.setSslCertificates",
77079          "path": "projects/{project}/regions/{region}/targetHttpsProxies/{targetHttpsProxy}/setSslCertificates",
77080          "flatPath": "projects/{project}/regions/{region}/targetHttpsProxies/{targetHttpsProxy}/setSslCertificates",
77081          "httpMethod": "POST",
77082          "parameters": {
77083            "project": {
77084              "description": "Project ID for this request.",
77085              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77086              "location": "path",
77087              "required": true,
77088              "type": "string"
77089            },
77090            "region": {
77091              "description": "Name of the region scoping this request.",
77092              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77093              "location": "path",
77094              "required": true,
77095              "type": "string"
77096            },
77097            "requestId": {
77098              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
77099              "location": "query",
77100              "type": "string"
77101            },
77102            "targetHttpsProxy": {
77103              "description": "Name of the TargetHttpsProxy resource to set an SslCertificates resource for.",
77104              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
77105              "location": "path",
77106              "required": true,
77107              "type": "string"
77108            }
77109          },
77110          "parameterOrder": [
77111            "project",
77112            "region",
77113            "targetHttpsProxy"
77114          ],
77115          "request": {
77116            "$ref": "RegionTargetHttpsProxiesSetSslCertificatesRequest"
77117          },
77118          "response": {
77119            "$ref": "Operation"
77120          },
77121          "scopes": [
77122            "https://www.googleapis.com/auth/cloud-platform",
77123            "https://www.googleapis.com/auth/compute"
77124          ],
77125          "description": "Replaces SslCertificates for TargetHttpsProxy."
77126        }
77127      }
77128    },
77129    "targetInstances": {
77130      "methods": {
77131        "list": {
77132          "id": "compute.targetInstances.list",
77133          "path": "projects/{project}/zones/{zone}/targetInstances",
77134          "flatPath": "projects/{project}/zones/{zone}/targetInstances",
77135          "httpMethod": "GET",
77136          "parameters": {
77137            "filter": {
77138              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
77139              "location": "query",
77140              "type": "string"
77141            },
77142            "maxResults": {
77143              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
77144              "default": "500",
77145              "minimum": "0",
77146              "location": "query",
77147              "type": "integer",
77148              "format": "uint32"
77149            },
77150            "orderBy": {
77151              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
77152              "location": "query",
77153              "type": "string"
77154            },
77155            "pageToken": {
77156              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
77157              "location": "query",
77158              "type": "string"
77159            },
77160            "project": {
77161              "description": "Project ID for this request.",
77162              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77163              "location": "path",
77164              "required": true,
77165              "type": "string"
77166            },
77167            "returnPartialSuccess": {
77168              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
77169              "location": "query",
77170              "type": "boolean"
77171            },
77172            "zone": {
77173              "description": "Name of the zone scoping this request.",
77174              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77175              "location": "path",
77176              "required": true,
77177              "type": "string"
77178            }
77179          },
77180          "parameterOrder": [
77181            "project",
77182            "zone"
77183          ],
77184          "response": {
77185            "$ref": "TargetInstanceList"
77186          },
77187          "scopes": [
77188            "https://www.googleapis.com/auth/cloud-platform",
77189            "https://www.googleapis.com/auth/compute",
77190            "https://www.googleapis.com/auth/compute.readonly"
77191          ],
77192          "description": "Retrieves a list of TargetInstance resources available to the specified project and zone."
77193        },
77194        "aggregatedList": {
77195          "id": "compute.targetInstances.aggregatedList",
77196          "path": "projects/{project}/aggregated/targetInstances",
77197          "flatPath": "projects/{project}/aggregated/targetInstances",
77198          "httpMethod": "GET",
77199          "parameters": {
77200            "filter": {
77201              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
77202              "location": "query",
77203              "type": "string"
77204            },
77205            "includeAllScopes": {
77206              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
77207              "location": "query",
77208              "type": "boolean"
77209            },
77210            "maxResults": {
77211              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
77212              "default": "500",
77213              "minimum": "0",
77214              "location": "query",
77215              "type": "integer",
77216              "format": "uint32"
77217            },
77218            "orderBy": {
77219              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
77220              "location": "query",
77221              "type": "string"
77222            },
77223            "pageToken": {
77224              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
77225              "location": "query",
77226              "type": "string"
77227            },
77228            "project": {
77229              "description": "Project ID for this request.",
77230              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77231              "location": "path",
77232              "required": true,
77233              "type": "string"
77234            },
77235            "returnPartialSuccess": {
77236              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
77237              "location": "query",
77238              "type": "boolean"
77239            },
77240            "serviceProjectNumber": {
77241              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
77242              "location": "query",
77243              "type": "string",
77244              "format": "int64"
77245            }
77246          },
77247          "parameterOrder": [
77248            "project"
77249          ],
77250          "response": {
77251            "$ref": "TargetInstanceAggregatedList"
77252          },
77253          "scopes": [
77254            "https://www.googleapis.com/auth/cloud-platform",
77255            "https://www.googleapis.com/auth/compute",
77256            "https://www.googleapis.com/auth/compute.readonly"
77257          ],
77258          "description": "Retrieves an aggregated list of target instances. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
77259        },
77260        "get": {
77261          "id": "compute.targetInstances.get",
77262          "path": "projects/{project}/zones/{zone}/targetInstances/{targetInstance}",
77263          "flatPath": "projects/{project}/zones/{zone}/targetInstances/{targetInstance}",
77264          "httpMethod": "GET",
77265          "parameters": {
77266            "project": {
77267              "description": "Project ID for this request.",
77268              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77269              "location": "path",
77270              "required": true,
77271              "type": "string"
77272            },
77273            "targetInstance": {
77274              "description": "Name of the TargetInstance resource to return.",
77275              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
77276              "location": "path",
77277              "required": true,
77278              "type": "string"
77279            },
77280            "zone": {
77281              "description": "Name of the zone scoping this request.",
77282              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77283              "location": "path",
77284              "required": true,
77285              "type": "string"
77286            }
77287          },
77288          "parameterOrder": [
77289            "project",
77290            "zone",
77291            "targetInstance"
77292          ],
77293          "response": {
77294            "$ref": "TargetInstance"
77295          },
77296          "scopes": [
77297            "https://www.googleapis.com/auth/cloud-platform",
77298            "https://www.googleapis.com/auth/compute",
77299            "https://www.googleapis.com/auth/compute.readonly"
77300          ],
77301          "description": "Returns the specified TargetInstance resource."
77302        },
77303        "insert": {
77304          "id": "compute.targetInstances.insert",
77305          "path": "projects/{project}/zones/{zone}/targetInstances",
77306          "flatPath": "projects/{project}/zones/{zone}/targetInstances",
77307          "httpMethod": "POST",
77308          "parameters": {
77309            "project": {
77310              "description": "Project ID for this request.",
77311              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77312              "location": "path",
77313              "required": true,
77314              "type": "string"
77315            },
77316            "requestId": {
77317              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
77318              "location": "query",
77319              "type": "string"
77320            },
77321            "zone": {
77322              "description": "Name of the zone scoping this request.",
77323              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77324              "location": "path",
77325              "required": true,
77326              "type": "string"
77327            }
77328          },
77329          "parameterOrder": [
77330            "project",
77331            "zone"
77332          ],
77333          "request": {
77334            "$ref": "TargetInstance"
77335          },
77336          "response": {
77337            "$ref": "Operation"
77338          },
77339          "scopes": [
77340            "https://www.googleapis.com/auth/cloud-platform",
77341            "https://www.googleapis.com/auth/compute"
77342          ],
77343          "description": "Creates a TargetInstance resource in the specified project and zone using the data included in the request."
77344        },
77345        "delete": {
77346          "id": "compute.targetInstances.delete",
77347          "path": "projects/{project}/zones/{zone}/targetInstances/{targetInstance}",
77348          "flatPath": "projects/{project}/zones/{zone}/targetInstances/{targetInstance}",
77349          "httpMethod": "DELETE",
77350          "parameters": {
77351            "project": {
77352              "description": "Project ID for this request.",
77353              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77354              "location": "path",
77355              "required": true,
77356              "type": "string"
77357            },
77358            "requestId": {
77359              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
77360              "location": "query",
77361              "type": "string"
77362            },
77363            "targetInstance": {
77364              "description": "Name of the TargetInstance resource to delete.",
77365              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
77366              "location": "path",
77367              "required": true,
77368              "type": "string"
77369            },
77370            "zone": {
77371              "description": "Name of the zone scoping this request.",
77372              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77373              "location": "path",
77374              "required": true,
77375              "type": "string"
77376            }
77377          },
77378          "parameterOrder": [
77379            "project",
77380            "zone",
77381            "targetInstance"
77382          ],
77383          "response": {
77384            "$ref": "Operation"
77385          },
77386          "scopes": [
77387            "https://www.googleapis.com/auth/cloud-platform",
77388            "https://www.googleapis.com/auth/compute"
77389          ],
77390          "description": "Deletes the specified TargetInstance resource."
77391        },
77392        "setSecurityPolicy": {
77393          "id": "compute.targetInstances.setSecurityPolicy",
77394          "path": "projects/{project}/zones/{zone}/targetInstances/{targetInstance}/setSecurityPolicy",
77395          "flatPath": "projects/{project}/zones/{zone}/targetInstances/{targetInstance}/setSecurityPolicy",
77396          "httpMethod": "POST",
77397          "parameters": {
77398            "project": {
77399              "description": "Project ID for this request.",
77400              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77401              "location": "path",
77402              "required": true,
77403              "type": "string"
77404            },
77405            "requestId": {
77406              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
77407              "location": "query",
77408              "type": "string"
77409            },
77410            "targetInstance": {
77411              "description": "Name of the TargetInstance resource to which the security policy should be set. The name should conform to RFC1035.",
77412              "location": "path",
77413              "required": true,
77414              "type": "string"
77415            },
77416            "zone": {
77417              "description": "Name of the zone scoping this request.",
77418              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77419              "location": "path",
77420              "required": true,
77421              "type": "string"
77422            }
77423          },
77424          "parameterOrder": [
77425            "project",
77426            "zone",
77427            "targetInstance"
77428          ],
77429          "request": {
77430            "$ref": "SecurityPolicyReference"
77431          },
77432          "response": {
77433            "$ref": "Operation"
77434          },
77435          "scopes": [
77436            "https://www.googleapis.com/auth/cloud-platform",
77437            "https://www.googleapis.com/auth/compute"
77438          ],
77439          "description": "Sets the Google Cloud Armor security policy for the specified target instance. For more information, see Google Cloud Armor Overview"
77440        }
77441      }
77442    },
77443    "targetPools": {
77444      "methods": {
77445        "list": {
77446          "id": "compute.targetPools.list",
77447          "path": "projects/{project}/regions/{region}/targetPools",
77448          "flatPath": "projects/{project}/regions/{region}/targetPools",
77449          "httpMethod": "GET",
77450          "parameters": {
77451            "filter": {
77452              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
77453              "location": "query",
77454              "type": "string"
77455            },
77456            "maxResults": {
77457              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
77458              "default": "500",
77459              "minimum": "0",
77460              "location": "query",
77461              "type": "integer",
77462              "format": "uint32"
77463            },
77464            "orderBy": {
77465              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
77466              "location": "query",
77467              "type": "string"
77468            },
77469            "pageToken": {
77470              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
77471              "location": "query",
77472              "type": "string"
77473            },
77474            "project": {
77475              "description": "Project ID for this request.",
77476              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77477              "location": "path",
77478              "required": true,
77479              "type": "string"
77480            },
77481            "region": {
77482              "description": "Name of the region scoping this request.",
77483              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77484              "location": "path",
77485              "required": true,
77486              "type": "string"
77487            },
77488            "returnPartialSuccess": {
77489              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
77490              "location": "query",
77491              "type": "boolean"
77492            }
77493          },
77494          "parameterOrder": [
77495            "project",
77496            "region"
77497          ],
77498          "response": {
77499            "$ref": "TargetPoolList"
77500          },
77501          "scopes": [
77502            "https://www.googleapis.com/auth/cloud-platform",
77503            "https://www.googleapis.com/auth/compute",
77504            "https://www.googleapis.com/auth/compute.readonly"
77505          ],
77506          "description": "Retrieves a list of target pools available to the specified project and region."
77507        },
77508        "aggregatedList": {
77509          "id": "compute.targetPools.aggregatedList",
77510          "path": "projects/{project}/aggregated/targetPools",
77511          "flatPath": "projects/{project}/aggregated/targetPools",
77512          "httpMethod": "GET",
77513          "parameters": {
77514            "filter": {
77515              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
77516              "location": "query",
77517              "type": "string"
77518            },
77519            "includeAllScopes": {
77520              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
77521              "location": "query",
77522              "type": "boolean"
77523            },
77524            "maxResults": {
77525              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
77526              "default": "500",
77527              "minimum": "0",
77528              "location": "query",
77529              "type": "integer",
77530              "format": "uint32"
77531            },
77532            "orderBy": {
77533              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
77534              "location": "query",
77535              "type": "string"
77536            },
77537            "pageToken": {
77538              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
77539              "location": "query",
77540              "type": "string"
77541            },
77542            "project": {
77543              "description": "Project ID for this request.",
77544              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77545              "location": "path",
77546              "required": true,
77547              "type": "string"
77548            },
77549            "returnPartialSuccess": {
77550              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
77551              "location": "query",
77552              "type": "boolean"
77553            },
77554            "serviceProjectNumber": {
77555              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
77556              "location": "query",
77557              "type": "string",
77558              "format": "int64"
77559            }
77560          },
77561          "parameterOrder": [
77562            "project"
77563          ],
77564          "response": {
77565            "$ref": "TargetPoolAggregatedList"
77566          },
77567          "scopes": [
77568            "https://www.googleapis.com/auth/cloud-platform",
77569            "https://www.googleapis.com/auth/compute",
77570            "https://www.googleapis.com/auth/compute.readonly"
77571          ],
77572          "description": "Retrieves an aggregated list of target pools. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
77573        },
77574        "get": {
77575          "id": "compute.targetPools.get",
77576          "path": "projects/{project}/regions/{region}/targetPools/{targetPool}",
77577          "flatPath": "projects/{project}/regions/{region}/targetPools/{targetPool}",
77578          "httpMethod": "GET",
77579          "parameters": {
77580            "project": {
77581              "description": "Project ID for this request.",
77582              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77583              "location": "path",
77584              "required": true,
77585              "type": "string"
77586            },
77587            "region": {
77588              "description": "Name of the region scoping this request.",
77589              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77590              "location": "path",
77591              "required": true,
77592              "type": "string"
77593            },
77594            "targetPool": {
77595              "description": "Name of the TargetPool resource to return.",
77596              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
77597              "location": "path",
77598              "required": true,
77599              "type": "string"
77600            }
77601          },
77602          "parameterOrder": [
77603            "project",
77604            "region",
77605            "targetPool"
77606          ],
77607          "response": {
77608            "$ref": "TargetPool"
77609          },
77610          "scopes": [
77611            "https://www.googleapis.com/auth/cloud-platform",
77612            "https://www.googleapis.com/auth/compute",
77613            "https://www.googleapis.com/auth/compute.readonly"
77614          ],
77615          "description": "Returns the specified target pool."
77616        },
77617        "insert": {
77618          "id": "compute.targetPools.insert",
77619          "path": "projects/{project}/regions/{region}/targetPools",
77620          "flatPath": "projects/{project}/regions/{region}/targetPools",
77621          "httpMethod": "POST",
77622          "parameters": {
77623            "project": {
77624              "description": "Project ID for this request.",
77625              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77626              "location": "path",
77627              "required": true,
77628              "type": "string"
77629            },
77630            "region": {
77631              "description": "Name of the region scoping this request.",
77632              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77633              "location": "path",
77634              "required": true,
77635              "type": "string"
77636            },
77637            "requestId": {
77638              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
77639              "location": "query",
77640              "type": "string"
77641            }
77642          },
77643          "parameterOrder": [
77644            "project",
77645            "region"
77646          ],
77647          "request": {
77648            "$ref": "TargetPool"
77649          },
77650          "response": {
77651            "$ref": "Operation"
77652          },
77653          "scopes": [
77654            "https://www.googleapis.com/auth/cloud-platform",
77655            "https://www.googleapis.com/auth/compute"
77656          ],
77657          "description": "Creates a target pool in the specified project and region using the data included in the request."
77658        },
77659        "delete": {
77660          "id": "compute.targetPools.delete",
77661          "path": "projects/{project}/regions/{region}/targetPools/{targetPool}",
77662          "flatPath": "projects/{project}/regions/{region}/targetPools/{targetPool}",
77663          "httpMethod": "DELETE",
77664          "parameters": {
77665            "project": {
77666              "description": "Project ID for this request.",
77667              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77668              "location": "path",
77669              "required": true,
77670              "type": "string"
77671            },
77672            "region": {
77673              "description": "Name of the region scoping this request.",
77674              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77675              "location": "path",
77676              "required": true,
77677              "type": "string"
77678            },
77679            "requestId": {
77680              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
77681              "location": "query",
77682              "type": "string"
77683            },
77684            "targetPool": {
77685              "description": "Name of the TargetPool resource to delete.",
77686              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
77687              "location": "path",
77688              "required": true,
77689              "type": "string"
77690            }
77691          },
77692          "parameterOrder": [
77693            "project",
77694            "region",
77695            "targetPool"
77696          ],
77697          "response": {
77698            "$ref": "Operation"
77699          },
77700          "scopes": [
77701            "https://www.googleapis.com/auth/cloud-platform",
77702            "https://www.googleapis.com/auth/compute"
77703          ],
77704          "description": "Deletes the specified target pool."
77705        },
77706        "getHealth": {
77707          "id": "compute.targetPools.getHealth",
77708          "path": "projects/{project}/regions/{region}/targetPools/{targetPool}/getHealth",
77709          "flatPath": "projects/{project}/regions/{region}/targetPools/{targetPool}/getHealth",
77710          "httpMethod": "POST",
77711          "parameters": {
77712            "project": {
77713              "description": "Project ID for this request.",
77714              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77715              "location": "path",
77716              "required": true,
77717              "type": "string"
77718            },
77719            "region": {
77720              "description": "Name of the region scoping this request.",
77721              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77722              "location": "path",
77723              "required": true,
77724              "type": "string"
77725            },
77726            "targetPool": {
77727              "description": "Name of the TargetPool resource to which the queried instance belongs.",
77728              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
77729              "location": "path",
77730              "required": true,
77731              "type": "string"
77732            }
77733          },
77734          "parameterOrder": [
77735            "project",
77736            "region",
77737            "targetPool"
77738          ],
77739          "request": {
77740            "$ref": "InstanceReference"
77741          },
77742          "response": {
77743            "$ref": "TargetPoolInstanceHealth"
77744          },
77745          "scopes": [
77746            "https://www.googleapis.com/auth/cloud-platform",
77747            "https://www.googleapis.com/auth/compute",
77748            "https://www.googleapis.com/auth/compute.readonly"
77749          ],
77750          "description": "Gets the most recent health check results for each IP for the instance that is referenced by the given target pool."
77751        },
77752        "addHealthCheck": {
77753          "id": "compute.targetPools.addHealthCheck",
77754          "path": "projects/{project}/regions/{region}/targetPools/{targetPool}/addHealthCheck",
77755          "flatPath": "projects/{project}/regions/{region}/targetPools/{targetPool}/addHealthCheck",
77756          "httpMethod": "POST",
77757          "parameters": {
77758            "project": {
77759              "description": "Project ID for this request.",
77760              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77761              "location": "path",
77762              "required": true,
77763              "type": "string"
77764            },
77765            "region": {
77766              "description": "Name of the region scoping this request.",
77767              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77768              "location": "path",
77769              "required": true,
77770              "type": "string"
77771            },
77772            "requestId": {
77773              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
77774              "location": "query",
77775              "type": "string"
77776            },
77777            "targetPool": {
77778              "description": "Name of the target pool to add a health check to.",
77779              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
77780              "location": "path",
77781              "required": true,
77782              "type": "string"
77783            }
77784          },
77785          "parameterOrder": [
77786            "project",
77787            "region",
77788            "targetPool"
77789          ],
77790          "request": {
77791            "$ref": "TargetPoolsAddHealthCheckRequest"
77792          },
77793          "response": {
77794            "$ref": "Operation"
77795          },
77796          "scopes": [
77797            "https://www.googleapis.com/auth/cloud-platform",
77798            "https://www.googleapis.com/auth/compute"
77799          ],
77800          "description": "Adds health check URLs to a target pool."
77801        },
77802        "removeHealthCheck": {
77803          "id": "compute.targetPools.removeHealthCheck",
77804          "path": "projects/{project}/regions/{region}/targetPools/{targetPool}/removeHealthCheck",
77805          "flatPath": "projects/{project}/regions/{region}/targetPools/{targetPool}/removeHealthCheck",
77806          "httpMethod": "POST",
77807          "parameters": {
77808            "project": {
77809              "description": "Project ID for this request.",
77810              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77811              "location": "path",
77812              "required": true,
77813              "type": "string"
77814            },
77815            "region": {
77816              "description": "Name of the region for this request.",
77817              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77818              "location": "path",
77819              "required": true,
77820              "type": "string"
77821            },
77822            "requestId": {
77823              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
77824              "location": "query",
77825              "type": "string"
77826            },
77827            "targetPool": {
77828              "description": "Name of the target pool to remove health checks from.",
77829              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
77830              "location": "path",
77831              "required": true,
77832              "type": "string"
77833            }
77834          },
77835          "parameterOrder": [
77836            "project",
77837            "region",
77838            "targetPool"
77839          ],
77840          "request": {
77841            "$ref": "TargetPoolsRemoveHealthCheckRequest"
77842          },
77843          "response": {
77844            "$ref": "Operation"
77845          },
77846          "scopes": [
77847            "https://www.googleapis.com/auth/cloud-platform",
77848            "https://www.googleapis.com/auth/compute"
77849          ],
77850          "description": "Removes health check URL from a target pool."
77851        },
77852        "addInstance": {
77853          "id": "compute.targetPools.addInstance",
77854          "path": "projects/{project}/regions/{region}/targetPools/{targetPool}/addInstance",
77855          "flatPath": "projects/{project}/regions/{region}/targetPools/{targetPool}/addInstance",
77856          "httpMethod": "POST",
77857          "parameters": {
77858            "project": {
77859              "description": "Project ID for this request.",
77860              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77861              "location": "path",
77862              "required": true,
77863              "type": "string"
77864            },
77865            "region": {
77866              "description": "Name of the region scoping this request.",
77867              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77868              "location": "path",
77869              "required": true,
77870              "type": "string"
77871            },
77872            "requestId": {
77873              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
77874              "location": "query",
77875              "type": "string"
77876            },
77877            "targetPool": {
77878              "description": "Name of the TargetPool resource to add instances to.",
77879              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
77880              "location": "path",
77881              "required": true,
77882              "type": "string"
77883            }
77884          },
77885          "parameterOrder": [
77886            "project",
77887            "region",
77888            "targetPool"
77889          ],
77890          "request": {
77891            "$ref": "TargetPoolsAddInstanceRequest"
77892          },
77893          "response": {
77894            "$ref": "Operation"
77895          },
77896          "scopes": [
77897            "https://www.googleapis.com/auth/cloud-platform",
77898            "https://www.googleapis.com/auth/compute"
77899          ],
77900          "description": "Adds an instance to a target pool."
77901        },
77902        "removeInstance": {
77903          "id": "compute.targetPools.removeInstance",
77904          "path": "projects/{project}/regions/{region}/targetPools/{targetPool}/removeInstance",
77905          "flatPath": "projects/{project}/regions/{region}/targetPools/{targetPool}/removeInstance",
77906          "httpMethod": "POST",
77907          "parameters": {
77908            "project": {
77909              "description": "Project ID for this request.",
77910              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77911              "location": "path",
77912              "required": true,
77913              "type": "string"
77914            },
77915            "region": {
77916              "description": "Name of the region scoping this request.",
77917              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77918              "location": "path",
77919              "required": true,
77920              "type": "string"
77921            },
77922            "requestId": {
77923              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
77924              "location": "query",
77925              "type": "string"
77926            },
77927            "targetPool": {
77928              "description": "Name of the TargetPool resource to remove instances from.",
77929              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
77930              "location": "path",
77931              "required": true,
77932              "type": "string"
77933            }
77934          },
77935          "parameterOrder": [
77936            "project",
77937            "region",
77938            "targetPool"
77939          ],
77940          "request": {
77941            "$ref": "TargetPoolsRemoveInstanceRequest"
77942          },
77943          "response": {
77944            "$ref": "Operation"
77945          },
77946          "scopes": [
77947            "https://www.googleapis.com/auth/cloud-platform",
77948            "https://www.googleapis.com/auth/compute"
77949          ],
77950          "description": "Removes instance URL from a target pool."
77951        },
77952        "setBackup": {
77953          "id": "compute.targetPools.setBackup",
77954          "path": "projects/{project}/regions/{region}/targetPools/{targetPool}/setBackup",
77955          "flatPath": "projects/{project}/regions/{region}/targetPools/{targetPool}/setBackup",
77956          "httpMethod": "POST",
77957          "parameters": {
77958            "failoverRatio": {
77959              "description": "New failoverRatio value for the target pool.",
77960              "location": "query",
77961              "type": "number",
77962              "format": "float"
77963            },
77964            "project": {
77965              "description": "Project ID for this request.",
77966              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
77967              "location": "path",
77968              "required": true,
77969              "type": "string"
77970            },
77971            "region": {
77972              "description": "Name of the region scoping this request.",
77973              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
77974              "location": "path",
77975              "required": true,
77976              "type": "string"
77977            },
77978            "requestId": {
77979              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
77980              "location": "query",
77981              "type": "string"
77982            },
77983            "targetPool": {
77984              "description": "Name of the TargetPool resource to set a backup pool for.",
77985              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
77986              "location": "path",
77987              "required": true,
77988              "type": "string"
77989            }
77990          },
77991          "parameterOrder": [
77992            "project",
77993            "region",
77994            "targetPool"
77995          ],
77996          "request": {
77997            "$ref": "TargetReference"
77998          },
77999          "response": {
78000            "$ref": "Operation"
78001          },
78002          "scopes": [
78003            "https://www.googleapis.com/auth/cloud-platform",
78004            "https://www.googleapis.com/auth/compute"
78005          ],
78006          "description": "Changes a backup target pool's configurations."
78007        },
78008        "setSecurityPolicy": {
78009          "id": "compute.targetPools.setSecurityPolicy",
78010          "path": "projects/{project}/regions/{region}/targetPools/{targetPool}/setSecurityPolicy",
78011          "flatPath": "projects/{project}/regions/{region}/targetPools/{targetPool}/setSecurityPolicy",
78012          "httpMethod": "POST",
78013          "parameters": {
78014            "project": {
78015              "description": "Project ID for this request.",
78016              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78017              "location": "path",
78018              "required": true,
78019              "type": "string"
78020            },
78021            "region": {
78022              "description": "Name of the region scoping this request.",
78023              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
78024              "location": "path",
78025              "required": true,
78026              "type": "string"
78027            },
78028            "requestId": {
78029              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
78030              "location": "query",
78031              "type": "string"
78032            },
78033            "targetPool": {
78034              "description": "Name of the TargetPool resource to which the security policy should be set. The name should conform to RFC1035.",
78035              "location": "path",
78036              "required": true,
78037              "type": "string"
78038            }
78039          },
78040          "parameterOrder": [
78041            "project",
78042            "region",
78043            "targetPool"
78044          ],
78045          "request": {
78046            "$ref": "SecurityPolicyReference"
78047          },
78048          "response": {
78049            "$ref": "Operation"
78050          },
78051          "scopes": [
78052            "https://www.googleapis.com/auth/cloud-platform",
78053            "https://www.googleapis.com/auth/compute"
78054          ],
78055          "description": "Sets the Google Cloud Armor security policy for the specified target pool. For more information, see Google Cloud Armor Overview"
78056        }
78057      }
78058    },
78059    "targetSslProxies": {
78060      "methods": {
78061        "list": {
78062          "id": "compute.targetSslProxies.list",
78063          "path": "projects/{project}/global/targetSslProxies",
78064          "flatPath": "projects/{project}/global/targetSslProxies",
78065          "httpMethod": "GET",
78066          "parameters": {
78067            "filter": {
78068              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
78069              "location": "query",
78070              "type": "string"
78071            },
78072            "maxResults": {
78073              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
78074              "default": "500",
78075              "minimum": "0",
78076              "location": "query",
78077              "type": "integer",
78078              "format": "uint32"
78079            },
78080            "orderBy": {
78081              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
78082              "location": "query",
78083              "type": "string"
78084            },
78085            "pageToken": {
78086              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
78087              "location": "query",
78088              "type": "string"
78089            },
78090            "project": {
78091              "description": "Project ID for this request.",
78092              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78093              "location": "path",
78094              "required": true,
78095              "type": "string"
78096            },
78097            "returnPartialSuccess": {
78098              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
78099              "location": "query",
78100              "type": "boolean"
78101            }
78102          },
78103          "parameterOrder": [
78104            "project"
78105          ],
78106          "response": {
78107            "$ref": "TargetSslProxyList"
78108          },
78109          "scopes": [
78110            "https://www.googleapis.com/auth/cloud-platform",
78111            "https://www.googleapis.com/auth/compute",
78112            "https://www.googleapis.com/auth/compute.readonly"
78113          ],
78114          "description": "Retrieves the list of TargetSslProxy resources available to the specified project."
78115        },
78116        "get": {
78117          "id": "compute.targetSslProxies.get",
78118          "path": "projects/{project}/global/targetSslProxies/{targetSslProxy}",
78119          "flatPath": "projects/{project}/global/targetSslProxies/{targetSslProxy}",
78120          "httpMethod": "GET",
78121          "parameters": {
78122            "project": {
78123              "description": "Project ID for this request.",
78124              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78125              "location": "path",
78126              "required": true,
78127              "type": "string"
78128            },
78129            "targetSslProxy": {
78130              "description": "Name of the TargetSslProxy resource to return.",
78131              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
78132              "location": "path",
78133              "required": true,
78134              "type": "string"
78135            }
78136          },
78137          "parameterOrder": [
78138            "project",
78139            "targetSslProxy"
78140          ],
78141          "response": {
78142            "$ref": "TargetSslProxy"
78143          },
78144          "scopes": [
78145            "https://www.googleapis.com/auth/cloud-platform",
78146            "https://www.googleapis.com/auth/compute",
78147            "https://www.googleapis.com/auth/compute.readonly"
78148          ],
78149          "description": "Returns the specified TargetSslProxy resource."
78150        },
78151        "insert": {
78152          "id": "compute.targetSslProxies.insert",
78153          "path": "projects/{project}/global/targetSslProxies",
78154          "flatPath": "projects/{project}/global/targetSslProxies",
78155          "httpMethod": "POST",
78156          "parameters": {
78157            "project": {
78158              "description": "Project ID for this request.",
78159              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78160              "location": "path",
78161              "required": true,
78162              "type": "string"
78163            },
78164            "requestId": {
78165              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
78166              "location": "query",
78167              "type": "string"
78168            }
78169          },
78170          "parameterOrder": [
78171            "project"
78172          ],
78173          "request": {
78174            "$ref": "TargetSslProxy"
78175          },
78176          "response": {
78177            "$ref": "Operation"
78178          },
78179          "scopes": [
78180            "https://www.googleapis.com/auth/cloud-platform",
78181            "https://www.googleapis.com/auth/compute"
78182          ],
78183          "description": "Creates a TargetSslProxy resource in the specified project using the data included in the request."
78184        },
78185        "delete": {
78186          "id": "compute.targetSslProxies.delete",
78187          "path": "projects/{project}/global/targetSslProxies/{targetSslProxy}",
78188          "flatPath": "projects/{project}/global/targetSslProxies/{targetSslProxy}",
78189          "httpMethod": "DELETE",
78190          "parameters": {
78191            "project": {
78192              "description": "Project ID for this request.",
78193              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78194              "location": "path",
78195              "required": true,
78196              "type": "string"
78197            },
78198            "requestId": {
78199              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
78200              "location": "query",
78201              "type": "string"
78202            },
78203            "targetSslProxy": {
78204              "description": "Name of the TargetSslProxy resource to delete.",
78205              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
78206              "location": "path",
78207              "required": true,
78208              "type": "string"
78209            }
78210          },
78211          "parameterOrder": [
78212            "project",
78213            "targetSslProxy"
78214          ],
78215          "response": {
78216            "$ref": "Operation"
78217          },
78218          "scopes": [
78219            "https://www.googleapis.com/auth/cloud-platform",
78220            "https://www.googleapis.com/auth/compute"
78221          ],
78222          "description": "Deletes the specified TargetSslProxy resource."
78223        },
78224        "setBackendService": {
78225          "id": "compute.targetSslProxies.setBackendService",
78226          "path": "projects/{project}/global/targetSslProxies/{targetSslProxy}/setBackendService",
78227          "flatPath": "projects/{project}/global/targetSslProxies/{targetSslProxy}/setBackendService",
78228          "httpMethod": "POST",
78229          "parameters": {
78230            "project": {
78231              "description": "Project ID for this request.",
78232              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78233              "location": "path",
78234              "required": true,
78235              "type": "string"
78236            },
78237            "requestId": {
78238              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
78239              "location": "query",
78240              "type": "string"
78241            },
78242            "targetSslProxy": {
78243              "description": "Name of the TargetSslProxy resource whose BackendService resource is to be set.",
78244              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
78245              "location": "path",
78246              "required": true,
78247              "type": "string"
78248            }
78249          },
78250          "parameterOrder": [
78251            "project",
78252            "targetSslProxy"
78253          ],
78254          "request": {
78255            "$ref": "TargetSslProxiesSetBackendServiceRequest"
78256          },
78257          "response": {
78258            "$ref": "Operation"
78259          },
78260          "scopes": [
78261            "https://www.googleapis.com/auth/cloud-platform",
78262            "https://www.googleapis.com/auth/compute"
78263          ],
78264          "description": "Changes the BackendService for TargetSslProxy."
78265        },
78266        "setSslCertificates": {
78267          "id": "compute.targetSslProxies.setSslCertificates",
78268          "path": "projects/{project}/global/targetSslProxies/{targetSslProxy}/setSslCertificates",
78269          "flatPath": "projects/{project}/global/targetSslProxies/{targetSslProxy}/setSslCertificates",
78270          "httpMethod": "POST",
78271          "parameters": {
78272            "project": {
78273              "description": "Project ID for this request.",
78274              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78275              "location": "path",
78276              "required": true,
78277              "type": "string"
78278            },
78279            "requestId": {
78280              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
78281              "location": "query",
78282              "type": "string"
78283            },
78284            "targetSslProxy": {
78285              "description": "Name of the TargetSslProxy resource whose SslCertificate resource is to be set.",
78286              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
78287              "location": "path",
78288              "required": true,
78289              "type": "string"
78290            }
78291          },
78292          "parameterOrder": [
78293            "project",
78294            "targetSslProxy"
78295          ],
78296          "request": {
78297            "$ref": "TargetSslProxiesSetSslCertificatesRequest"
78298          },
78299          "response": {
78300            "$ref": "Operation"
78301          },
78302          "scopes": [
78303            "https://www.googleapis.com/auth/cloud-platform",
78304            "https://www.googleapis.com/auth/compute"
78305          ],
78306          "description": "Changes SslCertificates for TargetSslProxy."
78307        },
78308        "setCertificateMap": {
78309          "id": "compute.targetSslProxies.setCertificateMap",
78310          "path": "projects/{project}/global/targetSslProxies/{targetSslProxy}/setCertificateMap",
78311          "flatPath": "projects/{project}/global/targetSslProxies/{targetSslProxy}/setCertificateMap",
78312          "httpMethod": "POST",
78313          "parameters": {
78314            "project": {
78315              "description": "Project ID for this request.",
78316              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78317              "location": "path",
78318              "required": true,
78319              "type": "string"
78320            },
78321            "requestId": {
78322              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
78323              "location": "query",
78324              "type": "string"
78325            },
78326            "targetSslProxy": {
78327              "description": "Name of the TargetSslProxy resource whose CertificateMap is to be set. The name must be 1-63 characters long, and comply with RFC1035.",
78328              "location": "path",
78329              "required": true,
78330              "type": "string"
78331            }
78332          },
78333          "parameterOrder": [
78334            "project",
78335            "targetSslProxy"
78336          ],
78337          "request": {
78338            "$ref": "TargetSslProxiesSetCertificateMapRequest"
78339          },
78340          "response": {
78341            "$ref": "Operation"
78342          },
78343          "scopes": [
78344            "https://www.googleapis.com/auth/cloud-platform",
78345            "https://www.googleapis.com/auth/compute"
78346          ],
78347          "description": "Changes the Certificate Map for TargetSslProxy."
78348        },
78349        "setProxyHeader": {
78350          "id": "compute.targetSslProxies.setProxyHeader",
78351          "path": "projects/{project}/global/targetSslProxies/{targetSslProxy}/setProxyHeader",
78352          "flatPath": "projects/{project}/global/targetSslProxies/{targetSslProxy}/setProxyHeader",
78353          "httpMethod": "POST",
78354          "parameters": {
78355            "project": {
78356              "description": "Project ID for this request.",
78357              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78358              "location": "path",
78359              "required": true,
78360              "type": "string"
78361            },
78362            "requestId": {
78363              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
78364              "location": "query",
78365              "type": "string"
78366            },
78367            "targetSslProxy": {
78368              "description": "Name of the TargetSslProxy resource whose ProxyHeader is to be set.",
78369              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
78370              "location": "path",
78371              "required": true,
78372              "type": "string"
78373            }
78374          },
78375          "parameterOrder": [
78376            "project",
78377            "targetSslProxy"
78378          ],
78379          "request": {
78380            "$ref": "TargetSslProxiesSetProxyHeaderRequest"
78381          },
78382          "response": {
78383            "$ref": "Operation"
78384          },
78385          "scopes": [
78386            "https://www.googleapis.com/auth/cloud-platform",
78387            "https://www.googleapis.com/auth/compute"
78388          ],
78389          "description": "Changes the ProxyHeaderType for TargetSslProxy."
78390        },
78391        "setSslPolicy": {
78392          "id": "compute.targetSslProxies.setSslPolicy",
78393          "path": "projects/{project}/global/targetSslProxies/{targetSslProxy}/setSslPolicy",
78394          "flatPath": "projects/{project}/global/targetSslProxies/{targetSslProxy}/setSslPolicy",
78395          "httpMethod": "POST",
78396          "parameters": {
78397            "project": {
78398              "description": "Project ID for this request.",
78399              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78400              "location": "path",
78401              "required": true,
78402              "type": "string"
78403            },
78404            "requestId": {
78405              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
78406              "location": "query",
78407              "type": "string"
78408            },
78409            "targetSslProxy": {
78410              "description": "Name of the TargetSslProxy resource whose SSL policy is to be set. The name must be 1-63 characters long, and comply with RFC1035.",
78411              "location": "path",
78412              "required": true,
78413              "type": "string"
78414            }
78415          },
78416          "parameterOrder": [
78417            "project",
78418            "targetSslProxy"
78419          ],
78420          "request": {
78421            "$ref": "SslPolicyReference"
78422          },
78423          "response": {
78424            "$ref": "Operation"
78425          },
78426          "scopes": [
78427            "https://www.googleapis.com/auth/cloud-platform",
78428            "https://www.googleapis.com/auth/compute"
78429          ],
78430          "description": "Sets the SSL policy for TargetSslProxy. The SSL policy specifies the server-side support for SSL features. This affects connections between clients and the load balancer. They do not affect the connection between the load balancer and the backends."
78431        }
78432      }
78433    },
78434    "targetTcpProxies": {
78435      "methods": {
78436        "list": {
78437          "id": "compute.targetTcpProxies.list",
78438          "path": "projects/{project}/global/targetTcpProxies",
78439          "flatPath": "projects/{project}/global/targetTcpProxies",
78440          "httpMethod": "GET",
78441          "parameters": {
78442            "filter": {
78443              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
78444              "location": "query",
78445              "type": "string"
78446            },
78447            "maxResults": {
78448              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
78449              "default": "500",
78450              "minimum": "0",
78451              "location": "query",
78452              "type": "integer",
78453              "format": "uint32"
78454            },
78455            "orderBy": {
78456              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
78457              "location": "query",
78458              "type": "string"
78459            },
78460            "pageToken": {
78461              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
78462              "location": "query",
78463              "type": "string"
78464            },
78465            "project": {
78466              "description": "Project ID for this request.",
78467              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78468              "location": "path",
78469              "required": true,
78470              "type": "string"
78471            },
78472            "returnPartialSuccess": {
78473              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
78474              "location": "query",
78475              "type": "boolean"
78476            }
78477          },
78478          "parameterOrder": [
78479            "project"
78480          ],
78481          "response": {
78482            "$ref": "TargetTcpProxyList"
78483          },
78484          "scopes": [
78485            "https://www.googleapis.com/auth/cloud-platform",
78486            "https://www.googleapis.com/auth/compute",
78487            "https://www.googleapis.com/auth/compute.readonly"
78488          ],
78489          "description": "Retrieves the list of TargetTcpProxy resources available to the specified project."
78490        },
78491        "aggregatedList": {
78492          "id": "compute.targetTcpProxies.aggregatedList",
78493          "path": "projects/{project}/aggregated/targetTcpProxies",
78494          "flatPath": "projects/{project}/aggregated/targetTcpProxies",
78495          "httpMethod": "GET",
78496          "parameters": {
78497            "filter": {
78498              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
78499              "location": "query",
78500              "type": "string"
78501            },
78502            "includeAllScopes": {
78503              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
78504              "location": "query",
78505              "type": "boolean"
78506            },
78507            "maxResults": {
78508              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
78509              "default": "500",
78510              "minimum": "0",
78511              "location": "query",
78512              "type": "integer",
78513              "format": "uint32"
78514            },
78515            "orderBy": {
78516              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
78517              "location": "query",
78518              "type": "string"
78519            },
78520            "pageToken": {
78521              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
78522              "location": "query",
78523              "type": "string"
78524            },
78525            "project": {
78526              "description": "Name of the project scoping this request.",
78527              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78528              "location": "path",
78529              "required": true,
78530              "type": "string"
78531            },
78532            "returnPartialSuccess": {
78533              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
78534              "location": "query",
78535              "type": "boolean"
78536            },
78537            "serviceProjectNumber": {
78538              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
78539              "location": "query",
78540              "type": "string",
78541              "format": "int64"
78542            }
78543          },
78544          "parameterOrder": [
78545            "project"
78546          ],
78547          "response": {
78548            "$ref": "TargetTcpProxyAggregatedList"
78549          },
78550          "scopes": [
78551            "https://www.googleapis.com/auth/cloud-platform",
78552            "https://www.googleapis.com/auth/compute",
78553            "https://www.googleapis.com/auth/compute.readonly"
78554          ],
78555          "description": "Retrieves the list of all TargetTcpProxy resources, regional and global, available to the specified project. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
78556        },
78557        "get": {
78558          "id": "compute.targetTcpProxies.get",
78559          "path": "projects/{project}/global/targetTcpProxies/{targetTcpProxy}",
78560          "flatPath": "projects/{project}/global/targetTcpProxies/{targetTcpProxy}",
78561          "httpMethod": "GET",
78562          "parameters": {
78563            "project": {
78564              "description": "Project ID for this request.",
78565              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78566              "location": "path",
78567              "required": true,
78568              "type": "string"
78569            },
78570            "targetTcpProxy": {
78571              "description": "Name of the TargetTcpProxy resource to return.",
78572              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
78573              "location": "path",
78574              "required": true,
78575              "type": "string"
78576            }
78577          },
78578          "parameterOrder": [
78579            "project",
78580            "targetTcpProxy"
78581          ],
78582          "response": {
78583            "$ref": "TargetTcpProxy"
78584          },
78585          "scopes": [
78586            "https://www.googleapis.com/auth/cloud-platform",
78587            "https://www.googleapis.com/auth/compute",
78588            "https://www.googleapis.com/auth/compute.readonly"
78589          ],
78590          "description": "Returns the specified TargetTcpProxy resource."
78591        },
78592        "insert": {
78593          "id": "compute.targetTcpProxies.insert",
78594          "path": "projects/{project}/global/targetTcpProxies",
78595          "flatPath": "projects/{project}/global/targetTcpProxies",
78596          "httpMethod": "POST",
78597          "parameters": {
78598            "project": {
78599              "description": "Project ID for this request.",
78600              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78601              "location": "path",
78602              "required": true,
78603              "type": "string"
78604            },
78605            "requestId": {
78606              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
78607              "location": "query",
78608              "type": "string"
78609            }
78610          },
78611          "parameterOrder": [
78612            "project"
78613          ],
78614          "request": {
78615            "$ref": "TargetTcpProxy"
78616          },
78617          "response": {
78618            "$ref": "Operation"
78619          },
78620          "scopes": [
78621            "https://www.googleapis.com/auth/cloud-platform",
78622            "https://www.googleapis.com/auth/compute"
78623          ],
78624          "description": "Creates a TargetTcpProxy resource in the specified project using the data included in the request."
78625        },
78626        "delete": {
78627          "id": "compute.targetTcpProxies.delete",
78628          "path": "projects/{project}/global/targetTcpProxies/{targetTcpProxy}",
78629          "flatPath": "projects/{project}/global/targetTcpProxies/{targetTcpProxy}",
78630          "httpMethod": "DELETE",
78631          "parameters": {
78632            "project": {
78633              "description": "Project ID for this request.",
78634              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78635              "location": "path",
78636              "required": true,
78637              "type": "string"
78638            },
78639            "requestId": {
78640              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
78641              "location": "query",
78642              "type": "string"
78643            },
78644            "targetTcpProxy": {
78645              "description": "Name of the TargetTcpProxy resource to delete.",
78646              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
78647              "location": "path",
78648              "required": true,
78649              "type": "string"
78650            }
78651          },
78652          "parameterOrder": [
78653            "project",
78654            "targetTcpProxy"
78655          ],
78656          "response": {
78657            "$ref": "Operation"
78658          },
78659          "scopes": [
78660            "https://www.googleapis.com/auth/cloud-platform",
78661            "https://www.googleapis.com/auth/compute"
78662          ],
78663          "description": "Deletes the specified TargetTcpProxy resource."
78664        },
78665        "setBackendService": {
78666          "id": "compute.targetTcpProxies.setBackendService",
78667          "path": "projects/{project}/global/targetTcpProxies/{targetTcpProxy}/setBackendService",
78668          "flatPath": "projects/{project}/global/targetTcpProxies/{targetTcpProxy}/setBackendService",
78669          "httpMethod": "POST",
78670          "parameters": {
78671            "project": {
78672              "description": "Project ID for this request.",
78673              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78674              "location": "path",
78675              "required": true,
78676              "type": "string"
78677            },
78678            "requestId": {
78679              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
78680              "location": "query",
78681              "type": "string"
78682            },
78683            "targetTcpProxy": {
78684              "description": "Name of the TargetTcpProxy resource whose BackendService resource is to be set.",
78685              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
78686              "location": "path",
78687              "required": true,
78688              "type": "string"
78689            }
78690          },
78691          "parameterOrder": [
78692            "project",
78693            "targetTcpProxy"
78694          ],
78695          "request": {
78696            "$ref": "TargetTcpProxiesSetBackendServiceRequest"
78697          },
78698          "response": {
78699            "$ref": "Operation"
78700          },
78701          "scopes": [
78702            "https://www.googleapis.com/auth/cloud-platform",
78703            "https://www.googleapis.com/auth/compute"
78704          ],
78705          "description": "Changes the BackendService for TargetTcpProxy."
78706        },
78707        "setProxyHeader": {
78708          "id": "compute.targetTcpProxies.setProxyHeader",
78709          "path": "projects/{project}/global/targetTcpProxies/{targetTcpProxy}/setProxyHeader",
78710          "flatPath": "projects/{project}/global/targetTcpProxies/{targetTcpProxy}/setProxyHeader",
78711          "httpMethod": "POST",
78712          "parameters": {
78713            "project": {
78714              "description": "Project ID for this request.",
78715              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78716              "location": "path",
78717              "required": true,
78718              "type": "string"
78719            },
78720            "requestId": {
78721              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
78722              "location": "query",
78723              "type": "string"
78724            },
78725            "targetTcpProxy": {
78726              "description": "Name of the TargetTcpProxy resource whose ProxyHeader is to be set.",
78727              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
78728              "location": "path",
78729              "required": true,
78730              "type": "string"
78731            }
78732          },
78733          "parameterOrder": [
78734            "project",
78735            "targetTcpProxy"
78736          ],
78737          "request": {
78738            "$ref": "TargetTcpProxiesSetProxyHeaderRequest"
78739          },
78740          "response": {
78741            "$ref": "Operation"
78742          },
78743          "scopes": [
78744            "https://www.googleapis.com/auth/cloud-platform",
78745            "https://www.googleapis.com/auth/compute"
78746          ],
78747          "description": "Changes the ProxyHeaderType for TargetTcpProxy."
78748        }
78749      }
78750    },
78751    "regionTargetTcpProxies": {
78752      "methods": {
78753        "list": {
78754          "id": "compute.regionTargetTcpProxies.list",
78755          "path": "projects/{project}/regions/{region}/targetTcpProxies",
78756          "flatPath": "projects/{project}/regions/{region}/targetTcpProxies",
78757          "httpMethod": "GET",
78758          "parameters": {
78759            "filter": {
78760              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
78761              "location": "query",
78762              "type": "string"
78763            },
78764            "maxResults": {
78765              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
78766              "default": "500",
78767              "minimum": "0",
78768              "location": "query",
78769              "type": "integer",
78770              "format": "uint32"
78771            },
78772            "orderBy": {
78773              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
78774              "location": "query",
78775              "type": "string"
78776            },
78777            "pageToken": {
78778              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
78779              "location": "query",
78780              "type": "string"
78781            },
78782            "project": {
78783              "description": "Project ID for this request.",
78784              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78785              "location": "path",
78786              "required": true,
78787              "type": "string"
78788            },
78789            "region": {
78790              "description": "Name of the region scoping this request.",
78791              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
78792              "location": "path",
78793              "required": true,
78794              "type": "string"
78795            },
78796            "returnPartialSuccess": {
78797              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
78798              "location": "query",
78799              "type": "boolean"
78800            }
78801          },
78802          "parameterOrder": [
78803            "project",
78804            "region"
78805          ],
78806          "response": {
78807            "$ref": "TargetTcpProxyList"
78808          },
78809          "scopes": [
78810            "https://www.googleapis.com/auth/cloud-platform",
78811            "https://www.googleapis.com/auth/compute",
78812            "https://www.googleapis.com/auth/compute.readonly"
78813          ],
78814          "description": "Retrieves a list of TargetTcpProxy resources available to the specified project in a given region."
78815        },
78816        "get": {
78817          "id": "compute.regionTargetTcpProxies.get",
78818          "path": "projects/{project}/regions/{region}/targetTcpProxies/{targetTcpProxy}",
78819          "flatPath": "projects/{project}/regions/{region}/targetTcpProxies/{targetTcpProxy}",
78820          "httpMethod": "GET",
78821          "parameters": {
78822            "project": {
78823              "description": "Project ID for this request.",
78824              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78825              "location": "path",
78826              "required": true,
78827              "type": "string"
78828            },
78829            "region": {
78830              "description": "Name of the region scoping this request.",
78831              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
78832              "location": "path",
78833              "required": true,
78834              "type": "string"
78835            },
78836            "targetTcpProxy": {
78837              "description": "Name of the TargetTcpProxy resource to return.",
78838              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
78839              "location": "path",
78840              "required": true,
78841              "type": "string"
78842            }
78843          },
78844          "parameterOrder": [
78845            "project",
78846            "region",
78847            "targetTcpProxy"
78848          ],
78849          "response": {
78850            "$ref": "TargetTcpProxy"
78851          },
78852          "scopes": [
78853            "https://www.googleapis.com/auth/cloud-platform",
78854            "https://www.googleapis.com/auth/compute",
78855            "https://www.googleapis.com/auth/compute.readonly"
78856          ],
78857          "description": "Returns the specified TargetTcpProxy resource."
78858        },
78859        "insert": {
78860          "id": "compute.regionTargetTcpProxies.insert",
78861          "path": "projects/{project}/regions/{region}/targetTcpProxies",
78862          "flatPath": "projects/{project}/regions/{region}/targetTcpProxies",
78863          "httpMethod": "POST",
78864          "parameters": {
78865            "project": {
78866              "description": "Project ID for this request.",
78867              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78868              "location": "path",
78869              "required": true,
78870              "type": "string"
78871            },
78872            "region": {
78873              "description": "Name of the region scoping this request.",
78874              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
78875              "location": "path",
78876              "required": true,
78877              "type": "string"
78878            },
78879            "requestId": {
78880              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
78881              "location": "query",
78882              "type": "string"
78883            }
78884          },
78885          "parameterOrder": [
78886            "project",
78887            "region"
78888          ],
78889          "request": {
78890            "$ref": "TargetTcpProxy"
78891          },
78892          "response": {
78893            "$ref": "Operation"
78894          },
78895          "scopes": [
78896            "https://www.googleapis.com/auth/cloud-platform",
78897            "https://www.googleapis.com/auth/compute"
78898          ],
78899          "description": "Creates a TargetTcpProxy resource in the specified project and region using the data included in the request."
78900        },
78901        "delete": {
78902          "id": "compute.regionTargetTcpProxies.delete",
78903          "path": "projects/{project}/regions/{region}/targetTcpProxies/{targetTcpProxy}",
78904          "flatPath": "projects/{project}/regions/{region}/targetTcpProxies/{targetTcpProxy}",
78905          "httpMethod": "DELETE",
78906          "parameters": {
78907            "project": {
78908              "description": "Project ID for this request.",
78909              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78910              "location": "path",
78911              "required": true,
78912              "type": "string"
78913            },
78914            "region": {
78915              "description": "Name of the region scoping this request.",
78916              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
78917              "location": "path",
78918              "required": true,
78919              "type": "string"
78920            },
78921            "requestId": {
78922              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
78923              "location": "query",
78924              "type": "string"
78925            },
78926            "targetTcpProxy": {
78927              "description": "Name of the TargetTcpProxy resource to delete.",
78928              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
78929              "location": "path",
78930              "required": true,
78931              "type": "string"
78932            }
78933          },
78934          "parameterOrder": [
78935            "project",
78936            "region",
78937            "targetTcpProxy"
78938          ],
78939          "response": {
78940            "$ref": "Operation"
78941          },
78942          "scopes": [
78943            "https://www.googleapis.com/auth/cloud-platform",
78944            "https://www.googleapis.com/auth/compute"
78945          ],
78946          "description": "Deletes the specified TargetTcpProxy resource."
78947        }
78948      }
78949    },
78950    "targetVpnGateways": {
78951      "methods": {
78952        "list": {
78953          "id": "compute.targetVpnGateways.list",
78954          "path": "projects/{project}/regions/{region}/targetVpnGateways",
78955          "flatPath": "projects/{project}/regions/{region}/targetVpnGateways",
78956          "httpMethod": "GET",
78957          "parameters": {
78958            "filter": {
78959              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
78960              "location": "query",
78961              "type": "string"
78962            },
78963            "maxResults": {
78964              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
78965              "default": "500",
78966              "minimum": "0",
78967              "location": "query",
78968              "type": "integer",
78969              "format": "uint32"
78970            },
78971            "orderBy": {
78972              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
78973              "location": "query",
78974              "type": "string"
78975            },
78976            "pageToken": {
78977              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
78978              "location": "query",
78979              "type": "string"
78980            },
78981            "project": {
78982              "description": "Project ID for this request.",
78983              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
78984              "location": "path",
78985              "required": true,
78986              "type": "string"
78987            },
78988            "region": {
78989              "description": "Name of the region for this request.",
78990              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
78991              "location": "path",
78992              "required": true,
78993              "type": "string"
78994            },
78995            "returnPartialSuccess": {
78996              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
78997              "location": "query",
78998              "type": "boolean"
78999            }
79000          },
79001          "parameterOrder": [
79002            "project",
79003            "region"
79004          ],
79005          "response": {
79006            "$ref": "TargetVpnGatewayList"
79007          },
79008          "scopes": [
79009            "https://www.googleapis.com/auth/cloud-platform",
79010            "https://www.googleapis.com/auth/compute",
79011            "https://www.googleapis.com/auth/compute.readonly"
79012          ],
79013          "description": "Retrieves a list of target VPN gateways available to the specified project and region."
79014        },
79015        "aggregatedList": {
79016          "id": "compute.targetVpnGateways.aggregatedList",
79017          "path": "projects/{project}/aggregated/targetVpnGateways",
79018          "flatPath": "projects/{project}/aggregated/targetVpnGateways",
79019          "httpMethod": "GET",
79020          "parameters": {
79021            "filter": {
79022              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
79023              "location": "query",
79024              "type": "string"
79025            },
79026            "includeAllScopes": {
79027              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
79028              "location": "query",
79029              "type": "boolean"
79030            },
79031            "maxResults": {
79032              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
79033              "default": "500",
79034              "minimum": "0",
79035              "location": "query",
79036              "type": "integer",
79037              "format": "uint32"
79038            },
79039            "orderBy": {
79040              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
79041              "location": "query",
79042              "type": "string"
79043            },
79044            "pageToken": {
79045              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
79046              "location": "query",
79047              "type": "string"
79048            },
79049            "project": {
79050              "description": "Project ID for this request.",
79051              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79052              "location": "path",
79053              "required": true,
79054              "type": "string"
79055            },
79056            "returnPartialSuccess": {
79057              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
79058              "location": "query",
79059              "type": "boolean"
79060            },
79061            "serviceProjectNumber": {
79062              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
79063              "location": "query",
79064              "type": "string",
79065              "format": "int64"
79066            }
79067          },
79068          "parameterOrder": [
79069            "project"
79070          ],
79071          "response": {
79072            "$ref": "TargetVpnGatewayAggregatedList"
79073          },
79074          "scopes": [
79075            "https://www.googleapis.com/auth/cloud-platform",
79076            "https://www.googleapis.com/auth/compute",
79077            "https://www.googleapis.com/auth/compute.readonly"
79078          ],
79079          "description": "Retrieves an aggregated list of target VPN gateways. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
79080        },
79081        "get": {
79082          "id": "compute.targetVpnGateways.get",
79083          "path": "projects/{project}/regions/{region}/targetVpnGateways/{targetVpnGateway}",
79084          "flatPath": "projects/{project}/regions/{region}/targetVpnGateways/{targetVpnGateway}",
79085          "httpMethod": "GET",
79086          "parameters": {
79087            "project": {
79088              "description": "Project ID for this request.",
79089              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79090              "location": "path",
79091              "required": true,
79092              "type": "string"
79093            },
79094            "region": {
79095              "description": "Name of the region for this request.",
79096              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
79097              "location": "path",
79098              "required": true,
79099              "type": "string"
79100            },
79101            "targetVpnGateway": {
79102              "description": "Name of the target VPN gateway to return.",
79103              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
79104              "location": "path",
79105              "required": true,
79106              "type": "string"
79107            }
79108          },
79109          "parameterOrder": [
79110            "project",
79111            "region",
79112            "targetVpnGateway"
79113          ],
79114          "response": {
79115            "$ref": "TargetVpnGateway"
79116          },
79117          "scopes": [
79118            "https://www.googleapis.com/auth/cloud-platform",
79119            "https://www.googleapis.com/auth/compute",
79120            "https://www.googleapis.com/auth/compute.readonly"
79121          ],
79122          "description": "Returns the specified target VPN gateway."
79123        },
79124        "insert": {
79125          "id": "compute.targetVpnGateways.insert",
79126          "path": "projects/{project}/regions/{region}/targetVpnGateways",
79127          "flatPath": "projects/{project}/regions/{region}/targetVpnGateways",
79128          "httpMethod": "POST",
79129          "parameters": {
79130            "project": {
79131              "description": "Project ID for this request.",
79132              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79133              "location": "path",
79134              "required": true,
79135              "type": "string"
79136            },
79137            "region": {
79138              "description": "Name of the region for this request.",
79139              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
79140              "location": "path",
79141              "required": true,
79142              "type": "string"
79143            },
79144            "requestId": {
79145              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
79146              "location": "query",
79147              "type": "string"
79148            }
79149          },
79150          "parameterOrder": [
79151            "project",
79152            "region"
79153          ],
79154          "request": {
79155            "$ref": "TargetVpnGateway"
79156          },
79157          "response": {
79158            "$ref": "Operation"
79159          },
79160          "scopes": [
79161            "https://www.googleapis.com/auth/cloud-platform",
79162            "https://www.googleapis.com/auth/compute"
79163          ],
79164          "description": "Creates a target VPN gateway in the specified project and region using the data included in the request."
79165        },
79166        "delete": {
79167          "id": "compute.targetVpnGateways.delete",
79168          "path": "projects/{project}/regions/{region}/targetVpnGateways/{targetVpnGateway}",
79169          "flatPath": "projects/{project}/regions/{region}/targetVpnGateways/{targetVpnGateway}",
79170          "httpMethod": "DELETE",
79171          "parameters": {
79172            "project": {
79173              "description": "Project ID for this request.",
79174              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79175              "location": "path",
79176              "required": true,
79177              "type": "string"
79178            },
79179            "region": {
79180              "description": "Name of the region for this request.",
79181              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
79182              "location": "path",
79183              "required": true,
79184              "type": "string"
79185            },
79186            "requestId": {
79187              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
79188              "location": "query",
79189              "type": "string"
79190            },
79191            "targetVpnGateway": {
79192              "description": "Name of the target VPN gateway to delete.",
79193              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
79194              "location": "path",
79195              "required": true,
79196              "type": "string"
79197            }
79198          },
79199          "parameterOrder": [
79200            "project",
79201            "region",
79202            "targetVpnGateway"
79203          ],
79204          "response": {
79205            "$ref": "Operation"
79206          },
79207          "scopes": [
79208            "https://www.googleapis.com/auth/cloud-platform",
79209            "https://www.googleapis.com/auth/compute"
79210          ],
79211          "description": "Deletes the specified target VPN gateway."
79212        },
79213        "setLabels": {
79214          "id": "compute.targetVpnGateways.setLabels",
79215          "path": "projects/{project}/regions/{region}/targetVpnGateways/{resource}/setLabels",
79216          "flatPath": "projects/{project}/regions/{region}/targetVpnGateways/{resource}/setLabels",
79217          "httpMethod": "POST",
79218          "parameters": {
79219            "project": {
79220              "description": "Project ID for this request.",
79221              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79222              "location": "path",
79223              "required": true,
79224              "type": "string"
79225            },
79226            "region": {
79227              "description": "The region for this request.",
79228              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
79229              "location": "path",
79230              "required": true,
79231              "type": "string"
79232            },
79233            "requestId": {
79234              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
79235              "location": "query",
79236              "type": "string"
79237            },
79238            "resource": {
79239              "description": "Name or id of the resource for this request.",
79240              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
79241              "location": "path",
79242              "required": true,
79243              "type": "string"
79244            }
79245          },
79246          "parameterOrder": [
79247            "project",
79248            "region",
79249            "resource"
79250          ],
79251          "request": {
79252            "$ref": "RegionSetLabelsRequest"
79253          },
79254          "response": {
79255            "$ref": "Operation"
79256          },
79257          "scopes": [
79258            "https://www.googleapis.com/auth/cloud-platform",
79259            "https://www.googleapis.com/auth/compute"
79260          ],
79261          "description": "Sets the labels on a TargetVpnGateway. To learn more about labels, read the Labeling Resources documentation."
79262        }
79263      }
79264    },
79265    "urlMaps": {
79266      "methods": {
79267        "list": {
79268          "id": "compute.urlMaps.list",
79269          "path": "projects/{project}/global/urlMaps",
79270          "flatPath": "projects/{project}/global/urlMaps",
79271          "httpMethod": "GET",
79272          "parameters": {
79273            "filter": {
79274              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
79275              "location": "query",
79276              "type": "string"
79277            },
79278            "maxResults": {
79279              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
79280              "default": "500",
79281              "minimum": "0",
79282              "location": "query",
79283              "type": "integer",
79284              "format": "uint32"
79285            },
79286            "orderBy": {
79287              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
79288              "location": "query",
79289              "type": "string"
79290            },
79291            "pageToken": {
79292              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
79293              "location": "query",
79294              "type": "string"
79295            },
79296            "project": {
79297              "description": "Project ID for this request.",
79298              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79299              "location": "path",
79300              "required": true,
79301              "type": "string"
79302            },
79303            "returnPartialSuccess": {
79304              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
79305              "location": "query",
79306              "type": "boolean"
79307            }
79308          },
79309          "parameterOrder": [
79310            "project"
79311          ],
79312          "response": {
79313            "$ref": "UrlMapList"
79314          },
79315          "scopes": [
79316            "https://www.googleapis.com/auth/cloud-platform",
79317            "https://www.googleapis.com/auth/compute",
79318            "https://www.googleapis.com/auth/compute.readonly"
79319          ],
79320          "description": "Retrieves the list of UrlMap resources available to the specified project."
79321        },
79322        "aggregatedList": {
79323          "id": "compute.urlMaps.aggregatedList",
79324          "path": "projects/{project}/aggregated/urlMaps",
79325          "flatPath": "projects/{project}/aggregated/urlMaps",
79326          "httpMethod": "GET",
79327          "parameters": {
79328            "filter": {
79329              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
79330              "location": "query",
79331              "type": "string"
79332            },
79333            "includeAllScopes": {
79334              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
79335              "location": "query",
79336              "type": "boolean"
79337            },
79338            "maxResults": {
79339              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
79340              "default": "500",
79341              "minimum": "0",
79342              "location": "query",
79343              "type": "integer",
79344              "format": "uint32"
79345            },
79346            "orderBy": {
79347              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
79348              "location": "query",
79349              "type": "string"
79350            },
79351            "pageToken": {
79352              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
79353              "location": "query",
79354              "type": "string"
79355            },
79356            "project": {
79357              "description": "Name of the project scoping this request.",
79358              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79359              "location": "path",
79360              "required": true,
79361              "type": "string"
79362            },
79363            "returnPartialSuccess": {
79364              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
79365              "location": "query",
79366              "type": "boolean"
79367            },
79368            "serviceProjectNumber": {
79369              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
79370              "location": "query",
79371              "type": "string",
79372              "format": "int64"
79373            }
79374          },
79375          "parameterOrder": [
79376            "project"
79377          ],
79378          "response": {
79379            "$ref": "UrlMapsAggregatedList"
79380          },
79381          "scopes": [
79382            "https://www.googleapis.com/auth/cloud-platform",
79383            "https://www.googleapis.com/auth/compute",
79384            "https://www.googleapis.com/auth/compute.readonly"
79385          ],
79386          "description": "Retrieves the list of all UrlMap resources, regional and global, available to the specified project. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
79387        },
79388        "get": {
79389          "id": "compute.urlMaps.get",
79390          "path": "projects/{project}/global/urlMaps/{urlMap}",
79391          "flatPath": "projects/{project}/global/urlMaps/{urlMap}",
79392          "httpMethod": "GET",
79393          "parameters": {
79394            "project": {
79395              "description": "Project ID for this request.",
79396              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79397              "location": "path",
79398              "required": true,
79399              "type": "string"
79400            },
79401            "urlMap": {
79402              "description": "Name of the UrlMap resource to return.",
79403              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
79404              "location": "path",
79405              "required": true,
79406              "type": "string"
79407            }
79408          },
79409          "parameterOrder": [
79410            "project",
79411            "urlMap"
79412          ],
79413          "response": {
79414            "$ref": "UrlMap"
79415          },
79416          "scopes": [
79417            "https://www.googleapis.com/auth/cloud-platform",
79418            "https://www.googleapis.com/auth/compute",
79419            "https://www.googleapis.com/auth/compute.readonly"
79420          ],
79421          "description": "Returns the specified UrlMap resource."
79422        },
79423        "insert": {
79424          "id": "compute.urlMaps.insert",
79425          "path": "projects/{project}/global/urlMaps",
79426          "flatPath": "projects/{project}/global/urlMaps",
79427          "httpMethod": "POST",
79428          "parameters": {
79429            "project": {
79430              "description": "Project ID for this request.",
79431              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79432              "location": "path",
79433              "required": true,
79434              "type": "string"
79435            },
79436            "requestId": {
79437              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
79438              "location": "query",
79439              "type": "string"
79440            }
79441          },
79442          "parameterOrder": [
79443            "project"
79444          ],
79445          "request": {
79446            "$ref": "UrlMap"
79447          },
79448          "response": {
79449            "$ref": "Operation"
79450          },
79451          "scopes": [
79452            "https://www.googleapis.com/auth/cloud-platform",
79453            "https://www.googleapis.com/auth/compute"
79454          ],
79455          "description": "Creates a UrlMap resource in the specified project using the data included in the request."
79456        },
79457        "delete": {
79458          "id": "compute.urlMaps.delete",
79459          "path": "projects/{project}/global/urlMaps/{urlMap}",
79460          "flatPath": "projects/{project}/global/urlMaps/{urlMap}",
79461          "httpMethod": "DELETE",
79462          "parameters": {
79463            "project": {
79464              "description": "Project ID for this request.",
79465              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79466              "location": "path",
79467              "required": true,
79468              "type": "string"
79469            },
79470            "requestId": {
79471              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
79472              "location": "query",
79473              "type": "string"
79474            },
79475            "urlMap": {
79476              "description": "Name of the UrlMap resource to delete.",
79477              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
79478              "location": "path",
79479              "required": true,
79480              "type": "string"
79481            }
79482          },
79483          "parameterOrder": [
79484            "project",
79485            "urlMap"
79486          ],
79487          "response": {
79488            "$ref": "Operation"
79489          },
79490          "scopes": [
79491            "https://www.googleapis.com/auth/cloud-platform",
79492            "https://www.googleapis.com/auth/compute"
79493          ],
79494          "description": "Deletes the specified UrlMap resource."
79495        },
79496        "update": {
79497          "id": "compute.urlMaps.update",
79498          "path": "projects/{project}/global/urlMaps/{urlMap}",
79499          "flatPath": "projects/{project}/global/urlMaps/{urlMap}",
79500          "httpMethod": "PUT",
79501          "parameters": {
79502            "project": {
79503              "description": "Project ID for this request.",
79504              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79505              "location": "path",
79506              "required": true,
79507              "type": "string"
79508            },
79509            "requestId": {
79510              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
79511              "location": "query",
79512              "type": "string"
79513            },
79514            "urlMap": {
79515              "description": "Name of the UrlMap resource to update.",
79516              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
79517              "location": "path",
79518              "required": true,
79519              "type": "string"
79520            }
79521          },
79522          "parameterOrder": [
79523            "project",
79524            "urlMap"
79525          ],
79526          "request": {
79527            "$ref": "UrlMap"
79528          },
79529          "response": {
79530            "$ref": "Operation"
79531          },
79532          "scopes": [
79533            "https://www.googleapis.com/auth/cloud-platform",
79534            "https://www.googleapis.com/auth/compute"
79535          ],
79536          "description": "Updates the specified UrlMap resource with the data included in the request."
79537        },
79538        "patch": {
79539          "id": "compute.urlMaps.patch",
79540          "path": "projects/{project}/global/urlMaps/{urlMap}",
79541          "flatPath": "projects/{project}/global/urlMaps/{urlMap}",
79542          "httpMethod": "PATCH",
79543          "parameters": {
79544            "project": {
79545              "description": "Project ID for this request.",
79546              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79547              "location": "path",
79548              "required": true,
79549              "type": "string"
79550            },
79551            "requestId": {
79552              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
79553              "location": "query",
79554              "type": "string"
79555            },
79556            "urlMap": {
79557              "description": "Name of the UrlMap resource to patch.",
79558              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
79559              "location": "path",
79560              "required": true,
79561              "type": "string"
79562            }
79563          },
79564          "parameterOrder": [
79565            "project",
79566            "urlMap"
79567          ],
79568          "request": {
79569            "$ref": "UrlMap"
79570          },
79571          "response": {
79572            "$ref": "Operation"
79573          },
79574          "scopes": [
79575            "https://www.googleapis.com/auth/cloud-platform",
79576            "https://www.googleapis.com/auth/compute"
79577          ],
79578          "description": "Patches the specified UrlMap resource with the data included in the request. This method supports PATCH semantics and uses the JSON merge patch format and processing rules."
79579        },
79580        "validate": {
79581          "id": "compute.urlMaps.validate",
79582          "path": "projects/{project}/global/urlMaps/{urlMap}/validate",
79583          "flatPath": "projects/{project}/global/urlMaps/{urlMap}/validate",
79584          "httpMethod": "POST",
79585          "parameters": {
79586            "project": {
79587              "description": "Project ID for this request.",
79588              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79589              "location": "path",
79590              "required": true,
79591              "type": "string"
79592            },
79593            "urlMap": {
79594              "description": "Name of the UrlMap resource to be validated as.",
79595              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
79596              "location": "path",
79597              "required": true,
79598              "type": "string"
79599            }
79600          },
79601          "parameterOrder": [
79602            "project",
79603            "urlMap"
79604          ],
79605          "request": {
79606            "$ref": "UrlMapsValidateRequest"
79607          },
79608          "response": {
79609            "$ref": "UrlMapsValidateResponse"
79610          },
79611          "scopes": [
79612            "https://www.googleapis.com/auth/cloud-platform",
79613            "https://www.googleapis.com/auth/compute"
79614          ],
79615          "description": "Runs static validation for the UrlMap. In particular, the tests of the provided UrlMap will be run. Calling this method does NOT create the UrlMap."
79616        },
79617        "invalidateCache": {
79618          "id": "compute.urlMaps.invalidateCache",
79619          "path": "projects/{project}/global/urlMaps/{urlMap}/invalidateCache",
79620          "flatPath": "projects/{project}/global/urlMaps/{urlMap}/invalidateCache",
79621          "httpMethod": "POST",
79622          "parameters": {
79623            "project": {
79624              "description": "Project ID for this request.",
79625              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79626              "location": "path",
79627              "required": true,
79628              "type": "string"
79629            },
79630            "requestId": {
79631              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
79632              "location": "query",
79633              "type": "string"
79634            },
79635            "urlMap": {
79636              "description": "Name of the UrlMap scoping this request.",
79637              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
79638              "location": "path",
79639              "required": true,
79640              "type": "string"
79641            }
79642          },
79643          "parameterOrder": [
79644            "project",
79645            "urlMap"
79646          ],
79647          "request": {
79648            "$ref": "CacheInvalidationRule"
79649          },
79650          "response": {
79651            "$ref": "Operation"
79652          },
79653          "scopes": [
79654            "https://www.googleapis.com/auth/cloud-platform",
79655            "https://www.googleapis.com/auth/compute"
79656          ],
79657          "description": "Initiates a cache invalidation operation, invalidating the specified path, scoped to the specified UrlMap. For more information, see [Invalidating cached content](/cdn/docs/invalidating-cached-content)."
79658        }
79659      }
79660    },
79661    "regionUrlMaps": {
79662      "methods": {
79663        "list": {
79664          "id": "compute.regionUrlMaps.list",
79665          "path": "projects/{project}/regions/{region}/urlMaps",
79666          "flatPath": "projects/{project}/regions/{region}/urlMaps",
79667          "httpMethod": "GET",
79668          "parameters": {
79669            "filter": {
79670              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
79671              "location": "query",
79672              "type": "string"
79673            },
79674            "maxResults": {
79675              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
79676              "default": "500",
79677              "minimum": "0",
79678              "location": "query",
79679              "type": "integer",
79680              "format": "uint32"
79681            },
79682            "orderBy": {
79683              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
79684              "location": "query",
79685              "type": "string"
79686            },
79687            "pageToken": {
79688              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
79689              "location": "query",
79690              "type": "string"
79691            },
79692            "project": {
79693              "description": "Project ID for this request.",
79694              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79695              "location": "path",
79696              "required": true,
79697              "type": "string"
79698            },
79699            "region": {
79700              "description": "Name of the region scoping this request.",
79701              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
79702              "location": "path",
79703              "required": true,
79704              "type": "string"
79705            },
79706            "returnPartialSuccess": {
79707              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
79708              "location": "query",
79709              "type": "boolean"
79710            }
79711          },
79712          "parameterOrder": [
79713            "project",
79714            "region"
79715          ],
79716          "response": {
79717            "$ref": "UrlMapList"
79718          },
79719          "scopes": [
79720            "https://www.googleapis.com/auth/cloud-platform",
79721            "https://www.googleapis.com/auth/compute",
79722            "https://www.googleapis.com/auth/compute.readonly"
79723          ],
79724          "description": "Retrieves the list of UrlMap resources available to the specified project in the specified region."
79725        },
79726        "get": {
79727          "id": "compute.regionUrlMaps.get",
79728          "path": "projects/{project}/regions/{region}/urlMaps/{urlMap}",
79729          "flatPath": "projects/{project}/regions/{region}/urlMaps/{urlMap}",
79730          "httpMethod": "GET",
79731          "parameters": {
79732            "project": {
79733              "description": "Project ID for this request.",
79734              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79735              "location": "path",
79736              "required": true,
79737              "type": "string"
79738            },
79739            "region": {
79740              "description": "Name of the region scoping this request.",
79741              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
79742              "location": "path",
79743              "required": true,
79744              "type": "string"
79745            },
79746            "urlMap": {
79747              "description": "Name of the UrlMap resource to return.",
79748              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
79749              "location": "path",
79750              "required": true,
79751              "type": "string"
79752            }
79753          },
79754          "parameterOrder": [
79755            "project",
79756            "region",
79757            "urlMap"
79758          ],
79759          "response": {
79760            "$ref": "UrlMap"
79761          },
79762          "scopes": [
79763            "https://www.googleapis.com/auth/cloud-platform",
79764            "https://www.googleapis.com/auth/compute",
79765            "https://www.googleapis.com/auth/compute.readonly"
79766          ],
79767          "description": "Returns the specified UrlMap resource."
79768        },
79769        "insert": {
79770          "id": "compute.regionUrlMaps.insert",
79771          "path": "projects/{project}/regions/{region}/urlMaps",
79772          "flatPath": "projects/{project}/regions/{region}/urlMaps",
79773          "httpMethod": "POST",
79774          "parameters": {
79775            "project": {
79776              "description": "Project ID for this request.",
79777              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79778              "location": "path",
79779              "required": true,
79780              "type": "string"
79781            },
79782            "region": {
79783              "description": "Name of the region scoping this request.",
79784              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
79785              "location": "path",
79786              "required": true,
79787              "type": "string"
79788            },
79789            "requestId": {
79790              "description": "begin_interface: MixerMutationRequestBuilder Request ID to support idempotency.",
79791              "location": "query",
79792              "type": "string"
79793            }
79794          },
79795          "parameterOrder": [
79796            "project",
79797            "region"
79798          ],
79799          "request": {
79800            "$ref": "UrlMap"
79801          },
79802          "response": {
79803            "$ref": "Operation"
79804          },
79805          "scopes": [
79806            "https://www.googleapis.com/auth/cloud-platform",
79807            "https://www.googleapis.com/auth/compute"
79808          ],
79809          "description": "Creates a UrlMap resource in the specified project using the data included in the request."
79810        },
79811        "delete": {
79812          "id": "compute.regionUrlMaps.delete",
79813          "path": "projects/{project}/regions/{region}/urlMaps/{urlMap}",
79814          "flatPath": "projects/{project}/regions/{region}/urlMaps/{urlMap}",
79815          "httpMethod": "DELETE",
79816          "parameters": {
79817            "project": {
79818              "description": "Project ID for this request.",
79819              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79820              "location": "path",
79821              "required": true,
79822              "type": "string"
79823            },
79824            "region": {
79825              "description": "Name of the region scoping this request.",
79826              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
79827              "location": "path",
79828              "required": true,
79829              "type": "string"
79830            },
79831            "requestId": {
79832              "description": "begin_interface: MixerMutationRequestBuilder Request ID to support idempotency.",
79833              "location": "query",
79834              "type": "string"
79835            },
79836            "urlMap": {
79837              "description": "Name of the UrlMap resource to delete.",
79838              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
79839              "location": "path",
79840              "required": true,
79841              "type": "string"
79842            }
79843          },
79844          "parameterOrder": [
79845            "project",
79846            "region",
79847            "urlMap"
79848          ],
79849          "response": {
79850            "$ref": "Operation"
79851          },
79852          "scopes": [
79853            "https://www.googleapis.com/auth/cloud-platform",
79854            "https://www.googleapis.com/auth/compute"
79855          ],
79856          "description": "Deletes the specified UrlMap resource."
79857        },
79858        "update": {
79859          "id": "compute.regionUrlMaps.update",
79860          "path": "projects/{project}/regions/{region}/urlMaps/{urlMap}",
79861          "flatPath": "projects/{project}/regions/{region}/urlMaps/{urlMap}",
79862          "httpMethod": "PUT",
79863          "parameters": {
79864            "project": {
79865              "description": "Project ID for this request.",
79866              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79867              "location": "path",
79868              "required": true,
79869              "type": "string"
79870            },
79871            "region": {
79872              "description": "Name of the region scoping this request.",
79873              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
79874              "location": "path",
79875              "required": true,
79876              "type": "string"
79877            },
79878            "requestId": {
79879              "description": "begin_interface: MixerMutationRequestBuilder Request ID to support idempotency.",
79880              "location": "query",
79881              "type": "string"
79882            },
79883            "urlMap": {
79884              "description": "Name of the UrlMap resource to update.",
79885              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
79886              "location": "path",
79887              "required": true,
79888              "type": "string"
79889            }
79890          },
79891          "parameterOrder": [
79892            "project",
79893            "region",
79894            "urlMap"
79895          ],
79896          "request": {
79897            "$ref": "UrlMap"
79898          },
79899          "response": {
79900            "$ref": "Operation"
79901          },
79902          "scopes": [
79903            "https://www.googleapis.com/auth/cloud-platform",
79904            "https://www.googleapis.com/auth/compute"
79905          ],
79906          "description": "Updates the specified UrlMap resource with the data included in the request."
79907        },
79908        "patch": {
79909          "id": "compute.regionUrlMaps.patch",
79910          "path": "projects/{project}/regions/{region}/urlMaps/{urlMap}",
79911          "flatPath": "projects/{project}/regions/{region}/urlMaps/{urlMap}",
79912          "httpMethod": "PATCH",
79913          "parameters": {
79914            "project": {
79915              "description": "Project ID for this request.",
79916              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79917              "location": "path",
79918              "required": true,
79919              "type": "string"
79920            },
79921            "region": {
79922              "description": "Name of the region scoping this request.",
79923              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
79924              "location": "path",
79925              "required": true,
79926              "type": "string"
79927            },
79928            "requestId": {
79929              "description": "begin_interface: MixerMutationRequestBuilder Request ID to support idempotency.",
79930              "location": "query",
79931              "type": "string"
79932            },
79933            "urlMap": {
79934              "description": "Name of the UrlMap resource to patch.",
79935              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
79936              "location": "path",
79937              "required": true,
79938              "type": "string"
79939            }
79940          },
79941          "parameterOrder": [
79942            "project",
79943            "region",
79944            "urlMap"
79945          ],
79946          "request": {
79947            "$ref": "UrlMap"
79948          },
79949          "response": {
79950            "$ref": "Operation"
79951          },
79952          "scopes": [
79953            "https://www.googleapis.com/auth/cloud-platform",
79954            "https://www.googleapis.com/auth/compute"
79955          ],
79956          "description": "Patches the specified UrlMap resource with the data included in the request. This method supports PATCH semantics and uses JSON merge patch format and processing rules."
79957        },
79958        "validate": {
79959          "id": "compute.regionUrlMaps.validate",
79960          "path": "projects/{project}/regions/{region}/urlMaps/{urlMap}/validate",
79961          "flatPath": "projects/{project}/regions/{region}/urlMaps/{urlMap}/validate",
79962          "httpMethod": "POST",
79963          "parameters": {
79964            "project": {
79965              "description": "Project ID for this request.",
79966              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
79967              "location": "path",
79968              "required": true,
79969              "type": "string"
79970            },
79971            "region": {
79972              "description": "Name of the region scoping this request.",
79973              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
79974              "location": "path",
79975              "required": true,
79976              "type": "string"
79977            },
79978            "urlMap": {
79979              "description": "Name of the UrlMap resource to be validated as.",
79980              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
79981              "location": "path",
79982              "required": true,
79983              "type": "string"
79984            }
79985          },
79986          "parameterOrder": [
79987            "project",
79988            "region",
79989            "urlMap"
79990          ],
79991          "request": {
79992            "$ref": "RegionUrlMapsValidateRequest"
79993          },
79994          "response": {
79995            "$ref": "UrlMapsValidateResponse"
79996          },
79997          "scopes": [
79998            "https://www.googleapis.com/auth/cloud-platform",
79999            "https://www.googleapis.com/auth/compute"
80000          ],
80001          "description": "Runs static validation for the UrlMap. In particular, the tests of the provided UrlMap will be run. Calling this method does NOT create the UrlMap."
80002        }
80003      }
80004    },
80005    "vpnGateways": {
80006      "methods": {
80007        "list": {
80008          "id": "compute.vpnGateways.list",
80009          "path": "projects/{project}/regions/{region}/vpnGateways",
80010          "flatPath": "projects/{project}/regions/{region}/vpnGateways",
80011          "httpMethod": "GET",
80012          "parameters": {
80013            "filter": {
80014              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
80015              "location": "query",
80016              "type": "string"
80017            },
80018            "maxResults": {
80019              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
80020              "default": "500",
80021              "minimum": "0",
80022              "location": "query",
80023              "type": "integer",
80024              "format": "uint32"
80025            },
80026            "orderBy": {
80027              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
80028              "location": "query",
80029              "type": "string"
80030            },
80031            "pageToken": {
80032              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
80033              "location": "query",
80034              "type": "string"
80035            },
80036            "project": {
80037              "description": "Project ID for this request.",
80038              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80039              "location": "path",
80040              "required": true,
80041              "type": "string"
80042            },
80043            "region": {
80044              "description": "Name of the region for this request.",
80045              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
80046              "location": "path",
80047              "required": true,
80048              "type": "string"
80049            },
80050            "returnPartialSuccess": {
80051              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
80052              "location": "query",
80053              "type": "boolean"
80054            }
80055          },
80056          "parameterOrder": [
80057            "project",
80058            "region"
80059          ],
80060          "response": {
80061            "$ref": "VpnGatewayList"
80062          },
80063          "scopes": [
80064            "https://www.googleapis.com/auth/cloud-platform",
80065            "https://www.googleapis.com/auth/compute",
80066            "https://www.googleapis.com/auth/compute.readonly"
80067          ],
80068          "description": "Retrieves a list of VPN gateways available to the specified project and region."
80069        },
80070        "aggregatedList": {
80071          "id": "compute.vpnGateways.aggregatedList",
80072          "path": "projects/{project}/aggregated/vpnGateways",
80073          "flatPath": "projects/{project}/aggregated/vpnGateways",
80074          "httpMethod": "GET",
80075          "parameters": {
80076            "filter": {
80077              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
80078              "location": "query",
80079              "type": "string"
80080            },
80081            "includeAllScopes": {
80082              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
80083              "location": "query",
80084              "type": "boolean"
80085            },
80086            "maxResults": {
80087              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
80088              "default": "500",
80089              "minimum": "0",
80090              "location": "query",
80091              "type": "integer",
80092              "format": "uint32"
80093            },
80094            "orderBy": {
80095              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
80096              "location": "query",
80097              "type": "string"
80098            },
80099            "pageToken": {
80100              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
80101              "location": "query",
80102              "type": "string"
80103            },
80104            "project": {
80105              "description": "Project ID for this request.",
80106              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80107              "location": "path",
80108              "required": true,
80109              "type": "string"
80110            },
80111            "returnPartialSuccess": {
80112              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
80113              "location": "query",
80114              "type": "boolean"
80115            },
80116            "serviceProjectNumber": {
80117              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
80118              "location": "query",
80119              "type": "string",
80120              "format": "int64"
80121            }
80122          },
80123          "parameterOrder": [
80124            "project"
80125          ],
80126          "response": {
80127            "$ref": "VpnGatewayAggregatedList"
80128          },
80129          "scopes": [
80130            "https://www.googleapis.com/auth/cloud-platform",
80131            "https://www.googleapis.com/auth/compute",
80132            "https://www.googleapis.com/auth/compute.readonly"
80133          ],
80134          "description": "Retrieves an aggregated list of VPN gateways. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
80135        },
80136        "get": {
80137          "id": "compute.vpnGateways.get",
80138          "path": "projects/{project}/regions/{region}/vpnGateways/{vpnGateway}",
80139          "flatPath": "projects/{project}/regions/{region}/vpnGateways/{vpnGateway}",
80140          "httpMethod": "GET",
80141          "parameters": {
80142            "project": {
80143              "description": "Project ID for this request.",
80144              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80145              "location": "path",
80146              "required": true,
80147              "type": "string"
80148            },
80149            "region": {
80150              "description": "Name of the region for this request.",
80151              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
80152              "location": "path",
80153              "required": true,
80154              "type": "string"
80155            },
80156            "vpnGateway": {
80157              "description": "Name of the VPN gateway to return.",
80158              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
80159              "location": "path",
80160              "required": true,
80161              "type": "string"
80162            }
80163          },
80164          "parameterOrder": [
80165            "project",
80166            "region",
80167            "vpnGateway"
80168          ],
80169          "response": {
80170            "$ref": "VpnGateway"
80171          },
80172          "scopes": [
80173            "https://www.googleapis.com/auth/cloud-platform",
80174            "https://www.googleapis.com/auth/compute",
80175            "https://www.googleapis.com/auth/compute.readonly"
80176          ],
80177          "description": "Returns the specified VPN gateway."
80178        },
80179        "getStatus": {
80180          "id": "compute.vpnGateways.getStatus",
80181          "path": "projects/{project}/regions/{region}/vpnGateways/{vpnGateway}/getStatus",
80182          "flatPath": "projects/{project}/regions/{region}/vpnGateways/{vpnGateway}/getStatus",
80183          "httpMethod": "GET",
80184          "parameters": {
80185            "project": {
80186              "description": "Project ID for this request.",
80187              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80188              "location": "path",
80189              "required": true,
80190              "type": "string"
80191            },
80192            "region": {
80193              "description": "Name of the region for this request.",
80194              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
80195              "location": "path",
80196              "required": true,
80197              "type": "string"
80198            },
80199            "vpnGateway": {
80200              "description": "Name of the VPN gateway to return.",
80201              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
80202              "location": "path",
80203              "required": true,
80204              "type": "string"
80205            }
80206          },
80207          "parameterOrder": [
80208            "project",
80209            "region",
80210            "vpnGateway"
80211          ],
80212          "response": {
80213            "$ref": "VpnGatewaysGetStatusResponse"
80214          },
80215          "scopes": [
80216            "https://www.googleapis.com/auth/cloud-platform",
80217            "https://www.googleapis.com/auth/compute",
80218            "https://www.googleapis.com/auth/compute.readonly"
80219          ],
80220          "description": "Returns the status for the specified VPN gateway."
80221        },
80222        "insert": {
80223          "id": "compute.vpnGateways.insert",
80224          "path": "projects/{project}/regions/{region}/vpnGateways",
80225          "flatPath": "projects/{project}/regions/{region}/vpnGateways",
80226          "httpMethod": "POST",
80227          "parameters": {
80228            "project": {
80229              "description": "Project ID for this request.",
80230              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80231              "location": "path",
80232              "required": true,
80233              "type": "string"
80234            },
80235            "region": {
80236              "description": "Name of the region for this request.",
80237              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
80238              "location": "path",
80239              "required": true,
80240              "type": "string"
80241            },
80242            "requestId": {
80243              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
80244              "location": "query",
80245              "type": "string"
80246            }
80247          },
80248          "parameterOrder": [
80249            "project",
80250            "region"
80251          ],
80252          "request": {
80253            "$ref": "VpnGateway"
80254          },
80255          "response": {
80256            "$ref": "Operation"
80257          },
80258          "scopes": [
80259            "https://www.googleapis.com/auth/cloud-platform",
80260            "https://www.googleapis.com/auth/compute"
80261          ],
80262          "description": "Creates a VPN gateway in the specified project and region using the data included in the request."
80263        },
80264        "delete": {
80265          "id": "compute.vpnGateways.delete",
80266          "path": "projects/{project}/regions/{region}/vpnGateways/{vpnGateway}",
80267          "flatPath": "projects/{project}/regions/{region}/vpnGateways/{vpnGateway}",
80268          "httpMethod": "DELETE",
80269          "parameters": {
80270            "project": {
80271              "description": "Project ID for this request.",
80272              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80273              "location": "path",
80274              "required": true,
80275              "type": "string"
80276            },
80277            "region": {
80278              "description": "Name of the region for this request.",
80279              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
80280              "location": "path",
80281              "required": true,
80282              "type": "string"
80283            },
80284            "requestId": {
80285              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
80286              "location": "query",
80287              "type": "string"
80288            },
80289            "vpnGateway": {
80290              "description": "Name of the VPN gateway to delete.",
80291              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
80292              "location": "path",
80293              "required": true,
80294              "type": "string"
80295            }
80296          },
80297          "parameterOrder": [
80298            "project",
80299            "region",
80300            "vpnGateway"
80301          ],
80302          "response": {
80303            "$ref": "Operation"
80304          },
80305          "scopes": [
80306            "https://www.googleapis.com/auth/cloud-platform",
80307            "https://www.googleapis.com/auth/compute"
80308          ],
80309          "description": "Deletes the specified VPN gateway."
80310        },
80311        "testIamPermissions": {
80312          "id": "compute.vpnGateways.testIamPermissions",
80313          "path": "projects/{project}/regions/{region}/vpnGateways/{resource}/testIamPermissions",
80314          "flatPath": "projects/{project}/regions/{region}/vpnGateways/{resource}/testIamPermissions",
80315          "httpMethod": "POST",
80316          "parameters": {
80317            "project": {
80318              "description": "Project ID for this request.",
80319              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80320              "location": "path",
80321              "required": true,
80322              "type": "string"
80323            },
80324            "region": {
80325              "description": "The name of the region for this request.",
80326              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
80327              "location": "path",
80328              "required": true,
80329              "type": "string"
80330            },
80331            "resource": {
80332              "description": "Name or id of the resource for this request.",
80333              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
80334              "location": "path",
80335              "required": true,
80336              "type": "string"
80337            }
80338          },
80339          "parameterOrder": [
80340            "project",
80341            "region",
80342            "resource"
80343          ],
80344          "request": {
80345            "$ref": "TestPermissionsRequest"
80346          },
80347          "response": {
80348            "$ref": "TestPermissionsResponse"
80349          },
80350          "scopes": [
80351            "https://www.googleapis.com/auth/cloud-platform",
80352            "https://www.googleapis.com/auth/compute",
80353            "https://www.googleapis.com/auth/compute.readonly"
80354          ],
80355          "description": "Returns permissions that a caller has on the specified resource."
80356        },
80357        "setLabels": {
80358          "id": "compute.vpnGateways.setLabels",
80359          "path": "projects/{project}/regions/{region}/vpnGateways/{resource}/setLabels",
80360          "flatPath": "projects/{project}/regions/{region}/vpnGateways/{resource}/setLabels",
80361          "httpMethod": "POST",
80362          "parameters": {
80363            "project": {
80364              "description": "Project ID for this request.",
80365              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80366              "location": "path",
80367              "required": true,
80368              "type": "string"
80369            },
80370            "region": {
80371              "description": "The region for this request.",
80372              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
80373              "location": "path",
80374              "required": true,
80375              "type": "string"
80376            },
80377            "requestId": {
80378              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
80379              "location": "query",
80380              "type": "string"
80381            },
80382            "resource": {
80383              "description": "Name or id of the resource for this request.",
80384              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
80385              "location": "path",
80386              "required": true,
80387              "type": "string"
80388            }
80389          },
80390          "parameterOrder": [
80391            "project",
80392            "region",
80393            "resource"
80394          ],
80395          "request": {
80396            "$ref": "RegionSetLabelsRequest"
80397          },
80398          "response": {
80399            "$ref": "Operation"
80400          },
80401          "scopes": [
80402            "https://www.googleapis.com/auth/cloud-platform",
80403            "https://www.googleapis.com/auth/compute"
80404          ],
80405          "description": "Sets the labels on a VpnGateway. To learn more about labels, read the Labeling Resources documentation."
80406        }
80407      }
80408    },
80409    "vpnTunnels": {
80410      "methods": {
80411        "list": {
80412          "id": "compute.vpnTunnels.list",
80413          "path": "projects/{project}/regions/{region}/vpnTunnels",
80414          "flatPath": "projects/{project}/regions/{region}/vpnTunnels",
80415          "httpMethod": "GET",
80416          "parameters": {
80417            "filter": {
80418              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
80419              "location": "query",
80420              "type": "string"
80421            },
80422            "maxResults": {
80423              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
80424              "default": "500",
80425              "minimum": "0",
80426              "location": "query",
80427              "type": "integer",
80428              "format": "uint32"
80429            },
80430            "orderBy": {
80431              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
80432              "location": "query",
80433              "type": "string"
80434            },
80435            "pageToken": {
80436              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
80437              "location": "query",
80438              "type": "string"
80439            },
80440            "project": {
80441              "description": "Project ID for this request.",
80442              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80443              "location": "path",
80444              "required": true,
80445              "type": "string"
80446            },
80447            "region": {
80448              "description": "Name of the region for this request.",
80449              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
80450              "location": "path",
80451              "required": true,
80452              "type": "string"
80453            },
80454            "returnPartialSuccess": {
80455              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
80456              "location": "query",
80457              "type": "boolean"
80458            }
80459          },
80460          "parameterOrder": [
80461            "project",
80462            "region"
80463          ],
80464          "response": {
80465            "$ref": "VpnTunnelList"
80466          },
80467          "scopes": [
80468            "https://www.googleapis.com/auth/cloud-platform",
80469            "https://www.googleapis.com/auth/compute",
80470            "https://www.googleapis.com/auth/compute.readonly"
80471          ],
80472          "description": "Retrieves a list of VpnTunnel resources contained in the specified project and region."
80473        },
80474        "aggregatedList": {
80475          "id": "compute.vpnTunnels.aggregatedList",
80476          "path": "projects/{project}/aggregated/vpnTunnels",
80477          "flatPath": "projects/{project}/aggregated/vpnTunnels",
80478          "httpMethod": "GET",
80479          "parameters": {
80480            "filter": {
80481              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
80482              "location": "query",
80483              "type": "string"
80484            },
80485            "includeAllScopes": {
80486              "description": "Indicates whether every visible scope for each scope type (zone, region, global) should be included in the response. For new resource types added after this field, the flag has no effect as new resource types will always include every visible scope for each scope type in response. For resource types which predate this field, if this flag is omitted or false, only scopes of the scope types where the resource type is expected to be found will be included.",
80487              "location": "query",
80488              "type": "boolean"
80489            },
80490            "maxResults": {
80491              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
80492              "default": "500",
80493              "minimum": "0",
80494              "location": "query",
80495              "type": "integer",
80496              "format": "uint32"
80497            },
80498            "orderBy": {
80499              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
80500              "location": "query",
80501              "type": "string"
80502            },
80503            "pageToken": {
80504              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
80505              "location": "query",
80506              "type": "string"
80507            },
80508            "project": {
80509              "description": "Project ID for this request.",
80510              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80511              "location": "path",
80512              "required": true,
80513              "type": "string"
80514            },
80515            "returnPartialSuccess": {
80516              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
80517              "location": "query",
80518              "type": "boolean"
80519            },
80520            "serviceProjectNumber": {
80521              "description": "The Shared VPC service project id or service project number for which aggregated list request is invoked for subnetworks list-usable api.",
80522              "location": "query",
80523              "type": "string",
80524              "format": "int64"
80525            }
80526          },
80527          "parameterOrder": [
80528            "project"
80529          ],
80530          "response": {
80531            "$ref": "VpnTunnelAggregatedList"
80532          },
80533          "scopes": [
80534            "https://www.googleapis.com/auth/cloud-platform",
80535            "https://www.googleapis.com/auth/compute",
80536            "https://www.googleapis.com/auth/compute.readonly"
80537          ],
80538          "description": "Retrieves an aggregated list of VPN tunnels. To prevent failure, Google recommends that you set the `returnPartialSuccess` parameter to `true`."
80539        },
80540        "get": {
80541          "id": "compute.vpnTunnels.get",
80542          "path": "projects/{project}/regions/{region}/vpnTunnels/{vpnTunnel}",
80543          "flatPath": "projects/{project}/regions/{region}/vpnTunnels/{vpnTunnel}",
80544          "httpMethod": "GET",
80545          "parameters": {
80546            "project": {
80547              "description": "Project ID for this request.",
80548              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80549              "location": "path",
80550              "required": true,
80551              "type": "string"
80552            },
80553            "region": {
80554              "description": "Name of the region for this request.",
80555              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
80556              "location": "path",
80557              "required": true,
80558              "type": "string"
80559            },
80560            "vpnTunnel": {
80561              "description": "Name of the VpnTunnel resource to return.",
80562              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
80563              "location": "path",
80564              "required": true,
80565              "type": "string"
80566            }
80567          },
80568          "parameterOrder": [
80569            "project",
80570            "region",
80571            "vpnTunnel"
80572          ],
80573          "response": {
80574            "$ref": "VpnTunnel"
80575          },
80576          "scopes": [
80577            "https://www.googleapis.com/auth/cloud-platform",
80578            "https://www.googleapis.com/auth/compute",
80579            "https://www.googleapis.com/auth/compute.readonly"
80580          ],
80581          "description": "Returns the specified VpnTunnel resource."
80582        },
80583        "insert": {
80584          "id": "compute.vpnTunnels.insert",
80585          "path": "projects/{project}/regions/{region}/vpnTunnels",
80586          "flatPath": "projects/{project}/regions/{region}/vpnTunnels",
80587          "httpMethod": "POST",
80588          "parameters": {
80589            "project": {
80590              "description": "Project ID for this request.",
80591              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80592              "location": "path",
80593              "required": true,
80594              "type": "string"
80595            },
80596            "region": {
80597              "description": "Name of the region for this request.",
80598              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
80599              "location": "path",
80600              "required": true,
80601              "type": "string"
80602            },
80603            "requestId": {
80604              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
80605              "location": "query",
80606              "type": "string"
80607            }
80608          },
80609          "parameterOrder": [
80610            "project",
80611            "region"
80612          ],
80613          "request": {
80614            "$ref": "VpnTunnel"
80615          },
80616          "response": {
80617            "$ref": "Operation"
80618          },
80619          "scopes": [
80620            "https://www.googleapis.com/auth/cloud-platform",
80621            "https://www.googleapis.com/auth/compute"
80622          ],
80623          "description": "Creates a VpnTunnel resource in the specified project and region using the data included in the request."
80624        },
80625        "delete": {
80626          "id": "compute.vpnTunnels.delete",
80627          "path": "projects/{project}/regions/{region}/vpnTunnels/{vpnTunnel}",
80628          "flatPath": "projects/{project}/regions/{region}/vpnTunnels/{vpnTunnel}",
80629          "httpMethod": "DELETE",
80630          "parameters": {
80631            "project": {
80632              "description": "Project ID for this request.",
80633              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80634              "location": "path",
80635              "required": true,
80636              "type": "string"
80637            },
80638            "region": {
80639              "description": "Name of the region for this request.",
80640              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
80641              "location": "path",
80642              "required": true,
80643              "type": "string"
80644            },
80645            "requestId": {
80646              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
80647              "location": "query",
80648              "type": "string"
80649            },
80650            "vpnTunnel": {
80651              "description": "Name of the VpnTunnel resource to delete.",
80652              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
80653              "location": "path",
80654              "required": true,
80655              "type": "string"
80656            }
80657          },
80658          "parameterOrder": [
80659            "project",
80660            "region",
80661            "vpnTunnel"
80662          ],
80663          "response": {
80664            "$ref": "Operation"
80665          },
80666          "scopes": [
80667            "https://www.googleapis.com/auth/cloud-platform",
80668            "https://www.googleapis.com/auth/compute"
80669          ],
80670          "description": "Deletes the specified VpnTunnel resource."
80671        },
80672        "setLabels": {
80673          "id": "compute.vpnTunnels.setLabels",
80674          "path": "projects/{project}/regions/{region}/vpnTunnels/{resource}/setLabels",
80675          "flatPath": "projects/{project}/regions/{region}/vpnTunnels/{resource}/setLabels",
80676          "httpMethod": "POST",
80677          "parameters": {
80678            "project": {
80679              "description": "Project ID for this request.",
80680              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80681              "location": "path",
80682              "required": true,
80683              "type": "string"
80684            },
80685            "region": {
80686              "description": "The region for this request.",
80687              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
80688              "location": "path",
80689              "required": true,
80690              "type": "string"
80691            },
80692            "requestId": {
80693              "description": "An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).",
80694              "location": "query",
80695              "type": "string"
80696            },
80697            "resource": {
80698              "description": "Name or id of the resource for this request.",
80699              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
80700              "location": "path",
80701              "required": true,
80702              "type": "string"
80703            }
80704          },
80705          "parameterOrder": [
80706            "project",
80707            "region",
80708            "resource"
80709          ],
80710          "request": {
80711            "$ref": "RegionSetLabelsRequest"
80712          },
80713          "response": {
80714            "$ref": "Operation"
80715          },
80716          "scopes": [
80717            "https://www.googleapis.com/auth/cloud-platform",
80718            "https://www.googleapis.com/auth/compute"
80719          ],
80720          "description": "Sets the labels on a VpnTunnel. To learn more about labels, read the Labeling Resources documentation."
80721        }
80722      }
80723    },
80724    "zones": {
80725      "methods": {
80726        "list": {
80727          "id": "compute.zones.list",
80728          "path": "projects/{project}/zones",
80729          "flatPath": "projects/{project}/zones",
80730          "httpMethod": "GET",
80731          "parameters": {
80732            "filter": {
80733              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
80734              "location": "query",
80735              "type": "string"
80736            },
80737            "maxResults": {
80738              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
80739              "default": "500",
80740              "minimum": "0",
80741              "location": "query",
80742              "type": "integer",
80743              "format": "uint32"
80744            },
80745            "orderBy": {
80746              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
80747              "location": "query",
80748              "type": "string"
80749            },
80750            "pageToken": {
80751              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
80752              "location": "query",
80753              "type": "string"
80754            },
80755            "project": {
80756              "description": "Project ID for this request.",
80757              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80758              "location": "path",
80759              "required": true,
80760              "type": "string"
80761            },
80762            "returnPartialSuccess": {
80763              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
80764              "location": "query",
80765              "type": "boolean"
80766            }
80767          },
80768          "parameterOrder": [
80769            "project"
80770          ],
80771          "response": {
80772            "$ref": "ZoneList"
80773          },
80774          "scopes": [
80775            "https://www.googleapis.com/auth/cloud-platform",
80776            "https://www.googleapis.com/auth/compute",
80777            "https://www.googleapis.com/auth/compute.readonly"
80778          ],
80779          "description": "Retrieves the list of Zone resources available to the specified project."
80780        },
80781        "get": {
80782          "id": "compute.zones.get",
80783          "path": "projects/{project}/zones/{zone}",
80784          "flatPath": "projects/{project}/zones/{zone}",
80785          "httpMethod": "GET",
80786          "parameters": {
80787            "project": {
80788              "description": "Project ID for this request.",
80789              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80790              "location": "path",
80791              "required": true,
80792              "type": "string"
80793            },
80794            "zone": {
80795              "description": "Name of the zone resource to return.",
80796              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?|[1-9][0-9]{0,19}",
80797              "location": "path",
80798              "required": true,
80799              "type": "string"
80800            }
80801          },
80802          "parameterOrder": [
80803            "project",
80804            "zone"
80805          ],
80806          "response": {
80807            "$ref": "Zone"
80808          },
80809          "scopes": [
80810            "https://www.googleapis.com/auth/cloud-platform",
80811            "https://www.googleapis.com/auth/compute",
80812            "https://www.googleapis.com/auth/compute.readonly"
80813          ],
80814          "description": "Returns the specified Zone resource."
80815        }
80816      }
80817    },
80818    "regionZones": {
80819      "methods": {
80820        "list": {
80821          "id": "compute.regionZones.list",
80822          "path": "projects/{project}/regions/{region}/zones",
80823          "flatPath": "projects/{project}/regions/{region}/zones",
80824          "httpMethod": "GET",
80825          "parameters": {
80826            "filter": {
80827              "description": "A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either `=`, `!=`, `\u003e`, `\u003c`, `\u003c=`, `\u003e=` or `:`. For example, if you are filtering Compute Engine instances, you can exclude instances named `example-instance` by specifying `name != example-instance`. The `:*` comparison can be used to test whether a key has been defined. For example, to find all objects with `owner` label use: ``` labels.owner:* ``` You can also filter nested fields. For example, you could specify `scheduling.automaticRestart = false` to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ``` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ``` By default, each expression is an `AND` expression. However, you can include `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ``` If you want to use a regular expression, use the `eq` (equal) or `ne` (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: `fieldname eq unquoted literal` `fieldname eq 'single quoted literal'` `fieldname eq \"double quoted literal\"` `(fieldname1 eq literal) (fieldname2 ne \"literal\")` The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name \"instance\", you would use `name ne .*instance`. You cannot combine constraints on multiple fields using regular expressions.",
80828              "location": "query",
80829              "type": "string"
80830            },
80831            "maxResults": {
80832              "description": "The maximum number of results per page that should be returned. If the number of available results is larger than `maxResults`, Compute Engine returns a `nextPageToken` that can be used to get the next page of results in subsequent list requests. Acceptable values are `0` to `500`, inclusive. (Default: `500`)",
80833              "default": "500",
80834              "minimum": "0",
80835              "location": "query",
80836              "type": "integer",
80837              "format": "uint32"
80838            },
80839            "orderBy": {
80840              "description": "Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using `orderBy=\"creationTimestamp desc\"`. This sorts results based on the `creationTimestamp` field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by `name` or `creationTimestamp desc` is supported.",
80841              "location": "query",
80842              "type": "string"
80843            },
80844            "pageToken": {
80845              "description": "Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.",
80846              "location": "query",
80847              "type": "string"
80848            },
80849            "project": {
80850              "description": "Project ID for this request.",
80851              "pattern": "(?:(?:[-a-z0-9]{1,63}\\.)*(?:[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?):)?(?:[0-9]{1,19}|(?:[a-z0-9](?:[-a-z0-9]{0,61}[a-z0-9])?))",
80852              "location": "path",
80853              "required": true,
80854              "type": "string"
80855            },
80856            "region": {
80857              "description": "Region for this request.",
80858              "pattern": "[a-z](?:[-a-z0-9]{0,61}[a-z0-9])?",
80859              "location": "path",
80860              "required": true,
80861              "type": "string"
80862            },
80863            "returnPartialSuccess": {
80864              "description": "Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code.",
80865              "location": "query",
80866              "type": "boolean"
80867            }
80868          },
80869          "parameterOrder": [
80870            "project",
80871            "region"
80872          ],
80873          "response": {
80874            "$ref": "ZoneList"
80875          },
80876          "scopes": [
80877            "https://www.googleapis.com/auth/cloud-platform",
80878            "https://www.googleapis.com/auth/compute",
80879            "https://www.googleapis.com/auth/compute.readonly"
80880          ],
80881          "description": "Retrieves the list of Zone resources under the specific region available to the specified project."
80882        }
80883      }
80884    }
80885  },
80886  "rootUrl": "https://compute.googleapis.com/",
80887  "discoveryVersion": "v1",
80888  "parameters": {
80889    "access_token": {
80890      "type": "string",
80891      "description": "OAuth access token.",
80892      "location": "query"
80893    },
80894    "alt": {
80895      "type": "string",
80896      "description": "Data format for response.",
80897      "default": "json",
80898      "enum": [
80899        "json",
80900        "media",
80901        "proto"
80902      ],
80903      "enumDescriptions": [
80904        "Responses with Content-Type of application/json",
80905        "Media download with context-dependent Content-Type",
80906        "Responses with Content-Type of application/x-protobuf"
80907      ],
80908      "location": "query"
80909    },
80910    "callback": {
80911      "type": "string",
80912      "description": "JSONP",
80913      "location": "query"
80914    },
80915    "fields": {
80916      "type": "string",
80917      "description": "Selector specifying which fields to include in a partial response.",
80918      "location": "query"
80919    },
80920    "key": {
80921      "type": "string",
80922      "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.",
80923      "location": "query"
80924    },
80925    "oauth_token": {
80926      "type": "string",
80927      "description": "OAuth 2.0 token for the current user.",
80928      "location": "query"
80929    },
80930    "prettyPrint": {
80931      "type": "boolean",
80932      "description": "Returns response with indentations and line breaks.",
80933      "default": "true",
80934      "location": "query"
80935    },
80936    "quotaUser": {
80937      "type": "string",
80938      "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.",
80939      "location": "query"
80940    },
80941    "upload_protocol": {
80942      "type": "string",
80943      "description": "Upload protocol for media (e.g. \"raw\", \"multipart\").",
80944      "location": "query"
80945    },
80946    "uploadType": {
80947      "type": "string",
80948      "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\").",
80949      "location": "query"
80950    },
80951    "userIp": {
80952      "type": "string",
80953      "description": "Legacy name for parameter that has been superseded by `quotaUser`.",
80954      "location": "query"
80955    },
80956    "$.xgafv": {
80957      "type": "string",
80958      "description": "V1 error format.",
80959      "enum": [
80960        "1",
80961        "2"
80962      ],
80963      "enumDescriptions": [
80964        "v1 error format",
80965        "v2 error format"
80966      ],
80967      "location": "query"
80968    }
80969  },
80970  "description": "Creates and runs virtual machines on Google Cloud Platform. ",
80971  "kind": "discovery#restDescription",
80972  "icons": {
80973    "x16": "https://www.google.com/images/icons/product/compute_engine-16.png",
80974    "x32": "https://www.google.com/images/icons/product/compute_engine-32.png"
80975  },
80976  "auth": {
80977    "oauth2": {
80978      "scopes": {
80979        "https://www.googleapis.com/auth/cloud-platform": {
80980          "description": "See, edit, configure, and delete your Google Cloud data and see the email address for your Google Account."
80981        },
80982        "https://www.googleapis.com/auth/compute": {
80983          "description": "View and manage your Google Compute Engine resources"
80984        },
80985        "https://www.googleapis.com/auth/compute.readonly": {
80986          "description": "View your Google Compute Engine resources"
80987        },
80988        "https://www.googleapis.com/auth/devstorage.full_control": {
80989          "description": "Manage your data and permissions in Cloud Storage and see the email address for your Google Account"
80990        },
80991        "https://www.googleapis.com/auth/devstorage.read_only": {
80992          "description": "View your data in Google Cloud Storage"
80993        },
80994        "https://www.googleapis.com/auth/devstorage.read_write": {
80995          "description": "Manage your data in Cloud Storage and see the email address of your Google Account"
80996        }
80997      }
80998    }
80999  },
81000  "documentationLink": "https://cloud.google.com/compute/",
81001  "mtlsRootUrl": "https://compute.mtls.googleapis.com/",
81002  "baseUrl": "https://compute.googleapis.com/compute/v1/",
81003  "version": "v1",
81004  "ownerName": "Google",
81005  "title": "Compute Engine API",
81006  "batchPath": "batch/compute/v1",
81007  "ownerDomain": "google.com",
81008  "id": "compute:v1"
81009}
81010