Skip to main content

InterconnectLocation

Struct InterconnectLocation 

Source
#[non_exhaustive]
pub struct InterconnectLocation {
Show 20 fields pub address: Option<String>, pub availability_zone: Option<String>, pub available_features: Vec<AvailableFeatures>, pub available_link_types: Vec<AvailableLinkTypes>, pub city: Option<String>, pub continent: Option<Continent>, pub creation_timestamp: Option<String>, pub cross_site_interconnect_infos: Vec<InterconnectLocationCrossSiteInterconnectInfo>, pub description: Option<String>, pub facility_provider: Option<String>, pub facility_provider_facility_id: Option<String>, pub id: Option<u64>, pub kind: Option<String>, pub name: Option<String>, pub peeringdb_facility_id: Option<String>, pub region_infos: Vec<InterconnectLocationRegionInfo>, pub self_link: Option<String>, pub single_region_production_critical_peer_locations: Vec<String>, pub status: Option<Status>, pub supports_pzs: Option<bool>, /* private fields */
}
Available on crate feature interconnect-locations only.
Expand description

Represents an Interconnect Attachment (VLAN) Location resource.

You can use this resource to find location details about an Interconnect attachment (VLAN). For more information about interconnect attachments, read Creating VLAN Attachments.

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§address: Option<String>

Output only. [Output Only] The postal address of the Point of Presence, each line in the address is separated by a newline character.

§availability_zone: Option<String>

[Output Only] Availability zone for this InterconnectLocation. Within a metropolitan area (metro), maintenance will not be simultaneously scheduled in more than one availability zone. Example: “zone1” or “zone2”.

§available_features: Vec<AvailableFeatures>

[Output only] List of features available at this InterconnectLocation, which can take one of the following values:

  • IF_MACSEC
  • IF_CROSS_SITE_NETWORK
§available_link_types: Vec<AvailableLinkTypes>

[Output only] List of link types available at this InterconnectLocation, which can take one of the following values:

  • LINK_TYPE_ETHERNET_10G_LR
  • LINK_TYPE_ETHERNET_100G_LR
  • LINK_TYPE_ETHERNET_400G_LR4
§city: Option<String>

[Output Only] Metropolitan area designator that indicates which city an interconnect is located. For example: “Chicago, IL”, “Amsterdam, Netherlands”.

§continent: Option<Continent>

[Output Only] Continent for this location, which can take one of the following values:

  • AFRICA
  • ASIA_PAC
  • EUROPE
  • NORTH_AMERICA
  • SOUTH_AMERICA
§creation_timestamp: Option<String>

Output only. [Output Only] Creation timestamp inRFC3339 text format.

§cross_site_interconnect_infos: Vec<InterconnectLocationCrossSiteInterconnectInfo>

[Output Only] A list of InterconnectLocation.CrossSiteInterconnectInfo objects, that describe where Cross-Site Interconnect wires may connect to from this location and associated connection parameters. Cross-Site Interconnect isn’t allowed to locations which are not listed.

§description: Option<String>

Output only. [Output Only] An optional description of the resource.

§facility_provider: Option<String>

Output only. [Output Only] The name of the provider for this facility (e.g., EQUINIX).

§facility_provider_facility_id: Option<String>

Output only. [Output Only] A provider-assigned Identifier for this facility (e.g., Ashburn-DC1).

§id: Option<u64>

Output only. [Output Only] The unique identifier for the resource. This identifier is defined by the server.

§kind: Option<String>

Output only. [Output Only] Type of the resource. Alwayscompute#interconnectLocation for interconnect locations.

§name: Option<String>

Output only. [Output Only] Name of the resource.

§peeringdb_facility_id: Option<String>

Output only. [Output Only] The peeringdb identifier for this facility (corresponding with a netfac type in peeringdb).

§region_infos: Vec<InterconnectLocationRegionInfo>

Output only. [Output Only] A list of InterconnectLocation.RegionInfo objects, that describe parameters pertaining to the relation between this InterconnectLocation and various Google Cloud regions.

