Class: Google::Apis::ComputeBeta::Route
- Inherits:
-
Object
- Object
- Google::Apis::ComputeBeta::Route
- Includes:
- Google::Apis::Core::Hashable, Google::Apis::Core::JsonObjectSupport
- Defined in:
- lib/google/apis/compute_beta/classes.rb,
lib/google/apis/compute_beta/representations.rb,
lib/google/apis/compute_beta/representations.rb
Overview
Represents a Route resource. A route defines a path from VM instances in the VPC network to a specific destination. This destination can be inside or outside the VPC network. For more information, read the Routes overview.
Defined Under Namespace
Classes: Warning
Instance Attribute Summary collapse
-
#as_paths ⇒ Array<Google::Apis::ComputeBeta::RouteAsPath>
[Output Only] AS path.
-
#creation_timestamp ⇒ String
[Output Only] Creation timestamp in RFC3339 text format.
-
#description ⇒ String
An optional description of this resource.
-
#dest_range ⇒ String
The destination range of outgoing packets that this route applies to.
-
#id ⇒ Fixnum
[Output Only] The unique identifier for the resource.
-
#kind ⇒ String
[Output Only] Type of this resource.
-
#name ⇒ String
Name of the resource.
-
#network ⇒ String
Fully-qualified URL of the network that this route applies to.
-
#next_hop_gateway ⇒ String
The URL to a gateway that should handle matching packets.
-
#next_hop_hub ⇒ String
[Output Only] The full resource name of the Network Connectivity Center hub that will handle matching packets.
-
#next_hop_ilb ⇒ String
The URL to a forwarding rule of type loadBalancingScheme=INTERNAL that should handle matching packets or the IP address of the forwarding Rule.
-
#next_hop_instance ⇒ String
The URL to an instance that should handle matching packets.
-
#next_hop_inter_region_cost ⇒ Fixnum
[Output only] Internal fixed region-to-region cost that Google Cloud calculates based on factors such as network performance, distance, and available bandwidth between regions.
-
#next_hop_interconnect_attachment ⇒ String
[Output Only] The URL to an InterconnectAttachment which is the next hop for the route.
-
#next_hop_ip ⇒ String
The network IP address of an instance that should handle matching packets.
-
#next_hop_med ⇒ Fixnum
[Output Only] Multi-Exit Discriminator, a BGP route metric that indicates the desirability of a particular route in a network.
-
#next_hop_network ⇒ String
The URL of the local network if it should handle matching packets.
-
#next_hop_origin ⇒ String
[Output Only] Indicates the origin of the route.
-
#next_hop_peering ⇒ String
[Output Only] The network peering name that should handle matching packets, which should conform to RFC1035.
-
#next_hop_vpn_tunnel ⇒ String
The URL to a VpnTunnel that should handle matching packets.
-
#priority ⇒ Fixnum
The priority of this route.
-
#route_status ⇒ String
[Output only] The status of the route.
-
#route_type ⇒ String
[Output Only] The type of this route, which can be one of the following values: - 'TRANSIT' for a transit route that this router learned from another Cloud Router and will readvertise to one of its BGP peers - 'SUBNET' for a route from a subnet of the VPC - 'BGP' for a route learned from a BGP peer of this router - 'STATIC' for a static route Corresponds to the JSON property
routeType
. -
#self_link ⇒ String
[Output Only] Server-defined fully-qualified URL for this resource.
-
#tags ⇒ Array<String>
A list of instance tags to which this route applies.
-
#warnings ⇒ Array<Google::Apis::ComputeBeta::Route::Warning>
[Output Only] If potential misconfigurations are detected for this route, this field will be populated with warning messages.
Instance Method Summary collapse
-
#initialize(**args) ⇒ Route
constructor
A new instance of Route.
-
#update!(**args) ⇒ Object
Update properties of this object.
Constructor Details
#initialize(**args) ⇒ Route
Returns a new instance of Route.
38481 38482 38483 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38481 def initialize(**args) update!(**args) end |
Instance Attribute Details
#as_paths ⇒ Array<Google::Apis::ComputeBeta::RouteAsPath>
[Output Only] AS path.
Corresponds to the JSON property asPaths
38309 38310 38311 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38309 def as_paths @as_paths end |
#creation_timestamp ⇒ String
[Output Only] Creation timestamp in RFC3339 text format.
Corresponds to the JSON property creationTimestamp
38314 38315 38316 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38314 def @creation_timestamp end |
#description ⇒ String
An optional description of this resource. Provide this field when you create
the resource.
Corresponds to the JSON property description
38320 38321 38322 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38320 def description @description end |
#dest_range ⇒ String
The destination range of outgoing packets that this route applies to. Both
IPv4 and IPv6 are supported. Must specify an IPv4 range (e.g. 192.0.2.0/24) or
an IPv6 range in RFC 4291 format (e.g. 2001:db8::/32). IPv6 range will be
displayed using RFC 5952 compressed format.
Corresponds to the JSON property destRange
38328 38329 38330 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38328 def dest_range @dest_range end |
#id ⇒ Fixnum
[Output Only] The unique identifier for the resource. This identifier is
defined by the server.
Corresponds to the JSON property id
38334 38335 38336 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38334 def id @id end |
#kind ⇒ String
[Output Only] Type of this resource. Always compute#routes for Route resources.
Corresponds to the JSON property kind
38339 38340 38341 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38339 def kind @kind end |
#name ⇒ String
Name of the resource. Provided by the client when the resource is created. The
name must be 1-63 characters long, and comply with RFC1035. Specifically, the
name must be 1-63 characters long and match the regular expression [a-z]([-a-
z0-9]*[a-z0-9])?
. The first character must be a lowercase letter, and all
following characters (except for the last character) must be a dash, lowercase
letter, or digit. The last character must be a lowercase letter or digit.
Corresponds to the JSON property name
38349 38350 38351 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38349 def name @name end |
#network ⇒ String
Fully-qualified URL of the network that this route applies to.
Corresponds to the JSON property network
38354 38355 38356 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38354 def network @network end |
#next_hop_gateway ⇒ String
The URL to a gateway that should handle matching packets. You can only specify
the internet gateway using a full or partial valid URL: projects/ project/
global/gateways/default-internet-gateway
Corresponds to the JSON property nextHopGateway
38361 38362 38363 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38361 def next_hop_gateway @next_hop_gateway end |
#next_hop_hub ⇒ String
[Output Only] The full resource name of the Network Connectivity Center hub
that will handle matching packets.
Corresponds to the JSON property nextHopHub
38367 38368 38369 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38367 def next_hop_hub @next_hop_hub end |
#next_hop_ilb ⇒ String
The URL to a forwarding rule of type loadBalancingScheme=INTERNAL that should
handle matching packets or the IP address of the forwarding Rule. For example,
the following are all valid URLs: - https://www.googleapis.com/compute/v1/
projects/project/regions/region /forwardingRules/forwardingRule - regions/
region/forwardingRules/forwardingRule If an IP address is provided, must
specify an IPv4 address in dot-decimal notation or an IPv6 address in RFC 4291
format. For example, the following are all valid IP addresses: - 10.128.0.56 -
2001:db8::2d9:51:0:0 - 2001:db8:0:0:2d9:51:0:0 IPv6 addresses will be
displayed using RFC 5952 compressed format (e.g. 2001:db8::2d9:51:0:0). Should
never be an IPv4-mapped IPv6 address.
Corresponds to the JSON property nextHopIlb
38381 38382 38383 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38381 def next_hop_ilb @next_hop_ilb end |
#next_hop_instance ⇒ String
The URL to an instance that should handle matching packets. You can specify
this as a full or partial URL. For example: https://www.googleapis.com/compute/
v1/projects/project/zones/zone/instances/
Corresponds to the JSON property nextHopInstance
38388 38389 38390 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38388 def next_hop_instance @next_hop_instance end |
#next_hop_inter_region_cost ⇒ Fixnum
[Output only] Internal fixed region-to-region cost that Google Cloud
calculates based on factors such as network performance, distance, and
available bandwidth between regions.
Corresponds to the JSON property nextHopInterRegionCost
38395 38396 38397 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38395 def next_hop_inter_region_cost @next_hop_inter_region_cost end |
#next_hop_interconnect_attachment ⇒ String
[Output Only] The URL to an InterconnectAttachment which is the next hop for
the route. This field will only be populated for the dynamic routes generated
by Cloud Router with a linked interconnectAttachment.
Corresponds to the JSON property nextHopInterconnectAttachment
38402 38403 38404 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38402 def @next_hop_interconnect_attachment end |
#next_hop_ip ⇒ String
The network IP address of an instance that should handle matching packets.
Both IPv6 address and IPv4 addresses are supported. Must specify an IPv4
address in dot-decimal notation (e.g. 192.0.2.99) or an IPv6 address in RFC
4291 format (e.g. 2001:db8::2d9:51:0:0 or 2001:db8:0:0:2d9:51:0:0). IPv6
addresses will be displayed using RFC 5952 compressed format (e.g. 2001:db8::
2d9:51:0:0). Should never be an IPv4-mapped IPv6 address.
Corresponds to the JSON property nextHopIp
38412 38413 38414 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38412 def next_hop_ip @next_hop_ip end |
#next_hop_med ⇒ Fixnum
[Output Only] Multi-Exit Discriminator, a BGP route metric that indicates the
desirability of a particular route in a network.
Corresponds to the JSON property nextHopMed
38418 38419 38420 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38418 def next_hop_med @next_hop_med end |
#next_hop_network ⇒ String
The URL of the local network if it should handle matching packets.
Corresponds to the JSON property nextHopNetwork
38423 38424 38425 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38423 def next_hop_network @next_hop_network end |
#next_hop_origin ⇒ String
[Output Only] Indicates the origin of the route. Can be IGP (Interior Gateway
Protocol), EGP (Exterior Gateway Protocol), or INCOMPLETE.
Corresponds to the JSON property nextHopOrigin
38429 38430 38431 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38429 def next_hop_origin @next_hop_origin end |
#next_hop_peering ⇒ String
[Output Only] The network peering name that should handle matching packets,
which should conform to RFC1035.
Corresponds to the JSON property nextHopPeering
38435 38436 38437 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38435 def next_hop_peering @next_hop_peering end |
#next_hop_vpn_tunnel ⇒ String
The URL to a VpnTunnel that should handle matching packets.
Corresponds to the JSON property nextHopVpnTunnel
38440 38441 38442 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38440 def next_hop_vpn_tunnel @next_hop_vpn_tunnel end |
#priority ⇒ Fixnum
The priority of this route. Priority is used to break ties in cases where
there is more than one matching route of equal prefix length. In cases where
multiple routes have equal prefix length, the one with the lowest-numbered
priority value wins. The default value is 1000
. The priority value must be
from 0
to 65535
, inclusive.
Corresponds to the JSON property priority
38449 38450 38451 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38449 def priority @priority end |
#route_status ⇒ String
[Output only] The status of the route.
Corresponds to the JSON property routeStatus
38454 38455 38456 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38454 def route_status @route_status end |
#route_type ⇒ String
[Output Only] The type of this route, which can be one of the following values:
- 'TRANSIT' for a transit route that this router learned from another Cloud
Router and will readvertise to one of its BGP peers - 'SUBNET' for a route
from a subnet of the VPC - 'BGP' for a route learned from a BGP peer of this
router - 'STATIC' for a static route
Corresponds to the JSON property
routeType
38463 38464 38465 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38463 def route_type @route_type end |
#self_link ⇒ String
[Output Only] Server-defined fully-qualified URL for this resource.
Corresponds to the JSON property selfLink
38468 38469 38470 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38468 def self_link @self_link end |
#tags ⇒ Array<String>
A list of instance tags to which this route applies.
Corresponds to the JSON property tags
38473 38474 38475 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38473 def @tags end |
#warnings ⇒ Array<Google::Apis::ComputeBeta::Route::Warning>
[Output Only] If potential misconfigurations are detected for this route, this
field will be populated with warning messages.
Corresponds to the JSON property warnings
38479 38480 38481 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38479 def warnings @warnings end |
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
38486 38487 38488 38489 38490 38491 38492 38493 38494 38495 38496 38497 38498 38499 38500 38501 38502 38503 38504 38505 38506 38507 38508 38509 38510 38511 38512 38513 |
# File 'lib/google/apis/compute_beta/classes.rb', line 38486 def update!(**args) @as_paths = args[:as_paths] if args.key?(:as_paths) @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp) @description = args[:description] if args.key?(:description) @dest_range = args[:dest_range] if args.key?(:dest_range) @id = args[:id] if args.key?(:id) @kind = args[:kind] if args.key?(:kind) @name = args[:name] if args.key?(:name) @network = args[:network] if args.key?(:network) @next_hop_gateway = args[:next_hop_gateway] if args.key?(:next_hop_gateway) @next_hop_hub = args[:next_hop_hub] if args.key?(:next_hop_hub) @next_hop_ilb = args[:next_hop_ilb] if args.key?(:next_hop_ilb) @next_hop_instance = args[:next_hop_instance] if args.key?(:next_hop_instance) @next_hop_inter_region_cost = args[:next_hop_inter_region_cost] if args.key?(:next_hop_inter_region_cost) @next_hop_interconnect_attachment = args[:next_hop_interconnect_attachment] if args.key?(:next_hop_interconnect_attachment) @next_hop_ip = args[:next_hop_ip] if args.key?(:next_hop_ip) @next_hop_med = args[:next_hop_med] if args.key?(:next_hop_med) @next_hop_network = args[:next_hop_network] if args.key?(:next_hop_network) @next_hop_origin = args[:next_hop_origin] if args.key?(:next_hop_origin) @next_hop_peering = args[:next_hop_peering] if args.key?(:next_hop_peering) @next_hop_vpn_tunnel = args[:next_hop_vpn_tunnel] if args.key?(:next_hop_vpn_tunnel) @priority = args[:priority] if args.key?(:priority) @route_status = args[:route_status] if args.key?(:route_status) @route_type = args[:route_type] if args.key?(:route_type) @self_link = args[:self_link] if args.key?(:self_link) @tags = args[:tags] if args.key?(:tags) @warnings = args[:warnings] if args.key?(:warnings) end |