google-cloud-compute-v1 2.20.0 → 2.21.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -2445,6 +2445,12 @@ module Google
2445
2445
  end
2446
2446
 
2447
2447
  # [Output Only] Contains output only fields.
2448
+ # @!attribute [rw] reservation_block_count
2449
+ # @return [::Integer]
2450
+ # The number of reservation blocks associated with this reservation.
2451
+ # @!attribute [rw] reservation_maintenance
2452
+ # @return [::Google::Cloud::Compute::V1::GroupMaintenanceInfo]
2453
+ # Maintenance information for this reservation
2448
2454
  # @!attribute [rw] specific_sku_allocation
2449
2455
  # @return [::Google::Cloud::Compute::V1::AllocationResourceStatusSpecificSKUAllocation]
2450
2456
  # Allocation Properties of this reservation.
@@ -3533,7 +3539,7 @@ module Google
3533
3539
  # 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).
3534
3540
  # @!attribute [rw] default_ttl
3535
3541
  # @return [::Integer]
3536
- # 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.
3542
+ # 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-maxage). 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.
3537
3543
  # @!attribute [rw] max_ttl
3538
3544
  # @return [::Integer]
3539
3545
  # 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.
@@ -3548,7 +3554,7 @@ module Google
3548
3554
  # If true then Cloud CDN will combine multiple concurrent cache fill requests into a small number of requests to the origin.
3549
3555
  # @!attribute [rw] serve_while_stale
3550
3556
  # @return [::Integer]
3551
- # 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.
3557
+ # 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-maxage) of a cached response. The maximum allowed value is 604800 (1 week). Set this to zero (0) to disable serve-while-stale.
3552
3558
  # @!attribute [rw] signed_url_cache_max_age_sec
3553
3559
  # @return [::Integer]
3554
3560
  # 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.
@@ -3703,6 +3709,13 @@ module Google
3703
3709
  # @!attribute [rw] enable_c_d_n
3704
3710
  # @return [::Boolean]
3705
3711
  # If true, enables Cloud CDN for the backend service of a global external Application Load Balancer.
3712
+ # @!attribute [rw] external_managed_migration_state
3713
+ # @return [::String]
3714
+ # Specifies the canary migration state. Possible values are PREPARE, TEST_BY_PERCENTAGE, and TEST_ALL_TRAFFIC. To begin the migration from EXTERNAL to EXTERNAL_MANAGED, the state must be changed to PREPARE. The state must be changed to TEST_ALL_TRAFFIC before the loadBalancingScheme can be changed to EXTERNAL_MANAGED. Optionally, the TEST_BY_PERCENTAGE state can be used to migrate traffic by percentage using externalManagedMigrationTestingPercentage. Rolling back a migration requires the states to be set in reverse order. So changing the scheme from EXTERNAL_MANAGED to EXTERNAL requires the state to be set to TEST_ALL_TRAFFIC at the same time. Optionally, the TEST_BY_PERCENTAGE state can be used to migrate some traffic back to EXTERNAL or PREPARE can be used to migrate all traffic back to EXTERNAL.
3715
+ # Check the ExternalManagedMigrationState enum for the list of possible values.
3716
+ # @!attribute [rw] external_managed_migration_testing_percentage
3717
+ # @return [::Float]
3718
+ # Determines the fraction of requests that should be processed by the Global external Application Load Balancer. The value of this field must be in the range [0, 100]. Session affinity options will slightly affect this routing behavior, for more details, see: Session Affinity. This value can only be set if the loadBalancingScheme in the BackendService is set to EXTERNAL (when using the classic Application Load Balancer) and the migration state is TEST_BY_PERCENTAGE.
3706
3719
  # @!attribute [rw] failover_policy
3707
3720
  # @return [::Google::Cloud::Compute::V1::BackendServiceFailoverPolicy]
3708
3721
  # 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). failoverPolicy cannot be specified with haPolicy.
@@ -3826,6 +3839,18 @@ module Google
3826
3839
  DISABLED = 516_696_700
3827
3840
  end
3828
3841
 
3842
+ # Specifies the canary migration state. Possible values are PREPARE, TEST_BY_PERCENTAGE, and TEST_ALL_TRAFFIC. To begin the migration from EXTERNAL to EXTERNAL_MANAGED, the state must be changed to PREPARE. The state must be changed to TEST_ALL_TRAFFIC before the loadBalancingScheme can be changed to EXTERNAL_MANAGED. Optionally, the TEST_BY_PERCENTAGE state can be used to migrate traffic by percentage using externalManagedMigrationTestingPercentage. Rolling back a migration requires the states to be set in reverse order. So changing the scheme from EXTERNAL_MANAGED to EXTERNAL requires the state to be set to TEST_ALL_TRAFFIC at the same time. Optionally, the TEST_BY_PERCENTAGE state can be used to migrate some traffic back to EXTERNAL or PREPARE can be used to migrate all traffic back to EXTERNAL.
3843
+ module ExternalManagedMigrationState
3844
+ # A value indicating that the enum field is not set.
3845
+ UNDEFINED_EXTERNAL_MANAGED_MIGRATION_STATE = 0
3846
+
3847
+ PREPARE = 399_612_135
3848
+
3849
+ TEST_ALL_TRAFFIC = 79_728_882
3850
+
3851
+ TEST_BY_PERCENTAGE = 513_738_389
3852
+ end
3853
+
3829
3854
  # Specifies a preference for traffic sent from the proxy to the backend (or from the client to the backend for proxyless gRPC). The possible values are: - IPV4_ONLY: Only send IPv4 traffic to the backends of the backend service (Instance Group, Managed Instance Group, Network Endpoint Group), regardless of traffic from the client to the proxy. Only IPv4 health checks are used to check the health of the backends. This is the default setting. - PREFER_IPV6: Prioritize the connection to the endpoint's IPv6 address over its IPv4 address (provided there is a healthy IPv6 address). - IPV6_ONLY: Only send IPv6 traffic to the backends of the backend service (Instance Group, Managed Instance Group, Network Endpoint Group), regardless of traffic from the client to the proxy. Only IPv6 health checks are used to check the health of the backends. This field is applicable to either: - Advanced global external Application Load Balancer (load balancing scheme EXTERNAL_MANAGED), - Regional external Application Load Balancer, - Internal proxy Network Load Balancer (load balancing scheme INTERNAL_MANAGED), - Regional internal Application Load Balancer (load balancing scheme INTERNAL_MANAGED), - Traffic Director with Envoy proxies and proxyless gRPC (load balancing scheme INTERNAL_SELF_MANAGED).
3830
3855
  module IpAddressSelectionPolicy
3831
3856
  # A value indicating that the enum field is not set.
@@ -4013,7 +4038,7 @@ module Google
4013
4038
  # 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).
4014
4039
  # @!attribute [rw] default_ttl
4015
4040
  # @return [::Integer]
4016
- # 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.
4041
+ # 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-maxage). 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.
4017
4042
  # @!attribute [rw] max_ttl
4018
4043
  # @return [::Integer]
4019
4044
  # 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.
@@ -4028,7 +4053,7 @@ module Google
4028
4053
  # If true then Cloud CDN will combine multiple concurrent cache fill requests into a small number of requests to the origin.
4029
4054
  # @!attribute [rw] serve_while_stale
4030
4055
  # @return [::Integer]
4031
- # 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.
4056
+ # 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-maxage) of a cached response. The maximum allowed value is 604800 (1 week). Set this to zero (0) to disable serve-while-stale.
4032
4057
  # @!attribute [rw] signed_url_cache_max_age_sec
4033
4058
  # @return [::Integer]
4034
4059
  # 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.
@@ -4174,13 +4199,13 @@ module Google
4174
4199
 
4175
4200
  # @!attribute [rw] fast_i_p_move
4176
4201
  # @return [::String]
