Class: Google::Apis::ComputeAlpha::Address

Inherits:
Object
  • Object
show all
Includes:
Google::Apis::Core::Hashable, Google::Apis::Core::JsonObjectSupport
Defined in:
generated/google/apis/compute_alpha/classes.rb,
generated/google/apis/compute_alpha/representations.rb,
generated/google/apis/compute_alpha/representations.rb

Overview

A reserved address resource. (== resource_for beta.addresses ==) (== resource_for v1.addresses ==) (== resource_for beta.globalAddresses ==) (== resource_for v1.globalAddresses ==)

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Google::Apis::Core::JsonObjectSupport

#to_json

Methods included from Google::Apis::Core::Hashable

process_value, #to_h

Constructor Details

#initialize(**args) ⇒ Address

Returns a new instance of Address



667
668
669
# File 'generated/google/apis/compute_alpha/classes.rb', line 667

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

Instance Attribute Details

#addressString

The static IP address represented by this resource. Corresponds to the JSON property address

Returns:

  • (String)


547
548
549
# File 'generated/google/apis/compute_alpha/classes.rb', line 547

def address
  @address
end

#address_typeString

The type of address to reserve, either INTERNAL or EXTERNAL. If unspecified, defaults to EXTERNAL. Corresponds to the JSON property addressType

Returns:

  • (String)


553
554
555
# File 'generated/google/apis/compute_alpha/classes.rb', line 553

def address_type
  @address_type
end

#creation_timestampString

[Output Only] Creation timestamp in RFC3339 text format. Corresponds to the JSON property creationTimestamp

Returns:

  • (String)


558
559
560
# File 'generated/google/apis/compute_alpha/classes.rb', line 558

def creation_timestamp
  @creation_timestamp
end

#descriptionString

An optional description of this resource. Provide this property when you create the resource. Corresponds to the JSON property description

Returns:

  • (String)


564
565
566
# File 'generated/google/apis/compute_alpha/classes.rb', line 564

def description
  @description
end

#idFixnum

[Output Only] The unique identifier for the resource. This identifier is defined by the server. Corresponds to the JSON property id

Returns:

  • (Fixnum)


570
571
572
# File 'generated/google/apis/compute_alpha/classes.rb', line 570

def id
  @id
end

#ip_versionString

The IP Version that will be used by this address. Valid options are IPV4 or IPV6. This can only be specified for a global address. Corresponds to the JSON property ipVersion

Returns:

  • (String)


576
577
578
# File 'generated/google/apis/compute_alpha/classes.rb', line 576

def ip_version
  @ip_version
end

#kindString

[Output Only] Type of the resource. Always compute#address for addresses. Corresponds to the JSON property kind

Returns:

  • (String)


581
582
583
# File 'generated/google/apis/compute_alpha/classes.rb', line 581

def kind
  @kind
end

#label_fingerprintString

A fingerprint for the labels being applied to this Address, which is essentially a hash of the labels set used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels. To see the latest fingerprint, make a get() request to retrieve an Address. Corresponds to the JSON property labelFingerprint NOTE: Values are automatically base64 encoded/decoded in the client library.

Returns:

  • (String)


592
593
594
# File 'generated/google/apis/compute_alpha/classes.rb', line 592

def label_fingerprint
  @label_fingerprint
end

#labelsHash<String,String>

Labels to apply to this Address resource. These can be later modified by the setLabels method. Each label key/value must comply with RFC1035. Label values may be empty. Corresponds to the JSON property labels

Returns:

  • (Hash<String,String>)


599
600
601
# File 'generated/google/apis/compute_alpha/classes.rb', line 599

def labels
  @labels
end

#nameString

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])? which means the first character must be a lowercase letter, and all following characters must be a dash, lowercase letter, or digit, except the last character, which cannot be a dash. Corresponds to the JSON property name

Returns:

  • (String)


609
610
611
# File 'generated/google/apis/compute_alpha/classes.rb', line 609

def name
  @name
end

#networkString

