google-apis-compute_v1 0.78.0 → 0.80.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: bd13d3a93347df8afff775b42ff622564a926e3aafc72686e36820ddc24bbebc
4
- data.tar.gz: 3683443ccf5cc89d27dd145a7eccfa5c6402d73fbea43ee67644bd781319d253
3
+ metadata.gz: a155203fed72f190c2cd6435e4020d1da62362e7dff6f1fbf80841c61b042d24
4
+ data.tar.gz: 606373ddf37df5358590898f84fd220282244ab8125cda8b457acca9143328dc
5
5
  SHA512:
6
- metadata.gz: 446e2da6f6b22edd0f1de9f9c028e43994acfaeda2d23a9f44d93a2e6d84fe580e0d045f86ff3fc9c9b38e2c13c2f319ed5529116d641d93dfc976a373f51bf4
7
- data.tar.gz: 7642f14714d17dc602969f4aa66950bd27dc1518979d3d85106e2c202027fb9ec343baf1c7e4c065a69ef01da0fa3c3d13caacfa4e0ddeaf0dca83e8698d7234
6
+ metadata.gz: 04c3d6fd43bf32fb0bbccfe570458b2e1069a9b6fbe4200ff87539559b7992a487274ac05bf6f42de93bb4cbcefccd25beb87d50b035d0b9dbdba78a94bf1b82
7
+ data.tar.gz: 5bbd6743154b0ba8a2c9f1e96297085092d1cdc1e7b92de65e78c3b7e8112537be03affa70e148f77addae211a8a86833d606ec32fb438c461982d0030e95e04
data/CHANGELOG.md CHANGED
@@ -1,5 +1,13 @@
1
1
  # Release history for google-apis-compute_v1
2
2
 
3
+ ### v0.80.0 (2023-10-01)
4
+
5
+ * Regenerated from discovery document revision 20230920
6
+
7
+ ### v0.79.0 (2023-09-24)
8
+
9
+ * Regenerated from discovery document revision 20230912
10
+
3
11
  ### v0.78.0 (2023-09-10)
4
12
 
5
13
  * Regenerated from discovery document revision 20230829
@@ -3402,11 +3402,11 @@ module Google
3402
3402
  # applicable to either: - A regional backend service with the service_protocol
3403
3403
  # set to HTTP, HTTPS, or HTTP2, and load_balancing_scheme set to
3404
3404
  # INTERNAL_MANAGED. - A global backend service with the load_balancing_scheme
3405
- # set to INTERNAL_SELF_MANAGED. If sessionAffinity is not NONE, and this field
3406
- # is not set to MAGLEV or RING_HASH, session affinity settings will not take
3407
- # effect. Only ROUND_ROBIN and RING_HASH are supported when the backend service
3408
- # is referenced by a URL map that is bound to target gRPC proxy that has
3409
- # validateForProxyless field set to true.
3405
+ # set to INTERNAL_SELF_MANAGED, INTERNAL_MANAGED, or EXTERNAL_MANAGED. If
3406
+ # sessionAffinity is not NONE, and this field is not set to MAGLEV or RING_HASH,
3407
+ # session affinity settings will not take effect. Only ROUND_ROBIN and RING_HASH
3408
+ # are supported when the backend service is referenced by a URL map that is
3409
+ # bound to target gRPC proxy that has validateForProxyless field set to true.
3410
3410
  # Corresponds to the JSON property `localityLbPolicy`
3411
3411
  # @return [String]
3412
3412
  attr_accessor :locality_lb_policy
@@ -4079,8 +4079,7 @@ module Google
4079
4079
  include Google::Apis::Core::Hashable
4080
4080
 
4081
4081
  # Whether the serving infrastructure will authenticate and authorize all
4082
- # incoming requests. If true, the oauth2ClientId and oauth2ClientSecret fields
4083
- # must be non-empty.
4082
+ # incoming requests.
4084
4083
  # Corresponds to the JSON property `enabled`
4085
4084
  # @return [Boolean]
4086
4085
  attr_accessor :enabled
@@ -5221,7 +5220,7 @@ module Google
5221
5220
  # @return [String]
5222
5221
  attr_accessor :region
5223
5222
 
5224
- # List of reservations in this commitment.
5223
+ # List of create-on-create reseravtions for this commitment.
5225
5224
  # Corresponds to the JSON property `reservations`
5226
5225
  # @return [Array<Google::Apis::ComputeV1::Reservation>]
5227
5226
  attr_accessor :reservations
@@ -9339,13 +9338,13 @@ module Google
9339
9338
  # @return [String]