4177
- # Specifies whether fast IP move is enabled, and if so, the mechanism to achieve it. Supported values are: - DISABLED: Fast IP Move is disabled. You can only use the haPolicy.leader API to update the leader. - >GARP_RA: Provides a method to very quickly define a new network endpoint as the leader. This method is faster than updating the leader using the haPolicy.leader API. Fast IP move works as follows: The VM hosting the network endpoint that should become the new leader sends either a Gratuitous ARP (GARP) packet (IPv4) or an ICMPv6 Router Advertisement(RA) packet (IPv6). Google Cloud immediately but temporarily associates the forwarding rule IP address with that VM, and both new and in-flight packets are quickly delivered to that VM. Note the important properties of the Fast IP Move functionality: - The GARP/RA-initiated re-routing stays active for approximately 20 minutes. After triggering fast failover, you must also appropriately set the haPolicy.leader. - The new leader instance should continue to send GARP/RA packets periodically every 10 seconds until at least 10 minutes after updating the haPolicy.leader (but stop immediately if it is no longer the leader). - After triggering a fast failover, we recommend that you wait at least 3 seconds before sending another GARP/RA packet from a different VM instance to avoid race conditions. - Don't send GARP/RA packets from different VM instances at the same time. If multiple instances continue to send GARP/RA packets, traffic might be routed to different destinations in an alternating order. This condition ceases when a single instance issues a GARP/RA packet. - The GARP/RA request always takes priority over the leader API. Using the haPolicy.leader API to change the leader to a different instance will have no effect until the GARP/RA request becomes inactive. - The GARP/RA packets should follow the GARP/RA Packet Specifications.. - When multiple forwarding rules refer to a regional backend service, you need only send a GARP or RA packet for a single forwarding rule virtual IP. The virtual IPs for all forwarding rules targeting the same backend service will also be moved to the sender of the GARP or RA packet. The following are the Fast IP Move limitations (that is, when fastIPMove is not DISABLED): - Multiple forwarding rules cannot use the same IP address if one of them refers to a regional backend service with fastIPMove. - The regional backend service must set the network field, and all NEGs must belong to that network. However, individual NEGs can belong to different subnetworks of that network. - The maximum number of network endpoints across all backends of a backend service with fastIPMove is 64. - The maximum number of backend services with fastIPMove that can have the same network endpoint attached to one of its backends is 64. - The maximum number of backend services with fastIPMove in a VPC in a region is 64. - The network endpoints that are attached to a backend of a backend service with fastIPMove cannot resolve to C3 machines. - Traffic directed to the leader by a static route next hop will not be redirected to a new leader by fast failover. Such traffic will only be redirected once an haPolicy.leader update has taken effect. Only traffic to the forwarding rule's virtual IP will be redirected to a new leader by fast failover. haPolicy.fastIPMove can be set only at backend service creation time. Once set, it cannot be updated. By default, fastIpMove is set to DISABLED.
4202
+ # Specifies whether fast IP move is enabled, and if so, the mechanism to achieve it. Supported values are: - DISABLED: Fast IP Move is disabled. You can only use the haPolicy.leader API to update the leader. - >GARP_RA: Provides a method to very quickly define a new network endpoint as the leader. This method is faster than updating the leader using the haPolicy.leader API. Fast IP move works as follows: The VM hosting the network endpoint that should become the new leader sends either a Gratuitous ARP (GARP) packet (IPv4) or an ICMPv6 Router Advertisement(RA) packet (IPv6). Google Cloud immediately but temporarily associates the forwarding rule IP address with that VM, and both new and in-flight packets are quickly delivered to that VM. Note the important properties of the Fast IP Move functionality: - The GARP/RA-initiated re-routing stays active for approximately 20 minutes. After triggering fast failover, you must also appropriately set the haPolicy.leader. - The new leader instance should continue to send GARP/RA packets periodically every 10 seconds until at least 10 minutes after updating the haPolicy.leader (but stop immediately if it is no longer the leader). - After triggering a fast failover, we recommend that you wait at least 3 seconds before sending another GARP/RA packet from a different VM instance to avoid race conditions. - Don't send GARP/RA packets from different VM instances at the same time. If multiple instances continue to send GARP/RA packets, traffic might be routed to different destinations in an alternating order. This condition ceases when a single instance issues a GARP/RA packet. - The GARP/RA request always takes priority over the leader API. Using the haPolicy.leader API to change the leader to a different instance will have no effect until the GARP/RA request becomes inactive. - The GARP/RA packets should follow the GARP/RA Packet Specifications.. - When multiple forwarding rules refer to a regional backend service, you need only send a GARP or RA packet for a single forwarding rule virtual IP. The virtual IPs for all forwarding rules targeting the same backend service will also be moved to the sender of the GARP or RA packet. The following are the Fast IP Move limitations (that is, when fastIPMove is not DISABLED): - Multiple forwarding rules cannot use the same IP address if one of them refers to a regional backend service with fastIPMove. - The regional backend service must set the network field, and all NEGs must belong to that network. However, individual NEGs can belong to different subnetworks of that network. - The maximum number of network endpoints across all backends of a backend service with fastIPMove is 64. - The maximum number of backend services with fastIPMove that can have the same network endpoint attached to one of its backends is 64. - The maximum number of backend services with fastIPMove in a VPC in a region is 64. - The network endpoints that are attached to a backend of a backend service with fastIPMove cannot resolve to Gen3+ machines for IPv6. - Traffic directed to the leader by a static route next hop will not be redirected to a new leader by fast failover. Such traffic will only be redirected once an haPolicy.leader update has taken effect. Only traffic to the forwarding rule's virtual IP will be redirected to a new leader by fast failover. haPolicy.fastIPMove can be set only at backend service creation time. Once set, it cannot be updated. By default, fastIpMove is set to DISABLED.
4178
4203
  # Check the FastIPMove enum for the list of possible values.
4179
4204
  class BackendServiceHAPolicy
4180
4205
  include ::Google::Protobuf::MessageExts
4181
4206
  extend ::Google::Protobuf::MessageExts::ClassMethods
4182
4207
 
