google-apis-compute_v1 0.112.0 → 0.113.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.
@@ -2991,7 +2991,8 @@ module Google
2991
2991
  # CACHE_ALL_STATIC Automatically cache static content, including common image
2992
2992
  # formats, media (video and audio), and web assets (JavaScript and CSS).
2993
2993
  # Requests and responses that are marked as uncacheable, as well as dynamic
2994
- # content (including HTML), will not be cached.
2994
+ # content (including HTML), will not be cached. If no value is provided for
2995
+ # cdnPolicy.cacheMode, it defaults to CACHE_ALL_STATIC.
2995
2996
  # Corresponds to the JSON property `cacheMode`
2996
2997
  # @return [String]
2997
2998
  attr_accessor :cache_mode
@@ -3903,7 +3904,8 @@ module Google
3903
3904
  # CACHE_ALL_STATIC Automatically cache static content, including common image
3904
3905
  # formats, media (video and audio), and web assets (JavaScript and CSS).
3905
3906
  # Requests and responses that are marked as uncacheable, as well as dynamic
3906
- # content (including HTML), will not be cached.
3907
+ # content (including HTML), will not be cached. If no value is provided for
3908
+ # cdnPolicy.cacheMode, it defaults to CACHE_ALL_STATIC.
3907
3909
  # Corresponds to the JSON property `cacheMode`
3908
3910
  # @return [String]
3909
3911
  attr_accessor :cache_mode
@@ -12959,12 +12961,10 @@ module Google
12959
12961
 
12960
12962
  # In response to a matching matchRule, the load balancer performs advanced
12961
12963
  # routing actions, such as URL rewrites and header transformations, before
12962
- # forwarding the request to the selected backend. If routeAction specifies any
12963
- # weightedBackendServices, service must not be set. Conversely if service is set,
12964
- # routeAction cannot contain any weightedBackendServices. Only one of
12965
- # urlRedirect, service or routeAction.weightedBackendService must be set. URL
12966
- # maps for classic Application Load Balancers only support the urlRewrite action
12967
- # within a route rule's routeAction.
12964
+ # forwarding the request to the selected backend. Only one of urlRedirect,
12965
+ # service or routeAction.weightedBackendService can be set. URL maps for classic
12966
+ # Application Load Balancers only support the urlRewrite action within a route
12967
+ # rule's routeAction.
12968
12968
  # Corresponds to the JSON property `routeAction`
12969
12969
  # @return [Google::Apis::ComputeV1::HttpRouteAction]
12970
12970
  attr_accessor :route_action
@@ -12972,10 +12972,8 @@ module Google
12972
12972
  # The full or partial URL of the backend service resource to which traffic is
12973
12973
  # directed if this rule is matched. If routeAction is also specified, advanced
12974
12974
  # routing actions, such as URL rewrites, take effect before sending the request
12975
- # to the backend. However, if service is specified, routeAction cannot contain
12976
- # any weightedBackendServices. Conversely, if routeAction specifies any
12977
- # weightedBackendServices, service must not be specified. Only one of
12978
- # urlRedirect, service or routeAction.weightedBackendService must be set.
12975
+ # to the backend. Only one of urlRedirect, service or routeAction.
12976
+ # weightedBackendService can be set.
12979
12977
  # Corresponds to the JSON property `service`
12980
12978
  # @return [String]
12981
12979
  attr_accessor :service
@@ -14877,6 +14875,11 @@ module Google
14877
14875
  # @return [String]
14878
14876
  attr_accessor :self_link
14879
14877
 
14878
+ # Standby policy for stopped and suspended instances.
14879
+ # Corresponds to the JSON property `standbyPolicy`
14880
+ # @return [Google::Apis::ComputeV1::InstanceGroupManagerStandbyPolicy]
14881
+ attr_accessor :standby_policy
14882
+
14880
14883
  # Stateful configuration for this Instanced Group Manager
14881
14884
  # Corresponds to the JSON property `statefulPolicy`
14882
14885
  # @return [Google::Apis::ComputeV1::StatefulPolicy]
@@ -14901,6 +14904,22 @@ module Google
14901
14904
  # @return [Fixnum]
14902
14905
  attr_accessor :target_size
14903
14906
 
14907
+ # The target number of stopped instances for this managed instance group. This
14908
+ # number changes when you: - Stop instance using the stopInstances method or
14909
+ # start instances using the startInstances method. - Manually change the
14910
+ # targetStoppedSize using the update method.
14911
+ # Corresponds to the JSON property `targetStoppedSize`
14912
+ # @return [Fixnum]
14913
+ attr_accessor :target_stopped_size
14914
+
14915
+ # The target number of suspended instances for this managed instance group. This
14916
+ # number changes when you: - Suspend instance using the suspendInstances method
14917
+ # or resume instances using the resumeInstances method. - Manually change the
14918
+ # targetSuspendedSize using the update method.
14919
+ # Corresponds to the JSON property `targetSuspendedSize`
14920
+ # @return [Fixnum]
14921
+ attr_accessor :target_suspended_size
14922
+
14904
14923
  # The update policy for this managed instance group.
14905
14924
  # Corresponds to the JSON property `updatePolicy`
14906
14925
  # @return [Google::Apis::ComputeV1::InstanceGroupManagerUpdatePolicy]
@@ -14950,10 +14969,13 @@ module Google
14950
14969
  @satisfies_pzi = args[:satisfies_pzi] if args.key?(:satisfies_pzi)
14951
14970
  @satisfies_pzs = args[:satisfies_pzs] if args.key?(:satisfies_pzs)
14952
14971
  @self_link = args[:self_link] if args.key?(:self_link)
14972
+ @standby_policy = args[:standby_policy] if args.key?(:standby_policy)
14953
14973
  @stateful_policy = args[:stateful_policy] if args.key?(:stateful_policy)
14954
14974
  @status = args[:status] if args.key?(:status)
14955
14975
  @target_pools = args[:target_pools] if args.key?(:target_pools)
14956
14976
  @target_size = args[:target_size] if args.key?(:target_size)
14977
+ @target_stopped_size = args[:target_stopped_size] if args.key?(:target_stopped_size)
14978
+ @target_suspended_size = args[:target_suspended_size] if args.key?(:target_suspended_size)
14957
14979
  @update_policy = args[:update_policy] if args.key?(:update_policy)
14958
14980
  @versions = args[:versions] if args.key?(:versions)
14959
14981
  @zone = args[:zone] if args.key?(:zone)
@@ -15937,6 +15959,35 @@ module Google
15937
15959
  end
15938
15960
  end
15939
15961
 
15962
+ #
15963
+ class InstanceGroupManagerStandbyPolicy
15964
+ include Google::Apis::Core::Hashable
15965
+
15966
+ # Specifies the number of seconds that the MIG should wait to suspend or stop a
15967
+ # VM after that VM was created. The initial delay gives the initialization
15968
+ # script the time to prepare your VM for a quick scale out. The value of initial
15969
+ # delay must be between 0 and 3600 seconds. The default value is 0.
15970
+ # Corresponds to the JSON property `initialDelaySec`
15971
+ # @return [Fixnum]
15972
+ attr_accessor :initial_delay_sec
15973
+
15974
+ # Defines how a MIG resumes or starts VMs from a standby pool when the group
15975
+ # scales out. The default mode is `MANUAL`.
15976
+ # Corresponds to the JSON property `mode`
15977
+ # @return [String]
15978
+ attr_accessor :mode
15979
+
15980
+ def initialize(**args)
15981
+ update!(**args)
15982
+ end
15983
+
15984
+ # Update properties of this object
15985
+ def update!(**args)
15986
+ @initial_delay_sec = args[:initial_delay_sec] if args.key?(:initial_delay_sec)
15987
+ @mode = args[:mode] if args.key?(:mode)
15988
+ end
15989
+ end
15990
+
15940
15991
  #
