1677 lines
65 KiB
Ruby
1677 lines
65 KiB
Ruby
# Copyright 2015 Google Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
require 'date'
|
|
require 'google/apis/core/base_service'
|
|
require 'google/apis/core/json_representation'
|
|
require 'google/apis/core/hashable'
|
|
require 'google/apis/errors'
|
|
|
|
module Google
|
|
module Apis
|
|
module DnsV1
|
|
|
|
# A Change represents a set of ResourceRecordSet additions and deletions applied
|
|
# atomically to a ManagedZone. ResourceRecordSets within a ManagedZone are
|
|
# modified by creating a new Change element in the Changes collection. In turn
|
|
# the Changes collection also records the past modifications to the
|
|
# ResourceRecordSets in a ManagedZone. The current state of the ManagedZone is
|
|
# the sum effect of applying all Change elements in the Changes collection in
|
|
# sequence.
|
|
class Change
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# Which ResourceRecordSets to add?
|
|
# Corresponds to the JSON property `additions`
|
|
# @return [Array<Google::Apis::DnsV1::ResourceRecordSet>]
|
|
attr_accessor :additions
|
|
|
|
# Which ResourceRecordSets to remove? Must match existing data exactly.
|
|
# Corresponds to the JSON property `deletions`
|
|
# @return [Array<Google::Apis::DnsV1::ResourceRecordSet>]
|
|
attr_accessor :deletions
|
|
|
|
# Unique identifier for the resource; defined by the server (output only).
|
|
# Corresponds to the JSON property `id`
|
|
# @return [String]
|
|
attr_accessor :id
|
|
|
|
# If the DNS queries for the zone will be served.
|
|
# Corresponds to the JSON property `isServing`
|
|
# @return [Boolean]
|
|
attr_accessor :is_serving
|
|
alias_method :is_serving?, :is_serving
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# The time that this operation was started by the server (output only). This is
|
|
# in RFC3339 text format.
|
|
# Corresponds to the JSON property `startTime`
|
|
# @return [String]
|
|
attr_accessor :start_time
|
|
|
|
# Status of the operation (output only). A status of "done" means that the
|
|
# request to update the authoritative servers has been sent but the servers
|
|
# might not be updated yet.
|
|
# Corresponds to the JSON property `status`
|
|
# @return [String]
|
|
attr_accessor :status
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@additions = args[:additions] if args.key?(:additions)
|
|
@deletions = args[:deletions] if args.key?(:deletions)
|
|
@id = args[:id] if args.key?(:id)
|
|
@is_serving = args[:is_serving] if args.key?(:is_serving)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@start_time = args[:start_time] if args.key?(:start_time)
|
|
@status = args[:status] if args.key?(:status)
|
|
end
|
|
end
|
|
|
|
# The response to a request to enumerate Changes to a ResourceRecordSets
|
|
# collection.
|
|
class ListChangesResponse
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# The requested changes.
|
|
# Corresponds to the JSON property `changes`
|
|
# @return [Array<Google::Apis::DnsV1::Change>]
|
|
attr_accessor :changes
|
|
|
|
# Elements common to every response.
|
|
# Corresponds to the JSON property `header`
|
|
# @return [Google::Apis::DnsV1::ResponseHeader]
|
|
attr_accessor :header
|
|
|
|
# Type of resource.
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# The presence of this field indicates that there exist more results following
|
|
# your last page of results in pagination order. To fetch them, make another
|
|
# list request using this value as your pagination token. In this way you can
|
|
# retrieve the complete contents of even very large collections one page at a
|
|
# time. However, if the contents of the collection change between the first and
|
|
# last paginated list request, the set of all elements returned will be an
|
|
# inconsistent view of the collection. There is no way to retrieve a "snapshot"
|
|
# of collections larger than the maximum page size.
|
|
# Corresponds to the JSON property `nextPageToken`
|
|
# @return [String]
|
|
attr_accessor :next_page_token
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@changes = args[:changes] if args.key?(:changes)
|
|
@header = args[:header] if args.key?(:header)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
|
|
end
|
|
end
|
|
|
|
# A DNSSEC key pair.
|
|
class DnsKey
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# String mnemonic specifying the DNSSEC algorithm of this key. Immutable after
|
|
# creation time.
|
|
# Corresponds to the JSON property `algorithm`
|
|
# @return [String]
|
|
attr_accessor :algorithm
|
|
|
|
# The time that this resource was created in the control plane. This is in
|
|
# RFC3339 text format. Output only.
|
|
# Corresponds to the JSON property `creationTime`
|
|
# @return [String]
|
|
attr_accessor :creation_time
|
|
|
|
# A mutable string of at most 1024 characters associated with this resource for
|
|
# the user's convenience. Has no effect on the resource's function.
|
|
# Corresponds to the JSON property `description`
|
|
# @return [String]
|
|
attr_accessor :description
|
|
|
|
# Cryptographic hashes of the DNSKEY resource record associated with this DnsKey.
|
|
# These digests are needed to construct a DS record that points at this DNS key.
|
|
# Output only.
|
|
# Corresponds to the JSON property `digests`
|
|
# @return [Array<Google::Apis::DnsV1::DnsKeyDigest>]
|
|
attr_accessor :digests
|
|
|
|
# Unique identifier for the resource; defined by the server (output only).
|
|
# Corresponds to the JSON property `id`
|
|
# @return [String]
|
|
attr_accessor :id
|
|
|
|
# Active keys will be used to sign subsequent changes to the ManagedZone.
|
|
# Inactive keys will still be present as DNSKEY Resource Records for the use of
|
|
# resolvers validating existing signatures.
|
|
# Corresponds to the JSON property `isActive`
|
|
# @return [Boolean]
|
|
attr_accessor :is_active
|
|
alias_method :is_active?, :is_active
|
|
|
|
# Length of the key in bits. Specified at creation time then immutable.
|
|
# Corresponds to the JSON property `keyLength`
|
|
# @return [Fixnum]
|
|
attr_accessor :key_length
|
|
|
|
# The key tag is a non-cryptographic hash of the a DNSKEY resource record
|
|
# associated with this DnsKey. The key tag can be used to identify a DNSKEY more
|
|
# quickly (but it is not a unique identifier). In particular, the key tag is
|
|
# used in a parent zone's DS record to point at the DNSKEY in this child
|
|
# ManagedZone. The key tag is a number in the range [0, 65535] and the algorithm
|
|
# to calculate it is specified in RFC4034 Appendix B. Output only.
|
|
# Corresponds to the JSON property `keyTag`
|
|
# @return [Fixnum]
|
|
attr_accessor :key_tag
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# Base64 encoded public half of this key. Output only.
|
|
# Corresponds to the JSON property `publicKey`
|
|
# @return [String]
|
|
attr_accessor :public_key
|
|
|
|
# One of "KEY_SIGNING" or "ZONE_SIGNING". Keys of type KEY_SIGNING have the
|
|
# Secure Entry Point flag set and, when active, will be used to sign only
|
|
# resource record sets of type DNSKEY. Otherwise, the Secure Entry Point flag
|
|
# will be cleared and this key will be used to sign only resource record sets of
|
|
# other types. Immutable after creation time.
|
|
# Corresponds to the JSON property `type`
|
|
# @return [String]
|
|
attr_accessor :type
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@algorithm = args[:algorithm] if args.key?(:algorithm)
|
|
@creation_time = args[:creation_time] if args.key?(:creation_time)
|
|
@description = args[:description] if args.key?(:description)
|
|
@digests = args[:digests] if args.key?(:digests)
|
|
@id = args[:id] if args.key?(:id)
|
|
@is_active = args[:is_active] if args.key?(:is_active)
|
|
@key_length = args[:key_length] if args.key?(:key_length)
|
|
@key_tag = args[:key_tag] if args.key?(:key_tag)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@public_key = args[:public_key] if args.key?(:public_key)
|
|
@type = args[:type] if args.key?(:type)
|
|
end
|
|
end
|
|
|
|
#
|
|
class DnsKeyDigest
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# The base-16 encoded bytes of this digest. Suitable for use in a DS resource
|
|
# record.
|
|
# Corresponds to the JSON property `digest`
|
|
# @return [String]
|
|
attr_accessor :digest
|
|
|
|
# Specifies the algorithm used to calculate this digest.
|
|
# Corresponds to the JSON property `type`
|
|
# @return [String]
|
|
attr_accessor :type
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@digest = args[:digest] if args.key?(:digest)
|
|
@type = args[:type] if args.key?(:type)
|
|
end
|
|
end
|
|
|
|
# Parameters for DnsKey key generation. Used for generating initial keys for a
|
|
# new ManagedZone and as default when adding a new DnsKey.
|
|
class DnsKeySpec
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# String mnemonic specifying the DNSSEC algorithm of this key.
|
|
# Corresponds to the JSON property `algorithm`
|
|
# @return [String]
|
|
attr_accessor :algorithm
|
|
|
|
# Length of the keys in bits.
|
|
# Corresponds to the JSON property `keyLength`
|
|
# @return [Fixnum]
|
|
attr_accessor :key_length
|
|
|
|
# Specifies whether this is a key signing key (KSK) or a zone signing key (ZSK).
|
|
# Key signing keys have the Secure Entry Point flag set and, when active, will
|
|
# only be used to sign resource record sets of type DNSKEY. Zone signing keys do
|
|
# not have the Secure Entry Point flag set and will be used to sign all other
|
|
# types of resource record sets.
|
|
# Corresponds to the JSON property `keyType`
|
|
# @return [String]
|
|
attr_accessor :key_type
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@algorithm = args[:algorithm] if args.key?(:algorithm)
|
|
@key_length = args[:key_length] if args.key?(:key_length)
|
|
@key_type = args[:key_type] if args.key?(:key_type)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
end
|
|
end
|
|
|
|
# The response to a request to enumerate DnsKeys in a ManagedZone.
|
|
class DnsKeysListResponse
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# The requested resources.
|
|
# Corresponds to the JSON property `dnsKeys`
|
|
# @return [Array<Google::Apis::DnsV1::DnsKey>]
|
|
attr_accessor :dns_keys
|
|
|
|
# Elements common to every response.
|
|
# Corresponds to the JSON property `header`
|
|
# @return [Google::Apis::DnsV1::ResponseHeader]
|
|
attr_accessor :header
|
|
|
|
# Type of resource.
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# The presence of this field indicates that there exist more results following
|
|
# your last page of results in pagination order. To fetch them, make another
|
|
# list request using this value as your pagination token. In this way you can
|
|
# retrieve the complete contents of even very large collections one page at a
|
|
# time. However, if the contents of the collection change between the first and
|
|
# last paginated list request, the set of all elements returned will be an
|
|
# inconsistent view of the collection. There is no way to retrieve a "snapshot"
|
|
# of collections larger than the maximum page size.
|
|
# Corresponds to the JSON property `nextPageToken`
|
|
# @return [String]
|
|
attr_accessor :next_page_token
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@dns_keys = args[:dns_keys] if args.key?(:dns_keys)
|
|
@header = args[:header] if args.key?(:header)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
|
|
end
|
|
end
|
|
|
|
# A zone is a subtree of the DNS namespace under one administrative
|
|
# responsibility. A ManagedZone is a resource that represents a DNS zone hosted
|
|
# by the Cloud DNS service.
|
|
class ManagedZone
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# The time that this resource was created on the server. This is in RFC3339 text
|
|
# format. Output only.
|
|
# Corresponds to the JSON property `creationTime`
|
|
# @return [String]
|
|
attr_accessor :creation_time
|
|
|
|
# A mutable string of at most 1024 characters associated with this resource for
|
|
# the user's convenience. Has no effect on the managed zone's function.
|
|
# Corresponds to the JSON property `description`
|
|
# @return [String]
|
|
attr_accessor :description
|
|
|
|
# The DNS name of this managed zone, for instance "example.com.".
|
|
# Corresponds to the JSON property `dnsName`
|
|
# @return [String]
|
|
attr_accessor :dns_name
|
|
|
|
# DNSSEC configuration.
|
|
# Corresponds to the JSON property `dnssecConfig`
|
|
# @return [Google::Apis::DnsV1::ManagedZoneDnsSecConfig]
|
|
attr_accessor :dnssec_config
|
|
|
|
# The presence for this field indicates that outbound forwarding is enabled for
|
|
# this zone. The value of this field contains the set of destinations to forward
|
|
# to.
|
|
# Corresponds to the JSON property `forwardingConfig`
|
|
# @return [Google::Apis::DnsV1::ManagedZoneForwardingConfig]
|
|
attr_accessor :forwarding_config
|
|
|
|
# Unique identifier for the resource; defined by the server (output only)
|
|
# Corresponds to the JSON property `id`
|
|
# @return [Fixnum]
|
|
attr_accessor :id
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# User labels.
|
|
# Corresponds to the JSON property `labels`
|
|
# @return [Hash<String,String>]
|
|
attr_accessor :labels
|
|
|
|
# User assigned name for this resource. Must be unique within the project. The
|
|
# name must be 1-63 characters long, must begin with a letter, end with a letter
|
|
# or digit, and only contain lowercase letters, digits or dashes.
|
|
# Corresponds to the JSON property `name`
|
|
# @return [String]
|
|
attr_accessor :name
|
|
|
|
# Optionally specifies the NameServerSet for this ManagedZone. A NameServerSet
|
|
# is a set of DNS name servers that all host the same ManagedZones. Most users
|
|
# will leave this field unset.
|
|
# Corresponds to the JSON property `nameServerSet`
|
|
# @return [String]
|
|
attr_accessor :name_server_set
|
|
|
|
# Delegate your managed_zone to these virtual name servers; defined by the
|
|
# server (output only)
|
|
# Corresponds to the JSON property `nameServers`
|
|
# @return [Array<String>]
|
|
attr_accessor :name_servers
|
|
|
|
# The presence of this field indicates that DNS Peering is enabled for this zone.
|
|
# The value of this field contains the network to peer with.
|
|
# Corresponds to the JSON property `peeringConfig`
|
|
# @return [Google::Apis::DnsV1::ManagedZonePeeringConfig]
|
|
attr_accessor :peering_config
|
|
|
|
# For privately visible zones, the set of Virtual Private Cloud resources that
|
|
# the zone is visible from.
|
|
# Corresponds to the JSON property `privateVisibilityConfig`
|
|
# @return [Google::Apis::DnsV1::ManagedZonePrivateVisibilityConfig]
|
|
attr_accessor :private_visibility_config
|
|
|
|
# The presence of this field indicates that this is a managed reverse lookup
|
|
# zone and Cloud DNS will resolve reverse lookup queries using automatically
|
|
# configured records for VPC resources. This only applies to networks listed
|
|
# under private_visibility_config.
|
|
# Corresponds to the JSON property `reverseLookupConfig`
|
|
# @return [Google::Apis::DnsV1::ManagedZoneReverseLookupConfig]
|
|
attr_accessor :reverse_lookup_config
|
|
|
|
# Contains information about Service Directory-backed zones.
|
|
# Corresponds to the JSON property `serviceDirectoryConfig`
|
|
# @return [Google::Apis::DnsV1::ManagedZoneServiceDirectoryConfig]
|
|
attr_accessor :service_directory_config
|
|
|
|
# The zone's visibility: public zones are exposed to the Internet, while private
|
|
# zones are visible only to Virtual Private Cloud resources.
|
|
# Corresponds to the JSON property `visibility`
|
|
# @return [String]
|
|
attr_accessor :visibility
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@creation_time = args[:creation_time] if args.key?(:creation_time)
|
|
@description = args[:description] if args.key?(:description)
|
|
@dns_name = args[:dns_name] if args.key?(:dns_name)
|
|
@dnssec_config = args[:dnssec_config] if args.key?(:dnssec_config)
|
|
@forwarding_config = args[:forwarding_config] if args.key?(:forwarding_config)
|
|
@id = args[:id] if args.key?(:id)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@labels = args[:labels] if args.key?(:labels)
|
|
@name = args[:name] if args.key?(:name)
|
|
@name_server_set = args[:name_server_set] if args.key?(:name_server_set)
|
|
@name_servers = args[:name_servers] if args.key?(:name_servers)
|
|
@peering_config = args[:peering_config] if args.key?(:peering_config)
|
|
@private_visibility_config = args[:private_visibility_config] if args.key?(:private_visibility_config)
|
|
@reverse_lookup_config = args[:reverse_lookup_config] if args.key?(:reverse_lookup_config)
|
|
@service_directory_config = args[:service_directory_config] if args.key?(:service_directory_config)
|
|
@visibility = args[:visibility] if args.key?(:visibility)
|
|
end
|
|
end
|
|
|
|
#
|
|
class ManagedZoneDnsSecConfig
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# Specifies parameters for generating initial DnsKeys for this ManagedZone. Can
|
|
# only be changed while the state is OFF.
|
|
# Corresponds to the JSON property `defaultKeySpecs`
|
|
# @return [Array<Google::Apis::DnsV1::DnsKeySpec>]
|
|
attr_accessor :default_key_specs
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# Specifies the mechanism for authenticated denial-of-existence responses. Can
|
|
# only be changed while the state is OFF.
|
|
# Corresponds to the JSON property `nonExistence`
|
|
# @return [String]
|
|
attr_accessor :non_existence
|
|
|
|
# Specifies whether DNSSEC is enabled, and what mode it is in.
|
|
# Corresponds to the JSON property `state`
|
|
# @return [String]
|
|
attr_accessor :state
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@default_key_specs = args[:default_key_specs] if args.key?(:default_key_specs)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@non_existence = args[:non_existence] if args.key?(:non_existence)
|
|
@state = args[:state] if args.key?(:state)
|
|
end
|
|
end
|
|
|
|
#
|
|
class ManagedZoneForwardingConfig
|
|
include Google::Apis::Core::Hashable
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# List of target name servers to forward to. Cloud DNS will select the best
|
|
# available name server if more than one target is given.
|
|
# Corresponds to the JSON property `targetNameServers`
|
|
# @return [Array<Google::Apis::DnsV1::ManagedZoneForwardingConfigNameServerTarget>]
|
|
attr_accessor :target_name_servers
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@target_name_servers = args[:target_name_servers] if args.key?(:target_name_servers)
|
|
end
|
|
end
|
|
|
|
#
|
|
class ManagedZoneForwardingConfigNameServerTarget
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# Forwarding path for this NameServerTarget. If unset or set to DEFAULT, Cloud
|
|
# DNS will make forwarding decision based on address ranges, i.e. RFC1918
|
|
# addresses go to the VPC, non-RFC1918 addresses go to the Internet. When set to
|
|
# PRIVATE, Cloud DNS will always send queries through VPC for this target.
|
|
# Corresponds to the JSON property `forwardingPath`
|
|
# @return [String]
|
|
attr_accessor :forwarding_path
|
|
|
|
# IPv4 address of a target name server.
|
|
# Corresponds to the JSON property `ipv4Address`
|
|
# @return [String]
|
|
attr_accessor :ipv4_address
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@forwarding_path = args[:forwarding_path] if args.key?(:forwarding_path)
|
|
@ipv4_address = args[:ipv4_address] if args.key?(:ipv4_address)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
end
|
|
end
|
|
|
|
#
|
|
class ManagedZoneOperationsListResponse
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# Elements common to every response.
|
|
# Corresponds to the JSON property `header`
|
|
# @return [Google::Apis::DnsV1::ResponseHeader]
|
|
attr_accessor :header
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# The presence of this field indicates that there exist more results following
|
|
# your last page of results in pagination order. To fetch them, make another
|
|
# list request using this value as your page token. In this way you can retrieve
|
|
# the complete contents of even very large collections one page at a time.
|
|
# However, if the contents of the collection change between the first and last
|
|
# paginated list request, the set of all elements returned will be an
|
|
# inconsistent view of the collection. There is no way to retrieve a consistent
|
|
# snapshot of a collection larger than the maximum page size.
|
|
# Corresponds to the JSON property `nextPageToken`
|
|
# @return [String]
|
|
attr_accessor :next_page_token
|
|
|
|
# The operation resources.
|
|
# Corresponds to the JSON property `operations`
|
|
# @return [Array<Google::Apis::DnsV1::Operation>]
|
|
attr_accessor :operations
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@header = args[:header] if args.key?(:header)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
|
|
@operations = args[:operations] if args.key?(:operations)
|
|
end
|
|
end
|
|
|
|
#
|
|
class ManagedZonePeeringConfig
|
|
include Google::Apis::Core::Hashable
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# The network with which to peer.
|
|
# Corresponds to the JSON property `targetNetwork`
|
|
# @return [Google::Apis::DnsV1::ManagedZonePeeringConfigTargetNetwork]
|
|
attr_accessor :target_network
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@target_network = args[:target_network] if args.key?(:target_network)
|
|
end
|
|
end
|
|
|
|
#
|
|
class ManagedZonePeeringConfigTargetNetwork
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# The time at which the zone was deactivated, in RFC 3339 date-time format. An
|
|
# empty string indicates that the peering connection is active. The producer
|
|
# network can deactivate a zone. The zone is automatically deactivated if the
|
|
# producer network that the zone targeted is deleted. Output only.
|
|
# Corresponds to the JSON property `deactivateTime`
|
|
# @return [String]
|
|
attr_accessor :deactivate_time
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# The fully qualified URL of the VPC network to forward queries to. This should
|
|
# be formatted like https://www.googleapis.com/compute/v1/projects/`project`/
|
|
# global/networks/`network`
|
|
# Corresponds to the JSON property `networkUrl`
|
|
# @return [String]
|
|
attr_accessor :network_url
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@deactivate_time = args[:deactivate_time] if args.key?(:deactivate_time)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@network_url = args[:network_url] if args.key?(:network_url)
|
|
end
|
|
end
|
|
|
|
#
|
|
class ManagedZonePrivateVisibilityConfig
|
|
include Google::Apis::Core::Hashable
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# The list of VPC networks that can see this zone.
|
|
# Corresponds to the JSON property `networks`
|
|
# @return [Array<Google::Apis::DnsV1::ManagedZonePrivateVisibilityConfigNetwork>]
|
|
attr_accessor :networks
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@networks = args[:networks] if args.key?(:networks)
|
|
end
|
|
end
|
|
|
|
#
|
|
class ManagedZonePrivateVisibilityConfigNetwork
|
|
include Google::Apis::Core::Hashable
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# The fully qualified URL of the VPC network to bind to. This should be
|
|
# formatted like https://www.googleapis.com/compute/v1/projects/`project`/global/
|
|
# networks/`network`
|
|
# Corresponds to the JSON property `networkUrl`
|
|
# @return [String]
|
|
attr_accessor :network_url
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@network_url = args[:network_url] if args.key?(:network_url)
|
|
end
|
|
end
|
|
|
|
#
|
|
class ManagedZoneReverseLookupConfig
|
|
include Google::Apis::Core::Hashable
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
end
|
|
end
|
|
|
|
# Contains information about Service Directory-backed zones.
|
|
class ManagedZoneServiceDirectoryConfig
|
|
include Google::Apis::Core::Hashable
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# Contains information about the namespace associated with the zone.
|
|
# Corresponds to the JSON property `namespace`
|
|
# @return [Google::Apis::DnsV1::ManagedZoneServiceDirectoryConfigNamespace]
|
|
attr_accessor :namespace
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@namespace = args[:namespace] if args.key?(:namespace)
|
|
end
|
|
end
|
|
|
|
#
|
|
class ManagedZoneServiceDirectoryConfigNamespace
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# The time that the namespace backing this zone was deleted, empty string if it
|
|
# still exists. This is in RFC3339 text format. Output only.
|
|
# Corresponds to the JSON property `deletionTime`
|
|
# @return [String]
|
|
attr_accessor :deletion_time
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# The fully qualified URL of the namespace associated with the zone. This should
|
|
# be formatted like https://servicedirectory.googleapis.com/v1/projects/`project`
|
|
# /locations/`location`/namespaces/`namespace`
|
|
# Corresponds to the JSON property `namespaceUrl`
|
|
# @return [String]
|
|
attr_accessor :namespace_url
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@deletion_time = args[:deletion_time] if args.key?(:deletion_time)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@namespace_url = args[:namespace_url] if args.key?(:namespace_url)
|
|
end
|
|
end
|
|
|
|
#
|
|
class ListManagedZonesResponse
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# Elements common to every response.
|
|
# Corresponds to the JSON property `header`
|
|
# @return [Google::Apis::DnsV1::ResponseHeader]
|
|
attr_accessor :header
|
|
|
|
# Type of resource.
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# The managed zone resources.
|
|
# Corresponds to the JSON property `managedZones`
|
|
# @return [Array<Google::Apis::DnsV1::ManagedZone>]
|
|
attr_accessor :managed_zones
|
|
|
|
# The presence of this field indicates that there exist more results following
|
|
# your last page of results in pagination order. To fetch them, make another
|
|
# list request using this value as your page token. In this way you can retrieve
|
|
# the complete contents of even very large collections one page at a time.
|
|
# However, if the contents of the collection change between the first and last
|
|
# paginated list request, the set of all elements returned will be an
|
|
# inconsistent view of the collection. There is no way to retrieve a consistent
|
|
# snapshot of a collection larger than the maximum page size.
|
|
# Corresponds to the JSON property `nextPageToken`
|
|
# @return [String]
|
|
attr_accessor :next_page_token
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@header = args[:header] if args.key?(:header)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@managed_zones = args[:managed_zones] if args.key?(:managed_zones)
|
|
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
|
|
end
|
|
end
|
|
|
|
# An operation represents a successful mutation performed on a Cloud DNS
|
|
# resource. Operations provide: - An audit log of server resource mutations. - A
|
|
# way to recover/retry API calls in the case where the response is never
|
|
# received by the caller. Use the caller specified client_operation_id.
|
|
class Operation
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# Only populated if the operation targeted a DnsKey (output only).
|
|
# Corresponds to the JSON property `dnsKeyContext`
|
|
# @return [Google::Apis::DnsV1::OperationDnsKeyContext]
|
|
attr_accessor :dns_key_context
|
|
|
|
# Unique identifier for the resource. This is the client_operation_id if the
|
|
# client specified it when the mutation was initiated, otherwise, it is
|
|
# generated by the server. The name must be 1-63 characters long and match the
|
|
# regular expression [-a-z0-9]? (output only)
|
|
# Corresponds to the JSON property `id`
|
|
# @return [String]
|
|
attr_accessor :id
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# The time that this operation was started by the server. This is in RFC3339
|
|
# text format (output only).
|
|
# Corresponds to the JSON property `startTime`
|
|
# @return [String]
|
|
attr_accessor :start_time
|
|
|
|
# Status of the operation. Can be one of the following: "PENDING" or "DONE" (
|
|
# output only). A status of "DONE" means that the request to update the
|
|
# authoritative servers has been sent, but the servers might not be updated yet.
|
|
# Corresponds to the JSON property `status`
|
|
# @return [String]
|
|
attr_accessor :status
|
|
|
|
# Type of the operation. Operations include insert, update, and delete (output
|
|
# only).
|
|
# Corresponds to the JSON property `type`
|
|
# @return [String]
|
|
attr_accessor :type
|
|
|
|
# User who requested the operation, for example: user@example.com. cloud-dns-
|
|
# system for operations automatically done by the system. (output only)
|
|
# Corresponds to the JSON property `user`
|
|
# @return [String]
|
|
attr_accessor :user
|
|
|
|
# Only populated if the operation targeted a ManagedZone (output only).
|
|
# Corresponds to the JSON property `zoneContext`
|
|
# @return [Google::Apis::DnsV1::OperationManagedZoneContext]
|
|
attr_accessor :zone_context
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@dns_key_context = args[:dns_key_context] if args.key?(:dns_key_context)
|
|
@id = args[:id] if args.key?(:id)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@start_time = args[:start_time] if args.key?(:start_time)
|
|
@status = args[:status] if args.key?(:status)
|
|
@type = args[:type] if args.key?(:type)
|
|
@user = args[:user] if args.key?(:user)
|
|
@zone_context = args[:zone_context] if args.key?(:zone_context)
|
|
end
|
|
end
|
|
|
|
#
|
|
class OperationDnsKeyContext
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# A DNSSEC key pair.
|
|
# Corresponds to the JSON property `newValue`
|
|
# @return [Google::Apis::DnsV1::DnsKey]
|
|
attr_accessor :new_value
|
|
|
|
# A DNSSEC key pair.
|
|
# Corresponds to the JSON property `oldValue`
|
|
# @return [Google::Apis::DnsV1::DnsKey]
|
|
attr_accessor :old_value
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@new_value = args[:new_value] if args.key?(:new_value)
|
|
@old_value = args[:old_value] if args.key?(:old_value)
|
|
end
|
|
end
|
|
|
|
#
|
|
class OperationManagedZoneContext
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# A zone is a subtree of the DNS namespace under one administrative
|
|
# responsibility. A ManagedZone is a resource that represents a DNS zone hosted
|
|
# by the Cloud DNS service.
|
|
# Corresponds to the JSON property `newValue`
|
|
# @return [Google::Apis::DnsV1::ManagedZone]
|
|
attr_accessor :new_value
|
|
|
|
# A zone is a subtree of the DNS namespace under one administrative
|
|
# responsibility. A ManagedZone is a resource that represents a DNS zone hosted
|
|
# by the Cloud DNS service.
|
|
# Corresponds to the JSON property `oldValue`
|
|
# @return [Google::Apis::DnsV1::ManagedZone]
|
|
attr_accessor :old_value
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@new_value = args[:new_value] if args.key?(:new_value)
|
|
@old_value = args[:old_value] if args.key?(:old_value)
|
|
end
|
|
end
|
|
|
|
#
|
|
class PoliciesListResponse
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# Elements common to every response.
|
|
# Corresponds to the JSON property `header`
|
|
# @return [Google::Apis::DnsV1::ResponseHeader]
|
|
attr_accessor :header
|
|
|
|
# Type of resource.
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# The presence of this field indicates that there exist more results following
|
|
# your last page of results in pagination order. To fetch them, make another
|
|
# list request using this value as your page token. In this way you can retrieve
|
|
# the complete contents of even very large collections one page at a time.
|
|
# However, if the contents of the collection change between the first and last
|
|
# paginated list request, the set of all elements returned will be an
|
|
# inconsistent view of the collection. There is no way to retrieve a consistent
|
|
# snapshot of a collection larger than the maximum page size.
|
|
# Corresponds to the JSON property `nextPageToken`
|
|
# @return [String]
|
|
attr_accessor :next_page_token
|
|
|
|
# The policy resources.
|
|
# Corresponds to the JSON property `policies`
|
|
# @return [Array<Google::Apis::DnsV1::Policy>]
|
|
attr_accessor :policies
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@header = args[:header] if args.key?(:header)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
|
|
@policies = args[:policies] if args.key?(:policies)
|
|
end
|
|
end
|
|
|
|
#
|
|
class PoliciesPatchResponse
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# Elements common to every response.
|
|
# Corresponds to the JSON property `header`
|
|
# @return [Google::Apis::DnsV1::ResponseHeader]
|
|
attr_accessor :header
|
|
|
|
# A policy is a collection of DNS rules applied to one or more Virtual Private
|
|
# Cloud resources.
|
|
# Corresponds to the JSON property `policy`
|
|
# @return [Google::Apis::DnsV1::Policy]
|
|
attr_accessor :policy
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@header = args[:header] if args.key?(:header)
|
|
@policy = args[:policy] if args.key?(:policy)
|
|
end
|
|
end
|
|
|
|
#
|
|
class PoliciesUpdateResponse
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# Elements common to every response.
|
|
# Corresponds to the JSON property `header`
|
|
# @return [Google::Apis::DnsV1::ResponseHeader]
|
|
attr_accessor :header
|
|
|
|
# A policy is a collection of DNS rules applied to one or more Virtual Private
|
|
# Cloud resources.
|
|
# Corresponds to the JSON property `policy`
|
|
# @return [Google::Apis::DnsV1::Policy]
|
|
attr_accessor :policy
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@header = args[:header] if args.key?(:header)
|
|
@policy = args[:policy] if args.key?(:policy)
|
|
end
|
|
end
|
|
|
|
# A policy is a collection of DNS rules applied to one or more Virtual Private
|
|
# Cloud resources.
|
|
class Policy
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# Sets an alternative name server for the associated networks. When specified,
|
|
# all DNS queries are forwarded to a name server that you choose. Names such as .
|
|
# internal are not available when an alternative name server is specified.
|
|
# Corresponds to the JSON property `alternativeNameServerConfig`
|
|
# @return [Google::Apis::DnsV1::PolicyAlternativeNameServerConfig]
|
|
attr_accessor :alternative_name_server_config
|
|
|
|
# A mutable string of at most 1024 characters associated with this resource for
|
|
# the user's convenience. Has no effect on the policy's function.
|
|
# Corresponds to the JSON property `description`
|
|
# @return [String]
|
|
attr_accessor :description
|
|
|
|
# Allows networks bound to this policy to receive DNS queries sent by VMs or
|
|
# applications over VPN connections. When enabled, a virtual IP address will be
|
|
# allocated from each of the sub-networks that are bound to this policy.
|
|
# Corresponds to the JSON property `enableInboundForwarding`
|
|
# @return [Boolean]
|
|
attr_accessor :enable_inbound_forwarding
|
|
alias_method :enable_inbound_forwarding?, :enable_inbound_forwarding
|
|
|
|
# Controls whether logging is enabled for the networks bound to this policy.
|
|
# Defaults to no logging if not set.
|
|
# Corresponds to the JSON property `enableLogging`
|
|
# @return [Boolean]
|
|
attr_accessor :enable_logging
|
|
alias_method :enable_logging?, :enable_logging
|
|
|
|
# Unique identifier for the resource; defined by the server (output only).
|
|
# Corresponds to the JSON property `id`
|
|
# @return [Fixnum]
|
|
attr_accessor :id
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# User assigned name for this policy.
|
|
# Corresponds to the JSON property `name`
|
|
# @return [String]
|
|
attr_accessor :name
|
|
|
|
# List of network names specifying networks to which this policy is applied.
|
|
# Corresponds to the JSON property `networks`
|
|
# @return [Array<Google::Apis::DnsV1::PolicyNetwork>]
|
|
attr_accessor :networks
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@alternative_name_server_config = args[:alternative_name_server_config] if args.key?(:alternative_name_server_config)
|
|
@description = args[:description] if args.key?(:description)
|
|
@enable_inbound_forwarding = args[:enable_inbound_forwarding] if args.key?(:enable_inbound_forwarding)
|
|
@enable_logging = args[:enable_logging] if args.key?(:enable_logging)
|
|
@id = args[:id] if args.key?(:id)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@name = args[:name] if args.key?(:name)
|
|
@networks = args[:networks] if args.key?(:networks)
|
|
end
|
|
end
|
|
|
|
#
|
|
class PolicyAlternativeNameServerConfig
|
|
include Google::Apis::Core::Hashable
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# Sets an alternative name server for the associated networks. When specified,
|
|
# all DNS queries are forwarded to a name server that you choose. Names such as .
|
|
# internal are not available when an alternative name server is specified.
|
|
# Corresponds to the JSON property `targetNameServers`
|
|
# @return [Array<Google::Apis::DnsV1::PolicyAlternativeNameServerConfigTargetNameServer>]
|
|
attr_accessor :target_name_servers
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@target_name_servers = args[:target_name_servers] if args.key?(:target_name_servers)
|
|
end
|
|
end
|
|
|
|
#
|
|
class PolicyAlternativeNameServerConfigTargetNameServer
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# Forwarding path for this TargetNameServer. If unset or set to DEFAULT, Cloud
|
|
# DNS will make forwarding decision based on address ranges, i.e. RFC1918
|
|
# addresses go to the VPC, non-RFC1918 addresses go to the Internet. When set to
|
|
# PRIVATE, Cloud DNS will always send queries through VPC for this target.
|
|
# Corresponds to the JSON property `forwardingPath`
|
|
# @return [String]
|
|
attr_accessor :forwarding_path
|
|
|
|
# IPv4 address to forward to.
|
|
# Corresponds to the JSON property `ipv4Address`
|
|
# @return [String]
|
|
attr_accessor :ipv4_address
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@forwarding_path = args[:forwarding_path] if args.key?(:forwarding_path)
|
|
@ipv4_address = args[:ipv4_address] if args.key?(:ipv4_address)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
end
|
|
end
|
|
|
|
#
|
|
class PolicyNetwork
|
|
include Google::Apis::Core::Hashable
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# The fully qualified URL of the VPC network to bind to. This should be
|
|
# formatted like https://www.googleapis.com/compute/v1/projects/`project`/global/
|
|
# networks/`network`
|
|
# Corresponds to the JSON property `networkUrl`
|
|
# @return [String]
|
|
attr_accessor :network_url
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@network_url = args[:network_url] if args.key?(:network_url)
|
|
end
|
|
end
|
|
|
|
# A project resource. The project is a top level container for resources
|
|
# including Cloud DNS ManagedZones. Projects can be created only in the APIs
|
|
# console.
|
|
class Project
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# User assigned unique identifier for the resource (output only).
|
|
# Corresponds to the JSON property `id`
|
|
# @return [String]
|
|
attr_accessor :id
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# Unique numeric identifier for the resource; defined by the server (output only)
|
|
# .
|
|
# Corresponds to the JSON property `number`
|
|
# @return [Fixnum]
|
|
attr_accessor :number
|
|
|
|
# Limits associated with a Project.
|
|
# Corresponds to the JSON property `quota`
|
|
# @return [Google::Apis::DnsV1::Quota]
|
|
attr_accessor :quota
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@id = args[:id] if args.key?(:id)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@number = args[:number] if args.key?(:number)
|
|
@quota = args[:quota] if args.key?(:quota)
|
|
end
|
|
end
|
|
|
|
# Limits associated with a Project.
|
|
class Quota
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# Maximum allowed number of DnsKeys per ManagedZone.
|
|
# Corresponds to the JSON property `dnsKeysPerManagedZone`
|
|
# @return [Fixnum]
|
|
attr_accessor :dns_keys_per_managed_zone
|
|
|
|
# Maximum allowed number of GKE clusters per policy.
|
|
# Corresponds to the JSON property `gkeClustersPerPolicy`
|
|
# @return [Fixnum]
|
|
attr_accessor :gke_clusters_per_policy
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# Maximum allowed number of managed zones in the project.
|
|
# Corresponds to the JSON property `managedZones`
|
|
# @return [Fixnum]
|
|
attr_accessor :managed_zones
|
|
|
|
# Maximum allowed number of managed zones which can be attached to a network.
|
|
# Corresponds to the JSON property `managedZonesPerNetwork`
|
|
# @return [Fixnum]
|
|
attr_accessor :managed_zones_per_network
|
|
|
|
# Maximum allowed number of networks to which a privately scoped zone can be
|
|
# attached.
|
|
# Corresponds to the JSON property `networksPerManagedZone`
|
|
# @return [Fixnum]
|
|
attr_accessor :networks_per_managed_zone
|
|
|
|
# Maximum allowed number of networks per policy.
|
|
# Corresponds to the JSON property `networksPerPolicy`
|
|
# @return [Fixnum]
|
|
attr_accessor :networks_per_policy
|
|
|
|
# Maximum allowed number of policies per project.
|
|
# Corresponds to the JSON property `policies`
|
|
# @return [Fixnum]
|
|
attr_accessor :policies
|
|
|
|
# Maximum allowed number of ResourceRecords per ResourceRecordSet.
|
|
# Corresponds to the JSON property `resourceRecordsPerRrset`
|
|
# @return [Fixnum]
|
|
attr_accessor :resource_records_per_rrset
|
|
|
|
# Maximum allowed number of ResourceRecordSets to add per ChangesCreateRequest.
|
|
# Corresponds to the JSON property `rrsetAdditionsPerChange`
|
|
# @return [Fixnum]
|
|
attr_accessor :rrset_additions_per_change
|
|
|
|
# Maximum allowed number of ResourceRecordSets to delete per
|
|
# ChangesCreateRequest.
|
|
# Corresponds to the JSON property `rrsetDeletionsPerChange`
|
|
# @return [Fixnum]
|
|
attr_accessor :rrset_deletions_per_change
|
|
|
|
# Maximum allowed number of ResourceRecordSets per zone in the project.
|
|
# Corresponds to the JSON property `rrsetsPerManagedZone`
|
|
# @return [Fixnum]
|
|
attr_accessor :rrsets_per_managed_zone
|
|
|
|
# Maximum allowed number of target name servers per managed forwarding zone.
|
|
# Corresponds to the JSON property `targetNameServersPerManagedZone`
|
|
# @return [Fixnum]
|
|
attr_accessor :target_name_servers_per_managed_zone
|
|
|
|
# Maximum allowed number of alternative target name servers per policy.
|
|
# Corresponds to the JSON property `targetNameServersPerPolicy`
|
|
# @return [Fixnum]
|
|
attr_accessor :target_name_servers_per_policy
|
|
|
|
# Maximum allowed size for total rrdata in one ChangesCreateRequest in bytes.
|
|
# Corresponds to the JSON property `totalRrdataSizePerChange`
|
|
# @return [Fixnum]
|
|
attr_accessor :total_rrdata_size_per_change
|
|
|
|
# DNSSEC algorithm and key length types that can be used for DnsKeys.
|
|
# Corresponds to the JSON property `whitelistedKeySpecs`
|
|
# @return [Array<Google::Apis::DnsV1::DnsKeySpec>]
|
|
attr_accessor :whitelisted_key_specs
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@dns_keys_per_managed_zone = args[:dns_keys_per_managed_zone] if args.key?(:dns_keys_per_managed_zone)
|
|
@gke_clusters_per_policy = args[:gke_clusters_per_policy] if args.key?(:gke_clusters_per_policy)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@managed_zones = args[:managed_zones] if args.key?(:managed_zones)
|
|
@managed_zones_per_network = args[:managed_zones_per_network] if args.key?(:managed_zones_per_network)
|
|
@networks_per_managed_zone = args[:networks_per_managed_zone] if args.key?(:networks_per_managed_zone)
|
|
@networks_per_policy = args[:networks_per_policy] if args.key?(:networks_per_policy)
|
|
@policies = args[:policies] if args.key?(:policies)
|
|
@resource_records_per_rrset = args[:resource_records_per_rrset] if args.key?(:resource_records_per_rrset)
|
|
@rrset_additions_per_change = args[:rrset_additions_per_change] if args.key?(:rrset_additions_per_change)
|
|
@rrset_deletions_per_change = args[:rrset_deletions_per_change] if args.key?(:rrset_deletions_per_change)
|
|
@rrsets_per_managed_zone = args[:rrsets_per_managed_zone] if args.key?(:rrsets_per_managed_zone)
|
|
@target_name_servers_per_managed_zone = args[:target_name_servers_per_managed_zone] if args.key?(:target_name_servers_per_managed_zone)
|
|
@target_name_servers_per_policy = args[:target_name_servers_per_policy] if args.key?(:target_name_servers_per_policy)
|
|
@total_rrdata_size_per_change = args[:total_rrdata_size_per_change] if args.key?(:total_rrdata_size_per_change)
|
|
@whitelisted_key_specs = args[:whitelisted_key_specs] if args.key?(:whitelisted_key_specs)
|
|
end
|
|
end
|
|
|
|
# A RRSetRoutingPolicy represents ResourceRecordSet data that will be returned
|
|
# dynamically with the response varying based on configured properties such as
|
|
# geolocation or by weighted random selection.
|
|
class RrSetRoutingPolicy
|
|
include Google::Apis::Core::Hashable
|
|
|
|
#
|
|
# Corresponds to the JSON property `geoPolicy`
|
|
# @return [Google::Apis::DnsV1::RrSetRoutingPolicyGeoPolicy]
|
|
attr_accessor :geo_policy
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
#
|
|
# Corresponds to the JSON property `wrrPolicy`
|
|
# @return [Google::Apis::DnsV1::RrSetRoutingPolicyWrrPolicy]
|
|
attr_accessor :wrr_policy
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@geo_policy = args[:geo_policy] if args.key?(:geo_policy)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@wrr_policy = args[:wrr_policy] if args.key?(:wrr_policy)
|
|
end
|
|
end
|
|
|
|
#
|
|
class RrSetRoutingPolicyGeoPolicy
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# If the health check for the primary target for a geo location returns an
|
|
# unhealthy status, the failover target is returned instead. This failover
|
|
# configuration is not mandatory. If a failover is not provided, the primary
|
|
# target won't be healthchecked - we'll return the primarily configured rrdata
|
|
# irrespective of whether it is healthy or not.
|
|
# Corresponds to the JSON property `failovers`
|
|
# @return [Array<Google::Apis::DnsV1::RrSetRoutingPolicyGeoPolicyGeoPolicyItem>]
|
|
attr_accessor :failovers
|
|
|
|
# The primary geo routing configuration. If there are multiple items with the
|
|
# same location, an error is returned instead.
|
|
# Corresponds to the JSON property `items`
|
|
# @return [Array<Google::Apis::DnsV1::RrSetRoutingPolicyGeoPolicyGeoPolicyItem>]
|
|
attr_accessor :items
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@failovers = args[:failovers] if args.key?(:failovers)
|
|
@items = args[:items] if args.key?(:items)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
end
|
|
end
|
|
|
|
#
|
|
class RrSetRoutingPolicyGeoPolicyGeoPolicyItem
|
|
include Google::Apis::Core::Hashable
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# The geo-location granularity is a GCP region. This location string should
|
|
# correspond to a GCP region. e.g "us-east1", "southamerica-east1", "asia-east1",
|
|
# etc.
|
|
# Corresponds to the JSON property `location`
|
|
# @return [String]
|
|
attr_accessor :location
|
|
|
|
#
|
|
# Corresponds to the JSON property `rrdatas`
|
|
# @return [Array<String>]
|
|
attr_accessor :rrdatas
|
|
|
|
# DNSSEC generated signatures for the above geo_rrdata.
|
|
# Corresponds to the JSON property `signatureRrdatas`
|
|
# @return [Array<String>]
|
|
attr_accessor :signature_rrdatas
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@location = args[:location] if args.key?(:location)
|
|
@rrdatas = args[:rrdatas] if args.key?(:rrdatas)
|
|
@signature_rrdatas = args[:signature_rrdatas] if args.key?(:signature_rrdatas)
|
|
end
|
|
end
|
|
|
|
#
|
|
class RrSetRoutingPolicyWrrPolicy
|
|
include Google::Apis::Core::Hashable
|
|
|
|
#
|
|
# Corresponds to the JSON property `items`
|
|
# @return [Array<Google::Apis::DnsV1::RrSetRoutingPolicyWrrPolicyWrrPolicyItem>]
|
|
attr_accessor :items
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@items = args[:items] if args.key?(:items)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
end
|
|
end
|
|
|
|
#
|
|
class RrSetRoutingPolicyWrrPolicyWrrPolicyItem
|
|
include Google::Apis::Core::Hashable
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
#
|
|
# Corresponds to the JSON property `rrdatas`
|
|
# @return [Array<String>]
|
|
attr_accessor :rrdatas
|
|
|
|
# DNSSEC generated signatures for the above wrr_rrdata.
|
|
# Corresponds to the JSON property `signatureRrdatas`
|
|
# @return [Array<String>]
|
|
attr_accessor :signature_rrdatas
|
|
|
|
# The weight corresponding to this subset of rrdata. When multiple
|
|
# WeightedRoundRobinPolicyItems are configured, the probability of returning an
|
|
# rrset is proportional to its weight relative to the sum of weights configured
|
|
# for all items. This weight should be a decimal in the range [0,1].
|
|
# Corresponds to the JSON property `weight`
|
|
# @return [Float]
|
|
attr_accessor :weight
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@rrdatas = args[:rrdatas] if args.key?(:rrdatas)
|
|
@signature_rrdatas = args[:signature_rrdatas] if args.key?(:signature_rrdatas)
|
|
@weight = args[:weight] if args.key?(:weight)
|
|
end
|
|
end
|
|
|
|
# A unit of data that will be returned by the DNS servers.
|
|
class ResourceRecordSet
|
|
include Google::Apis::Core::Hashable
|
|
|
|
#
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# For example, www.example.com.
|
|
# Corresponds to the JSON property `name`
|
|
# @return [String]
|
|
attr_accessor :name
|
|
|
|
# A RRSetRoutingPolicy represents ResourceRecordSet data that will be returned
|
|
# dynamically with the response varying based on configured properties such as
|
|
# geolocation or by weighted random selection.
|
|
# Corresponds to the JSON property `routingPolicy`
|
|
# @return [Google::Apis::DnsV1::RrSetRoutingPolicy]
|
|
attr_accessor :routing_policy
|
|
|
|
# As defined in RFC 1035 (section 5) and RFC 1034 (section 3.6.1) -- see
|
|
# examples.
|
|
# Corresponds to the JSON property `rrdatas`
|
|
# @return [Array<String>]
|
|
attr_accessor :rrdatas
|
|
|
|
# As defined in RFC 4034 (section 3.2).
|
|
# Corresponds to the JSON property `signatureRrdatas`
|
|
# @return [Array<String>]
|
|
attr_accessor :signature_rrdatas
|
|
|
|
# Number of seconds that this ResourceRecordSet can be cached by resolvers.
|
|
# Corresponds to the JSON property `ttl`
|
|
# @return [Fixnum]
|
|
attr_accessor :ttl
|
|
|
|
# The identifier of a supported record type. See the list of Supported DNS
|
|
# record types.
|
|
# Corresponds to the JSON property `type`
|
|
# @return [String]
|
|
attr_accessor :type
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@name = args[:name] if args.key?(:name)
|
|
@routing_policy = args[:routing_policy] if args.key?(:routing_policy)
|
|
@rrdatas = args[:rrdatas] if args.key?(:rrdatas)
|
|
@signature_rrdatas = args[:signature_rrdatas] if args.key?(:signature_rrdatas)
|
|
@ttl = args[:ttl] if args.key?(:ttl)
|
|
@type = args[:type] if args.key?(:type)
|
|
end
|
|
end
|
|
|
|
#
|
|
class ListResourceRecordSetsResponse
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# Elements common to every response.
|
|
# Corresponds to the JSON property `header`
|
|
# @return [Google::Apis::DnsV1::ResponseHeader]
|
|
attr_accessor :header
|
|
|
|
# Type of resource.
|
|
# Corresponds to the JSON property `kind`
|
|
# @return [String]
|
|
attr_accessor :kind
|
|
|
|
# The presence of this field indicates that there exist more results following
|
|
# your last page of results in pagination order. To fetch them, make another
|
|
# list request using this value as your pagination token. In this way you can
|
|
# retrieve the complete contents of even very large collections one page at a
|
|
# time. However, if the contents of the collection change between the first and
|
|
# last paginated list request, the set of all elements returned will be an
|
|
# inconsistent view of the collection. There is no way to retrieve a consistent
|
|
# snapshot of a collection larger than the maximum page size.
|
|
# Corresponds to the JSON property `nextPageToken`
|
|
# @return [String]
|
|
attr_accessor :next_page_token
|
|
|
|
# The resource record set resources.
|
|
# Corresponds to the JSON property `rrsets`
|
|
# @return [Array<Google::Apis::DnsV1::ResourceRecordSet>]
|
|
attr_accessor :rrsets
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@header = args[:header] if args.key?(:header)
|
|
@kind = args[:kind] if args.key?(:kind)
|
|
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
|
|
@rrsets = args[:rrsets] if args.key?(:rrsets)
|
|
end
|
|
end
|
|
|
|
# Elements common to every response.
|
|
class ResponseHeader
|
|
include Google::Apis::Core::Hashable
|
|
|
|
# For mutating operation requests that completed successfully. This is the
|
|
# client_operation_id if the client specified it, otherwise it is generated by
|
|
# the server (output only).
|
|
# Corresponds to the JSON property `operationId`
|
|
# @return [String]
|
|
attr_accessor :operation_id
|
|
|
|
def initialize(**args)
|
|
update!(**args)
|
|
end
|
|
|
|
# Update properties of this object
|
|
def update!(**args)
|
|
@operation_id = args[:operation_id] if args.key?(:operation_id)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|