4183
- # Specifies whether fast IP move is enabled, and if so, the mechanism to achieve it. Supported values are: - DISABLED: Fast IP Move is disabled. You can only use the haPolicy.leader API to update the leader. - >GARP_RA: Provides a method to very quickly define a new network endpoint as the leader. This method is faster than updating the leader using the haPolicy.leader API. Fast IP move works as follows: The VM hosting the network endpoint that should become the new leader sends either a Gratuitous ARP (GARP) packet (IPv4) or an ICMPv6 Router Advertisement(RA) packet (IPv6). Google Cloud immediately but temporarily associates the forwarding rule IP address with that VM, and both new and in-flight packets are quickly delivered to that VM. Note the important properties of the Fast IP Move functionality: - The GARP/RA-initiated re-routing stays active for approximately 20 minutes. After triggering fast failover, you must also appropriately set the haPolicy.leader. - The new leader instance should continue to send GARP/RA packets periodically every 10 seconds until at least 10 minutes after updating the haPolicy.leader (but stop immediately if it is no longer the leader). - After triggering a fast failover, we recommend that you wait at least 3 seconds before sending another GARP/RA packet from a different VM instance to avoid race conditions. - Don't send GARP/RA packets from different VM instances at the same time. If multiple instances continue to send GARP/RA packets, traffic might be routed to different destinations in an alternating order. This condition ceases when a single instance issues a GARP/RA packet. - The GARP/RA request always takes priority over the leader API. Using the haPolicy.leader API to change the leader to a different instance will have no effect until the GARP/RA request becomes inactive. - The GARP/RA packets should follow the GARP/RA Packet Specifications.. - When multiple forwarding rules refer to a regional backend service, you need only send a GARP or RA packet for a single forwarding rule virtual IP. The virtual IPs for all forwarding rules targeting the same backend service will also be moved to the sender of the GARP or RA packet. The following are the Fast IP Move limitations (that is, when fastIPMove is not DISABLED): - Multiple forwarding rules cannot use the same IP address if one of them refers to a regional backend service with fastIPMove. - The regional backend service must set the network field, and all NEGs must belong to that network. However, individual NEGs can belong to different subnetworks of that network. - The maximum number of network endpoints across all backends of a backend service with fastIPMove is 64. - The maximum number of backend services with fastIPMove that can have the same network endpoint attached to one of its backends is 64. - The maximum number of backend services with fastIPMove in a VPC in a region is 64. - The network endpoints that are attached to a backend of a backend service with fastIPMove cannot resolve to C3 machines. - Traffic directed to the leader by a static route next hop will not be redirected to a new leader by fast failover. Such traffic will only be redirected once an haPolicy.leader update has taken effect. Only traffic to the forwarding rule's virtual IP will be redirected to a new leader by fast failover. haPolicy.fastIPMove can be set only at backend service creation time. Once set, it cannot be updated. By default, fastIpMove is set to DISABLED.
4208
+ # Specifies whether fast IP move is enabled, and if so, the mechanism to achieve it. Supported values are: - DISABLED: Fast IP Move is disabled. You can only use the haPolicy.leader API to update the leader. - >GARP_RA: Provides a method to very quickly define a new network endpoint as the leader. This method is faster than updating the leader using the haPolicy.leader API. Fast IP move works as follows: The VM hosting the network endpoint that should become the new leader sends either a Gratuitous ARP (GARP) packet (IPv4) or an ICMPv6 Router Advertisement(RA) packet (IPv6). Google Cloud immediately but temporarily associates the forwarding rule IP address with that VM, and both new and in-flight packets are quickly delivered to that VM. Note the important properties of the Fast IP Move functionality: - The GARP/RA-initiated re-routing stays active for approximately 20 minutes. After triggering fast failover, you must also appropriately set the haPolicy.leader. - The new leader instance should continue to send GARP/RA packets periodically every 10 seconds until at least 10 minutes after updating the haPolicy.leader (but stop immediately if it is no longer the leader). - After triggering a fast failover, we recommend that you wait at least 3 seconds before sending another GARP/RA packet from a different VM instance to avoid race conditions. - Don't send GARP/RA packets from different VM instances at the same time. If multiple instances continue to send GARP/RA packets, traffic might be routed to different destinations in an alternating order. This condition ceases when a single instance issues a GARP/RA packet. - The GARP/RA request always takes priority over the leader API. Using the haPolicy.leader API to change the leader to a different instance will have no effect until the GARP/RA request becomes inactive. - The GARP/RA packets should follow the GARP/RA Packet Specifications.. - When multiple forwarding rules refer to a regional backend service, you need only send a GARP or RA packet for a single forwarding rule virtual IP. The virtual IPs for all forwarding rules targeting the same backend service will also be moved to the sender of the GARP or RA packet. The following are the Fast IP Move limitations (that is, when fastIPMove is not DISABLED): - Multiple forwarding rules cannot use the same IP address if one of them refers to a regional backend service with fastIPMove. - The regional backend service must set the network field, and all NEGs must belong to that network. However, individual NEGs can belong to different subnetworks of that network. - The maximum number of network endpoints across all backends of a backend service with fastIPMove is 64. - The maximum number of backend services with fastIPMove that can have the same network endpoint attached to one of its backends is 64. - The maximum number of backend services with fastIPMove in a VPC in a region is 64. - The network endpoints that are attached to a backend of a backend service with fastIPMove cannot resolve to Gen3+ machines for IPv6. - Traffic directed to the leader by a static route next hop will not be redirected to a new leader by fast failover. Such traffic will only be redirected once an haPolicy.leader update has taken effect. Only traffic to the forwarding rule's virtual IP will be redirected to a new leader by fast failover. haPolicy.fastIPMove can be set only at backend service creation time. Once set, it cannot be updated. By default, fastIpMove is set to DISABLED.
4184
4209
  module FastIPMove
4185
4210
  # A value indicating that the enum field is not set.
4186
4211
  UNDEFINED_FAST_I_P_MOVE = 0
@@ -4854,6 +4879,9 @@ module Google
4854
4879
  extend ::Google::Protobuf::MessageExts::ClassMethods
4855
4880
  end
4856
4881
 
4882
+ # @!attribute [rw] cache_tags
4883
+ # @return [::Array<::String>]
4884
+ # A list of cache tags used to identify cached objects. - Cache tags are specified when the response is first cached, by setting the `Cache-Tag` response header at the origin. - Multiple cache tags in the same invalidation request are treated as Boolean `OR` - for example, `tag1 OR tag2 OR tag3`. - If other fields are also specified, these are treated as Boolean `AND` with any tags. Up to 10 tags can be specified in a single invalidation request.
4857
4885
  # @!attribute [rw] host
4858
4886
  # @return [::String]
4859
4887
  # If set, this invalidation rule will only apply to requests with a Host header matching host.
@@ -5118,6 +5146,8 @@ module Google
5118
5146
 
5119
5147
  ACCELERATOR_OPTIMIZED_A3_ULTRA = 27_812_811
5120
5148
 
5149
+ ACCELERATOR_OPTIMIZED_A4 = 158_574_527
5150
+
5121
5151
  COMPUTE_OPTIMIZED = 158_349_023
5122
5152
 
5123
5153
  COMPUTE_OPTIMIZED_C2D = 383_246_453
@@ -10542,6 +10572,24 @@ module Google
10542
10572
  extend ::Google::Protobuf::MessageExts::ClassMethods
10543
10573
  end
10544
10574
 
10575
+ # A request message for ReservationBlocks.Get. See the method description for details.
10576
+ # @!attribute [rw] project
10577
+ # @return [::String]
10578
+ # Project ID for this request.
10579
+ # @!attribute [rw] reservation
10580
+ # @return [::String]
10581
+ # The name of the reservation. Name should conform to RFC1035 or be a resource ID.
10582
+ # @!attribute [rw] reservation_block
10583
+ # @return [::String]
10584
+ # The name of the reservation block. Name should conform to RFC1035 or be a resource ID.
10585
+ # @!attribute [rw] zone
10586
+ # @return [::String]
10587
+ # Name of the zone for this request. Zone name should conform to RFC1035.
10588
+ class GetReservationBlockRequest
10589
+ include ::Google::Protobuf::MessageExts
10590
+ extend ::Google::Protobuf::MessageExts::ClassMethods
10591
+ end
10592
+
10545
10593
  # A request message for Reservations.Get. See the method description for details.
10546
10594
  # @!attribute [rw] project
10547
10595
  # @return [::String]
@@ -11175,6 +11223,40 @@ module Google
11175
11223
  extend ::Google::Protobuf::MessageExts::ClassMethods
11176
11224
  end
11177
11225
 
11226
+ # Maintenance Info for ReservationBlocks.
11227
+ # @!attribute [rw] maintenance_ongoing_count
11228
+ # @return [::Integer]
11229
+ # Progress for ongoing maintenance for this group of VMs/hosts. Describes number of hosts in the block that have ongoing maintenance.
11230
+ # @!attribute [rw] maintenance_pending_count
11231
+ # @return [::Integer]
11232
+ # Progress for ongoing maintenance for this group of VMs/hosts. Describes number of hosts in the block that have pending maintenance.
11233
+ # @!attribute [rw] scheduling_type
11234
+ # @return [::String]
11235
+ # The type of maintenance for the reservation.
11236
+ # Check the SchedulingType enum for the list of possible values.
11237
+ # @!attribute [rw] upcoming_group_maintenance
11238
+ # @return [::Google::Cloud::Compute::V1::UpcomingMaintenance]
11239
+ # Maintenance information on this group of VMs.
11240
+ class GroupMaintenanceInfo
11241
+ include ::Google::Protobuf::MessageExts
11242
+ extend ::Google::Protobuf::MessageExts::ClassMethods
11243
+
11244
+ # The type of maintenance for the reservation.
11245
+ module SchedulingType
11246
+ # A value indicating that the enum field is not set.
11247
+ UNDEFINED_SCHEDULING_TYPE = 0
11248
+
11249
+ # Maintenance on all reserved instances in the reservation is synchronized.
11250
+ GROUPED = 474_540_862
11251
+
11252
+ # Unknown maintenance type.
11253
+ GROUP_MAINTENANCE_TYPE_UNSPECIFIED = 447_183_678
11254
+
11255
+ # Maintenance is not synchronized for this reservation. Instead, each instance has its own maintenance window.
11256
+ INDEPENDENT = 127_011_674
11257
+ end
11258
+ end
11259
+
11178
11260
  # A guest attributes entry.
11179
11261
  # @!attribute [rw] kind
11180
11262
  # @return [::String]
@@ -11225,13 +11307,13 @@ module Google
11225
11307
  # Guest OS features.
11226
11308
  # @!attribute [rw] type
11227
11309
  # @return [::String]
11228
- # 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_V2 - SEV_SNP_CAPABLE - TDX_CAPABLE - IDPF For more information, see Enabling guest operating system features.
11310
+ # 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_V2 - SEV_SNP_CAPABLE - TDX_CAPABLE - IDPF - SNP_SVSM_CAPABLE For more information, see Enabling guest operating system features.
11229
11311
  # Check the Type enum for the list of possible values.