15941
15992
  class InstanceGroupManagerStatus
15942
15993
  include Google::Apis::Core::Hashable
@@ -16549,6 +16600,26 @@ module Google
16549
16600
  end
16550
16601
  end
16551
16602
 
16603
+ #
16604
+ class InstanceGroupManagersResumeInstancesRequest
16605
+ include Google::Apis::Core::Hashable
16606
+
16607
+ # The URLs of one or more instances to resume. This can be a full URL or a
16608
+ # partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].
16609
+ # Corresponds to the JSON property `instances`
16610
+ # @return [Array<String>]
16611
+ attr_accessor :instances
16612
+
16613
+ def initialize(**args)
16614
+ update!(**args)
16615
+ end
16616
+
16617
+ # Update properties of this object
16618
+ def update!(**args)
16619
+ @instances = args[:instances] if args.key?(:instances)
16620
+ end
16621
+ end
16622
+
16552
16623
  #
16553
16624
  class InstanceGroupManagersScopedList
16554
16625
  include Google::Apis::Core::Hashable
@@ -16697,6 +16768,82 @@ module Google
16697
16768
  end
16698
16769
  end
16699
16770
 
16771
+ #
16772
+ class InstanceGroupManagersStartInstancesRequest
16773
+ include Google::Apis::Core::Hashable
16774
+
16775
+ # The URLs of one or more instances to start. This can be a full URL or a
16776
+ # partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].
16777
+ # Corresponds to the JSON property `instances`
16778
+ # @return [Array<String>]
16779
+ attr_accessor :instances
16780
+
16781
+ def initialize(**args)
16782
+ update!(**args)
16783
+ end
16784
+
16785
+ # Update properties of this object
16786
+ def update!(**args)
16787
+ @instances = args[:instances] if args.key?(:instances)
16788
+ end
16789
+ end
16790
+
16791
+ #
16792
+ class InstanceGroupManagersStopInstancesRequest
16793
+ include Google::Apis::Core::Hashable
16794
+
16795
+ # If this flag is set to true, the Instance Group Manager will proceed to stop
16796
+ # the instances, skipping initialization on them.
16797
+ # Corresponds to the JSON property `forceStop`
16798
+ # @return [Boolean]
16799
+ attr_accessor :force_stop
16800
+ alias_method :force_stop?, :force_stop
16801
+
16802
+ # The URLs of one or more instances to stop. This can be a full URL or a partial
16803
+ # URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].
16804
+ # Corresponds to the JSON property `instances`
16805
+ # @return [Array<String>]
16806
+ attr_accessor :instances
16807
+
16808
+ def initialize(**args)
16809
+ update!(**args)
16810
+ end
16811
+
16812
+ # Update properties of this object
16813
+ def update!(**args)
16814
+ @force_stop = args[:force_stop] if args.key?(:force_stop)
16815
+ @instances = args[:instances] if args.key?(:instances)
16816
+ end
16817
+ end
16818
+
16819
+ #
16820
+ class InstanceGroupManagersSuspendInstancesRequest
16821
+ include Google::Apis::Core::Hashable
16822
+
16823
+ # If this flag is set to true, the Instance Group Manager will proceed to
16824
+ # suspend the instances, skipping initialization on them.
16825
+ # Corresponds to the JSON property `forceSuspend`
16826
+ # @return [Boolean]
16827
+ attr_accessor :force_suspend
16828
+ alias_method :force_suspend?, :force_suspend
16829
+
16830
+ # The URLs of one or more instances to suspend. This can be a full URL or a
16831
+ # partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].
16832
+ # Corresponds to the JSON property `instances`
16833
+ # @return [Array<String>]
16834
+ attr_accessor :instances
16835
+
16836
+ def initialize(**args)
16837
+ update!(**args)
16838
+ end
16839
+
16840
+ # Update properties of this object
16841
+ def update!(**args)
16842
+ @force_suspend = args[:force_suspend] if args.key?(:force_suspend)
16843
+ @instances = args[:instances] if args.key?(:instances)
16844
+ end
16845
+ end
16846
+
16700
16847
  # InstanceGroupManagers.updatePerInstanceConfigs
16701
16848
  class InstanceGroupManagersUpdatePerInstanceConfigsReq
16702
16849
  include Google::Apis::Core::Hashable
@@ -20599,7 +20746,7 @@ module Google
20599
20746
  attr_accessor :availability_zone
20600
20747
 
20601
20748
  # [Output only] List of features available at this InterconnectLocation, which
20602
- # can take one of the following values: - MACSEC
20749
+ # can take one of the following values: - IF_MACSEC
20603
20750
  # Corresponds to the JSON property `availableFeatures`
20604
20751
  # @return [Array<String>]
20605
20752
  attr_accessor :available_features
@@ -21539,7 +21686,7 @@ module Google
21539
21686
  # @return [String]
21540
21687
  attr_accessor :name
21541
21688
 
21542
- #
21689
+ # [Input Only] Deprecated.
21543
21690
  # Corresponds to the JSON property `resourceRequirements`
21544
21691
  # @return [Google::Apis::ComputeV1::LicenseResourceRequirements]
21545
21692
  attr_accessor :resource_requirements
@@ -21709,14 +21856,14 @@ module Google
21709
21856
  class LicenseResourceRequirements
21710
21857
  include Google::Apis::Core::Hashable
21711
21858
 
21712
- # Minimum number of guest cpus required to use the Instance. Enforced at
21713
- # Instance creation and Instance start.
21859
+ # [Input Only] Deprecated. This field no longer reflects the minimum number of
21860
+ # guest cpus required to use the Instance.
21714
21861
  # Corresponds to the JSON property `minGuestCpuCount`
21715
21862
  # @return [Fixnum]
21716
21863
  attr_accessor :min_guest_cpu_count
21717
21864
 
21718
- # Minimum memory required to use the Instance. Enforced at Instance creation and
21719
- # Instance start.
21865
+ # [Input Only] Deprecated. This field no longer reflects the minimum memory
21866
+ # required to use the Instance.
21720
21867
  # Corresponds to the JSON property `minMemoryMb`
21721
21868
  # @return [Fixnum]
21722
21869
  attr_accessor :min_memory_mb
@@ -23392,6 +23539,15 @@ module Google
23392
23539
  # @return [String]
23393
23540
  attr_accessor :network_firewall_policy_enforcement_order
23394
23541
 
23542
+ # A full or partial URL of the network profile to apply to this network. This
23543
+ # field can be set only at resource creation time. For example, the following
23544
+ # are valid URLs: - https://www.googleapis.com/compute/`api_version`/projects/`
23545
+ # project_id`/global/networkProfiles/`network_profile_name` - projects/`
23546
+ # project_id`/global/networkProfiles/`network_profile_name`
23547
+ # Corresponds to the JSON property `networkProfile`
23548
+ # @return [String]
23549
+ attr_accessor :network_profile
23550
+
23395
23551
  # [Output Only] A list of network peerings for the resource.