§self_link: Option<String>

Output only. [Output Only] Server-defined URL for the resource.

§single_region_production_critical_peer_locations: Vec<String>

Output only. [Output Only] URLs of the other locations that can pair up with this location to support Single-Region 99.99% SLA. E.g. iad-zone1-1 and iad-zone2-5467 are Single-Region 99.99% peer locations of each other.

§status: Option<Status>

[Output Only] The status of this InterconnectLocation, which can take one of the following values:

  • CLOSED: The InterconnectLocation is closed and is unavailable for provisioning new Interconnects.
  • AVAILABLE: The InterconnectLocation is available for provisioning new Interconnects.
§supports_pzs: Option<bool>

Output only. [Output Only] Reserved for future use.

Implementations§

Source§

impl InterconnectLocation

Source

pub fn new() -> Self

Source

pub fn set_address<T>(self, v: T) -> Self
where T: Into<String>,

Sets the value of address.

§Example
let x = InterconnectLocation::new().set_address("example");
Source

pub fn set_or_clear_address<T>(self, v: Option<T>) -> Self
where T: Into<String>,

Sets or clears the value of address.

§Example
let x = InterconnectLocation::new().set_or_clear_address(Some("example"));
let x = InterconnectLocation::new().set_or_clear_address(None::<String>);
Source

pub fn set_availability_zone<T>(self, v: T) -> Self
where T: Into<String>,

Sets the value of availability_zone.

§Example
let x = InterconnectLocation::new().set_availability_zone("example");
Source

pub fn set_or_clear_availability_zone<T>(self, v: Option<T>) -> Self
where T: Into<String>,

Sets or clears the value of availability_zone.

§Example
let x = InterconnectLocation::new().set_or_clear_availability_zone(Some("example"));
let x = InterconnectLocation::new().set_or_clear_availability_zone(None::<String>);
Source

pub fn set_available_features<T, V>(self, v: T) -> Self
where T: IntoIterator<Item = V>, V: Into<AvailableFeatures>,

Sets the value of available_features.

§Example
use google_cloud_compute_v1::model::interconnect_location::AvailableFeatures;
let x = InterconnectLocation::new().set_available_features([
    AvailableFeatures::IfL2Forwarding,
    AvailableFeatures::IfMacsec,
]);

Sets the value of available_link_types.

§Example
use google_cloud_compute_v1::model::interconnect_location::AvailableLinkTypes;
let x = InterconnectLocation::new().set_available_link_types([
    AvailableLinkTypes::LinkTypeEthernet10GLr,
    AvailableLinkTypes::LinkTypeEthernet400GLr4,
]);
Source

pub fn set_city<T>(self, v: T) -> Self
where T: Into<String>,

Sets the value of city.

§Example
let x = InterconnectLocation::new().set_city("example");
Source

pub fn set_or_clear_city<T>(self, v: Option<T>) -> Self
where T: Into<String>,

Sets or clears the value of city.

§Example
let x = InterconnectLocation::new().set_or_clear_city(Some("example"));
let x = InterconnectLocation::new().set_or_clear_city(None::<String>);
Source

pub fn set_continent<T>(self, v: T) -> Self
where T: Into<Continent>,

Sets the value of continent.

§Example
use google_cloud_compute_v1::model::interconnect_location::Continent;
let x0 = InterconnectLocation::new().set_continent(Continent::AsiaPac);
let x1 = InterconnectLocation::new().set_continent(Continent::CAfrica);
let x2 = InterconnectLocation::new().set_continent(Continent::CAsiaPac);
Source

pub fn set_or_clear_continent<T>(self, v: Option<T>) -> Self
where T: Into<Continent>,

Sets or clears the value of continent.