11230
11312
  class GuestOsFeature
11231
11313
  include ::Google::Protobuf::MessageExts
11232
11314
  extend ::Google::Protobuf::MessageExts::ClassMethods
11233
11315
 
11234
- # 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_V2 - SEV_SNP_CAPABLE - TDX_CAPABLE - IDPF For more information, see Enabling guest operating system features.
11316
+ # 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_V2 - SEV_SNP_CAPABLE - TDX_CAPABLE - IDPF - SNP_SVSM_CAPABLE For more information, see Enabling guest operating system features.
11235
11317
  module Type
11236
11318
  # A value indicating that the enum field is not set.
11237
11319
  UNDEFINED_TYPE = 0
@@ -15526,7 +15608,7 @@ module Google
15526
15608
 
15527
15609
  # @!attribute [rw] disruption_schedule
15528
15610
  # @return [::String]
15529
- # The disruption schedule for the VM. Default to IMMEDIATE.
15611
+ # The disruption schedule for the VM. Required field, only allows IMMEDIATE.
15530
15612
  # Check the DisruptionSchedule enum for the list of possible values.
15531
15613
  # @!attribute [rw] fault_reasons
15532
15614
  # @return [::Array<::Google::Cloud::Compute::V1::InstancesReportHostAsFaultyRequestFaultReason>]
@@ -15534,7 +15616,7 @@ module Google
15534
15616
  include ::Google::Protobuf::MessageExts
15535
15617
  extend ::Google::Protobuf::MessageExts::ClassMethods
15536
15618
 
15537
- # The disruption schedule for the VM. Default to IMMEDIATE.
15619
+ # The disruption schedule for the VM. Required field, only allows IMMEDIATE.
15538
15620
  module DisruptionSchedule
15539
15621
  # A value indicating that the enum field is not set.
15540
15622
  UNDEFINED_DISRUPTION_SCHEDULE = 0
@@ -16679,7 +16761,7 @@ module Google
16679
16761
  # Check the AvailableFeatures enum for the list of possible values.
16680
16762
  # @!attribute [rw] available_link_types
16681
16763
  # @return [::Array<::String>]
16682
- # [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
16764
+ # [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 - LINK_TYPE_ETHERNET_400G_LR4
16683
16765
  # Check the AvailableLinkTypes enum for the list of possible values.
16684
16766
  # @!attribute [rw] city
16685
16767
  # @return [::String]
@@ -19740,6 +19822,36 @@ module Google
19740
19822
  extend ::Google::Protobuf::MessageExts::ClassMethods
19741
19823
  end
19742
19824
 
19825
+ # A request message for ReservationBlocks.List. See the method description for details.
19826
+ # @!attribute [rw] filter
19827
+ # @return [::String]
19828
+ # 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 `=`, `!=`, `>`, `<`, `<=`, `>=` 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.
19829
+ # @!attribute [rw] max_results
19830
+ # @return [::Integer]
19831
+ # 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`)
19832
+ # @!attribute [rw] order_by
19833
+ # @return [::String]
19834
+ # 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.
19835
+ # @!attribute [rw] page_token
19836
+ # @return [::String]
19837
+ # Specifies a page token to use. Set `pageToken` to the `nextPageToken` returned by a previous list request to get the next page of results.
19838
+ # @!attribute [rw] project
19839
+ # @return [::String]
19840
+ # Project ID for this request.
19841
+ # @!attribute [rw] reservation
19842
+ # @return [::String]
19843
+ # The name of the reservation. Name should conform to RFC1035 or be a resource ID.
19844
+ # @!attribute [rw] return_partial_success
19845
+ # @return [::Boolean]
19846
+ # 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.
19847
+ # @!attribute [rw] zone
19848
+ # @return [::String]
19849
+ # Name of the zone for this request. Zone name should conform to RFC1035.
19850
+ class ListReservationBlocksRequest
19851
+ include ::Google::Protobuf::MessageExts
19852
+ extend ::Google::Protobuf::MessageExts::ClassMethods
19853
+ end
19854
+
19743
19855
  # A request message for Reservations.List. See the method description for details.
19744
19856
  # @!attribute [rw] filter
19745
19857
  # @return [::String]
@@ -20629,6 +20741,12 @@ module Google
20629
20741
  # @!attribute [rw] kind
20630
20742
  # @return [::String]
20631
20743
  # [Output Only] The resource type, which is always compute#machineImage for machine image.
20744
+ # @!attribute [rw] label_fingerprint
20745
+ # @return [::String]
20746
+ # A fingerprint for the labels being applied to this machine image, 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 machine image.
20747
+ # @!attribute [rw] labels
20748
+ # @return [::Google::Protobuf::Map{::String => ::String}]
20749
+ # Labels to apply to this machine image. These can be later modified by the setLabels method.
20632
20750
  # @!attribute [rw] machine_image_encryption_key
20633
20751
  # @return [::Google::Cloud::Compute::V1::CustomerEncryptionKey]
20634
20752
  # 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.
@@ -20670,6 +20788,15 @@ module Google
20670
20788
  include ::Google::Protobuf::MessageExts
20671
20789
  extend ::Google::Protobuf::MessageExts::ClassMethods
20672
20790
 
20791
+ # @!attribute [rw] key
20792
+ # @return [::String]
20793
+ # @!attribute [rw] value
20794
+ # @return [::String]
20795
+ class LabelsEntry
20796
+ include ::Google::Protobuf::MessageExts
20797
+ extend ::Google::Protobuf::MessageExts::ClassMethods
20798
+ end
20799
+
20673
20800
  # [Output Only] The status of the machine image. One of the following values: INVALID, CREATING, READY, DELETING, and UPLOADING.
20674
20801
  module Status
20675
20802
  # A value indicating that the enum field is not set.
@@ -22146,7 +22273,7 @@ module Google
22146
22273
  # 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.
22147
22274
  # @!attribute [rw] peer_mtu
22148
22275
  # @return [::Integer]
22149
- # Maximum Transmission Unit in bytes.
22276
+ # [Output Only] Maximum Transmission Unit in bytes of the peer network.
22150
22277
  # @!attribute [rw] stack_type
22151
22278
  # @return [::String]
22152
22279
  # Which IP version(s) of traffic and routes are allowed to be imported or exported between peer networks. The default value is IPV4_ONLY.
@@ -22284,6 +22411,10 @@ module Google
22284
22411
  # @return [::String]
22285
22412
  # Specifies whether cloud router creation is allowed.
22286
22413
  # Check the AllowCloudRouter enum for the list of possible values.
22414
+ # @!attribute [rw] allow_default_nic_attachment
22415
+ # @return [::String]
22416
+ # Specifies whether default NIC attachment is allowed.
22417
+ # Check the AllowDefaultNicAttachment enum for the list of possible values.
22287
22418
  # @!attribute [rw] allow_external_ip_access
22288
22419
  # @return [::String]
22289
22420
  # Specifies whether VMs are allowed to have external IP access on network interfaces connected to this VPC.
@@ -22292,6 +22423,10 @@ module Google
22292
22423
  # @return [::String]
22293
22424
  # Specifies whether Cloud Interconnect creation is allowed.
22294
22425
  # Check the AllowInterconnect enum for the list of possible values.
22426
+ # @!attribute [rw] allow_ip_forwarding
22427
+ # @return [::String]
22428
+ # Specifies whether IP forwarding is allowed.
22429
+ # Check the AllowIpForwarding enum for the list of possible values.
22295
22430
  # @!attribute [rw] allow_load_balancing
22296
22431
  # @return [::String]
22297
22432
  # Specifies whether cloud load balancing is allowed.
@@ -22300,6 +22435,14 @@ module Google
22300
22435
  # @return [::String]
22301
22436
  # Specifies whether multi-nic in the same network is allowed.
22302
22437
  # Check the AllowMultiNicInSameNetwork enum for the list of possible values.
22438
+ # @!attribute [rw] allow_ncc
22439
+ # @return [::String]
22440
+ # Specifies whether NCC is allowed.
22441
+ # Check the AllowNcc enum for the list of possible values.
22442
+ # @!attribute [rw] allow_network_migration
22443
+ # @return [::String]
22444
+ # Specifies whether VM network migration is allowed.
22445
+ # Check the AllowNetworkMigration enum for the list of possible values.
22303
22446
  # @!attribute [rw] allow_packet_mirroring