23396
23552
  # Corresponds to the JSON property `peerings`
23397
23553
  # @return [Array<Google::Apis::ComputeV1::NetworkPeering>]
@@ -23439,6 +23595,7 @@ module Google
23439
23595
  @mtu = args[:mtu] if args.key?(:mtu)
23440
23596
  @name = args[:name] if args.key?(:name)
23441
23597
  @network_firewall_policy_enforcement_order = args[:network_firewall_policy_enforcement_order] if args.key?(:network_firewall_policy_enforcement_order)
23598
+ @network_profile = args[:network_profile] if args.key?(:network_profile)
23442
23599
  @peerings = args[:peerings] if args.key?(:peerings)
23443
23600
  @routing_config = args[:routing_config] if args.key?(:routing_config)
23444
23601
  @self_link = args[:self_link] if args.key?(:self_link)
@@ -25596,12 +25753,412 @@ module Google
25596
25753
  end
25597
25754
  end
25598
25755
 
25756
+ # NetworkProfile represents a Google managed network profile resource.
25757
+ class NetworkProfile
25758
+ include Google::Apis::Core::Hashable
25759
+
25760
+ # [Output Only] Creation timestamp in RFC3339 text format.
25761
+ # Corresponds to the JSON property `creationTimestamp`
25762
+ # @return [String]
25763
+ attr_accessor :creation_timestamp
25764
+
25765
+ # [Output Only] An optional description of this resource.
25766
+ # Corresponds to the JSON property `description`
25767
+ # @return [String]
25768
+ attr_accessor :description
25769
+
25770
+ # [Output Only] Features supported by the network.
25771
+ # Corresponds to the JSON property `features`
25772
+ # @return [Google::Apis::ComputeV1::NetworkProfileNetworkFeatures]
25773
+ attr_accessor :features
25774
+
25775
+ # [Output Only] The unique identifier for the resource. This identifier is
25776
+ # defined by the server.
25777
+ # Corresponds to the JSON property `id`
25778
+ # @return [Fixnum]
25779
+ attr_accessor :id
25780
+
25781
+ # [Output Only] Type of the resource. Always compute#networkProfile for network
25782
+ # profiles.
25783
+ # Corresponds to the JSON property `kind`
25784
+ # @return [String]
25785
+ attr_accessor :kind
25786
+
25787
+ # [Output Only] Location to which the network is restricted.
25788
+ # Corresponds to the JSON property `location`
25789
+ # @return [Google::Apis::ComputeV1::NetworkProfileLocation]
25790
+ attr_accessor :location
25791
+
25792
+ # [Output Only] Name of the resource.
25793
+ # Corresponds to the JSON property `name`
25794
+ # @return [String]
25795
+ attr_accessor :name
25796
+
25797
+ # [Output Only] Server-defined URL for the resource.
25798
+ # Corresponds to the JSON property `selfLink`
25799
+ # @return [String]
25800
+ attr_accessor :self_link
25801
+
25802
+ # [Output Only] Server-defined URL for this resource with the resource id.
25803
+ # Corresponds to the JSON property `selfLinkWithId`
25804
+ # @return [String]
25805
+ attr_accessor :self_link_with_id
25806
+
25807
+ # [Output Only] Zone to which the network is restricted.
25808
+ # Corresponds to the JSON property `zone`
25809
+ # @return [String]
25810
+ attr_accessor :zone
25811
+
25812
+ def initialize(**args)
25813
+ update!(**args)
25814
+ end
25815
+
25816
+ # Update properties of this object
25817
+ def update!(**args)
25818
+ @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
25819
+ @description = args[:description] if args.key?(:description)
25820
+ @features = args[:features] if args.key?(:features)
25821
+ @id = args[:id] if args.key?(:id)
25822
+ @kind = args[:kind] if args.key?(:kind)
25823
+ @location = args[:location] if args.key?(:location)
25824
+ @name = args[:name] if args.key?(:name)
25825
+ @self_link = args[:self_link] if args.key?(:self_link)
25826
+ @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
25827
+ @zone = args[:zone] if args.key?(:zone)
25828
+ end
25829
+ end
25830
+
25831
+ #
25832
+ class NetworkProfileLocation
25833
+ include Google::Apis::Core::Hashable
25834
+
25835
+ #
25836
+ # Corresponds to the JSON property `name`
25837
+ # @return [String]
25838
+ attr_accessor :name
25839
+
25840
+ #
25841
+ # Corresponds to the JSON property `scope`
25842
+ # @return [String]
25843
+ attr_accessor :scope
25844
+
25845
+ def initialize(**args)
25846
+ update!(**args)
25847
+ end
25848
+
25849
+ # Update properties of this object
25850
+ def update!(**args)
25851
+ @name = args[:name] if args.key?(:name)
25852
+ @scope = args[:scope] if args.key?(:scope)
25853
+ end
25854
+ end
25855
+
25856
+ #
25857
+ class NetworkProfileNetworkFeatures
25858
+ include Google::Apis::Core::Hashable
25859
+
25860
+ # Specifies what address purposes are supported. If empty, all address purposes
25861
+ # are supported.
25862
+ # Corresponds to the JSON property `addressPurposes`
25863
+ # @return [Array<String>]
25864
+ attr_accessor :address_purposes
25865
+
25866
+ # Specifies whether alias IP ranges (and secondary address ranges) are allowed.
25867
+ # Corresponds to the JSON property `allowAliasIpRanges`
25868
+ # @return [String]
25869
+ attr_accessor :allow_alias_ip_ranges
25870
+
25871
+ # Specifies whether auto mode subnet creation is allowed.
25872
+ # Corresponds to the JSON property `allowAutoModeSubnet`
25873
+ # @return [String]
25874
+ attr_accessor :allow_auto_mode_subnet
25875
+
25876
+ # Specifies whether firewalls for Class D address ranges are supported.
25877
+ # Corresponds to the JSON property `allowClassDFirewalls`
25878
+ # @return [String]
25879
+ attr_accessor :allow_class_d_firewalls
25880
+
25881
+ # Specifies whether cloud NAT creation is allowed.
25882
+ # Corresponds to the JSON property `allowCloudNat`
25883
+ # @return [String]
25884
+ attr_accessor :allow_cloud_nat
25885
+
25886
+ # Specifies whether cloud router creation is allowed.
25887
+ # Corresponds to the JSON property `allowCloudRouter`
25888
+ # @return [String]
25889
+ attr_accessor :allow_cloud_router
25890
+
25891
+ # Specifies whether VMs are allowed to have external IP access on network
25892
+ # interfaces connected to this VPC.
25893
+ # Corresponds to the JSON property `allowExternalIpAccess`
25894
+ # @return [String]
25895
+ attr_accessor :allow_external_ip_access
25896
+
25897
+ # Specifies whether Cloud Interconnect creation is allowed.
25898
+ # Corresponds to the JSON property `allowInterconnect`
25899
+ # @return [String]
25900
+ attr_accessor :allow_interconnect
25901
+
25902
+ # Specifies whether cloud load balancing is allowed.
25903
+ # Corresponds to the JSON property `allowLoadBalancing`
25904
+ # @return [String]
25905
+ attr_accessor :allow_load_balancing
25906
+
25907
+ # Specifies whether multi-nic in the same network is allowed.
25908
+ # Corresponds to the JSON property `allowMultiNicInSameNetwork`
25909
+ # @return [String]
25910
+ attr_accessor :allow_multi_nic_in_same_network
25911
+
25912
+ # Specifies whether Packet Mirroring 1.0 is supported.
25913
+ # Corresponds to the JSON property `allowPacketMirroring`
25914
+ # @return [String]
25915
+ attr_accessor :allow_packet_mirroring
25916
+
25917
+ # Specifies whether private Google access is allowed.
25918
+ # Corresponds to the JSON property `allowPrivateGoogleAccess`
25919
+ # @return [String]
25920
+ attr_accessor :allow_private_google_access
25921
+
25922
+ # Specifies whether PSC creation is allowed.
25923
+ # Corresponds to the JSON property `allowPsc`
25924
+ # @return [String]
25925
+ attr_accessor :allow_psc
25926
+
25927
+ # Specifies whether unicast within the same network is allowed.
25928
+ # Corresponds to the JSON property `allowSameNetworkUnicast`
25929
+ # @return [String]
25930
+ attr_accessor :allow_same_network_unicast
25931
+
25932
+ # Specifies whether static route creation is allowed.
25933
+ # Corresponds to the JSON property `allowStaticRoutes`
25934
+ # @return [String]
25935
+ attr_accessor :allow_static_routes
25936
+
25937
+ # Specifies whether sub interfaces are allowed.
25938
+ # Corresponds to the JSON property `allowSubInterfaces`
25939
+ # @return [String]
25940
+ attr_accessor :allow_sub_interfaces
25941
+
25942
+ # Specifies whether VPC peering is allowed.
25943
+ # Corresponds to the JSON property `allowVpcPeering`
25944
+ # @return [String]
25945
+ attr_accessor :allow_vpc_peering
25946
+
25947
+ # Specifies whether VPN creation is allowed.
25948
+ # Corresponds to the JSON property `allowVpn`
25949
+ # @return [String]
25950
+ attr_accessor :allow_vpn
25951
+
25952
+ # If set, limits the interface types that the network supports. If empty, all
25953
+ # interface types are supported.
25954
+ # Corresponds to the JSON property `interfaceTypes`
25955
+ # @return [Array<String>]
25956
+ attr_accessor :interface_types
25957
+
25958
+ # Specifies which subnetwork purposes are supported.
25959
+ # Corresponds to the JSON property `subnetPurposes`
25960
+ # @return [Array<String>]
25961
+ attr_accessor :subnet_purposes
25962
+
25963
+ # Specifies which subnetwork stack types are supported.
25964
+ # Corresponds to the JSON property `subnetStackTypes`
25965
+ # @return [Array<String>]
25966
+ attr_accessor :subnet_stack_types
25967
+
25968
+ # Specifies which type of unicast is supported.
25969
+ # Corresponds to the JSON property `unicast`
25970
+ # @return [String]
25971
+ attr_accessor :unicast
25972
+
25973
+ def initialize(**args)
25974
+ update!(**args)
25975
+ end
25976
+
25977
+ # Update properties of this object
25978
+ def update!(**args)
25979
+ @address_purposes = args[:address_purposes] if args.key?(:address_purposes)
25980
+ @allow_alias_ip_ranges = args[:allow_alias_ip_ranges] if args.key?(:allow_alias_ip_ranges)
25981
+ @allow_auto_mode_subnet = args[:allow_auto_mode_subnet] if args.key?(:allow_auto_mode_subnet)
25982
+ @allow_class_d_firewalls = args[:allow_class_d_firewalls] if args.key?(:allow_class_d_firewalls)
25983
+ @allow_cloud_nat = args[:allow_cloud_nat] if args.key?(:allow_cloud_nat)
25984
+ @allow_cloud_router = args[:allow_cloud_router] if args.key?(:allow_cloud_router)
25985
+ @allow_external_ip_access = args[:allow_external_ip_access] if args.key?(:allow_external_ip_access)
25986
+ @allow_interconnect = args[:allow_interconnect] if args.key?(:allow_interconnect)
25987
+ @allow_load_balancing = args[:allow_load_balancing] if args.key?(:allow_load_balancing)
25988
+ @allow_multi_nic_in_same_network = args[:allow_multi_nic_in_same_network] if args.key?(:allow_multi_nic_in_same_network)
25989
+ @allow_packet_mirroring = args[:allow_packet_mirroring] if args.key?(:allow_packet_mirroring)
25990
+ @allow_private_google_access = args[:allow_private_google_access] if args.key?(:allow_private_google_access)
25991
+ @allow_psc = args[:allow_psc] if args.key?(:allow_psc)
25992
+ @allow_same_network_unicast = args[:allow_same_network_unicast] if args.key?(:allow_same_network_unicast)
25993
+ @allow_static_routes = args[:allow_static_routes] if args.key?(:allow_static_routes)
25994
+ @allow_sub_interfaces = args[:allow_sub_interfaces] if args.key?(:allow_sub_interfaces)
25995
+ @allow_vpc_peering = args[:allow_vpc_peering] if args.key?(:allow_vpc_peering)
25996
+ @allow_vpn = args[:allow_vpn] if args.key?(:allow_vpn)
25997
+ @interface_types = args[:interface_types] if args.key?(:interface_types)
25998
+ @subnet_purposes = args[:subnet_purposes] if args.key?(:subnet_purposes)
25999
+ @subnet_stack_types = args[:subnet_stack_types] if args.key?(:subnet_stack_types)
26000
+ @unicast = args[:unicast] if args.key?(:unicast)
26001
+ end
26002
+ end
26003
+
26004
+ # Contains a list of network profiles.
26005
+ class NetworkProfilesListResponse
26006
+ include Google::Apis::Core::Hashable
26007
+
26008
+ #
26009
+ # Corresponds to the JSON property `etag`
26010
+ # @return [String]
26011
+ attr_accessor :etag
26012
+
26013
+ # [Output Only] Unique identifier for the resource; defined by the server.
26014
+ # Corresponds to the JSON property `id`
26015
+ # @return [String]
26016
+ attr_accessor :id
26017
+
26018
+ # A list of NetworkProfile resources.
26019
+ # Corresponds to the JSON property `items`
26020
+ # @return [Array<Google::Apis::ComputeV1::NetworkProfile>]
26021
+ attr_accessor :items
26022
+
26023
+ # [Output Only] Type of resource. Always compute#networkProfileList for network
26024
+ # profiles.
26025
+ # Corresponds to the JSON property `kind`
26026
+ # @return [String]
26027
+ attr_accessor :kind
26028
+
26029
+ # [Output Only] This token allows you to get the next page of results for list
26030
+ # requests. If the number of results is larger than maxResults, use the
26031
+ # nextPageToken as a value for the query parameter pageToken in the next list
26032
+ # request. Subsequent list requests will have their own nextPageToken to
26033
+ # continue paging through the results.
26034
+ # Corresponds to the JSON property `nextPageToken`
26035
+ # @return [String]
26036
+ attr_accessor :next_page_token
26037
+
26038
+ # [Output Only] Server-defined URL for this resource.
26039
+ # Corresponds to the JSON property `selfLink`
26040
+ # @return [String]
26041
+ attr_accessor :self_link
26042
+
26043
+ # [Output Only] Unreachable resources. end_interface:
26044
+ # MixerListResponseWithEtagBuilder
26045
+ # Corresponds to the JSON property `unreachables`
26046
+ # @return [Array<String>]
26047
+ attr_accessor :unreachables
26048
+
26049
+ # [Output Only] Informational warning message.
26050
+ # Corresponds to the JSON property `warning`
26051
+ # @return [Google::Apis::ComputeV1::NetworkProfilesListResponse::Warning]
26052
+ attr_accessor :warning
26053
+
26054
+ def initialize(**args)
26055
+ update!(**args)
26056
+ end
26057
+
26058
+ # Update properties of this object
26059
+ def update!(**args)
26060
+ @etag = args[:etag] if args.key?(:etag)
26061
+ @id = args[:id] if args.key?(:id)
26062
+ @items = args[:items] if args.key?(:items)
26063
+ @kind = args[:kind] if args.key?(:kind)
26064
+ @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
26065
+ @self_link = args[:self_link] if args.key?(:self_link)
26066
+ @unreachables = args[:unreachables] if args.key?(:unreachables)
26067
+ @warning = args[:warning] if args.key?(:warning)
26068
+ end
26069
+
26070
+ # [Output Only] Informational warning message.
26071
+ class Warning
26072
+ include Google::Apis::Core::Hashable
26073
+
26074
+ # [Output Only] A warning code, if applicable. For example, Compute Engine
26075
+ # returns NO_RESULTS_ON_PAGE if there are no results in the response.
26076
+ # Corresponds to the JSON property `code`
26077
+ # @return [String]
26078
+ attr_accessor :code
26079
+
26080
+ # [Output Only] Metadata about this warning in key: value format. For example: "
26081
+ # data": [ ` "key": "scope", "value": "zones/us-east1-d" `
26082
+ # Corresponds to the JSON property `data`
26083
+ # @return [Array<Google::Apis::ComputeV1::NetworkProfilesListResponse::Warning::Datum>]
26084
+ attr_accessor :data
26085
+
26086
+ # [Output Only] A human-readable description of the warning code.
26087
+ # Corresponds to the JSON property `message`
26088
+ # @return [String]
26089
+ attr_accessor :message
26090
+
26091
+ def initialize(**args)
26092
+ update!(**args)
26093
+ end
26094
+
26095
+ # Update properties of this object
26096
+ def update!(**args)
26097
+ @code = args[:code] if args.key?(:code)
26098
+ @data = args[:data] if args.key?(:data)
26099
+ @message = args[:message] if args.key?(:message)
26100
+ end
26101
+
26102
+ #
26103
+ class Datum
26104
+ include Google::Apis::Core::Hashable
26105
+
26106
+ # [Output Only] A key that provides more detail on the warning being returned.
26107
+ # For example, for warnings where there are no results in a list request for a
26108
+ # particular zone, this key might be scope and the key value might be the zone
26109
+ # name. Other examples might be a key indicating a deprecated resource and a
26110
+ # suggested replacement, or a warning about invalid network settings (for
26111
+ # example, if an instance attempts to perform IP forwarding but is not enabled
26112
+ # for IP forwarding).
26113
+ # Corresponds to the JSON property `key`
26114
+ # @return [String]
26115
+ attr_accessor :key
26116
+
26117
+ # [Output Only] A warning data value corresponding to the key.
26118
+ # Corresponds to the JSON property `value`
26119
+ # @return [String]
26120
+ attr_accessor :value
26121
+
26122
+ def initialize(**args)
26123
+ update!(**args)
26124
+ end
26125
+
26126
+ # Update properties of this object
26127
+ def update!(**args)
26128
+ @key = args[:key] if args.key?(:key)
26129
+ @value = args[:value] if args.key?(:value)
26130
+ end
26131
+ end
26132
+ end
26133
+ end
26134
+
25599
26135
  # A routing configuration attached to a network resource. The message includes
