Skip to main content

Hub

#[non_exhaustive]
pub struct Hub {
Show 13 fields pub name: String, pub create_time: Option<Timestamp>, pub update_time: Option<Timestamp>, pub labels: HashMap<String, String>, pub description: String, pub unique_id: String, pub state: State, pub routing_vpcs: Vec<RoutingVPC>, pub route_tables: Vec<String>, pub spoke_summary: Option<SpokeSummary>, pub policy_mode: PolicyMode, pub preset_topology: PresetTopology, pub export_psc: Option<bool>, /* private fields */
}
Expand description

A Network Connectivity Center hub is a global management resource to which you attach spokes. A single hub can contain spokes from multiple regions. However, if any of a hub’s spokes use the site-to-site data transfer feature, the resources associated with those spokes must all be in the same VPC network. Spokes that do not use site-to-site data transfer can be associated with any VPC network in your project.

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.
§name: String

Immutable. The name of the hub. Hub names must be unique. They use the following form: projects/{project_number}/locations/global/hubs/{hub_id}

§create_time: Option<Timestamp>

Output only. The time the hub was created.

§update_time: Option<Timestamp>

Output only. The time the hub was last updated.

§labels: HashMap<String, String>

Optional labels in key-value pair format. For more information about labels, see Requirements for labels.

§description: String

Optional. An optional description of the hub.

§unique_id: String

Output only. The Google-generated UUID for the hub. This value is unique across all hub resources. If a hub is deleted and another with the same name is created, the new hub is assigned a different unique_id.

§state: State

Output only. The current lifecycle state of this hub.

§routing_vpcs: Vec<RoutingVPC>

The VPC networks associated with this hub’s spokes.

This field is read-only. Network Connectivity Center automatically populates it based on the set of spokes attached to the hub.

§route_tables: Vec<String>

Output only. The route tables that belong to this hub. They use the following form: projects/{project_number}/locations/global/hubs/{hub_id}/routeTables/{route_table_id}

This field is read-only. Network Connectivity Center automatically populates it based on the route tables nested under the hub.

§spoke_summary: Option<SpokeSummary>

Output only. A summary of the spokes associated with a hub. The summary includes a count of spokes according to type and according to state. If any spokes are inactive, the summary also lists the reasons they are inactive, including a count for each reason.

§policy_mode: PolicyMode

Optional. The policy mode of this hub. This field can be either PRESET or CUSTOM. If unspecified, the policy_mode defaults to PRESET.

§preset_topology: PresetTopology

Optional. The topology implemented in this hub. Currently, this field is only used when policy_mode = PRESET. The available preset topologies are MESH and STAR. If preset_topology is unspecified and policy_mode = PRESET, the preset_topology defaults to MESH. When policy_mode = CUSTOM, the preset_topology is set to PRESET_TOPOLOGY_UNSPECIFIED.

§export_psc: Option<bool>

Optional. Whether Private Service Connect connection propagation is enabled for the hub. If true, Private Service Connect endpoints in VPC spokes attached to the hub are made accessible to other VPC spokes attached to the hub. The default value is false.

Implementations§

Source§

impl Hub

Source

pub fn new() -> Self

Source

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

Sets the value of name.

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

pub fn set_create_time<T>(self, v: T) -> Self
where T: Into<Timestamp>,

Sets the value of create_time.

§Example
use wkt::Timestamp;
let x = Hub::new().set_create_time(Timestamp::default()/* use setters */);
Source

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

Sets or clears the value of create_time.

§Example
use wkt::Timestamp;
let x = Hub::new().set_or_clear_create_time(Some(Timestamp::default()/* use setters */));
let x = Hub::new().set_or_clear_create_time(None::<Timestamp>);
Source

pub fn set_update_time<T>(self, v: T) -> Self
where T: Into<Timestamp>,

Sets the value of update_time.

§Example
use wkt::Timestamp;
let x = Hub::new().set_update_time(Timestamp::default()/* use setters */);
Source

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

Sets or clears the value of update_time.

§Example
use wkt::Timestamp;
let x = Hub::new().set_or_clear_update_time(Some(Timestamp::default()/* use setters */));
let x = Hub::new().set_or_clear_update_time(None::<Timestamp>);
Source

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

Sets the value of labels.

§Example
let x = Hub::new().set_labels([
    ("key0", "abc"),
    ("key1", "xyz"),
]);
Source

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

Sets the value of description.

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

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

Sets the value of unique_id.

§Example
let x = Hub::new().set_unique_id("example");
Source

pub fn set_state<T: Into<State>>(self, v: T) -> Self

Sets the value of state.

§Example
use google_cloud_networkconnectivity_v1::model::State;
let x0 = Hub::new().set_state(State::Creating);
let x1 = Hub::new().set_state(State::Active);
let x2 = Hub::new().set_state(State::Deleting);
Source

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

Sets the value of routing_vpcs.

§Example
use google_cloud_networkconnectivity_v1::model::RoutingVPC;
let x = Hub::new()
    .set_routing_vpcs([
        RoutingVPC::default()/* use setters */,
        RoutingVPC::default()/* use (different) setters */,
    ]);
Source

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

Sets the value of route_tables.

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

pub fn set_spoke_summary<T>(self, v: T) -> Self
where T: Into<SpokeSummary>,

Sets the value of spoke_summary.

§Example
use google_cloud_networkconnectivity_v1::model::SpokeSummary;
let x = Hub::new().set_spoke_summary(SpokeSummary::default()/* use setters */);
Source

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

Sets or clears the value of spoke_summary.

§Example
use google_cloud_networkconnectivity_v1::model::SpokeSummary;
let x = Hub::new().set_or_clear_spoke_summary(Some(SpokeSummary::default()/* use setters */));
let x = Hub::new().set_or_clear_spoke_summary(None::<SpokeSummary>);
Source

pub fn set_policy_mode<T: Into<PolicyMode>>(self, v: T) -> Self

Sets the value of policy_mode.

§Example
use google_cloud_networkconnectivity_v1::model::PolicyMode;
let x0 = Hub::new().set_policy_mode(PolicyMode::Preset);
Source

pub fn set_preset_topology<T: Into<PresetTopology>>(self, v: T) -> Self

Sets the value of preset_topology.

§Example
use google_cloud_networkconnectivity_v1::model::PresetTopology;
let x0 = Hub::new().set_preset_topology(PresetTopology::Mesh);
let x1 = Hub::new().set_preset_topology(PresetTopology::Star);
Source

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

Sets the value of export_psc.

§Example
let x = Hub::new().set_export_psc(true);
Source

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

Sets or clears the value of export_psc.

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

Trait Implementations§

Source§

impl Clone for Hub

Source§

fn clone(&self) -> Hub

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 Hub

Source§

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

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

impl Default for Hub

Source§

fn default() -> Hub

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

impl Message for Hub

Source§

fn typename() -> &'static str

The typename of this message.
Source§

impl PartialEq for Hub

Source§

fn eq(&self, other: &Hub) -> 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 Hub

Auto Trait Implementations§

§

impl Freeze for Hub

§

impl RefUnwindSafe for Hub

§

impl Send for Hub

§

impl Sync for Hub

§

impl Unpin for Hub

§

impl UnwindSafe for Hub

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>,