22304
22447
  # @return [::String]
22305
22448
  # Specifies whether Packet Mirroring 1.0 is supported.
@@ -22344,6 +22487,14 @@ module Google
22344
22487
  # @return [::Array<::String>]
22345
22488
  # Specifies which subnetwork stack types are supported.
22346
22489
  # Check the SubnetStackTypes enum for the list of possible values.
22490
+ # @!attribute [rw] subnetwork_purposes
22491
+ # @return [::Array<::String>]
22492
+ # Specifies which subnetwork purposes are supported.
22493
+ # Check the SubnetworkPurposes enum for the list of possible values.
22494
+ # @!attribute [rw] subnetwork_stack_types
22495
+ # @return [::Array<::String>]
22496
+ # Specifies which subnetwork stack types are supported.
22497
+ # Check the SubnetworkStackTypes enum for the list of possible values.
22347
22498
  # @!attribute [rw] unicast
22348
22499
  # @return [::String]
22349
22500
  # Specifies which type of unicast is supported.
@@ -22352,7 +22503,8 @@ module Google
22352
22503
  include ::Google::Protobuf::MessageExts
22353
22504
  extend ::Google::Protobuf::MessageExts::ClassMethods
22354
22505
 
22355
-
22506
+ # Additional supported values which may be not listed in the enum directly due to technical reasons:
22507
+ # PRIVATE_SERVICE_CONNECT
22356
22508
  module AddressPurposes
22357
22509
  # A value indicating that the enum field is not set.
22358
22510
  UNDEFINED_ADDRESS_PURPOSES = 0
@@ -22369,7 +22521,6 @@ module Google
22369
22521
  # External IP automatically reserved for Cloud NAT.
22370
22522
  NAT_AUTO = 163_666_477
22371
22523
 
22372
- # 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
22373
22524
  PRIVATE_SERVICE_CONNECT = 48_134_724
22374
22525
 
22375
22526
  # A regional internal IP address range reserved for Serverless.
@@ -22432,6 +22583,16 @@ module Google
22432
22583
  CLOUD_ROUTER_BLOCKED = 181_551_680
22433
22584
  end
22434
22585
 
22586
+ # Specifies whether default NIC attachment is allowed.
22587
+ module AllowDefaultNicAttachment
22588
+ # A value indicating that the enum field is not set.
22589
+ UNDEFINED_ALLOW_DEFAULT_NIC_ATTACHMENT = 0
22590
+
22591
+ DEFAULT_NIC_ATTACHMENT_ALLOWED = 11_570_689
22592
+
22593
+ DEFAULT_NIC_ATTACHMENT_BLOCKED = 364_604_997
22594
+ end
22595
+
22435
22596
  # Specifies whether VMs are allowed to have external IP access on network interfaces connected to this VPC.
22436
22597
  module AllowExternalIpAccess
22437
22598
  # A value indicating that the enum field is not set.
@@ -22452,6 +22613,16 @@ module Google
22452
22613
  INTERCONNECT_BLOCKED = 515_879_707
22453
22614
  end
22454
22615
 
22616
+ # Specifies whether IP forwarding is allowed.
22617
+ module AllowIpForwarding
22618
+ # A value indicating that the enum field is not set.
22619
+ UNDEFINED_ALLOW_IP_FORWARDING = 0
22620
+
22621
+ IP_FORWARDING_ALLOWED = 152_595_550
22622
+
22623
+ IP_FORWARDING_BLOCKED = 505_629_858
22624
+ end
22625
+
22455
22626
  # Specifies whether cloud load balancing is allowed.
22456
22627
  module AllowLoadBalancing
22457
22628
  # A value indicating that the enum field is not set.
@@ -22472,6 +22643,26 @@ module Google
22472
22643
  MULTI_NIC_IN_SAME_NETWORK_BLOCKED = 273_718_815
22473
22644
  end
22474
22645
 
22646
+ # Specifies whether NCC is allowed.
22647
+ module AllowNcc
22648
+ # A value indicating that the enum field is not set.
22649
+ UNDEFINED_ALLOW_NCC = 0
22650
+
22651
+ NCC_ALLOWED = 467_227_511
22652
+
22653
+ NCC_BLOCKED = 283_390_907
22654
+ end
22655
+
22656
+ # Specifies whether VM network migration is allowed.
22657
+ module AllowNetworkMigration
22658
+ # A value indicating that the enum field is not set.
22659
+ UNDEFINED_ALLOW_NETWORK_MIGRATION = 0
22660
+
22661
+ NETWORK_MIGRATION_ALLOWED = 14_389_766
22662
+
22663
+ NETWORK_MIGRATION_BLOCKED = 367_424_074
22664
+ end
22665
+
22475
22666
  # Specifies whether Packet Mirroring 1.0 is supported.
22476
22667
  module AllowPacketMirroring
22477
22668
  # A value indicating that the enum field is not set.
@@ -22595,6 +22786,48 @@ module Google
22595
22786
  SUBNET_STACK_TYPE_IPV6_ONLY = 98_889_336
22596
22787
  end
22597
22788
 
22789
+ # Additional supported values which may be not listed in the enum directly due to technical reasons:
22790
+ # PRIVATE_SERVICE_CONNECT
22791
+ module SubnetworkPurposes
22792
+ # A value indicating that the enum field is not set.
22793
+ UNDEFINED_SUBNETWORK_PURPOSES = 0
22794
+
22795
+ # Subnet reserved for Global Envoy-based Load Balancing.
22796
+ GLOBAL_MANAGED_PROXY = 236_463_602
22797
+
22798
+ # Subnet reserved for Internal HTTP(S) Load Balancing. This is a legacy purpose, please use REGIONAL_MANAGED_PROXY instead.
22799
+ INTERNAL_HTTPS_LOAD_BALANCER = 248_748_889
22800
+
22801
+ # Subnetwork will be used for Migration from one peered VPC to another. (a transient state of subnetwork while migrating resources from one project to another).
22802
+ PEER_MIGRATION = 491_902_225
22803
+
22804
+ # Regular user created or automatically created subnet.
22805
+ PRIVATE = 403_485_027
22806
+
22807
+ # Subnetwork used as source range for Private NAT Gateways.
22808
+ PRIVATE_NAT = 367_764_517
22809
+
22810
+ # Regular user created or automatically created subnet.
22811
+ PRIVATE_RFC_1918 = 254_902_107
22812
+
22813
+ # Subnetwork used for Regional Envoy-based Load Balancing.
22814
+ REGIONAL_MANAGED_PROXY = 153_049_966
22815
+ end
22816
+
22817
+ module SubnetworkStackTypes
22818
+ # A value indicating that the enum field is not set.
22819
+ UNDEFINED_SUBNETWORK_STACK_TYPES = 0
22820
+
22821
+ # New VMs in this subnet can have both IPv4 and IPv6 addresses.
22822
+ IPV4_IPV6 = 22_197_249
22823
+
22824
+ # New VMs in this subnet will only be assigned IPv4 addresses.
22825
+ IPV4_ONLY = 22_373_798
22826
+
22827
+ # New VMs in this subnet will only be assigned IPv6 addresses.
22828
+ IPV6_ONLY = 79_632_100
22829
+ end
22830
+
22598
22831
  # Specifies which type of unicast is supported.
22599
22832
  module Unicast
22600
22833
  # A value indicating that the enum field is not set.
@@ -25176,6 +25409,51 @@ module Google
25176
25409
  extend ::Google::Protobuf::MessageExts::ClassMethods
25177
25410
  end
25178
25411
 