25600
26136
  # the list of routers associated with the network, and a flag indicating the
25601
26137
  # type of routing behavior to enforce network-wide.
25602
26138
  class NetworkRoutingConfig
25603
26139
  include Google::Apis::Core::Hashable
25604
26140
 
26141
+ # Enable comparison of Multi-Exit Discriminators (MED) across routes with
26142
+ # different neighbor ASNs when using the STANDARD BGP best path selection
26143
+ # algorithm.
26144
+ # Corresponds to the JSON property `bgpAlwaysCompareMed`
26145
+ # @return [Boolean]
26146
+ attr_accessor :bgp_always_compare_med
26147
+ alias_method :bgp_always_compare_med?, :bgp_always_compare_med
26148
+
26149
+ # The BGP best path selection algorithm to be employed within this network for
26150
+ # dynamic routes learned by Cloud Routers. Can be LEGACY (default) or STANDARD.
26151
+ # Corresponds to the JSON property `bgpBestPathSelectionMode`
26152
+ # @return [String]
26153
+ attr_accessor :bgp_best_path_selection_mode
26154
+
26155
+ # Allows to define a preferred approach for handling inter-region cost in the
26156
+ # selection process when using the STANDARD BGP best path selection algorithm.
26157
+ # Can be DEFAULT or ADD_COST_TO_MED.
26158
+ # Corresponds to the JSON property `bgpInterRegionCost`
26159
+ # @return [String]
26160
+ attr_accessor :bgp_inter_region_cost
26161
+
25605
26162
  # The network-wide routing mode to use. If set to REGIONAL, this network's Cloud