9340
9339
  attr_accessor :name
9341
9340
 
9342
- # This field is not used for external load balancing. For Internal TCP/UDP Load
9343
- # Balancing, this field identifies the network that the load balanced IP should
9344
- # belong to for this Forwarding Rule. If the subnetwork is specified, the
9345
- # network of the subnetwork will be used. If neither subnetwork nor this field
9346
- # is specified, the default network will be used. For Private Service Connect
9347
- # forwarding rules that forward traffic to Google APIs, a network must be
9348
- # provided.
9341
+ # This field is not used for global external load balancing. For Internal TCP/
9342
+ # UDP Load Balancing, this field identifies the network that the load balanced
9343
+ # IP should belong to for this Forwarding Rule. If the subnetwork is specified,
9344
+ # the network of the subnetwork will be used. If neither subnetwork nor this
9345
+ # field is specified, the default network will be used. For Private Service
9346
+ # Connect forwarding rules that forward traffic to Google APIs, a network must
9347
+ # be provided.
9349
9348
  # Corresponds to the JSON property `network`
9350
9349
  # @return [String]
9351
9350
  attr_accessor :network
@@ -10564,19 +10563,22 @@ module Google
10564
10563
  end
10565
10564
  end
10566
10565
 
10567
- # Represents a Health Check resource. Google Compute Engine has two Health Check
10568
- # resources: * [Global](/compute/docs/reference/rest/v1/healthChecks) * [
10569
- # Regional](/compute/docs/reference/rest/v1/regionHealthChecks) Internal HTTP(S)
10570
- # load balancers must use regional health checks (`compute.v1.regionHealthChecks`
10571
- # ). Traffic Director must use global health checks (`compute.v1.healthChecks`).
10572
- # Internal TCP/UDP load balancers can use either regional or global health
10573
- # checks (`compute.v1.regionHealthChecks` or `compute.v1.healthChecks`).
10574
- # External HTTP(S), TCP proxy, and SSL proxy load balancers as well as managed
10575
- # instance group auto-healing must use global health checks (`compute.v1.
10576
- # healthChecks`). Backend service-based network load balancers must use regional
10577
- # health checks (`compute.v1.regionHealthChecks`). Target pool-based network
10578
- # load balancers must use legacy HTTP health checks (`compute.v1.
10579
- # httpHealthChecks`). For more information, see Health checks overview.
10566
+ # Represents a health check resource. Google Compute Engine has two health check
10567
+ # resources: * [Regional](/compute/docs/reference/rest/v1/regionHealthChecks) * [
10568
+ # Global](/compute/docs/reference/rest/v1/healthChecks) These health check
10569
+ # resources can be used for load balancing and for autohealing VMs in a managed
10570
+ # instance group (MIG). **Load balancing** The following load balancer can use
10571
+ # either regional or global health check: * Internal TCP/UDP load balancer The
10572
+ # following load balancers require regional health check: * Internal HTTP(S)
10573
+ # load balancer * Backend service-based network load balancer Traffic Director
10574
+ # and the following load balancers require global health check: * External HTTP(
10575
+ # S) load balancer * TCP proxy load balancer * SSL proxy load balancer The
10576
+ # following load balancer require [legacy HTTP health checks](/compute/docs/
10577
+ # reference/rest/v1/httpHealthChecks): * Target pool-based network load balancer
10578
+ # **Autohealing in MIGs** The health checks that you use for autohealing VMs in
10579
+ # a MIG can be either regional or global. For more information, see Set up an
10580
+ # application health check and autohealing. For more information, see Health
10581
+ # checks overview.
10580
10582
  class HealthCheck
10581
10583
  include Google::Apis::Core::Hashable
10582
10584
 
@@ -16329,9 +16331,15 @@ module Google
16329
16331
  end
16330
16332
  end
16331
16333
 
16332
- # Represents an Instance Template resource. You can use instance templates to
16333
- # create VM instances and managed instance groups. For more information, read
16334
- # Instance Templates.
16334
+ # Represents an Instance Template resource. Google Compute Engine has two
16335
+ # Instance Template resources: * [Global](/compute/docs/reference/rest/v1/
16336
+ # instanceTemplates) * [Regional](/compute/docs/reference/rest/v1/
16337
+ # regionInstanceTemplates) You can reuse a global instance template in different
16338
+ # regions whereas you can use a regional instance template in a specified region
16339
+ # only. If you want to reduce cross-region dependency or achieve data residency,
16340
+ # use a regional instance template. To create VMs, managed instance groups, and
16341
+ # reservations, you can use either global or regional instance templates. For
16342
+ # more information, read Instance Templates.
16335
16343
  class InstanceTemplate