25412
+ # A request message for ReservationBlocks.PerformMaintenance. See the method description for details.
25413
+ # @!attribute [rw] project
25414
+ # @return [::String]
25415
+ # Project ID for this request.
25416
+ # @!attribute [rw] request_id
25417
+ # @return [::String]
25418
+ # An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).
25419
+ # @!attribute [rw] reservation
25420
+ # @return [::String]
25421
+ # The name of the reservation. Name should conform to RFC1035 or be a resource ID.
25422
+ # @!attribute [rw] reservation_block
25423
+ # @return [::String]
25424
+ # The name of the reservation block. Name should conform to RFC1035 or be a resource ID.
25425
+ # @!attribute [rw] reservations_blocks_perform_maintenance_request_resource
25426
+ # @return [::Google::Cloud::Compute::V1::ReservationsBlocksPerformMaintenanceRequest]
25427
+ # The body resource for this request
25428
+ # @!attribute [rw] zone
25429
+ # @return [::String]
25430
+ # Name of the zone for this request. Zone name should conform to RFC1035.
25431
+ class PerformMaintenanceReservationBlockRequest
25432
+ include ::Google::Protobuf::MessageExts
25433
+ extend ::Google::Protobuf::MessageExts::ClassMethods
25434
+ end
25435
+
25436
+ # A request message for Reservations.PerformMaintenance. See the method description for details.
25437
+ # @!attribute [rw] project
25438
+ # @return [::String]
25439
+ # Project ID for this request.
25440
+ # @!attribute [rw] request_id
25441
+ # @return [::String]
25442
+ # An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server will know to ignore the request if it has already been completed. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, will ignore the second request. This prevents clients from accidentally creating duplicate commitments. The request ID must be a valid UUID with the exception that zero UUID is not supported ( 00000000-0000-0000-0000-000000000000).
25443
+ # @!attribute [rw] reservation
25444
+ # @return [::String]
25445
+ # The name of the reservation. Name should conform to RFC1035 or be a resource ID.
25446
+ # @!attribute [rw] reservations_perform_maintenance_request_resource
25447
+ # @return [::Google::Cloud::Compute::V1::ReservationsPerformMaintenanceRequest]
25448
+ # The body resource for this request
25449
+ # @!attribute [rw] zone
25450
+ # @return [::String]
25451
+ # Name of the zone for this request. Zone name should conform to RFC1035.
25452
+ class PerformMaintenanceReservationRequest
25453
+ include ::Google::Protobuf::MessageExts
25454
+ extend ::Google::Protobuf::MessageExts::ClassMethods
25455
+ end
25456
+
25179
25457
  # An Identity and Access Management (IAM) policy, which specifies access controls for Google Cloud resources. A `Policy` is a collection of `bindings`. A `binding` binds one or more `members`, or principals, to a single `role`. Principals can be user accounts, service accounts, Google groups, and domains (such as G Suite). A `role` is a named list of permissions; each `role` can be an IAM predefined role or a user-created custom role. For some types of Google Cloud resources, a `binding` can also specify a `condition`, which is a logical expression that allows access to a resource only if the expression evaluates to `true`. A condition can add constraints based on attributes of the request, the resource, or both. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies). **JSON example:** ``` { "bindings": [ { "role": "roles/resourcemanager.organizationAdmin", "members": [ "user:mike@example.com", "group:admins@example.com", "domain:google.com", "serviceAccount:my-project-id@appspot.gserviceaccount.com" ] }, { "role": "roles/resourcemanager.organizationViewer", "members": [ "user:eve@example.com" ], "condition": { "title": "expirable access", "description": "Does not grant access after Sep 2020", "expression": "request.time < timestamp('2020-10-01T00:00:00.000Z')", } } ], "etag": "BwWWja0YfJA=", "version": 3 } ``` **YAML example:** ``` bindings: - members: - user:mike@example.com - group:admins@example.com - domain:google.com - serviceAccount:my-project-id@appspot.gserviceaccount.com role: roles/resourcemanager.organizationAdmin - members: - user:eve@example.com role: roles/resourcemanager.organizationViewer condition: title: expirable access description: Does not grant access after Sep 2020 expression: request.time < 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/).
25180
25458
  # @!attribute [rw] audit_configs
25181
25459
  # @return [::Array<::Google::Cloud::Compute::V1::AuditConfig>]
@@ -27467,6 +27745,10 @@ module Google
27467
27745
  # @!attribute [rw] creation_timestamp
27468
27746
  # @return [::String]
27469
27747
  # [Output Only] Creation timestamp in RFC3339 text format.
27748
+ # @!attribute [rw] deployment_type
27749
+ # @return [::String]
27750
+ # Specifies the deployment strategy for this reservation.
27751
+ # Check the DeploymentType enum for the list of possible values.
27470
27752
  # @!attribute [rw] description
27471
27753
  # @return [::String]
27472
27754
  # An optional description of this resource. Provide this property when you create the resource.
@@ -27476,6 +27758,9 @@ module Google
27476
27758
  # @!attribute [rw] kind
27477
27759
  # @return [::String]
27478
27760
  # [Output Only] Type of the resource. Always compute#reservations for reservations.
27761
+ # @!attribute [rw] linked_commitments
27762
+ # @return [::Array<::String>]
27763
+ # [Output Only] Full or partial URL to parent commitments. This field displays for reservations that are tied to multiple commitments.
27479
27764
  # @!attribute [rw] name
27480
27765
  # @return [::String]
27481
27766
  # 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.
@@ -27523,6 +27808,17 @@ module Google
27523
27808
  extend ::Google::Protobuf::MessageExts::ClassMethods
27524
27809
  end
27525
27810
 
27811
+ # Specifies the deployment strategy for this reservation.
27812
+ module DeploymentType
27813
+ # A value indicating that the enum field is not set.
27814
+ UNDEFINED_DEPLOYMENT_TYPE = 0
27815
+
27816
+ # The reserved capacity is made up of densely deployed reservation blocks.
27817
+ DENSE = 64_932_607
27818
+
27819
+ DEPLOYMENT_TYPE_UNSPECIFIED = 234_847_180
27820
+ end
27821
+
27526
27822
  # [Output Only] The status of the reservation. - CREATING: Reservation resources are being allocated. - READY: Reservation resources have been allocated, and the reservation is ready for use. - DELETING: Reservation deletion is in progress. - UPDATING: Reservation update is in progress.
27527
27823
  module Status
27528
27824
  # A value indicating that the enum field is not set.
@@ -27613,6 +27909,108 @@ module Google
27613
27909
  end
27614
27910
  end
27615
27911
 