25606
26163
  # Routers will only advertise routes with subnets of this network in the same
25607
26164
  # region as the router. If set to GLOBAL, this network's Cloud Routers will
@@ -25616,6 +26173,9 @@ module Google
25616
26173
 
25617
26174
  # Update properties of this object
25618
26175
  def update!(**args)
26176
+ @bgp_always_compare_med = args[:bgp_always_compare_med] if args.key?(:bgp_always_compare_med)
26177
+ @bgp_best_path_selection_mode = args[:bgp_best_path_selection_mode] if args.key?(:bgp_best_path_selection_mode)
26178
+ @bgp_inter_region_cost = args[:bgp_inter_region_cost] if args.key?(:bgp_inter_region_cost)
25619
26179
  @routing_mode = args[:routing_mode] if args.key?(:routing_mode)
25620
26180
  end
25621
26181
  end
@@ -29315,11 +29875,8 @@ module Google
29315
29875
  # defaultRouteAction takes effect when none of the pathRules or routeRules match.
29316
29876
  # The load balancer performs advanced routing actions, such as URL rewrites and
29317
29877
  # header transformations, before forwarding the request to the selected backend.
29318
- # If defaultRouteAction specifies any weightedBackendServices, defaultService
29319
- # must not be set. Conversely if defaultService is set, defaultRouteAction
29320
- # cannot contain any weightedBackendServices. If defaultRouteAction is specified,
29321
- # don't set defaultUrlRedirect. If defaultRouteAction.weightedBackendServices
29322
- # is specified, don't set defaultService. URL maps for classic Application Load
29878
+ # Only one of defaultUrlRedirect, defaultService or defaultRouteAction.
29879
+ # weightedBackendService can be set. URL maps for classic Application Load
29323
29880
  # Balancers only support the urlRewrite action within a path matcher's
29324
29881
  # defaultRouteAction.
29325
29882
  # Corresponds to the JSON property `defaultRouteAction`
@@ -29333,14 +29890,11 @@ module Google
29333
29890
  # backendService - compute/v1/projects/project/global/backendServices/
29334
29891
  # backendService - global/backendServices/backendService If defaultRouteAction
29335
29892
  # is also specified, advanced routing actions, such as URL rewrites, take effect