16336
16344
  include Google::Apis::Core::Hashable
16337
16345
 
@@ -17224,6 +17232,15 @@ module Google
17224
17232
  attr_accessor :admin_enabled
17225
17233
  alias_method :admin_enabled?, :admin_enabled
17226
17234
 
17235
+ # [Output only] List of features available for this Interconnect connection,
17236
+ # which can take one of the following values: - MACSEC If present then the
17237
+ # Interconnect connection is provisioned on MACsec capable hardware ports. If
17238
+ # not present then the Interconnect connection is provisioned on non-MACsec
17239
+ # capable ports and MACsec isn't supported and enabling MACsec fails.
17240
+ # Corresponds to the JSON property `availableFeatures`
17241
+ # @return [Array<String>]
17242
+ attr_accessor :available_features
17243
+
17227
17244
  # [Output Only] A list of CircuitInfo objects, that describe the individual
17228
17245
  # circuits in this LAG.
17229
17246
  # Corresponds to the JSON property `circuitInfos`
@@ -17324,6 +17341,20 @@ module Google
17324
17341
  # @return [String]
17325
17342
  attr_accessor :location
17326
17343
 
17344
+ # Configuration information for enabling Media Access Control security (MACsec)
17345
+ # on this Cloud Interconnect connection between Google and your on-premises
17346
+ # router.
17347
+ # Corresponds to the JSON property `macsec`
17348
+ # @return [Google::Apis::ComputeV1::InterconnectMacsec]
17349
+ attr_accessor :macsec
17350
+
17351
+ # Enable or disable MACsec on this Interconnect connection. MACsec enablement
17352
+ # fails if the MACsec object is not specified.
17353
+ # Corresponds to the JSON property `macsecEnabled`
17354
+ # @return [Boolean]
17355
+ attr_accessor :macsec_enabled
17356
+ alias_method :macsec_enabled?, :macsec_enabled
17357
+
17327
17358
  # Name of the resource. Provided by the client when the resource is created. The
17328
17359
  # name must be 1-63 characters long, and comply with RFC1035. Specifically, the
17329
17360
  # name must be 1-63 characters long and match the regular expression `[a-z]([-a-
@@ -17372,6 +17403,16 @@ module Google
17372
17403
  # @return [String]
17373
17404
  attr_accessor :remote_location
17374
17405
 
17406
+ # Optional. List of features requested for this Interconnect connection, which
17407
+ # can take one of the following values: - MACSEC If specified then the
17408
+ # connection is created on MACsec capable hardware ports. If not specified, the
17409
+ # default value is false, which allocates non-MACsec capable ports first if
17410
+ # available. This parameter can be provided only with Interconnect INSERT. It
17411
+ # isn't valid for Interconnect PATCH.
17412
+ # Corresponds to the JSON property `requestedFeatures`
17413
+ # @return [Array<String>]
17414
+ attr_accessor :requested_features
17415
+
17375
17416
  # Target number of physical links in the link bundle, as requested by the
17376
17417
  # customer.
17377
17418
  # Corresponds to the JSON property `requestedLinkCount`
@@ -17407,6 +17448,7 @@ module Google
17407
17448
  # Update properties of this object
17408
17449
  def update!(**args)
17409
17450
  @admin_enabled = args[:admin_enabled] if args.key?(:admin_enabled)
17451
+ @available_features = args[:available_features] if args.key?(:available_features)
17410
17452
  @circuit_infos = args[:circuit_infos] if args.key?(:circuit_infos)
17411
17453
  @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
17412
17454
  @customer_name = args[:customer_name] if args.key?(:customer_name)
@@ -17422,12 +17464,15 @@ module Google
17422
17464
  @labels = args[:labels] if args.key?(:labels)
17423
17465
  @link_type = args[:link_type] if args.key?(:link_type)
17424
17466
  @location = args[:location] if args.key?(:location)
17467
+ @macsec = args[:macsec] if args.key?(:macsec)
17468
+ @macsec_enabled = args[:macsec_enabled] if args.key?(:macsec_enabled)
17425
17469
  @name = args[:name] if args.key?(:name)
17426
17470
  @noc_contact_email = args[:noc_contact_email] if args.key?(:noc_contact_email)
17427
17471
  @operational_status = args[:operational_status] if args.key?(:operational_status)
17428
17472
  @peer_ip_address = args[:peer_ip_address] if args.key?(:peer_ip_address)
17429
17473
  @provisioned_link_count = args[:provisioned_link_count] if args.key?(:provisioned_link_count)