27912
+ # Represents a reservation block resource.
27913
+ # @!attribute [rw] count
27914
+ # @return [::Integer]
27915
+ # [Output Only] The number of resources that are allocated in this reservation block.
27916
+ # @!attribute [rw] creation_timestamp
27917
+ # @return [::String]
27918
+ # [Output Only] Creation timestamp in RFC3339 text format.
27919
+ # @!attribute [rw] id
27920
+ # @return [::Integer]
27921
+ # [Output Only] The unique identifier for the resource. This identifier is defined by the server.
27922
+ # @!attribute [rw] in_use_count
27923
+ # @return [::Integer]
27924
+ # [Output Only] The number of instances that are currently in use on this reservation block.
27925
+ # @!attribute [rw] kind
27926
+ # @return [::String]
27927
+ # [Output Only] Type of the resource. Always compute#reservationBlock for reservation blocks.
27928
+ # @!attribute [rw] name
27929
+ # @return [::String]
27930
+ # [Output Only] The name of this reservation block generated by Google Compute Engine. The name must be 1-63 characters long, and comply with RFC1035 @pattern [a-z](?:[-a-z0-9]\\{0,61}[a-z0-9])?
27931
+ # @!attribute [rw] physical_topology
27932
+ # @return [::Google::Cloud::Compute::V1::ReservationBlockPhysicalTopology]
27933
+ # [Output Only] The physical topology of the reservation block.
27934
+ # @!attribute [rw] reservation_maintenance
27935
+ # @return [::Google::Cloud::Compute::V1::GroupMaintenanceInfo]
27936
+ # [Output Only] Maintenance information for this reservation block.
27937
+ # @!attribute [rw] self_link
27938
+ # @return [::String]
27939
+ # [Output Only] Server-defined fully-qualified URL for this resource.
27940
+ # @!attribute [rw] self_link_with_id
27941
+ # @return [::String]
27942
+ # [Output Only] Server-defined URL for this resource with the resource id.
27943
+ # @!attribute [rw] status
27944
+ # @return [::String]
27945
+ # [Output Only] Status of the reservation block.
27946
+ # Check the Status enum for the list of possible values.
27947
+ # @!attribute [rw] zone
27948
+ # @return [::String]
27949
+ # [Output Only] Zone in which the reservation block resides.
27950
+ class ReservationBlock
27951
+ include ::Google::Protobuf::MessageExts
27952
+ extend ::Google::Protobuf::MessageExts::ClassMethods
27953
+
27954
+ # [Output Only] Status of the reservation block.
27955
+ module Status
27956
+ # A value indicating that the enum field is not set.
27957
+ UNDEFINED_STATUS = 0
27958
+
27959
+ # Resources are being allocated for the reservation block.
27960
+ CREATING = 455_564_985
27961
+
27962
+ # Reservation block is currently being deleted.
27963
+ DELETING = 528_602_024
27964
+
27965
+ INVALID = 530_283_991
27966
+
27967
+ # Reservation block has allocated all its resources.
27968
+ READY = 77_848_963
27969
+ end
27970
+ end
27971
+
27972
+ # @!attribute [rw] block
27973
+ # @return [::String]
27974
+ # The hash of the capacity block within the cluster.
27975
+ # @!attribute [rw] cluster
27976
+ # @return [::String]
27977
+ # The cluster name of the reservation block.
27978
+ class ReservationBlockPhysicalTopology
27979
+ include ::Google::Protobuf::MessageExts
27980
+ extend ::Google::Protobuf::MessageExts::ClassMethods
27981
+ end
27982
+
27983
+ # @!attribute [rw] resource
27984
+ # @return [::Google::Cloud::Compute::V1::ReservationBlock]
27985
+ class ReservationBlocksGetResponse
27986
+ include ::Google::Protobuf::MessageExts
27987
+ extend ::Google::Protobuf::MessageExts::ClassMethods
27988
+ end
27989
+
27990
+ # A list of reservation blocks under a single reservation.
27991
+ # @!attribute [rw] id
27992
+ # @return [::String]
27993
+ # Unique identifier for the resource; defined by the server.
27994
+ # @!attribute [rw] items
27995
+ # @return [::Array<::Google::Cloud::Compute::V1::ReservationBlock>]
27996
+ # A list of reservation block resources.
27997
+ # @!attribute [rw] kind
27998
+ # @return [::String]
27999
+ # Type of the resource. Always compute#reservationBlock for a list of reservation blocks.
28000
+ # @!attribute [rw] next_page_token
28001
+ # @return [::String]
28002
+ # 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.
28003
+ # @!attribute [rw] self_link
28004
+ # @return [::String]
28005
+ # Server-defined URL for this resource.
28006
+ # @!attribute [rw] warning
28007
+ # @return [::Google::Cloud::Compute::V1::Warning]
28008
+ # Informational warning message.
28009
+ class ReservationBlocksListResponse
28010
+ include ::Google::Protobuf::MessageExts
28011
+ extend ::Google::Protobuf::MessageExts::ClassMethods
28012
+ end
28013
+
27616
28014
  # @!attribute [rw] id
27617
28015
  # @return [::String]
27618
28016
  # [Output Only] The unique identifier for the resource. This identifier is defined by the server.
@@ -27636,6 +28034,60 @@ module Google
27636
28034
  extend ::Google::Protobuf::MessageExts::ClassMethods
27637
28035
  end
27638
28036
 
28037
+ # @!attribute [rw] maintenance_scope
28038
+ # @return [::String]
28039
+ # Specifies if all, running or unused hosts are in scope for this request.
28040
+ # Check the MaintenanceScope enum for the list of possible values.
28041
+ class ReservationsBlocksPerformMaintenanceRequest
28042
+ include ::Google::Protobuf::MessageExts
28043
+ extend ::Google::Protobuf::MessageExts::ClassMethods
28044
+
28045
+ # Specifies if all, running or unused hosts are in scope for this request.
28046
+ module MaintenanceScope
28047
+ # A value indicating that the enum field is not set.
28048
+ UNDEFINED_MAINTENANCE_SCOPE = 0
28049
+
28050
+ # Trigger maintenance for all hosts belonging to this reservation irrespective of whether VMs are running on them or not.
28051
+ ALL = 64_897
28052
+
28053
+ # Internal only
28054
+ MAINTENANCE_SCOPE_UNSPECIFIED = 78_827_328
28055
+
28056
+ # Trigger maintenance only on the hosts belonging to this reservation which have VMs running on them.
28057
+ RUNNING_VMS = 535_770_588
28058
+
28059
+ # Trigger maintenance only on the hosts belonging to this reservation which do not have any VMs running on them. This is not allowed for Standard ExR
28060
+ UNUSED_CAPACITY = 212_724_995
28061
+ end
28062
+ end
28063
+
28064
+ # @!attribute [rw] maintenance_scope
28065
+ # @return [::String]
28066
+ # Specifies if all, running or unused hosts are in scope for this request.
28067
+ # Check the MaintenanceScope enum for the list of possible values.
28068
+ class ReservationsPerformMaintenanceRequest
28069
+ include ::Google::Protobuf::MessageExts
28070
+ extend ::Google::Protobuf::MessageExts::ClassMethods
28071
+
28072
+ # Specifies if all, running or unused hosts are in scope for this request.
28073
+ module MaintenanceScope
28074
+ # A value indicating that the enum field is not set.
28075
+ UNDEFINED_MAINTENANCE_SCOPE = 0
28076
+
28077
+ # Trigger maintenance for all hosts belonging to this reservation irrespective of whether VMs are running on them or not.
28078
+ ALL = 64_897
28079
+
28080
+ # Internal only
28081
+ MAINTENANCE_SCOPE_UNSPECIFIED = 78_827_328
28082
+
28083
+ # Trigger maintenance only on the hosts belonging to this reservation which have VMs running on them.
28084
+ RUNNING_VMS = 535_770_588
28085
+
28086
+ # Trigger maintenance only on the hosts belonging to this reservation which do not have any VMs running on them. This is not allowed for Standard ExR
28087
+ UNUSED_CAPACITY = 212_724_995
28088
+ end
28089
+ end
28090
+
27639
28091
  # @!attribute [rw] specific_sku_count
27640
28092
  # @return [::Integer]
27641
28093
  # Number of allocated resources can be resized with minimum = 1 and maximum = 1000.
@@ -28940,6 +29392,9 @@ module Google
28940
29392
  # @!attribute [rw] name
28941
29393
  # @return [::String]
28942
29394
  # Unique name of this Nat service. The name must be 1-63 characters long and comply with RFC1035.
29395
+ # @!attribute [rw] nat64_subnetworks
29396
+ # @return [::Array<::Google::Cloud::Compute::V1::RouterNatSubnetworkToNat64>]
29397
+ # List of Subnetwork resources whose traffic should be translated by NAT64 Gateway. It is used only when LIST_OF_IPV6_SUBNETWORKS is selected for the SubnetworkIpRangeToNat64Option above.
28943
29398
  # @!attribute [rw] nat_ip_allocate_option
28944
29399
  # @return [::String]
28945
29400
  # 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.
@@ -28954,6 +29409,10 @@ module Google
28954
29409
  # @return [::String]
28955
29410
  # 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.
28956
29411
  # Check the SourceSubnetworkIpRangesToNat enum for the list of possible values.
29412
+ # @!attribute [rw] source_subnetwork_ip_ranges_to_nat64
29413
+ # @return [::String]
29414
+ # Specify the Nat option for NAT64, which can take one of the following values: - ALL_IPV6_SUBNETWORKS: All of the IP ranges in every Subnetwork are allowed to Nat. - LIST_OF_IPV6_SUBNETWORKS: A list of Subnetworks are allowed to Nat (specified in the field nat64_subnetwork below) The default is NAT64_OPTION_UNSPECIFIED. Note that if this field contains NAT64_ALL_V6_SUBNETWORKS no other Router.Nat section in this region can also enable NAT64 for any Subnetworks in this network. Other Router.Nat sections can still be present to enable NAT44 only.
29415
+ # Check the SourceSubnetworkIpRangesToNat64 enum for the list of possible values.
28957
29416
  # @!attribute [rw] subnetworks
28958
29417
  # @return [::Array<::Google::Cloud::Compute::V1::RouterNatSubnetworkToNat>]
28959
29418
  # 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.
@@ -29036,6 +29495,18 @@ module Google
29036
29495
  LIST_OF_SUBNETWORKS = 517_542_270
29037
29496
  end
29038
29497
 