29336
- # before sending the request to the backend. However, if defaultService is
29337
- # specified, defaultRouteAction cannot contain any weightedBackendServices.
29338
- # Conversely, if defaultRouteAction specifies any weightedBackendServices,
29339
- # defaultService must not be specified. If defaultService is specified, then set
29340
- # either defaultUrlRedirect or defaultRouteAction.weightedBackendService. Don't
29341
- # set both. Authorization requires one or more of the following Google IAM
29342
- # permissions on the specified resource default_service: - compute.
29343
- # backendBuckets.use - compute.backendServices.use
29893
+ # before sending the request to the backend. Only one of defaultUrlRedirect,
29894
+ # defaultService or defaultRouteAction.weightedBackendService can be set.
29895
+ # Authorization requires one or more of the following Google IAM permissions on
29896
+ # the specified resource default_service: - compute.backendBuckets.use - compute.
29897
+ # backendServices.use
29344
29898
  # Corresponds to the JSON property `defaultService`
29345
29899
  # @return [String]
29346
29900
  attr_accessor :default_service
@@ -29424,11 +29978,10 @@ module Google
29424
29978
 
29425
29979
  # In response to a matching path, the load balancer performs advanced routing
29426
29980
  # actions, such as URL rewrites and header transformations, before forwarding
29427
- # the request to the selected backend. If routeAction specifies any
29428
- # weightedBackendServices, service must not be set. Conversely if service is set,
29429
- # routeAction cannot contain any weightedBackendServices. Only one of
29430
- # routeAction or urlRedirect must be set. URL maps for classic Application Load
29431
- # Balancers only support the urlRewrite action within a path rule's routeAction.
29981
+ # the request to the selected backend. Only one of urlRedirect, service or
29982
+ # routeAction.weightedBackendService can be set. URL maps for classic
29983
+ # Application Load Balancers only support the urlRewrite action within a path
29984
+ # rule's routeAction.
29432
29985
  # Corresponds to the JSON property `routeAction`
29433
29986
  # @return [Google::Apis::ComputeV1::HttpRouteAction]
29434
29987
  attr_accessor :route_action
@@ -29436,10 +29989,8 @@ module Google
29436
29989
  # The full or partial URL of the backend service resource to which traffic is
29437
29990
  # directed if this rule is matched. If routeAction is also specified, advanced
29438
29991
  # routing actions, such as URL rewrites, take effect before sending the request
29439
- # to the backend. However, if service is specified, routeAction cannot contain
29440
- # any weightedBackendServices. Conversely, if routeAction specifies any
29441
- # weightedBackendServices, service must not be specified. Only one of
29442
- # urlRedirect, service or routeAction.weightedBackendService must be set.
29992
+ # to the backend. Only one of urlRedirect, service or routeAction.
29993
+ # weightedBackendService can be set.
29443
29994
  # Corresponds to the JSON property `service`
29444
29995
  # @return [String]
29445
29996
  attr_accessor :service
@@ -29480,7 +30031,7 @@ module Google
29480
30031
  # Serves as a merge key during UpdatePerInstanceConfigs operations, that is, if
29481
30032
  # a per-instance configuration with the same name exists then it will be updated,
29482
30033
  # otherwise a new one will be created for the VM instance with the same name.
29483
- # An attempt to create a per-instance configconfiguration for a VM instance that
30034
+ # An attempt to create a per-instance configuration for a VM instance that
29484
30035
  # either doesn't exist or is not part of the group will result in an error.
29485
30036
  # Corresponds to the JSON property `name`
29486
30037
  # @return [String]
@@ -29795,7 +30346,7 @@ module Google
29795
30346
  # @return [String]
29796
30347
  attr_accessor :description
29797
30348
 
29798
- # Restricted features enabled for use on this project.
30349
+ # An optional list of restricted features enabled for use on this project.
29799
30350
  # Corresponds to the JSON property `enabledFeatures`
29800
30351
  # @return [Array<String>]
29801
30352
  attr_accessor :enabled_features
@@ -32068,6 +32619,26 @@ module Google
32068
32619
  end
32069
32620
  end
32070
32621
 
32622
+ #
32623
+ class RegionInstanceGroupManagersResumeInstancesRequest
32624
+ include Google::Apis::Core::Hashable
32625
+
32626
+ # The URLs of one or more instances to resume. This can be a full URL or a
32627
+ # partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].
32628
+ # Corresponds to the JSON property `instances`
32629
+ # @return [Array<String>]
32630
+ attr_accessor :instances
32631
+
32632
+ def initialize(**args)
32633
+ update!(**args)
32634
+ end
32635
+
32636
+ # Update properties of this object
32637
+ def update!(**args)
32638
+ @instances = args[:instances] if args.key?(:instances)
32639
+ end
32640
+ end
32641
+
32071
32642
  #
32072
32643
  class RegionInstanceGroupManagersSetTargetPoolsRequest
32073
32644
  include Google::Apis::Core::Hashable
@@ -32118,6 +32689,82 @@ module Google
32118
32689
  end
32119
32690
  end
32120
32691
 
32692
+ #
32693
+ class RegionInstanceGroupManagersStartInstancesRequest
32694
+ include Google::Apis::Core::Hashable
32695
+
32696
+ # The URLs of one or more instances to start. This can be a full URL or a
32697
+ # partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].
32698
+ # Corresponds to the JSON property `instances`
32699
+ # @return [Array<String>]
32700
+ attr_accessor :instances
32701
+
32702
+ def initialize(**args)
32703
+ update!(**args)
32704
+ end
32705
+
32706
+ # Update properties of this object
32707
+ def update!(**args)
32708
+ @instances = args[:instances] if args.key?(:instances)
32709
+ end
32710
+ end
32711
+
32712
+ #
32713
+ class RegionInstanceGroupManagersStopInstancesRequest
32714
+ include Google::Apis::Core::Hashable
32715
+
32716
+ # If this flag is set to true, the Instance Group Manager will proceed to stop
32717
+ # the instances, skipping initialization on them.
32718
+ # Corresponds to the JSON property `forceStop`
32719
+ # @return [Boolean]
32720
+ attr_accessor :force_stop
32721
+ alias_method :force_stop?, :force_stop
32722
+
32723
+ # The URLs of one or more instances to stop. This can be a full URL or a partial
32724
+ # URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].
32725
+ # Corresponds to the JSON property `instances`
32726
+ # @return [Array<String>]
32727
+ attr_accessor :instances
32728
+
32729
+ def initialize(**args)
32730
+ update!(**args)
32731
+ end
32732
+
32733
+ # Update properties of this object
32734
+ def update!(**args)
32735
+ @force_stop = args[:force_stop] if args.key?(:force_stop)
32736
+ @instances = args[:instances] if args.key?(:instances)
32737
+ end
32738
+ end
32739
+
32740
+ #
32741
+ class RegionInstanceGroupManagersSuspendInstancesRequest
32742
+ include Google::Apis::Core::Hashable
32743
+
32744
+ # If this flag is set to true, the Instance Group Manager will proceed to
32745
+ # suspend the instances, skipping initialization on them.
32746
+ # Corresponds to the JSON property `forceSuspend`
32747
+ # @return [Boolean]
32748
+ attr_accessor :force_suspend
32749
+ alias_method :force_suspend?, :force_suspend
32750
+
32751
+ # The URLs of one or more instances to suspend. This can be a full URL or a
32752
+ # partial URL, such as zones/[ZONE]/instances/[INSTANCE_NAME].
32753
+ # Corresponds to the JSON property `instances`
32754
+ # @return [Array<String>]
32755
+ attr_accessor :instances
32756
+
32757
+ def initialize(**args)
32758
+ update!(**args)
32759
+ end
32760
+
32761
+ # Update properties of this object
32762
+ def update!(**args)
32763
+ @force_suspend = args[:force_suspend] if args.key?(:force_suspend)
32764
+ @instances = args[:instances] if args.key?(:instances)
32765
+ end
32766
+ end
32767
+
32121
32768
  #