17430
17474
  @remote_location = args[:remote_location] if args.key?(:remote_location)
17475
+ @requested_features = args[:requested_features] if args.key?(:requested_features)
17431
17476
  @requested_link_count = args[:requested_link_count] if args.key?(:requested_link_count)
17432
17477
  @satisfies_pzs = args[:satisfies_pzs] if args.key?(:satisfies_pzs)
17433
17478
  @self_link = args[:self_link] if args.key?(:self_link)
@@ -18465,6 +18510,11 @@ module Google
18465
18510
  # @return [Google::Apis::ComputeV1::InterconnectDiagnosticsLinkLacpStatus]
18466
18511
  attr_accessor :lacp_status
18467
18512
 
18513
+ # Describes the status of MACsec encryption on the link.
18514
+ # Corresponds to the JSON property `macsec`
18515
+ # @return [Google::Apis::ComputeV1::InterconnectDiagnosticsMacsecStatus]
18516
+ attr_accessor :macsec
18517
+
18468
18518
  # The operational status of the link.
18469
18519
  # Corresponds to the JSON property `operationalStatus`
18470
18520
  # @return [String]
@@ -18492,12 +18542,40 @@ module Google
18492
18542
  @circuit_id = args[:circuit_id] if args.key?(:circuit_id)
18493
18543
  @google_demarc = args[:google_demarc] if args.key?(:google_demarc)
18494
18544
  @lacp_status = args[:lacp_status] if args.key?(:lacp_status)
18545
+ @macsec = args[:macsec] if args.key?(:macsec)
18495
18546
  @operational_status = args[:operational_status] if args.key?(:operational_status)
18496
18547
  @receiving_optical_power = args[:receiving_optical_power] if args.key?(:receiving_optical_power)
18497
18548
  @transmitting_optical_power = args[:transmitting_optical_power] if args.key?(:transmitting_optical_power)
18498
18549
  end
18499
18550
  end
18500
18551
 
18552
+ # Describes the status of MACsec encryption on the link.
18553
+ class InterconnectDiagnosticsMacsecStatus
18554
+ include Google::Apis::Core::Hashable
18555
+
18556
+ # Indicates the Connectivity Association Key Name (CKN) currently being used if
18557
+ # MACsec is operational.
18558
+ # Corresponds to the JSON property `ckn`
18559
+ # @return [String]
18560
+ attr_accessor :ckn
18561
+
18562
+ # Indicates whether or not MACsec is operational on this link.
18563
+ # Corresponds to the JSON property `operational`
18564
+ # @return [Boolean]
18565
+ attr_accessor :operational
18566
+ alias_method :operational?, :operational
18567
+
18568
+ def initialize(**args)
18569
+ update!(**args)
18570
+ end
18571
+
18572
+ # Update properties of this object
18573
+ def update!(**args)
18574
+ @ckn = args[:ckn] if args.key?(:ckn)
18575
+ @operational = args[:operational] if args.key?(:operational)
18576
+ end
18577
+ end
18578
+
18501
18579
  # Response to the list request, and contains a list of interconnects.
18502
18580
  class InterconnectList
18503
18581
  include Google::Apis::Core::Hashable
@@ -18636,6 +18714,19 @@ module Google
18636
18714
  # @return [String]
18637
18715
  attr_accessor :availability_zone
18638
18716
 
18717
+ # [Output only] List of features available at this InterconnectLocation, which
18718
+ # can take one of the following values: - MACSEC
18719
+ # Corresponds to the JSON property `availableFeatures`
18720
+ # @return [Array<String>]
18721
+ attr_accessor :available_features
18722
+
18723
+ # [Output only] List of link types available at this InterconnectLocation, which
18724
+ # can take one of the following values: - LINK_TYPE_ETHERNET_10G_LR -
18725
+ # LINK_TYPE_ETHERNET_100G_LR
18726
+ # Corresponds to the JSON property `availableLinkTypes`
18727
+ # @return [Array<String>]
18728
+ attr_accessor :available_link_types
18729
+
18639
18730
  # [Output Only] Metropolitan area designator that indicates which city an
18640
18731
  # interconnect is located. For example: "Chicago, IL", "Amsterdam, Netherlands".
18641
18732
  # Corresponds to the JSON property `city`
@@ -18726,6 +18817,8 @@ module Google
18726
18817
  def update!(**args)
18727
18818
  @address = args[:address] if args.key?(:address)
18728
18819
  @availability_zone = args[:availability_zone] if args.key?(:availability_zone)