§Example
use google_cloud_compute_v1::model::interconnect_location::Continent;
let x0 = InterconnectLocation::new().set_or_clear_continent(Some(Continent::AsiaPac));
let x1 = InterconnectLocation::new().set_or_clear_continent(Some(Continent::CAfrica));
let x2 = InterconnectLocation::new().set_or_clear_continent(Some(Continent::CAsiaPac));
let x_none = InterconnectLocation::new().set_or_clear_continent(None::<Continent>);
Source

pub fn set_creation_timestamp<T>(self, v: T) -> Self
where T: Into<String>,

Sets the value of creation_timestamp.

§Example
let x = InterconnectLocation::new().set_creation_timestamp("example");
Source

pub fn set_or_clear_creation_timestamp<T>(self, v: Option<T>) -> Self
where T: Into<String>,

Sets or clears the value of creation_timestamp.

§Example
let x = InterconnectLocation::new().set_or_clear_creation_timestamp(Some("example"));
let x = InterconnectLocation::new().set_or_clear_creation_timestamp(None::<String>);
Source

pub fn set_cross_site_interconnect_infos<T, V>(self, v: T) -> Self

Sets the value of cross_site_interconnect_infos.

§Example
use google_cloud_compute_v1::model::InterconnectLocationCrossSiteInterconnectInfo;
let x = InterconnectLocation::new()
    .set_cross_site_interconnect_infos([
        InterconnectLocationCrossSiteInterconnectInfo::default()/* use setters */,
        InterconnectLocationCrossSiteInterconnectInfo::default()/* use (different) setters */,
    ]);
Source

pub fn set_description<T>(self, v: T) -> Self
where T: Into<String>,

Sets the value of description.

§Example
let x = InterconnectLocation::new().set_description("example");
Source

pub fn set_or_clear_description<T>(self, v: Option<T>) -> Self
where T: Into<String>,

Sets or clears the value of description.

§Example
let x = InterconnectLocation::new().set_or_clear_description(Some("example"));
let x = InterconnectLocation::new().set_or_clear_description(None::<String>);
Source

pub fn set_facility_provider<T>(self, v: T) -> Self
where T: Into<String>,

Sets the value of facility_provider.

§Example
let x = InterconnectLocation::new().set_facility_provider("example");
Source

pub fn set_or_clear_facility_provider<T>(self, v: Option<T>) -> Self
where T: Into<String>,

Sets or clears the value of facility_provider.

§Example
let x = InterconnectLocation::new().set_or_clear_facility_provider(Some("example"));
let x = InterconnectLocation::new().set_or_clear_facility_provider(None::<String>);
Source

pub fn set_facility_provider_facility_id<T>(self, v: T) -> Self
where T: Into<String>,

Sets the value of facility_provider_facility_id.

§Example
let x = InterconnectLocation::new().set_facility_provider_facility_id("example");
Source

pub fn set_or_clear_facility_provider_facility_id<T>(self, v: Option<T>) -> Self
where T: Into<String>,

Sets or clears the value of facility_provider_facility_id.

§Example
let x = InterconnectLocation::new().set_or_clear_facility_provider_facility_id(Some("example"));
let x = InterconnectLocation::new().set_or_clear_facility_provider_facility_id(None::<String>);
Source

pub fn set_id<T>(self, v: T) -> Self
where T: Into<u64>,

Sets the value of id.

§Example
let x = InterconnectLocation::new().set_id(42_u32);
Source

pub fn set_or_clear_id<T>(self, v: Option<T>) -> Self
where T: Into<u64>,

Sets or clears the value of id.

§Example
let x = InterconnectLocation::new().set_or_clear_id(Some(42_u32));
let x = InterconnectLocation::new().set_or_clear_id(None::<u32>);
Source

pub fn set_kind<T>(self, v: T) -> Self
where T: Into<String>,

Sets the value of kind.

§Example
let x = InterconnectLocation::new().set_kind("example");
Source

pub fn set_or_clear_kind<T>(self, v: Option<T>) -> Self
where T: Into<String>,

Sets or clears the value of kind.

§Example
let x = InterconnectLocation::new().set_or_clear_kind(Some("example"));
let x = InterconnectLocation::new().set_or_clear_kind(None::<String>);
Source