32122
32769
  class RegionInstanceGroupsListInstances
32123
32770
  include Google::Apis::Core::Hashable
@@ -34142,7 +34789,9 @@ module Google
34142
34789
  class ResourceStatus
34143
34790
  include Google::Apis::Core::Hashable
34144
34791
 
34145
- # [Output Only] An opaque ID of the host on which the VM is running.
34792
+ # [Output Only] The precise location of your instance within the zone's data
34793
+ # center, including the block, sub-block, and host. The field is formatted as
34794
+ # follows: blockId/subBlockId/hostId.
34146
34795
  # Corresponds to the JSON property `physicalHost`
34147
34796
  # @return [String]
34148
34797
  attr_accessor :physical_host
@@ -34280,6 +34929,13 @@ module Google
34280
34929
  # @return [String]
34281
34930
  attr_accessor :next_hop_instance
34282
34931
 
34932
+ # [Output only] Internal fixed region-to-region cost that Google Cloud
34933
+ # calculates based on factors such as network performance, distance, and
34934
+ # available bandwidth between regions.
34935
+ # Corresponds to the JSON property `nextHopInterRegionCost`
34936
+ # @return [Fixnum]
34937
+ attr_accessor :next_hop_inter_region_cost
34938
+
34283
34939
  # The network IP address of an instance that should handle matching packets.
34284
34940
  # Both IPv6 address and IPv4 addresses are supported. Must specify an IPv4
34285
34941
  # address in dot-decimal notation (e.g. 192.0.2.99) or an IPv6 address in RFC
@@ -34290,11 +34946,23 @@ module Google
34290
34946
  # @return [String]
34291
34947
  attr_accessor :next_hop_ip
34292
34948
 
34949
+ # [Output Only] Multi-Exit Discriminator, a BGP route metric that indicates the
34950
+ # desirability of a particular route in a network.
34951
+ # Corresponds to the JSON property `nextHopMed`
34952
+ # @return [Fixnum]
34953
+ attr_accessor :next_hop_med
34954
+
34293
34955
  # The URL of the local network if it should handle matching packets.
34294
34956
  # Corresponds to the JSON property `nextHopNetwork`
34295
34957
  # @return [String]
34296
34958
  attr_accessor :next_hop_network
34297
34959
 
34960
+ # [Output Only] Indicates the origin of the route. Can be IGP (Interior Gateway
34961
+ # Protocol), EGP (Exterior Gateway Protocol), or INCOMPLETE.
34962
+ # Corresponds to the JSON property `nextHopOrigin`
34963
+ # @return [String]
34964
+ attr_accessor :next_hop_origin
34965
+
34298
34966
  # [Output Only] The network peering name that should handle matching packets,
34299
34967
  # which should conform to RFC1035.
34300
34968
  # Corresponds to the JSON property `nextHopPeering`
@@ -34363,8 +35031,11 @@ module Google
34363
35031
  @next_hop_hub = args[:next_hop_hub] if args.key?(:next_hop_hub)
34364
35032
  @next_hop_ilb = args[:next_hop_ilb] if args.key?(:next_hop_ilb)
34365
35033
  @next_hop_instance = args[:next_hop_instance] if args.key?(:next_hop_instance)
35034
+ @next_hop_inter_region_cost = args[:next_hop_inter_region_cost] if args.key?(:next_hop_inter_region_cost)
34366
35035
  @next_hop_ip = args[:next_hop_ip] if args.key?(:next_hop_ip)
35036
+ @next_hop_med = args[:next_hop_med] if args.key?(:next_hop_med)
34367
35037
  @next_hop_network = args[:next_hop_network] if args.key?(:next_hop_network)
35038
+ @next_hop_origin = args[:next_hop_origin] if args.key?(:next_hop_origin)
34368
35039
  @next_hop_peering = args[:next_hop_peering] if args.key?(:next_hop_peering)
34369
35040
  @next_hop_vpn_tunnel = args[:next_hop_vpn_tunnel] if args.key?(:next_hop_vpn_tunnel)
34370
35041
  @priority = args[:priority] if args.key?(:priority)
@@ -38041,7 +38712,9 @@ module Google
38041
38712
  # originating client, which is resolved based on "userIpRequestHeaders"
38042
38713
  # configured with the security policy. If there is no "userIpRequestHeaders"
38043
38714
  # configuration or an IP address cannot be resolved from it, the key type
38044
- # defaults to IP.
38715
+ # defaults to IP. - TLS_JA4_FINGERPRINT: JA4 TLS/SSL fingerprint if the client
38716
+ # connects using HTTPS, HTTP/2 or HTTP/3. If not available, the key type
38717
+ # defaults to ALL.
38045
38718
  # Corresponds to the JSON property `enforceOnKey`
38046
38719
  # @return [String]
38047
38720
  attr_accessor :enforce_on_key
@@ -38136,7 +38809,9 @@ module Google
38136
38809
  # originating client, which is resolved based on "userIpRequestHeaders"
38137
38810
  # configured with the security policy. If there is no "userIpRequestHeaders"
38138
38811
  # configuration or an IP address cannot be resolved from it, the key type
38139
- # defaults to IP.
38812
+ # defaults to IP. - TLS_JA4_FINGERPRINT: JA4 TLS/SSL fingerprint if the client
38813
+ # connects using HTTPS, HTTP/2 or HTTP/3. If not available, the key type
38814
+ # defaults to ALL.
38140
38815
  # Corresponds to the JSON property `enforceOnKeyType`
38141
38816
  # @return [String]
38142
38817
  attr_accessor :enforce_on_key_type
@@ -42470,15 +43145,17 @@ module Google
42470
43145
  attr_accessor :private_ipv6_google_access
42471
43146
 
42472
43147
  # The purpose of the resource. This field can be either PRIVATE,
42473
- # GLOBAL_MANAGED_PROXY, REGIONAL_MANAGED_PROXY, PRIVATE_SERVICE_CONNECT, or
42474
- # PRIVATE is the default purpose for user-created subnets or subnets that are
42475
- # automatically created in auto mode networks. Subnets with purpose set to
42476
- # GLOBAL_MANAGED_PROXY or REGIONAL_MANAGED_PROXY are user-created subnetworks
42477
- # that are reserved for Envoy-based load balancers. A subnet with purpose set to
42478
- # PRIVATE_SERVICE_CONNECT is used to publish services using Private Service
42479
- # Connect. If unspecified, the subnet purpose defaults to PRIVATE. The
42480
- # enableFlowLogs field isn't supported if the subnet purpose field is set to
42481
- # GLOBAL_MANAGED_PROXY or REGIONAL_MANAGED_PROXY.
43148
+ # GLOBAL_MANAGED_PROXY, REGIONAL_MANAGED_PROXY, PEER_MIGRATION or
43149
+ # PRIVATE_SERVICE_CONNECT. PRIVATE is the default purpose for user-created
43150
+ # subnets or subnets that are automatically created in auto mode networks.
43151
+ # Subnets with purpose set to GLOBAL_MANAGED_PROXY or REGIONAL_MANAGED_PROXY are
43152
+ # user-created subnetworks that are reserved for Envoy-based load balancers. A
43153
+ # subnet with purpose set to PRIVATE_SERVICE_CONNECT is used to publish services
43154
+ # using Private Service Connect. A subnet with purpose set to PEER_MIGRATION is
43155
+ # used for subnet migration from one peered VPC to another. If unspecified, the
43156
+ # subnet purpose defaults to PRIVATE. The enableFlowLogs field isn't supported
43157
+ # if the subnet purpose field is set to GLOBAL_MANAGED_PROXY or
43158
+ # REGIONAL_MANAGED_PROXY.
42482
43159
  # Corresponds to the JSON property `purpose`