18820
+ @available_features = args[:available_features] if args.key?(:available_features)
18821
+ @available_link_types = args[:available_link_types] if args.key?(:available_link_types)
18729
18822
  @city = args[:city] if args.key?(:city)
18730
18823
  @continent = args[:continent] if args.key?(:continent)
18731
18824
  @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
@@ -18894,6 +18987,138 @@ module Google
18894
18987
  end
18895
18988
  end
18896
18989
 
18990
+ # Configuration information for enabling Media Access Control security (MACsec)
18991
+ # on this Cloud Interconnect connection between Google and your on-premises
18992
+ # router.
18993
+ class InterconnectMacsec
18994
+ include Google::Apis::Core::Hashable
18995
+
18996
+ # If set to true, the Interconnect connection is configured with a should-secure
18997
+ # MACsec security policy, that allows the Google router to fallback to cleartext
18998
+ # traffic if the MKA session cannot be established. By default, the Interconnect
18999
+ # connection is configured with a must-secure security policy that drops all
19000
+ # traffic if the MKA session cannot be established with your router.
19001
+ # Corresponds to the JSON property `failOpen`
19002
+ # @return [Boolean]
19003
+ attr_accessor :fail_open
19004
+ alias_method :fail_open?, :fail_open
19005
+
19006
+ # Required. A keychain placeholder describing a set of named key objects along
19007
+ # with their start times. A MACsec CKN/CAK is generated for each key in the key
19008
+ # chain. Google router automatically picks the key with the most recent
19009
+ # startTime when establishing or re-establishing a MACsec secure link.
19010
+ # Corresponds to the JSON property `preSharedKeys`
19011
+ # @return [Array<Google::Apis::ComputeV1::InterconnectMacsecPreSharedKey>]
19012
+ attr_accessor :pre_shared_keys
19013
+
19014
+ def initialize(**args)
19015
+ update!(**args)
19016
+ end
19017
+
19018
+ # Update properties of this object
19019
+ def update!(**args)
19020
+ @fail_open = args[:fail_open] if args.key?(:fail_open)
19021
+ @pre_shared_keys = args[:pre_shared_keys] if args.key?(:pre_shared_keys)
19022
+ end
19023
+ end
19024
+
19025
+ # MACsec configuration information for the Interconnect connection. Contains the
19026
+ # generated Connectivity Association Key Name (CKN) and the key (CAK) for this
19027
+ # Interconnect connection.
19028
+ class InterconnectMacsecConfig
19029
+ include Google::Apis::Core::Hashable
19030
+
19031
+ # A keychain placeholder describing a set of named key objects along with their
19032
+ # start times. A MACsec CKN/CAK is generated for each key in the key chain.
19033
+ # Google router automatically picks the key with the most recent startTime when
19034
+ # establishing or re-establishing a MACsec secure link.
19035
+ # Corresponds to the JSON property `preSharedKeys`
19036
+ # @return [Array<Google::Apis::ComputeV1::InterconnectMacsecConfigPreSharedKey>]
19037
+ attr_accessor :pre_shared_keys
19038
+
19039
+ def initialize(**args)
19040
+ update!(**args)
19041
+ end
19042
+
19043
+ # Update properties of this object
19044
+ def update!(**args)
19045
+ @pre_shared_keys = args[:pre_shared_keys] if args.key?(:pre_shared_keys)
19046
+ end
19047
+ end
19048
+
19049
+ # Describes a pre-shared key used to setup MACsec in static connectivity
19050
+ # association key (CAK) mode.
19051
+ class InterconnectMacsecConfigPreSharedKey
19052
+ include Google::Apis::Core::Hashable
19053
+
19054
+ # An auto-generated Connectivity Association Key (CAK) for this key.
19055
+ # Corresponds to the JSON property `cak`
19056
+ # @return [String]
19057
+ attr_accessor :cak
19058
+
19059
+ # An auto-generated Connectivity Association Key Name (CKN) for this key.
19060
+ # Corresponds to the JSON property `ckn`
19061
+ # @return [String]
19062
+ attr_accessor :ckn
19063
+
19064
+ # User provided name for this pre-shared key.
19065
+ # Corresponds to the JSON property `name`
19066
+ # @return [String]
19067
+ attr_accessor :name
19068
+
19069
+ # User provided timestamp on or after which this key is valid.
19070
+ # Corresponds to the JSON property `startTime`
19071
+ # @return [String]
19072
+ attr_accessor :start_time
19073
+
19074
+ def initialize(**args)
19075
+ update!(**args)
19076
+ end
19077
+
19078
+ # Update properties of this object
19079
+ def update!(**args)
19080
+ @cak = args[:cak] if args.key?(:cak)
19081
+ @ckn = args[:ckn] if args.key?(:ckn)
19082
+ @name = args[:name] if args.key?(:name)
19083
+ @start_time = args[:start_time] if args.key?(:start_time)
19084
+ end
19085
+ end
19086
+
19087
+ # Describes a pre-shared key used to setup MACsec in static connectivity
19088
+ # association key (CAK) mode.
19089
+ class InterconnectMacsecPreSharedKey
19090
+ include Google::Apis::Core::Hashable
19091
+
19092
+ # Required. A name for this pre-shared key. The name must be 1-63 characters
19093
+ # long, and comply with RFC1035. Specifically, the name must be 1-63 characters
19094
+ # long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means
19095
+ # the first character must be a lowercase letter, and all following characters
19096
+ # must be a dash, lowercase letter, or digit, except the last character, which
19097
+ # cannot be a dash.
19098
+ # Corresponds to the JSON property `name`
19099
+ # @return [String]
19100
+ attr_accessor :name
19101
+
19102
+ # A RFC3339 timestamp on or after which the key is valid. startTime can be in
19103
+ # the future. If the keychain has a single key, startTime can be omitted. If the
19104
+ # keychain has multiple keys, startTime is mandatory for each key. The start
19105
+ # times of keys must be in increasing order. The start times of two consecutive
19106
+ # keys must be at least 6 hours apart.
19107
+ # Corresponds to the JSON property `startTime`
19108
+ # @return [String]
19109
+ attr_accessor :start_time
19110
+
19111
+ def initialize(**args)
19112
+ update!(**args)
19113
+ end
19114
+
19115
+ # Update properties of this object
19116
+ def update!(**args)
19117
+ @name = args[:name] if args.key?(:name)
19118
+ @start_time = args[:start_time] if args.key?(:start_time)
19119
+ end
19120
+ end
19121
+
18897
19122
  # Description of a planned outage on this Interconnect.