The URL of the network in which to reserve the address. This field can only be used with INTERNAL type with VPC_PEERING purpose. Corresponds to the JSON property network

Returns:

  • (String)


615
616
617
# File 'generated/google/apis/compute_alpha/classes.rb', line 615

def network
  @network
end

#network_tierString

This signifies the networking tier used for configuring this Address and can only take the following values: PREMIUM , STANDARD. If this field is not specified, it is assumed to be PREMIUM. Corresponds to the JSON property networkTier

Returns:

  • (String)


622
623
624
# File 'generated/google/apis/compute_alpha/classes.rb', line 622

def network_tier
  @network_tier
end

#prefix_lengthFixnum

The prefix length if the resource reprensents an IP range. Corresponds to the JSON property prefixLength

Returns:

  • (Fixnum)


627
628
629
# File 'generated/google/apis/compute_alpha/classes.rb', line 627

def prefix_length
  @prefix_length
end

#purposeString

The purpose of resource, only used with INTERNAL type. Corresponds to the JSON property purpose

Returns:

  • (String)


632
633
634
# File 'generated/google/apis/compute_alpha/classes.rb', line 632

def purpose
  @purpose
end

#regionString

[Output Only] URL of the region where the regional address resides. This field is not applicable to global addresses. You must specify this field as part of the HTTP request URL. You cannot set this field in the request body. Corresponds to the JSON property region

Returns:

  • (String)


639
640
641
# File 'generated/google/apis/compute_alpha/classes.rb', line 639

def region
  @region
end

[Output Only] Server-defined URL for the resource. Corresponds to the JSON property selfLink

Returns:

  • (String)


644
645
646
# File 'generated/google/apis/compute_alpha/classes.rb', line 644

def self_link
  @self_link
end

#statusString

[Output Only] The status of the address, which can be one of RESERVING, RESERVED, or IN_USE. An address that is RESERVING is currently in the process of being reserved. A RESERVED address is currently reserved and available to use. An IN_USE address is currently being used by another resource and is not available. Corresponds to the JSON property status

Returns:

  • (String)


653
654
655
# File 'generated/google/apis/compute_alpha/classes.rb', line 653

def status
  @status
end

#subnetworkString

The URL of the subnetwork in which to reserve the address. If an IP address is specified, it must be within the subnetwork's IP range. This field can only be used with INTERNAL type with GCE_ENDPOINT/DNS_RESOLVER purposes. Corresponds to the JSON property subnetwork

Returns:

  • (String)


660
661
662
# File 'generated/google/apis/compute_alpha/classes.rb', line 660

def subnetwork
  @subnetwork
end

#usersArray<String>

[Output Only] The URLs of the resources that are using this address. Corresponds to the JSON property users

Returns:

  • (Array<String>)


665
666
667
# File 'generated/google/apis/compute_alpha/classes.rb', line 665

def users
  @users
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
# File 'generated/google/apis/compute_alpha/classes.rb', line 672

def update!(**args)
  @address = args[:address] if args.key?(:address)
  @address_type = args[:address_type] if args.key?(:address_type)
  @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
  @description = args[:description] if args.key?(:description)
  @id = args[:id] if args.key?(:id)
  @ip_version = args[:ip_version] if args.key?(:ip_version)
  @kind = args[:kind] if args.key?(:kind)
  @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
  @labels = args[:labels] if args.key?(:labels)
  @name = args[:name] if args.key?(:name)
  @network = args[:network] if args.key?(:network)
  @network_tier = args[:network_tier] if args.key?(:network_tier)
  @prefix_length = args[:prefix_length] if args.key?(:prefix_length)
  @purpose = args[:purpose] if args.key?(:purpose)
  @region = args[:region] if args.key?(:region)
  @self_link = args[:self_link] if args.key?(:self_link)
  @status = args[:status] if args.key?(:status)
  @subnetwork = args[:subnetwork] if args.key?(:subnetwork)
  @users = args[:users] if args.key?(:users)
end