Class: Google::Apis::NetworkconnectivityV1::Hub

Inherits:
Object
  • Object
show all
Includes:
Core::Hashable, Core::JsonObjectSupport
Defined in:
lib/google/apis/networkconnectivity_v1/classes.rb,
lib/google/apis/networkconnectivity_v1/representations.rb,
lib/google/apis/networkconnectivity_v1/representations.rb

Overview

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.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ Hub

Returns a new instance of Hub.



938
939
940
# File 'lib/google/apis/networkconnectivity_v1/classes.rb', line 938

def initialize(**args)
   update!(**args)
end

Instance Attribute Details

#create_timeString

Output only. The time the hub was created. Corresponds to the JSON property createTime

Returns:

  • (String)


854
855
856
# File 'lib/google/apis/networkconnectivity_v1/classes.rb', line 854

def create_time
  @create_time
end

#descriptionString

An optional description of the hub. Corresponds to the JSON property description

Returns:

  • (String)


859
860
861
# File 'lib/google/apis/networkconnectivity_v1/classes.rb', line 859

def description
  @description
end

#export_pscBoolean Also known as: export_psc?

Optional. Whether Private Service Connect transitivity 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. Corresponds to the JSON property exportPsc

Returns:

  • (Boolean)


867
868
869
# File 'lib/google/apis/networkconnectivity_v1/classes.rb', line 867

def export_psc
  @export_psc
end

#labelsHash<String,String>

Optional labels in key-value pair format. For more information about labels, see Requirements for labels. Corresponds to the JSON property labels

Returns:

  • (Hash<String,String>)


875
876
877
# File 'lib/google/apis/networkconnectivity_v1/classes.rb', line 875

def labels
  @labels
end

#nameString

Immutable. The name of the hub. Hub names must be unique. They use the following form: projects/project_number/locations/global/hubs/hub_id` Corresponds to the JSON propertyname`

Returns:

  • (String)


881
882
883
# File 'lib/google/apis/networkconnectivity_v1/classes.rb', line 881

def name
  @name
end

#policy_modeString

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

Returns:

  • (String)


887
888
889
# File 'lib/google/apis/networkconnectivity_v1/classes.rb', line 887

def policy_mode
  @policy_mode
end

#preset_topologyString

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. Corresponds to the JSON property presetTopology

Returns:

  • (String)


896
897
898
# File 'lib/google/apis/networkconnectivity_v1/classes.rb', line 896

def preset_topology
  @preset_topology
end

#route_tablesArray<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. Corresponds to the JSON propertyrouteTables`

Returns:

  • (Array<String>)


904
905
906
# File 'lib/google/apis/networkconnectivity_v1/classes.rb', line 904

def route_tables
  @route_tables
end

#routing_vpcsArray<Google::Apis::NetworkconnectivityV1::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. Corresponds to the JSON property routingVpcs



911
912
913
# File 'lib/google/apis/networkconnectivity_v1/classes.rb', line 911

def routing_vpcs
  @routing_vpcs
end

#spoke_summaryGoogle::Apis::NetworkconnectivityV1::SpokeSummary

Summarizes information about 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. Corresponds to the JSON property spokeSummary



919
920
921
# File 'lib/google/apis/networkconnectivity_v1/classes.rb', line 919

def spoke_summary
  @spoke_summary
end

#stateString

Output only. The current lifecycle state of this hub. Corresponds to the JSON property state

Returns:

  • (String)


924
925
926
# File 'lib/google/apis/networkconnectivity_v1/classes.rb', line 924

def state
  @state
end

#unique_idString

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. Corresponds to the JSON property uniqueId

Returns:

  • (String)


931
932
933
# File 'lib/google/apis/networkconnectivity_v1/classes.rb', line 931

def unique_id
  @unique_id
end

#update_timeString

Output only. The time the hub was last updated. Corresponds to the JSON property updateTime

Returns:

  • (String)


936
937
938
# File 'lib/google/apis/networkconnectivity_v1/classes.rb', line 936

def update_time
  @update_time
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
# File 'lib/google/apis/networkconnectivity_v1/classes.rb', line 943

def update!(**args)
  @create_time = args[:create_time] if args.key?(:create_time)
  @description = args[:description] if args.key?(:description)
  @export_psc = args[:export_psc] if args.key?(:export_psc)
  @labels = args[:labels] if args.key?(:labels)
  @name = args[:name] if args.key?(:name)
  @policy_mode = args[:policy_mode] if args.key?(:policy_mode)
  @preset_topology = args[:preset_topology] if args.key?(:preset_topology)
  @route_tables = args[:route_tables] if args.key?(:route_tables)
  @routing_vpcs = args[:routing_vpcs] if args.key?(:routing_vpcs)
  @spoke_summary = args[:spoke_summary] if args.key?(:spoke_summary)
  @state = args[:state] if args.key?(:state)
  @unique_id = args[:unique_id] if args.key?(:unique_id)
  @update_time = args[:update_time] if args.key?(:update_time)
end