18898
19123
  class InterconnectOutageNotification
18899
19124
  include Google::Apis::Core::Hashable
@@ -19355,6 +19580,33 @@ module Google
19355
19580
  end
19356
19581
  end
19357
19582
 
19583
+ # Response for the InterconnectsGetMacsecConfigRequest.
19584
+ class InterconnectsGetMacsecConfigResponse
19585
+ include Google::Apis::Core::Hashable
19586
+
19587
+ # end_interface: MixerGetResponseWithEtagBuilder
19588
+ # Corresponds to the JSON property `etag`
19589
+ # @return [String]
19590
+ attr_accessor :etag
19591
+
19592
+ # MACsec configuration information for the Interconnect connection. Contains the
19593
+ # generated Connectivity Association Key Name (CKN) and the key (CAK) for this
19594
+ # Interconnect connection.
19595
+ # Corresponds to the JSON property `result`
19596
+ # @return [Google::Apis::ComputeV1::InterconnectMacsecConfig]
19597
+ attr_accessor :result
19598
+
19599
+ def initialize(**args)
19600
+ update!(**args)
19601
+ end
19602
+
19603
+ # Update properties of this object
19604
+ def update!(**args)
19605
+ @etag = args[:etag] if args.key?(:etag)
19606
+ @result = args[:result] if args.key?(:result)
19607
+ end
19608
+ end
19609
+
19358
19610
  # Represents a License resource. A License represents billing and aggregate
19359
19611
  # usage data for public and marketplace images. *Caution* This resource is
19360
19612
  # intended for use only by third-party partners who are creating Cloud
@@ -27477,6 +27729,18 @@ module Google
27477
27729
  # @return [Hash<String,Google::Apis::ComputeV1::PreservedStatePreservedDisk>]
27478
27730
  attr_accessor :disks
27479
27731
 
27732
+ # Preserved external IPs defined for this instance. This map is keyed with the
27733
+ # name of the network interface.
27734
+ # Corresponds to the JSON property `externalIPs`
27735
+ # @return [Hash<String,Google::Apis::ComputeV1::PreservedStatePreservedNetworkIp>]
27736
+ attr_accessor :external_i_ps
27737
+
27738
+ # Preserved internal IPs defined for this instance. This map is keyed with the
27739
+ # name of the network interface.
27740
+ # Corresponds to the JSON property `internalIPs`
27741
+ # @return [Hash<String,Google::Apis::ComputeV1::PreservedStatePreservedNetworkIp>]
27742
+ attr_accessor :internal_i_ps
27743
+
27480
27744
  # Preserved metadata defined for this instance.
