Class: Google::Apis::NetworkconnectivityV1alpha1::InternalRange

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

Overview

The internal range resource for IPAM operations within a VPC network. Used to represent a private address range along with behavioral characterstics of that range (its usage and peering behavior). Networking resources can link to this range if they are created as belonging to it.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ InternalRange

Returns a new instance of InternalRange.



564
565
566
# File 'lib/google/apis/networkconnectivity_v1alpha1/classes.rb', line 564

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

Instance Attribute Details

#create_timeString

Time when the internal range was created. Corresponds to the JSON property createTime

Returns:

  • (String)


484
485
486
# File 'lib/google/apis/networkconnectivity_v1alpha1/classes.rb', line 484

def create_time
  @create_time
end

#descriptionString

A description of this resource. Corresponds to the JSON property description

Returns:

  • (String)


489
490
491
# File 'lib/google/apis/networkconnectivity_v1alpha1/classes.rb', line 489

def description
  @description
end

#ip_cidr_rangeString

IP range that this internal range defines. Corresponds to the JSON property ipCidrRange

Returns:

  • (String)


494
495
496
# File 'lib/google/apis/networkconnectivity_v1alpha1/classes.rb', line 494

def ip_cidr_range
  @ip_cidr_range
end

#labelsHash<String,String>

User-defined labels. Corresponds to the JSON property labels

Returns:

  • (Hash<String,String>)


499
500
501
# File 'lib/google/apis/networkconnectivity_v1alpha1/classes.rb', line 499

def labels
  @labels
end

#nameString

Immutable. The name of an internal range. Format: projects/project/locations/ location/internalRanges/internal_range See: https://google.aip.dev/122# fields-representing-resource-names Corresponds to the JSON property name

Returns:

  • (String)


506
507
508
# File 'lib/google/apis/networkconnectivity_v1alpha1/classes.rb', line 506

def name
  @name
end

#networkString

The URL or resource ID of the network in which to reserve the internal range. The network cannot be deleted if there are any reserved internal ranges referring to it. Legacy networks are not supported. For example: https://www. googleapis.com/compute/v1/projects/project/locations/global/networks/ network projects/project/locations/global/networks/network network Corresponds to the JSON property network

Returns:

  • (String)


515
516
517
# File 'lib/google/apis/networkconnectivity_v1alpha1/classes.rb', line 515

def network
  @network
end

#overlapsArray<String>

Optional. Types of resources that are allowed to overlap with the current internal range. Corresponds to the JSON property overlaps

Returns:

  • (Array<String>)


521
522
523
# File 'lib/google/apis/networkconnectivity_v1alpha1/classes.rb', line 521

def overlaps
  @overlaps
end

#peeringString

The type of peering set for this internal range. Corresponds to the JSON property peering

Returns:

  • (String)


526
527
528
# File 'lib/google/apis/networkconnectivity_v1alpha1/classes.rb', line 526

def peering
  @peering
end

#prefix_lengthFixnum

An alternative to ip_cidr_range. Can be set when trying to create a reservation that automatically finds a free range of the given size. If both ip_cidr_range and prefix_length are set, there is an error if the range sizes do not match. Can also be used during updates to change the range size. Corresponds to the JSON property prefixLength

Returns:

  • (Fixnum)


534
535
536
# File 'lib/google/apis/networkconnectivity_v1alpha1/classes.rb', line 534

def prefix_length
  @prefix_length
end

#target_cidr_rangeArray<String>

Optional. Can be set to narrow down or pick a different address space while searching for a free range. If not set, defaults to the "10.0.0.0/8" address space. This can be used to search in other rfc-1918 address spaces like "172. 16.0.0/12" and "192.168.0.0/16" or non-rfc-1918 address spaces used in the VPC. Corresponds to the JSON property targetCidrRange

Returns:

  • (Array<String>)


542
543
544
# File 'lib/google/apis/networkconnectivity_v1alpha1/classes.rb', line 542

def target_cidr_range
  @target_cidr_range
end

#update_timeString

Time when the internal range was updated. Corresponds to the JSON property updateTime

Returns:

  • (String)


547
548
549
# File 'lib/google/apis/networkconnectivity_v1alpha1/classes.rb', line 547

def update_time
  @update_time
end

#usageString

The type of usage set for this internal range. Corresponds to the JSON property usage

Returns:

  • (String)


552
553
554
# File 'lib/google/apis/networkconnectivity_v1alpha1/classes.rb', line 552

def usage
  @usage
end

#usersArray<String>

Output only. The list of resources that refer to this internal range. Resources that use the internal range for their range allocation are referred to as users of the range. Other resources mark themselves as users while doing so by creating a reference to this internal range. Having a user, based on this reference, prevents deletion of the internal range that is referred to. Can be empty. Corresponds to the JSON property users

Returns:

  • (Array<String>)


562
563
564
# File 'lib/google/apis/networkconnectivity_v1alpha1/classes.rb', line 562

def users
  @users
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
# File 'lib/google/apis/networkconnectivity_v1alpha1/classes.rb', line 569

def update!(**args)
  @create_time = args[:create_time] if args.key?(:create_time)
  @description = args[:description] if args.key?(:description)
  @ip_cidr_range = args[:ip_cidr_range] if args.key?(:ip_cidr_range)
  @labels = args[:labels] if args.key?(:labels)
  @name = args[:name] if args.key?(:name)
  @network = args[:network] if args.key?(:network)
  @overlaps = args[:overlaps] if args.key?(:overlaps)
  @peering = args[:peering] if args.key?(:peering)
  @prefix_length = args[:prefix_length] if args.key?(:prefix_length)
  @target_cidr_range = args[:target_cidr_range] if args.key?(:target_cidr_range)
  @update_time = args[:update_time] if args.key?(:update_time)
  @usage = args[:usage] if args.key?(:usage)
  @users = args[:users] if args.key?(:users)
end