29498
+ # Specify the Nat option for NAT64, which can take one of the following values: - ALL_IPV6_SUBNETWORKS: All of the IP ranges in every Subnetwork are allowed to Nat. - LIST_OF_IPV6_SUBNETWORKS: A list of Subnetworks are allowed to Nat (specified in the field nat64_subnetwork below) The default is NAT64_OPTION_UNSPECIFIED. Note that if this field contains NAT64_ALL_V6_SUBNETWORKS no other Router.Nat section in this region can also enable NAT64 for any Subnetworks in this network. Other Router.Nat sections can still be present to enable NAT44 only.
29499
+ module SourceSubnetworkIpRangesToNat64
29500
+ # A value indicating that the enum field is not set.
29501
+ UNDEFINED_SOURCE_SUBNETWORK_IP_RANGES_TO_NAT64 = 0
29502
+
29503
+ # NAT64 is enabled for all the IPv6 subnet ranges. In dual stack subnets, NAT64 will only be enabled for IPv6-only VMs.
29504
+ ALL_IPV6_SUBNETWORKS = 341_632_747
29505
+
29506
+ # NAT64 is enabled for a list of IPv6 subnet ranges. In dual stack subnets, NAT64 will only be enabled for IPv6-only VMs. If this option is used, the nat64_subnetworks field must be specified.
29507
+ LIST_OF_IPV6_SUBNETWORKS = 521_079_860
29508
+ end
29509
+
29039
29510
  # Indicates whether this NAT is used for public or private IP translation. If unspecified, it defaults to PUBLIC.
29040
29511
  module Type
29041
29512
  # A value indicating that the enum field is not set.
@@ -29142,6 +29613,15 @@ module Google
29142
29613
  end
29143
29614
  end
29144
29615
 
29616
+ # Specifies a subnetwork to enable NAT64.
29617
+ # @!attribute [rw] name
29618
+ # @return [::String]
29619
+ # URL for the subnetwork resource that will use NAT64.
29620
+ class RouterNatSubnetworkToNat64
29621
+ include ::Google::Protobuf::MessageExts
29622
+ extend ::Google::Protobuf::MessageExts::ClassMethods
29623
+ end
29624
+
29145
29625
  # @!attribute [rw] best_routes
29146
29626
  # @return [::Array<::Google::Cloud::Compute::V1::Route>]
29147
29627
  # A list of the best dynamic routes for this Cloud Router's Virtual Private Cloud (VPC) network in the same region as this Cloud Router. Lists all of the best routes per prefix that are programmed into this region's VPC data plane. When global dynamic routing mode is turned on in the VPC network, this list can include cross-region dynamic routes from Cloud Routers in other regions.
@@ -31717,6 +32197,21 @@ module Google
31717
32197
  extend ::Google::Protobuf::MessageExts::ClassMethods
31718
32198
  end
31719
32199
 
32200
+ # A request message for MachineImages.SetLabels. See the method description for details.
32201
+ # @!attribute [rw] global_set_labels_request_resource
32202
+ # @return [::Google::Cloud::Compute::V1::GlobalSetLabelsRequest]
32203
+ # The body resource for this request
32204
+ # @!attribute [rw] project
32205
+ # @return [::String]
32206
+ # Project ID for this request.
32207
+ # @!attribute [rw] resource
32208
+ # @return [::String]
32209
+ # Name or id of the resource for this request.
32210
+ class SetLabelsMachineImageRequest
32211
+ include ::Google::Protobuf::MessageExts
32212
+ extend ::Google::Protobuf::MessageExts::ClassMethods
32213
+ end
32214
+
31720
32215
  # A request message for RegionDisks.SetLabels. See the method description for details.
31721
32216
  # @!attribute [rw] project
31722
32217
  # @return [::String]
@@ -32723,7 +33218,7 @@ module Google
32723
33218
  extend ::Google::Protobuf::MessageExts::ClassMethods
32724
33219
  end
32725
33220
 
32726
- # 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.
33221
+ # 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. LINT.IfChange
32727
33222
  # @!attribute [rw] architecture
32728
33223
  # @return [::String]
32729
33224
  # [Output Only] The architecture of the snapshot. Valid values are ARM64 or X86_64.
@@ -32752,6 +33247,9 @@ module Google
32752
33247
  # @!attribute [rw] enable_confidential_compute
32753
33248
  # @return [::Boolean]
32754
33249
  # Whether this snapshot is created from a confidential compute mode disk. [Output Only]: This field is not set by user, but from source disk.
33250
+ # @!attribute [rw] guest_flush
33251
+ # @return [::Boolean]
33252
+ # [Input Only] Whether to attempt an application consistent snapshot by informing the OS to prepare for the snapshot process.
32755
33253
  # @!attribute [rw] guest_os_features
32756
33254
  # @return [::Array<::Google::Cloud::Compute::V1::GuestOsFeature>]
32757
33255
  # [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.
@@ -34300,7 +34798,6 @@ module Google
34300
34798
  # Check the PrivateIpv6GoogleAccess enum for the list of possible values.
34301
34799
  # @!attribute [rw] purpose
34302
34800
  # @return [::String]
34303
- # The purpose of the resource. This field can be either PRIVATE, GLOBAL_MANAGED_PROXY, REGIONAL_MANAGED_PROXY, PEER_MIGRATION, PRIVATE_SERVICE_CONNECT or PRIVATE_NAT. 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. A subnet with purpose set to PEER_MIGRATION is used for subnet migration from one peered VPC to another. A subnet with purpose set to PRIVATE_NAT is used for Private NAT IP address by Private NAT Gateway. 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.
34304
34801
  # Check the Purpose enum for the list of possible values.
34305
34802
  # @!attribute [rw] region
34306
34803
  # @return [::String]
@@ -34369,7 +34866,6 @@ module Google
34369
34866
  ENABLE_OUTBOUND_VM_ACCESS_TO_GOOGLE = 288_210_263
34370
34867
  end
34371
34868
 
34372
- # The purpose of the resource. This field can be either PRIVATE, GLOBAL_MANAGED_PROXY, REGIONAL_MANAGED_PROXY, PEER_MIGRATION, PRIVATE_SERVICE_CONNECT or PRIVATE_NAT. 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. A subnet with purpose set to PEER_MIGRATION is used for subnet migration from one peered VPC to another. A subnet with purpose set to PRIVATE_NAT is used for Private NAT IP address by Private NAT Gateway. 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.
34373
34869
  module Purpose
34374
34870
  # A value indicating that the enum field is not set.
34375
34871
  UNDEFINED_PURPOSE = 0
@@ -37263,7 +37759,6 @@ module Google
37263
37759
  # Network URL.
37264
37760
  # @!attribute [rw] purpose
37265
37761
  # @return [::String]
37266
- # The purpose of the resource. This field can be either PRIVATE, GLOBAL_MANAGED_PROXY, REGIONAL_MANAGED_PROXY, PEER_MIGRATION, PRIVATE_SERVICE_CONNECT or PRIVATE_NAT. 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. A subnet with purpose set to PEER_MIGRATION is used for subnet migration from one peered VPC to another. A subnet with purpose set to PRIVATE_NAT is used for Private NAT IP address by Private NAT Gateway. 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.
37267
37762
  # Check the Purpose enum for the list of possible values.
37268
37763
  # @!attribute [rw] role
37269
37764
  # @return [::String]
@@ -37295,7 +37790,6 @@ module Google
37295
37790
  INTERNAL = 279_295_677
37296
37791
  end
37297
37792
 
37298
- # The purpose of the resource. This field can be either PRIVATE, GLOBAL_MANAGED_PROXY, REGIONAL_MANAGED_PROXY, PEER_MIGRATION, PRIVATE_SERVICE_CONNECT or PRIVATE_NAT. 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. A subnet with purpose set to PEER_MIGRATION is used for subnet migration from one peered VPC to another. A subnet with purpose set to PRIVATE_NAT is used for Private NAT IP address by Private NAT Gateway. 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.
37299
37793
  module Purpose
37300
37794
  # A value indicating that the enum field is not set.
37301
37795
  UNDEFINED_PURPOSE = 0
@@ -38039,7 +38533,7 @@ module Google
38039
38533
  extend ::Google::Protobuf::MessageExts::ClassMethods
38040
38534
  end
38041
38535
 
38042
- # [Output Only] Informational warning message.
38536
+ # Informational warning message.
38043
38537
  # @!attribute [rw] code
38044
38538
  # @return [::String]
38045
38539
  # [Output Only] A warning code, if applicable. For example, Compute Engine returns NO_RESULTS_ON_PAGE if there are no results in the response.