27481
27745
  # Corresponds to the JSON property `metadata`
27482
27746
  # @return [Hash<String,String>]
@@ -27489,6 +27753,8 @@ module Google
27489
27753
  # Update properties of this object
27490
27754
  def update!(**args)
27491
27755
  @disks = args[:disks] if args.key?(:disks)
27756
+ @external_i_ps = args[:external_i_ps] if args.key?(:external_i_ps)
27757
+ @internal_i_ps = args[:internal_i_ps] if args.key?(:internal_i_ps)
27492
27758
  @metadata = args[:metadata] if args.key?(:metadata)
27493
27759
  end
27494
27760
  end
@@ -27530,6 +27796,60 @@ module Google
27530
27796
  end
27531
27797
  end
27532
27798
 
27799
+ #
27800
+ class PreservedStatePreservedNetworkIp
27801
+ include Google::Apis::Core::Hashable
27802
+
27803
+ # These stateful IPs will never be released during autohealing, update or VM
27804
+ # instance recreate operations. This flag is used to configure if the IP
27805
+ # reservation should be deleted after it is no longer used by the group, e.g.
27806
+ # when the given instance or the whole group is deleted.
27807
+ # Corresponds to the JSON property `autoDelete`
27808
+ # @return [String]
27809
+ attr_accessor :auto_delete
27810
+
27811
+ # Ip address representation
27812
+ # Corresponds to the JSON property `ipAddress`
27813
+ # @return [Google::Apis::ComputeV1::PreservedStatePreservedNetworkIpIpAddress]
27814
+ attr_accessor :ip_address
27815
+
27816
+ def initialize(**args)
27817
+ update!(**args)
27818
+ end
27819
+
27820
+ # Update properties of this object
27821
+ def update!(**args)
27822
+ @auto_delete = args[:auto_delete] if args.key?(:auto_delete)
27823
+ @ip_address = args[:ip_address] if args.key?(:ip_address)
27824
+ end
27825
+ end
27826
+
27827
+ #
27828
+ class PreservedStatePreservedNetworkIpIpAddress
27829
+ include Google::Apis::Core::Hashable
27830
+
27831
+ # The URL of the reservation for this IP address.
27832
+ # Corresponds to the JSON property `address`
27833
+ # @return [String]
27834
+ attr_accessor :address
27835
+
27836
+ # An IPv4 internal network address to assign to the instance for this network
27837
+ # interface.
27838
+ # Corresponds to the JSON property `literal`
27839
+ # @return [String]
27840
+ attr_accessor :literal
27841
+
27842
+ def initialize(**args)
27843
+ update!(**args)
27844
+ end
27845
+
27846
+ # Update properties of this object
27847
+ def update!(**args)
27848
+ @address = args[:address] if args.key?(:address)
27849
+ @literal = args[:literal] if args.key?(:literal)
27850
+ end
27851
+ end
27852
+
27533
27853
  # Represents a Project resource. A project is used to organize resources in a
27534
27854
  # Google Cloud Platform environment. For more information, read about the
27535
27855
  # Resource Hierarchy.
@@ -30038,6 +30358,44 @@ module Google
30038
30358
  end
30039
30359
  end
30040
30360
 
30361
+ #
30362
+ class RegionNetworkEndpointGroupsAttachEndpointsRequest
30363
+ include Google::Apis::Core::Hashable
30364
+
30365
+ # The list of network endpoints to be attached.
30366
+ # Corresponds to the JSON property `networkEndpoints`
30367
+ # @return [Array<Google::Apis::ComputeV1::NetworkEndpoint>]
30368
+ attr_accessor :network_endpoints
30369
+
30370
+ def initialize(**args)
30371
+ update!(**args)
30372
+ end
30373
+
30374
+ # Update properties of this object
30375
+ def update!(**args)
30376
+ @network_endpoints = args[:network_endpoints] if args.key?(:network_endpoints)
30377
+ end
30378
+ end
30379
+
30380
+ #
30381
+ class RegionNetworkEndpointGroupsDetachEndpointsRequest
30382
+ include Google::Apis::Core::Hashable
30383
+
30384
+ # The list of network endpoints to be detached.
30385
+ # Corresponds to the JSON property `networkEndpoints`
30386
+ # @return [Array<Google::Apis::ComputeV1::NetworkEndpoint>]
30387
+ attr_accessor :network_endpoints
30388
+
30389
+ def initialize(**args)
30390
+ update!(**args)
30391
+ end
30392
+
30393
+ # Update properties of this object
30394
+ def update!(**args)
30395
+ @network_endpoints = args[:network_endpoints] if args.key?(:network_endpoints)
30396
+ end
30397
+ end
30398
+
30041
30399
  #