42483
43160
  # @return [String]
42484
43161
  attr_accessor :purpose
@@ -43925,14 +44602,14 @@ module Google
43925
44602
  # Represents a Target HTTPS Proxy resource. Google Compute Engine has two Target
43926
44603
  # HTTPS Proxy resources: * [Global](/compute/docs/reference/rest/v1/
43927
44604
  # targetHttpsProxies) * [Regional](/compute/docs/reference/rest/v1/
43928
- # regionTargetHttpsProxies) A target HTTPS proxy is a component of GCP HTTPS
43929
- # load balancers. * targetHttpProxies are used by global external Application
43930
- # Load Balancers, classic Application Load Balancers, cross-region internal
43931
- # Application Load Balancers, and Traffic Director. * regionTargetHttpProxies
43932
- # are used by regional internal Application Load Balancers and regional external
43933
- # Application Load Balancers. Forwarding rules reference a target HTTPS proxy,
43934
- # and the target proxy then references a URL map. For more information, read
43935
- # Using Target Proxies and Forwarding rule concepts.
44605
+ # regionTargetHttpsProxies) A target HTTPS proxy is a component of Google Cloud
44606
+ # HTTPS load balancers. * targetHttpProxies are used by global external
44607
+ # Application Load Balancers, classic Application Load Balancers, cross-region
44608
+ # internal Application Load Balancers, and Traffic Director. *
44609
+ # regionTargetHttpProxies are used by regional internal Application Load
44610
+ # Balancers and regional external Application Load Balancers. Forwarding rules
44611
+ # reference a target HTTPS proxy, and the target proxy then references a URL map.
44612
+ # For more information, read Using Target Proxies and Forwarding rule concepts.
43936
44613
  class TargetHttpsProxy
43937
44614
  include Google::Apis::Core::Hashable
43938
44615
 
@@ -46839,11 +47516,9 @@ module Google
46839
47516
 
46840
47517
  # defaultRouteAction takes effect when none of the hostRules match. The load
46841
47518
  # balancer performs advanced routing actions, such as URL rewrites and header
46842
- # transformations, before forwarding the request to the selected backend. If
46843
- # defaultRouteAction specifies any weightedBackendServices, defaultService must
46844
- # not be set. Conversely if defaultService is set, defaultRouteAction cannot
46845
- # contain any weightedBackendServices. Only one of defaultRouteAction or
46846
- # defaultUrlRedirect must be set. URL maps for classic Application Load
47519
+ # transformations, before forwarding the request to the selected backend. Only
47520
+ # one of defaultUrlRedirect, defaultService or defaultRouteAction.
47521
+ # weightedBackendService can be set. URL maps for classic Application Load
46847
47522
  # Balancers only support the urlRewrite action within defaultRouteAction.
46848
47523
  # defaultRouteAction has no effect when the URL map is bound to a target gRPC
46849
47524
  # proxy that has the validateForProxyless field set to true.
@@ -46854,14 +47529,10 @@ module Google
46854
47529
  # The full or partial URL of the defaultService resource to which traffic is
46855
47530
  # directed if none of the hostRules match. If defaultRouteAction is also
46856
47531
  # specified, advanced routing actions, such as URL rewrites, take effect before
46857
- # sending the request to the backend. However, if defaultService is specified,
46858
- # defaultRouteAction cannot contain any defaultRouteAction.
46859
- # weightedBackendServices. Conversely, if defaultRouteAction specifies any
46860
- # defaultRouteAction.weightedBackendServices, defaultService must not be
46861
- # specified. If defaultService is specified, then set either defaultUrlRedirect ,
46862
- # or defaultRouteAction.weightedBackendService Don't set both. defaultService
46863
- # has no effect when the URL map is bound to a target gRPC proxy that has the
46864
- # validateForProxyless field set to true.
47532
+ # sending the request to the backend. Only one of defaultUrlRedirect,
47533
+ # defaultService or defaultRouteAction.weightedBackendService can be set.
47534
+ # defaultService has no effect when the URL map is bound to a target gRPC proxy
47535
+ # that has the validateForProxyless field set to true.
46865
47536
  # Corresponds to the JSON property `defaultService`
46866
47537
  # @return [String]
46867
47538
  attr_accessor :default_service
@@ -47609,15 +48280,17 @@ module Google
47609
48280
  attr_accessor :network
47610
48281
 
47611
48282
  # The purpose of the resource. This field can be either PRIVATE,
47612
- # GLOBAL_MANAGED_PROXY, REGIONAL_MANAGED_PROXY, PRIVATE_SERVICE_CONNECT, or
47613
- # PRIVATE is the default purpose for user-created subnets or subnets that are
47614
- # automatically created in auto mode networks. Subnets with purpose set to
47615
- # GLOBAL_MANAGED_PROXY or REGIONAL_MANAGED_PROXY are user-created subnetworks
47616
- # that are reserved for Envoy-based load balancers. A subnet with purpose set to
47617
- # PRIVATE_SERVICE_CONNECT is used to publish services using Private Service
47618
- # Connect. If unspecified, the subnet purpose defaults to PRIVATE. The
47619
- # enableFlowLogs field isn't supported if the subnet purpose field is set to
47620
- # GLOBAL_MANAGED_PROXY or REGIONAL_MANAGED_PROXY.
48283
+ # GLOBAL_MANAGED_PROXY, REGIONAL_MANAGED_PROXY, PEER_MIGRATION or
48284
+ # PRIVATE_SERVICE_CONNECT. PRIVATE is the default purpose for user-created
48285
+ # subnets or subnets that are automatically created in auto mode networks.
48286
+ # Subnets with purpose set to GLOBAL_MANAGED_PROXY or REGIONAL_MANAGED_PROXY are
48287
+ # user-created subnetworks that are reserved for Envoy-based load balancers. A
48288
+ # subnet with purpose set to PRIVATE_SERVICE_CONNECT is used to publish services
48289
+ # using Private Service Connect. A subnet with purpose set to PEER_MIGRATION is
48290
+ # used for subnet migration from one peered VPC to another. If unspecified, the
48291
+ # subnet purpose defaults to PRIVATE. The enableFlowLogs field isn't supported
48292
+ # if the subnet purpose field is set to GLOBAL_MANAGED_PROXY or
48293
+ # REGIONAL_MANAGED_PROXY.
47621
48294
  # Corresponds to the JSON property `purpose`
47622
48295
  # @return [String]
47623
48296
  attr_accessor :purpose