pub fn set_name<T>(self, v: T) -> Self
where T: Into<String>,

Sets the value of name.

§Example
let x = InterconnectLocation::new().set_name("example");
Source

pub fn set_or_clear_name<T>(self, v: Option<T>) -> Self
where T: Into<String>,

Sets or clears the value of name.

§Example
let x = InterconnectLocation::new().set_or_clear_name(Some("example"));
let x = InterconnectLocation::new().set_or_clear_name(None::<String>);
Source

pub fn set_peeringdb_facility_id<T>(self, v: T) -> Self
where T: Into<String>,

Sets the value of peeringdb_facility_id.

§Example
let x = InterconnectLocation::new().set_peeringdb_facility_id("example");
Source

pub fn set_or_clear_peeringdb_facility_id<T>(self, v: Option<T>) -> Self
where T: Into<String>,

Sets or clears the value of peeringdb_facility_id.

§Example
let x = InterconnectLocation::new().set_or_clear_peeringdb_facility_id(Some("example"));
let x = InterconnectLocation::new().set_or_clear_peeringdb_facility_id(None::<String>);
Source

pub fn set_region_infos<T, V>(self, v: T) -> Self

Sets the value of region_infos.

§Example
use google_cloud_compute_v1::model::InterconnectLocationRegionInfo;
let x = InterconnectLocation::new()
    .set_region_infos([
        InterconnectLocationRegionInfo::default()/* use setters */,
        InterconnectLocationRegionInfo::default()/* use (different) setters */,
    ]);

Sets the value of self_link.

§Example
let x = InterconnectLocation::new().set_self_link("example");

Sets or clears the value of self_link.

§Example
let x = InterconnectLocation::new().set_or_clear_self_link(Some("example"));
let x = InterconnectLocation::new().set_or_clear_self_link(None::<String>);
Source

pub fn set_single_region_production_critical_peer_locations<T, V>( self, v: T, ) -> Self
where T: IntoIterator<Item = V>, V: Into<String>,

Sets the value of single_region_production_critical_peer_locations.

§Example
let x = InterconnectLocation::new().set_single_region_production_critical_peer_locations(["a", "b", "c"]);
Source

pub fn set_status<T>(self, v: T) -> Self
where T: Into<Status>,

Sets the value of status.

§Example
use google_cloud_compute_v1::model::interconnect_location::Status;
let x0 = InterconnectLocation::new().set_status(Status::Closed);
Source

pub fn set_or_clear_status<T>(self, v: Option<T>) -> Self
where T: Into<Status>,

Sets or clears the value of status.

§Example
use google_cloud_compute_v1::model::interconnect_location::Status;
let x0 = InterconnectLocation::new().set_or_clear_status(Some(Status::Closed));
let x_none = InterconnectLocation::new().set_or_clear_status(None::<Status>);
Source

pub fn set_supports_pzs<T>(self, v: T) -> Self
where T: Into<bool>,

Sets the value of supports_pzs.

§Example
let x = InterconnectLocation::new().set_supports_pzs(true);
Source

pub fn set_or_clear_supports_pzs<T>(self, v: Option<T>) -> Self
where T: Into<bool>,

Sets or clears the value of supports_pzs.

§Example
let x = InterconnectLocation::new().set_or_clear_supports_pzs(Some(false));
let x = InterconnectLocation::new().set_or_clear_supports_pzs(None::<bool>);

Trait Implementations§

Source§

impl Clone for InterconnectLocation

Source§

fn clone(&self) -> InterconnectLocation

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for InterconnectLocation

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for InterconnectLocation

Source§

fn default() -> InterconnectLocation

Returns the “default value” for a type. Read more
Source§

impl Message for InterconnectLocation

Source§

fn typename() -> &'static str

The typename of this message.
Source§

impl PartialEq for InterconnectLocation

Source§

fn eq(&self, other: &InterconnectLocation) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl StructuralPartialEq for InterconnectLocation

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,