30042
30400
  class RegionNetworkFirewallPoliciesGetEffectiveFirewallsResponse
30043
30401
  include Google::Apis::Core::Hashable
@@ -33142,8 +33500,8 @@ module Google
33142
33500
  # "inIpRange(destination.ip, '1.1.0.0/16') || inIpRange(destination.ip, '2.2.0.
33143
33501
  # 0/16')" "destination.ip == '1.1.0.1' || destination.ip == '8.8.8.8'" The
33144
33502
  # following example is a valid match expression for private NAT: "nexthop.hub ==
33145
- # 'https://networkconnectivity.googleapis.com/v1alpha1/projects/my-project/
33146
- # global/hub/hub-1'"
33503
+ # '//networkconnectivity.googleapis.com/projects/my-project/locations/global/
33504
+ # hubs/hub-1'"
33147
33505
  # Corresponds to the JSON property `match`
33148
33506
  # @return [String]
33149
33507
  attr_accessor :match
@@ -35811,7 +36169,7 @@ module Google
35811
36169
  # affect both PENDING and ACCEPTED/REJECTED PSC endpoints. For example, an
35812
36170
  # ACCEPTED PSC endpoint will be moved to REJECTED if its project is added to the
35813
36171
  # reject list. For newly created service attachment, this boolean defaults to
35814
- # true.
36172
+ # false.
35815
36173
  # Corresponds to the JSON property `reconcileConnections`
35816
36174
  # @return [Boolean]
35817
36175
  attr_accessor :reconcile_connections
@@ -38137,6 +38495,20 @@ module Google
38137
38495
  # @return [Hash<String,Google::Apis::ComputeV1::StatefulPolicyPreservedStateDiskDevice>]
38138
38496
  attr_accessor :disks
38139
38497
 
38498
+ # External network IPs assigned to the instances that will be preserved on
38499
+ # instance delete, update, etc. This map is keyed with the network interface
38500
+ # name.
38501
+ # Corresponds to the JSON property `externalIPs`
38502
+ # @return [Hash<String,Google::Apis::ComputeV1::StatefulPolicyPreservedStateNetworkIp>]
38503
+ attr_accessor :external_i_ps
38504
+
38505
+ # Internal network IPs assigned to the instances that will be preserved on
38506
+ # instance delete, update, etc. This map is keyed with the network interface
38507
+ # name.
38508
+ # Corresponds to the JSON property `internalIPs`
38509
+ # @return [Hash<String,Google::Apis::ComputeV1::StatefulPolicyPreservedStateNetworkIp>]
38510
+ attr_accessor :internal_i_ps
38511
+
38140
38512
  def initialize(**args)
38141
38513
  update!(**args)
38142
38514
  end
@@ -38144,6 +38516,8 @@ module Google
38144
38516
  # Update properties of this object
38145
38517
  def update!(**args)
38146
38518
  @disks = args[:disks] if args.key?(:disks)
38519
+ @external_i_ps = args[:external_i_ps] if args.key?(:external_i_ps)
38520
+ @internal_i_ps = args[:internal_i_ps] if args.key?(:internal_i_ps)
38147
38521
  end
38148
38522
  end
38149
38523
 
@@ -38170,6 +38544,28 @@ module Google
38170
38544
  end
38171
38545
  end
38172
38546
 
38547
+ #
38548
+ class StatefulPolicyPreservedStateNetworkIp
38549
+ include Google::Apis::Core::Hashable
38550
+
38551
+ # These stateful IPs will never be released during autohealing, update or VM
38552
+ # instance recreate operations. This flag is used to configure if the IP
38553
+ # reservation should be deleted after it is no longer used by the group, e.g.
38554
+ # when the given instance or the whole group is deleted.
38555
+ # Corresponds to the JSON property `autoDelete`
38556
+ # @return [String]
38557
+ attr_accessor :auto_delete
38558
+
38559
+ def initialize(**args)
38560
+ update!(**args)
38561
+ end
38562
+
38563
+ # Update properties of this object
38564
+ def update!(**args)
38565
+ @auto_delete = args[:auto_delete] if args.key?(:auto_delete)
38566
+ end
38567
+ end
38568
+
38173
38569
  # The `Status` type defines a logical error model that is suitable for different
38174
38570
  # programming environments, including REST APIs and RPC APIs. It is used by [
38175
38571
  # gRPC](https://github.com/grpc). Each `Status` message contains three pieces of