generated/google/apis/container_v1/classes.rb in google-api-client-0.13.2 vs generated/google/apis/container_v1/classes.rb in google-api-client-0.13.3
- old
+ new
@@ -20,233 +20,237 @@
module Google
module Apis
module ContainerV1
- # SetLocationsRequest sets the locations of the cluster.
- class SetLocationsRequest
+ # AcceleratorConfig represents a Hardware Accelerator request.
+ class AcceleratorConfig
include Google::Apis::Core::Hashable
- # The desired list of Google Compute Engine
- # [locations](/compute/docs/zones#available) in which the cluster's nodes
- # should be located. Changing the locations a cluster is in will result
- # in nodes being either created or removed from the cluster, depending on
- # whether locations are being added or removed.
- # This list must always include the cluster's primary zone.
- # Corresponds to the JSON property `locations`
- # @return [Array<String>]
- attr_accessor :locations
+ # The number of the accelerator cards exposed to an instance.
+ # Corresponds to the JSON property `acceleratorCount`
+ # @return [Fixnum]
+ attr_accessor :accelerator_count
+ # The accelerator type resource name. List of supported accelerators
+ # [here](/compute/docs/gpus/#Introduction)
+ # Corresponds to the JSON property `acceleratorType`
+ # @return [String]
+ attr_accessor :accelerator_type
+
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @locations = args[:locations] if args.key?(:locations)
+ @accelerator_count = args[:accelerator_count] if args.key?(:accelerator_count)
+ @accelerator_type = args[:accelerator_type] if args.key?(:accelerator_type)
end
end
- # RollbackNodePoolUpgradeRequest rollbacks the previously Aborted or Failed
- # NodePool upgrade. This will be an no-op if the last upgrade successfully
- # completed.
- class RollbackNodePoolUpgradeRequest
+ # Configuration for the addons that can be automatically spun up in the
+ # cluster, enabling additional functionality.
+ class AddonsConfig
include Google::Apis::Core::Hashable
+ # Configuration options for the horizontal pod autoscaling feature, which
+ # increases or decreases the number of replica pods a replication controller
+ # has based on the resource usage of the existing pods.
+ # Corresponds to the JSON property `horizontalPodAutoscaling`
+ # @return [Google::Apis::ContainerV1::HorizontalPodAutoscaling]
+ attr_accessor :horizontal_pod_autoscaling
+
+ # Configuration options for the HTTP (L7) load balancing controller addon,
+ # which makes it easy to set up HTTP load balancers for services in a cluster.
+ # Corresponds to the JSON property `httpLoadBalancing`
+ # @return [Google::Apis::ContainerV1::HttpLoadBalancing]
+ attr_accessor :http_load_balancing
+
+ # Configuration for the Kubernetes Dashboard.
+ # Corresponds to the JSON property `kubernetesDashboard`
+ # @return [Google::Apis::ContainerV1::KubernetesDashboard]
+ attr_accessor :kubernetes_dashboard
+
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
+ @horizontal_pod_autoscaling = args[:horizontal_pod_autoscaling] if args.key?(:horizontal_pod_autoscaling)
+ @http_load_balancing = args[:http_load_balancing] if args.key?(:http_load_balancing)
+ @kubernetes_dashboard = args[:kubernetes_dashboard] if args.key?(:kubernetes_dashboard)
end
end
- # SetNodePoolSizeRequest sets the size a node
- # pool.
- class SetNodePoolSizeRequest
+ # AutoUpgradeOptions defines the set of options for the user to control how
+ # the Auto Upgrades will proceed.
+ class AutoUpgradeOptions
include Google::Apis::Core::Hashable
- # The desired node count for the pool.
- # Corresponds to the JSON property `nodeCount`
- # @return [Fixnum]
- attr_accessor :node_count
+ # [Output only] This field is set when upgrades are about to commence
+ # with the approximate start time for the upgrades, in
+ # [RFC3339](https://www.ietf.org/rfc/rfc3339.txt) text format.
+ # Corresponds to the JSON property `autoUpgradeStartTime`
+ # @return [String]
+ attr_accessor :auto_upgrade_start_time
+ # [Output only] This field is set when upgrades are about to commence
+ # with the description of the upgrade.
+ # Corresponds to the JSON property `description`
+ # @return [String]
+ attr_accessor :description
+
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @node_count = args[:node_count] if args.key?(:node_count)
+ @auto_upgrade_start_time = args[:auto_upgrade_start_time] if args.key?(:auto_upgrade_start_time)
+ @description = args[:description] if args.key?(:description)
end
end
- # UpdateClusterRequest updates the settings of a cluster.
- class UpdateClusterRequest
+ # CancelOperationRequest cancels a single operation.
+ class CancelOperationRequest
include Google::Apis::Core::Hashable
- # ClusterUpdate describes an update to the cluster. Exactly one update can
- # be applied to a cluster with each request, so at most one field can be
- # provided.
- # Corresponds to the JSON property `update`
- # @return [Google::Apis::ContainerV1::ClusterUpdate]
- attr_accessor :update
-
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @update = args[:update] if args.key?(:update)
end
end
- # Configuration options for the NetworkPolicy feature.
- # https://kubernetes.io/docs/concepts/services-networking/networkpolicies/
- class NetworkPolicy
+ # CidrBlock contains an optional name and one CIDR block.
+ class CidrBlock
include Google::Apis::Core::Hashable
- # Whether network policy is enabled on the cluster.
- # Corresponds to the JSON property `enabled`
- # @return [Boolean]
- attr_accessor :enabled
- alias_method :enabled?, :enabled
+ # cidr_block must be specified in CIDR notation.
+ # Corresponds to the JSON property `cidrBlock`
+ # @return [String]
+ attr_accessor :cidr_block
- # The selected network policy provider.
- # Corresponds to the JSON property `provider`
+ # display_name is an optional field for users to identify CIDR blocks.
+ # Corresponds to the JSON property `displayName`
# @return [String]
- attr_accessor :provider
+ attr_accessor :display_name
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @enabled = args[:enabled] if args.key?(:enabled)
- @provider = args[:provider] if args.key?(:provider)
+ @cidr_block = args[:cidr_block] if args.key?(:cidr_block)
+ @display_name = args[:display_name] if args.key?(:display_name)
end
end
- # UpdateMasterRequest updates the master of the cluster.
- class UpdateMasterRequest
+ # Configuration for client certificates on the cluster.
+ class ClientCertificateConfig
include Google::Apis::Core::Hashable
- # The Kubernetes version to change the master to. The only valid value is the
- # latest supported version. Use "-" to have the server automatically select
- # the latest version.
- # Corresponds to the JSON property `masterVersion`
- # @return [String]
- attr_accessor :master_version
+ # Issue a client certificate.
+ # Corresponds to the JSON property `issueClientCertificate`
+ # @return [Boolean]
+ attr_accessor :issue_client_certificate
+ alias_method :issue_client_certificate?, :issue_client_certificate
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @master_version = args[:master_version] if args.key?(:master_version)
+ @issue_client_certificate = args[:issue_client_certificate] if args.key?(:issue_client_certificate)
end
end
# A Google Container Engine cluster.
class Cluster
include Google::Apis::Core::Hashable
- # [Output only] The current software version of the master endpoint.
- # Corresponds to the JSON property `currentMasterVersion`
- # @return [String]
- attr_accessor :current_master_version
-
- # Parameters that describe the nodes in a cluster.
- # Corresponds to the JSON property `nodeConfig`
- # @return [Google::Apis::ContainerV1::NodeConfig]
- attr_accessor :node_config
-
# Configuration for the addons that can be automatically spun up in the
# cluster, enabling additional functionality.
# Corresponds to the JSON property `addonsConfig`
# @return [Google::Apis::ContainerV1::AddonsConfig]
attr_accessor :addons_config
- # [Output only] The current status of this cluster.
- # Corresponds to the JSON property `status`
+ # The IP address range of the container pods in this cluster, in
+ # [CIDR](http://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing)
+ # notation (e.g. `10.96.0.0/14`). Leave blank to have
+ # one automatically chosen or specify a `/14` block in `10.0.0.0/8`.
+ # Corresponds to the JSON property `clusterIpv4Cidr`
# @return [String]
- attr_accessor :status
+ attr_accessor :cluster_ipv4_cidr
+ # [Output only] The time the cluster was created, in
+ # [RFC3339](https://www.ietf.org/rfc/rfc3339.txt) text format.
+ # Corresponds to the JSON property `createTime`
+ # @return [String]
+ attr_accessor :create_time
+
+ # [Output only] The current software version of the master endpoint.
+ # Corresponds to the JSON property `currentMasterVersion`
+ # @return [String]
+ attr_accessor :current_master_version
+
+ # [Output only] The number of nodes currently in the cluster.
+ # Corresponds to the JSON property `currentNodeCount`
+ # @return [Fixnum]
+ attr_accessor :current_node_count
+
# [Output only] The current version of the node software components.
# If they are currently at multiple versions because they're in the process
# of being upgraded, this reflects the minimum version of all nodes.
# Corresponds to the JSON property `currentNodeVersion`
# @return [String]
attr_accessor :current_node_version
- # The name of the Google Compute Engine
- # [subnetwork](/compute/docs/subnetworks) to which the
- # cluster is connected.
- # Corresponds to the JSON property `subnetwork`
+ # An optional description of this cluster.
+ # Corresponds to the JSON property `description`
# @return [String]
- attr_accessor :subnetwork
+ attr_accessor :description
- # The name of this cluster. The name must be unique within this project
- # and zone, and can be up to 40 characters with the following restrictions:
- # * Lowercase letters, numbers, and hyphens only.
- # * Must start with a letter.
- # * Must end with a number or a letter.
- # Corresponds to the JSON property `name`
- # @return [String]
- attr_accessor :name
+ # Kubernetes alpha features are enabled on this cluster. This includes alpha
+ # API groups (e.g. v1alpha1) and features that may not be production ready in
+ # the kubernetes version of the master and nodes.
+ # The cluster has no SLA for uptime and master/node upgrades are disabled.
+ # Alpha enabled clusters are automatically deleted thirty days after
+ # creation.
+ # Corresponds to the JSON property `enableKubernetesAlpha`
+ # @return [Boolean]
+ attr_accessor :enable_kubernetes_alpha
+ alias_method :enable_kubernetes_alpha?, :enable_kubernetes_alpha
- # The resource labels for the cluster to use to annotate any related
- # Google Compute Engine resources.
- # Corresponds to the JSON property `resourceLabels`
- # @return [Hash<String,String>]
- attr_accessor :resource_labels
-
- # The initial Kubernetes version for this cluster. Valid versions are those
- # found in validMasterVersions returned by getServerConfig. The version can
- # be upgraded over time; such upgrades are reflected in
- # currentMasterVersion and currentNodeVersion.
- # Corresponds to the JSON property `initialClusterVersion`
- # @return [String]
- attr_accessor :initial_cluster_version
-
- # Configuration for controlling how IPs are allocated in the cluster.
- # Corresponds to the JSON property `ipAllocationPolicy`
- # @return [Google::Apis::ContainerV1::IpAllocationPolicy]
- attr_accessor :ip_allocation_policy
-
- # Configuration for the legacy Attribute Based Access Control authorization
- # mode.
- # Corresponds to the JSON property `legacyAbac`
- # @return [Google::Apis::ContainerV1::LegacyAbac]
- attr_accessor :legacy_abac
-
# [Output only] The IP address of this cluster's master endpoint.
# The endpoint can be accessed from the internet at
# `https://username:password@endpoint/`.
# See the `masterAuth` property of this resource for username and
# password information.
# Corresponds to the JSON property `endpoint`
# @return [String]
attr_accessor :endpoint
- # [Output only] The time the cluster was created, in
- # [RFC3339](https://www.ietf.org/rfc/rfc3339.txt) text format.
- # Corresponds to the JSON property `createTime`
+ # [Output only] The time the cluster will be automatically
+ # deleted in [RFC3339](https://www.ietf.org/rfc/rfc3339.txt) text format.
+ # Corresponds to the JSON property `expireTime`
# @return [String]
- attr_accessor :create_time
+ attr_accessor :expire_time
- # The IP address range of the container pods in this cluster, in
- # [CIDR](http://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing)
- # notation (e.g. `10.96.0.0/14`). Leave blank to have
- # one automatically chosen or specify a `/14` block in `10.0.0.0/8`.
- # Corresponds to the JSON property `clusterIpv4Cidr`
+ # The initial Kubernetes version for this cluster. Valid versions are those
+ # found in validMasterVersions returned by getServerConfig. The version can
+ # be upgraded over time; such upgrades are reflected in
+ # currentMasterVersion and currentNodeVersion.
+ # Corresponds to the JSON property `initialClusterVersion`
# @return [String]
- attr_accessor :cluster_ipv4_cidr
+ attr_accessor :initial_cluster_version
# The number of nodes to create in this cluster. You must ensure that your
# Compute Engine <a href="/compute/docs/resource-quotas">resource quota</a>
# is sufficient for this number of instances. You must also have available
# firewall and routes quota.
@@ -256,178 +260,327 @@
# auto-generated name. Do not use this and a node_pool at the same time.
# Corresponds to the JSON property `initialNodeCount`
# @return [Fixnum]
attr_accessor :initial_node_count
- # The node pools associated with this cluster.
- # This field should not be set if "node_config" or "initial_node_count" are
- # specified.
- # Corresponds to the JSON property `nodePools`
- # @return [Array<Google::Apis::ContainerV1::NodePool>]
- attr_accessor :node_pools
-
- # The list of Google Compute Engine
- # [locations](/compute/docs/zones#available) in which the cluster's nodes
- # should be located.
- # Corresponds to the JSON property `locations`
- # @return [Array<String>]
- attr_accessor :locations
-
- # [Output only] Server-defined URL for the resource.
- # Corresponds to the JSON property `selfLink`
- # @return [String]
- attr_accessor :self_link
-
# [Output only] The resource URLs of [instance
# groups](/compute/docs/instance-groups/) associated with this
# cluster.
# Corresponds to the JSON property `instanceGroupUrls`
# @return [Array<String>]
attr_accessor :instance_group_urls
- # [Output only] The IP address range of the Kubernetes services in
- # this cluster, in
- # [CIDR](http://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing)
- # notation (e.g. `1.2.3.4/29`). Service addresses are
- # typically put in the last `/16` from the container CIDR.
- # Corresponds to the JSON property `servicesIpv4Cidr`
+ # Configuration for controlling how IPs are allocated in the cluster.
+ # Corresponds to the JSON property `ipAllocationPolicy`
+ # @return [Google::Apis::ContainerV1::IpAllocationPolicy]
+ attr_accessor :ip_allocation_policy
+
+ # The fingerprint of the set of labels for this cluster.
+ # Corresponds to the JSON property `labelFingerprint`
# @return [String]
- attr_accessor :services_ipv4_cidr
+ attr_accessor :label_fingerprint
- # Configuration options for the NetworkPolicy feature.
- # https://kubernetes.io/docs/concepts/services-networking/networkpolicies/
- # Corresponds to the JSON property `networkPolicy`
- # @return [Google::Apis::ContainerV1::NetworkPolicy]
- attr_accessor :network_policy
+ # Configuration for the legacy Attribute Based Access Control authorization
+ # mode.
+ # Corresponds to the JSON property `legacyAbac`
+ # @return [Google::Apis::ContainerV1::LegacyAbac]
+ attr_accessor :legacy_abac
- # Kubernetes alpha features are enabled on this cluster. This includes alpha
- # API groups (e.g. v1alpha1) and features that may not be production ready in
- # the kubernetes version of the master and nodes.
- # The cluster has no SLA for uptime and master/node upgrades are disabled.
- # Alpha enabled clusters are automatically deleted thirty days after
- # creation.
- # Corresponds to the JSON property `enableKubernetesAlpha`
- # @return [Boolean]
- attr_accessor :enable_kubernetes_alpha
- alias_method :enable_kubernetes_alpha?, :enable_kubernetes_alpha
+ # The list of Google Compute Engine
+ # [locations](/compute/docs/zones#available) in which the cluster's nodes
+ # should be located.
+ # Corresponds to the JSON property `locations`
+ # @return [Array<String>]
+ attr_accessor :locations
- # An optional description of this cluster.
- # Corresponds to the JSON property `description`
+ # The logging service the cluster should use to write logs.
+ # Currently available options:
+ # * `logging.googleapis.com` - the Google Cloud Logging service.
+ # * `none` - no logs will be exported from the cluster.
+ # * if left as an empty string,`logging.googleapis.com` will be used.
+ # Corresponds to the JSON property `loggingService`
# @return [String]
- attr_accessor :description
+ attr_accessor :logging_service
- # [Output only] The number of nodes currently in the cluster.
- # Corresponds to the JSON property `currentNodeCount`
- # @return [Fixnum]
- attr_accessor :current_node_count
+ # The authentication information for accessing the master endpoint.
+ # Authentication can be done using HTTP basic auth or using client
+ # certificates.
+ # Corresponds to the JSON property `masterAuth`
+ # @return [Google::Apis::ContainerV1::MasterAuth]
+ attr_accessor :master_auth
+ # Master authorized networks is a Beta feature.
+ # Configuration options for the master authorized networks feature. Enabled
+ # master authorized networks will disallow all external traffic to access
+ # Kubernetes master through HTTPS except traffic from the given CIDR blocks,
+ # Google Compute Engine Public IPs and Google Prod IPs.
+ # Corresponds to the JSON property `masterAuthorizedNetworksConfig`
+ # @return [Google::Apis::ContainerV1::MasterAuthorizedNetworksConfig]
+ attr_accessor :master_authorized_networks_config
+
# The monitoring service the cluster should use to write metrics.
# Currently available options:
# * `monitoring.googleapis.com` - the Google Cloud Monitoring service.
# * `none` - no metrics will be exported from the cluster.
# * if left as an empty string, `monitoring.googleapis.com` will be used.
# Corresponds to the JSON property `monitoringService`
# @return [String]
attr_accessor :monitoring_service
+ # The name of this cluster. The name must be unique within this project
+ # and zone, and can be up to 40 characters with the following restrictions:
+ # * Lowercase letters, numbers, and hyphens only.
+ # * Must start with a letter.
+ # * Must end with a number or a letter.
+ # Corresponds to the JSON property `name`
+ # @return [String]
+ attr_accessor :name
+
# The name of the Google Compute Engine
# [network](/compute/docs/networks-and-firewalls#networks) to which the
# cluster is connected. If left unspecified, the `default` network
# will be used.
# Corresponds to the JSON property `network`
# @return [String]
attr_accessor :network
- # The fingerprint of the set of labels for this cluster.
- # Corresponds to the JSON property `labelFingerprint`
- # @return [String]
- attr_accessor :label_fingerprint
+ # Configuration options for the NetworkPolicy feature.
+ # https://kubernetes.io/docs/concepts/services-networking/networkpolicies/
+ # Corresponds to the JSON property `networkPolicy`
+ # @return [Google::Apis::ContainerV1::NetworkPolicy]
+ attr_accessor :network_policy
- # [Output only] The name of the Google Compute Engine
- # [zone](/compute/docs/zones#available) in which the cluster
- # resides.
- # Corresponds to the JSON property `zone`
- # @return [String]
- attr_accessor :zone
+ # Parameters that describe the nodes in a cluster.
+ # Corresponds to the JSON property `nodeConfig`
+ # @return [Google::Apis::ContainerV1::NodeConfig]
+ attr_accessor :node_config
# [Output only] The size of the address space on each node for hosting
# containers. This is provisioned from within the `container_ipv4_cidr`
# range.
# Corresponds to the JSON property `nodeIpv4CidrSize`
# @return [Fixnum]
attr_accessor :node_ipv4_cidr_size
- # The logging service the cluster should use to write logs.
- # Currently available options:
- # * `logging.googleapis.com` - the Google Cloud Logging service.
- # * `none` - no logs will be exported from the cluster.
- # * if left as an empty string,`logging.googleapis.com` will be used.
- # Corresponds to the JSON property `loggingService`
+ # The node pools associated with this cluster.
+ # This field should not be set if "node_config" or "initial_node_count" are
+ # specified.
+ # Corresponds to the JSON property `nodePools`
+ # @return [Array<Google::Apis::ContainerV1::NodePool>]
+ attr_accessor :node_pools
+
+ # The resource labels for the cluster to use to annotate any related
+ # Google Compute Engine resources.
+ # Corresponds to the JSON property `resourceLabels`
+ # @return [Hash<String,String>]
+ attr_accessor :resource_labels
+
+ # [Output only] Server-defined URL for the resource.
+ # Corresponds to the JSON property `selfLink`
# @return [String]
- attr_accessor :logging_service
+ attr_accessor :self_link
- # [Output only] The time the cluster will be automatically
- # deleted in [RFC3339](https://www.ietf.org/rfc/rfc3339.txt) text format.
- # Corresponds to the JSON property `expireTime`
+ # [Output only] The IP address range of the Kubernetes services in
+ # this cluster, in
+ # [CIDR](http://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing)
+ # notation (e.g. `1.2.3.4/29`). Service addresses are
+ # typically put in the last `/16` from the container CIDR.
+ # Corresponds to the JSON property `servicesIpv4Cidr`
# @return [String]
- attr_accessor :expire_time
+ attr_accessor :services_ipv4_cidr
+ # [Output only] The current status of this cluster.
+ # Corresponds to the JSON property `status`
+ # @return [String]
+ attr_accessor :status
+
# [Output only] Additional information about the current status of this
# cluster, if available.
# Corresponds to the JSON property `statusMessage`
# @return [String]
attr_accessor :status_message
- # The authentication information for accessing the master endpoint.
- # Authentication can be done using HTTP basic auth or using client
- # certificates.
- # Corresponds to the JSON property `masterAuth`
- # @return [Google::Apis::ContainerV1::MasterAuth]
- attr_accessor :master_auth
+ # The name of the Google Compute Engine
+ # [subnetwork](/compute/docs/subnetworks) to which the
+ # cluster is connected.
+ # Corresponds to the JSON property `subnetwork`
+ # @return [String]
+ attr_accessor :subnetwork
+ # [Output only] The name of the Google Compute Engine
+ # [zone](/compute/docs/zones#available) in which the cluster
+ # resides.
+ # Corresponds to the JSON property `zone`
+ # @return [String]
+ attr_accessor :zone
+
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @current_master_version = args[:current_master_version] if args.key?(:current_master_version)
- @node_config = args[:node_config] if args.key?(:node_config)
@addons_config = args[:addons_config] if args.key?(:addons_config)
- @status = args[:status] if args.key?(:status)
+ @cluster_ipv4_cidr = args[:cluster_ipv4_cidr] if args.key?(:cluster_ipv4_cidr)
+ @create_time = args[:create_time] if args.key?(:create_time)
+ @current_master_version = args[:current_master_version] if args.key?(:current_master_version)
+ @current_node_count = args[:current_node_count] if args.key?(:current_node_count)
@current_node_version = args[:current_node_version] if args.key?(:current_node_version)
- @subnetwork = args[:subnetwork] if args.key?(:subnetwork)
- @name = args[:name] if args.key?(:name)
- @resource_labels = args[:resource_labels] if args.key?(:resource_labels)
+ @description = args[:description] if args.key?(:description)
+ @enable_kubernetes_alpha = args[:enable_kubernetes_alpha] if args.key?(:enable_kubernetes_alpha)
+ @endpoint = args[:endpoint] if args.key?(:endpoint)
+ @expire_time = args[:expire_time] if args.key?(:expire_time)
@initial_cluster_version = args[:initial_cluster_version] if args.key?(:initial_cluster_version)
+ @initial_node_count = args[:initial_node_count] if args.key?(:initial_node_count)
+ @instance_group_urls = args[:instance_group_urls] if args.key?(:instance_group_urls)
@ip_allocation_policy = args[:ip_allocation_policy] if args.key?(:ip_allocation_policy)
+ @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
@legacy_abac = args[:legacy_abac] if args.key?(:legacy_abac)
- @endpoint = args[:endpoint] if args.key?(:endpoint)
- @create_time = args[:create_time] if args.key?(:create_time)
- @cluster_ipv4_cidr = args[:cluster_ipv4_cidr] if args.key?(:cluster_ipv4_cidr)
- @initial_node_count = args[:initial_node_count] if args.key?(:initial_node_count)
- @node_pools = args[:node_pools] if args.key?(:node_pools)
@locations = args[:locations] if args.key?(:locations)
- @self_link = args[:self_link] if args.key?(:self_link)
- @instance_group_urls = args[:instance_group_urls] if args.key?(:instance_group_urls)
- @services_ipv4_cidr = args[:services_ipv4_cidr] if args.key?(:services_ipv4_cidr)
- @network_policy = args[:network_policy] if args.key?(:network_policy)
- @enable_kubernetes_alpha = args[:enable_kubernetes_alpha] if args.key?(:enable_kubernetes_alpha)
- @description = args[:description] if args.key?(:description)
- @current_node_count = args[:current_node_count] if args.key?(:current_node_count)
+ @logging_service = args[:logging_service] if args.key?(:logging_service)
+ @master_auth = args[:master_auth] if args.key?(:master_auth)
+ @master_authorized_networks_config = args[:master_authorized_networks_config] if args.key?(:master_authorized_networks_config)
@monitoring_service = args[:monitoring_service] if args.key?(:monitoring_service)
+ @name = args[:name] if args.key?(:name)
@network = args[:network] if args.key?(:network)
- @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
- @zone = args[:zone] if args.key?(:zone)
+ @network_policy = args[:network_policy] if args.key?(:network_policy)
+ @node_config = args[:node_config] if args.key?(:node_config)
@node_ipv4_cidr_size = args[:node_ipv4_cidr_size] if args.key?(:node_ipv4_cidr_size)
- @logging_service = args[:logging_service] if args.key?(:logging_service)
- @expire_time = args[:expire_time] if args.key?(:expire_time)
+ @node_pools = args[:node_pools] if args.key?(:node_pools)
+ @resource_labels = args[:resource_labels] if args.key?(:resource_labels)
+ @self_link = args[:self_link] if args.key?(:self_link)
+ @services_ipv4_cidr = args[:services_ipv4_cidr] if args.key?(:services_ipv4_cidr)
+ @status = args[:status] if args.key?(:status)
@status_message = args[:status_message] if args.key?(:status_message)
- @master_auth = args[:master_auth] if args.key?(:master_auth)
+ @subnetwork = args[:subnetwork] if args.key?(:subnetwork)
+ @zone = args[:zone] if args.key?(:zone)
end
end
+ # ClusterUpdate describes an update to the cluster. Exactly one update can
+ # be applied to a cluster with each request, so at most one field can be
+ # provided.
+ class ClusterUpdate
+ include Google::Apis::Core::Hashable
+
+ # Configuration for the addons that can be automatically spun up in the
+ # cluster, enabling additional functionality.
+ # Corresponds to the JSON property `desiredAddonsConfig`
+ # @return [Google::Apis::ContainerV1::AddonsConfig]
+ attr_accessor :desired_addons_config
+
+ # The desired image type for the node pool.
+ # NOTE: Set the "desired_node_pool" field as well.
+ # Corresponds to the JSON property `desiredImageType`
+ # @return [String]
+ attr_accessor :desired_image_type
+
+ # The desired list of Google Compute Engine
+ # [locations](/compute/docs/zones#available) in which the cluster's nodes
+ # should be located. Changing the locations a cluster is in will result
+ # in nodes being either created or removed from the cluster, depending on
+ # whether locations are being added or removed.
+ # This list must always include the cluster's primary zone.
+ # Corresponds to the JSON property `desiredLocations`
+ # @return [Array<String>]
+ attr_accessor :desired_locations
+
+ # Master authorized networks is a Beta feature.
+ # Configuration options for the master authorized networks feature. Enabled
+ # master authorized networks will disallow all external traffic to access
+ # Kubernetes master through HTTPS except traffic from the given CIDR blocks,
+ # Google Compute Engine Public IPs and Google Prod IPs.
+ # Corresponds to the JSON property `desiredMasterAuthorizedNetworksConfig`
+ # @return [Google::Apis::ContainerV1::MasterAuthorizedNetworksConfig]
+ attr_accessor :desired_master_authorized_networks_config
+
+ # The Kubernetes version to change the master to. The only valid value is the
+ # latest supported version. Use "-" to have the server automatically select
+ # the latest version.
+ # Corresponds to the JSON property `desiredMasterVersion`
+ # @return [String]
+ attr_accessor :desired_master_version
+
+ # The monitoring service the cluster should use to write metrics.
+ # Currently available options:
+ # * "monitoring.googleapis.com" - the Google Cloud Monitoring service
+ # * "none" - no metrics will be exported from the cluster
+ # Corresponds to the JSON property `desiredMonitoringService`
+ # @return [String]
+ attr_accessor :desired_monitoring_service
+
+ # NodePoolAutoscaling contains information required by cluster autoscaler to
+ # adjust the size of the node pool to the current cluster usage.
+ # Corresponds to the JSON property `desiredNodePoolAutoscaling`
+ # @return [Google::Apis::ContainerV1::NodePoolAutoscaling]
+ attr_accessor :desired_node_pool_autoscaling
+
+ # The node pool to be upgraded. This field is mandatory if
+ # "desired_node_version", "desired_image_family" or
+ # "desired_node_pool_autoscaling" is specified and there is more than one
+ # node pool on the cluster.
+ # Corresponds to the JSON property `desiredNodePoolId`
+ # @return [String]
+ attr_accessor :desired_node_pool_id
+
+ # The Kubernetes version to change the nodes to (typically an
+ # upgrade). Use `-` to upgrade to the latest version supported by
+ # the server.
+ # Corresponds to the JSON property `desiredNodeVersion`
+ # @return [String]
+ attr_accessor :desired_node_version
+
+ def initialize(**args)
+ update!(**args)
+ end
+
+ # Update properties of this object
+ def update!(**args)
+ @desired_addons_config = args[:desired_addons_config] if args.key?(:desired_addons_config)
+ @desired_image_type = args[:desired_image_type] if args.key?(:desired_image_type)
+ @desired_locations = args[:desired_locations] if args.key?(:desired_locations)
+ @desired_master_authorized_networks_config = args[:desired_master_authorized_networks_config] if args.key?(:desired_master_authorized_networks_config)
+ @desired_master_version = args[:desired_master_version] if args.key?(:desired_master_version)
+ @desired_monitoring_service = args[:desired_monitoring_service] if args.key?(:desired_monitoring_service)
+ @desired_node_pool_autoscaling = args[:desired_node_pool_autoscaling] if args.key?(:desired_node_pool_autoscaling)
+ @desired_node_pool_id = args[:desired_node_pool_id] if args.key?(:desired_node_pool_id)
+ @desired_node_version = args[:desired_node_version] if args.key?(:desired_node_version)
+ end
+ end
+
+ # CompleteIPRotationRequest moves the cluster master back into single-IP mode.
+ class CompleteIpRotationRequest
+ include Google::Apis::Core::Hashable
+
+ def initialize(**args)
+ update!(**args)
+ end
+
+ # Update properties of this object
+ def update!(**args)
+ end
+ end
+
+ # CreateClusterRequest creates a cluster.
+ class CreateClusterRequest
+ include Google::Apis::Core::Hashable
+
+ # A Google Container Engine cluster.
+ # Corresponds to the JSON property `cluster`
+ # @return [Google::Apis::ContainerV1::Cluster]
+ attr_accessor :cluster
+
+ def initialize(**args)
+ update!(**args)
+ end
+
+ # Update properties of this object
+ def update!(**args)
+ @cluster = args[:cluster] if args.key?(:cluster)
+ end
+ end
+
# CreateNodePoolRequest creates a node pool for a cluster.
class CreateNodePoolRequest
include Google::Apis::Core::Hashable
# NodePool contains the name and configuration for a cluster's node pool.
@@ -448,98 +601,269 @@
def update!(**args)
@node_pool = args[:node_pool] if args.key?(:node_pool)
end
end
- # ListOperationsResponse is the result of ListOperationsRequest.
- class ListOperationsResponse
+ # A generic empty message that you can re-use to avoid defining duplicated
+ # empty messages in your APIs. A typical example is to use it as the request
+ # or the response type of an API method. For instance:
+ # service Foo `
+ # rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty);
+ # `
+ # The JSON representation for `Empty` is empty JSON object ````.
+ class Empty
include Google::Apis::Core::Hashable
- # A list of operations in the project in the specified zone.
- # Corresponds to the JSON property `operations`
- # @return [Array<Google::Apis::ContainerV1::Operation>]
- attr_accessor :operations
+ def initialize(**args)
+ update!(**args)
+ end
- # If any zones are listed here, the list of operations returned
- # may be missing the operations from those zones.
- # Corresponds to the JSON property `missingZones`
- # @return [Array<String>]
- attr_accessor :missing_zones
+ # Update properties of this object
+ def update!(**args)
+ end
+ end
+ # Configuration options for the horizontal pod autoscaling feature, which
+ # increases or decreases the number of replica pods a replication controller
+ # has based on the resource usage of the existing pods.
+ class HorizontalPodAutoscaling
+ include Google::Apis::Core::Hashable
+
+ # Whether the Horizontal Pod Autoscaling feature is enabled in the cluster.
+ # When enabled, it ensures that a Heapster pod is running in the cluster,
+ # which is also used by the Cloud Monitoring service.
+ # Corresponds to the JSON property `disabled`
+ # @return [Boolean]
+ attr_accessor :disabled
+ alias_method :disabled?, :disabled
+
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @operations = args[:operations] if args.key?(:operations)
- @missing_zones = args[:missing_zones] if args.key?(:missing_zones)
+ @disabled = args[:disabled] if args.key?(:disabled)
end
end
- # SetMonitoringServiceRequest sets the monitoring service of a cluster.
- class SetMonitoringServiceRequest
+ # Configuration options for the HTTP (L7) load balancing controller addon,
+ # which makes it easy to set up HTTP load balancers for services in a cluster.
+ class HttpLoadBalancing
include Google::Apis::Core::Hashable
- # The monitoring service the cluster should use to write metrics.
- # Currently available options:
- # * "monitoring.googleapis.com" - the Google Cloud Monitoring service
- # * "none" - no metrics will be exported from the cluster
- # Corresponds to the JSON property `monitoringService`
- # @return [String]
- attr_accessor :monitoring_service
+ # Whether the HTTP Load Balancing controller is enabled in the cluster.
+ # When enabled, it runs a small pod in the cluster that manages the load
+ # balancers.
+ # Corresponds to the JSON property `disabled`
+ # @return [Boolean]
+ attr_accessor :disabled
+ alias_method :disabled?, :disabled
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @monitoring_service = args[:monitoring_service] if args.key?(:monitoring_service)
+ @disabled = args[:disabled] if args.key?(:disabled)
end
end
- # Container Engine service configuration.
- class ServerConfig
+ # Configuration for controlling how IPs are allocated in the cluster.
+ class IpAllocationPolicy
include Google::Apis::Core::Hashable
- # List of valid master versions.
- # Corresponds to the JSON property `validMasterVersions`
- # @return [Array<String>]
- attr_accessor :valid_master_versions
+ # The IP address range for the cluster pod IPs. If this field is set, then
+ # `cluster.cluster_ipv4_cidr` must be left blank.
+ # This field is only applicable when `use_ip_aliases` is true.
+ # Set to blank to have a range will be chosen with the default size.
+ # Set to /netmask (e.g. `/14`) to have a range be chosen with a specific
+ # netmask.
+ # Set to a [CIDR](http://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing)
+ # notation (e.g. `10.96.0.0/14`) from the RFC-1918 private networks (e.g.
+ # `10.0.0.0/8`, `172.16.0.0/12`, `192.168.0.0/16`) to pick a specific range
+ # to use.
+ # Corresponds to the JSON property `clusterIpv4Cidr`
+ # @return [String]
+ attr_accessor :cluster_ipv4_cidr
- # Default image type.
- # Corresponds to the JSON property `defaultImageType`
+ # Whether a new subnetwork will be created automatically for the cluster.
+ # This field is only applicable when `use_ip_aliases` is true.
+ # Corresponds to the JSON property `createSubnetwork`
+ # @return [Boolean]
+ attr_accessor :create_subnetwork
+ alias_method :create_subnetwork?, :create_subnetwork
+
+ # The IP address range of the instance IPs in this cluster.
+ # This is applicable only if `create_subnetwork` is true.
+ # Set to blank to have a range will be chosen with the default size.
+ # Set to /netmask (e.g. `/14`) to have a range be chosen with a specific
+ # netmask.
+ # Set to a [CIDR](http://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing)
+ # notation (e.g. `10.96.0.0/14`) from the RFC-1918 private networks (e.g.
+ # `10.0.0.0/8`, `172.16.0.0/12`, `192.168.0.0/16`) to pick a specific range
+ # to use.
+ # Corresponds to the JSON property `nodeIpv4Cidr`
# @return [String]
- attr_accessor :default_image_type
+ attr_accessor :node_ipv4_cidr
- # Version of Kubernetes the service deploys by default.
- # Corresponds to the JSON property `defaultClusterVersion`
+ # The IP address range of the services IPs in this cluster. If blank, a range
+ # will be automatically chosen with the default size.
+ # This field is only applicable when `use_ip_aliases` is true.
+ # Set to blank to have a range will be chosen with the default size.
+ # Set to /netmask (e.g. `/14`) to have a range be chosen with a specific
+ # netmask.
+ # Set to a [CIDR](http://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing)
+ # notation (e.g. `10.96.0.0/14`) from the RFC-1918 private networks (e.g.
+ # `10.0.0.0/8`, `172.16.0.0/12`, `192.168.0.0/16`) to pick a specific range
+ # to use.
+ # Corresponds to the JSON property `servicesIpv4Cidr`
# @return [String]
- attr_accessor :default_cluster_version
+ attr_accessor :services_ipv4_cidr
- # List of valid image types.
- # Corresponds to the JSON property `validImageTypes`
+ # A custom subnetwork name to be used if `create_subnetwork` is true. If
+ # this field is empty, then an automatic name will be chosen for the new
+ # subnetwork.
+ # Corresponds to the JSON property `subnetworkName`
+ # @return [String]
+ attr_accessor :subnetwork_name
+
+ # Whether alias IPs will be used for pod IPs in the cluster.
+ # Corresponds to the JSON property `useIpAliases`
+ # @return [Boolean]
+ attr_accessor :use_ip_aliases
+ alias_method :use_ip_aliases?, :use_ip_aliases
+
+ def initialize(**args)
+ update!(**args)
+ end
+
+ # Update properties of this object
+ def update!(**args)
+ @cluster_ipv4_cidr = args[:cluster_ipv4_cidr] if args.key?(:cluster_ipv4_cidr)
+ @create_subnetwork = args[:create_subnetwork] if args.key?(:create_subnetwork)
+ @node_ipv4_cidr = args[:node_ipv4_cidr] if args.key?(:node_ipv4_cidr)
+ @services_ipv4_cidr = args[:services_ipv4_cidr] if args.key?(:services_ipv4_cidr)
+ @subnetwork_name = args[:subnetwork_name] if args.key?(:subnetwork_name)
+ @use_ip_aliases = args[:use_ip_aliases] if args.key?(:use_ip_aliases)
+ end
+ end
+
+ # Configuration for the Kubernetes Dashboard.
+ class KubernetesDashboard
+ include Google::Apis::Core::Hashable
+
+ # Whether the Kubernetes Dashboard is enabled for this cluster.
+ # Corresponds to the JSON property `disabled`
+ # @return [Boolean]
+ attr_accessor :disabled
+ alias_method :disabled?, :disabled
+
+ def initialize(**args)
+ update!(**args)
+ end
+
+ # Update properties of this object
+ def update!(**args)
+ @disabled = args[:disabled] if args.key?(:disabled)
+ end
+ end
+
+ # Configuration for the legacy Attribute Based Access Control authorization
+ # mode.
+ class LegacyAbac
+ include Google::Apis::Core::Hashable
+
+ # Whether the ABAC authorizer is enabled for this cluster. When enabled,
+ # identities in the system, including service accounts, nodes, and
+ # controllers, will have statically granted permissions beyond those
+ # provided by the RBAC configuration or IAM.
+ # Corresponds to the JSON property `enabled`
+ # @return [Boolean]
+ attr_accessor :enabled
+ alias_method :enabled?, :enabled
+
+ def initialize(**args)
+ update!(**args)
+ end
+
+ # Update properties of this object
+ def update!(**args)
+ @enabled = args[:enabled] if args.key?(:enabled)
+ end
+ end
+
+ # ListClustersResponse is the result of ListClustersRequest.
+ class ListClustersResponse
+ include Google::Apis::Core::Hashable
+
+ # A list of clusters in the project in the specified zone, or
+ # across all ones.
+ # Corresponds to the JSON property `clusters`
+ # @return [Array<Google::Apis::ContainerV1::Cluster>]
+ attr_accessor :clusters
+
+ # If any zones are listed here, the list of clusters returned
+ # may be missing those zones.
+ # Corresponds to the JSON property `missingZones`
# @return [Array<String>]
- attr_accessor :valid_image_types
+ attr_accessor :missing_zones
- # List of valid node upgrade target versions.
- # Corresponds to the JSON property `validNodeVersions`
+ def initialize(**args)
+ update!(**args)
+ end
+
+ # Update properties of this object
+ def update!(**args)
+ @clusters = args[:clusters] if args.key?(:clusters)
+ @missing_zones = args[:missing_zones] if args.key?(:missing_zones)
+ end
+ end
+
+ # ListNodePoolsResponse is the result of ListNodePoolsRequest.
+ class ListNodePoolsResponse
+ include Google::Apis::Core::Hashable
+
+ # A list of node pools for a cluster.
+ # Corresponds to the JSON property `nodePools`
+ # @return [Array<Google::Apis::ContainerV1::NodePool>]
+ attr_accessor :node_pools
+
+ def initialize(**args)
+ update!(**args)
+ end
+
+ # Update properties of this object
+ def update!(**args)
+ @node_pools = args[:node_pools] if args.key?(:node_pools)
+ end
+ end
+
+ # ListOperationsResponse is the result of ListOperationsRequest.
+ class ListOperationsResponse
+ include Google::Apis::Core::Hashable
+
+ # If any zones are listed here, the list of operations returned
+ # may be missing the operations from those zones.
+ # Corresponds to the JSON property `missingZones`
# @return [Array<String>]
- attr_accessor :valid_node_versions
+ attr_accessor :missing_zones
+ # A list of operations in the project in the specified zone.
+ # Corresponds to the JSON property `operations`
+ # @return [Array<Google::Apis::ContainerV1::Operation>]
+ attr_accessor :operations
+
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @valid_master_versions = args[:valid_master_versions] if args.key?(:valid_master_versions)
- @default_image_type = args[:default_image_type] if args.key?(:default_image_type)
- @default_cluster_version = args[:default_cluster_version] if args.key?(:default_cluster_version)
- @valid_image_types = args[:valid_image_types] if args.key?(:valid_image_types)
- @valid_node_versions = args[:valid_node_versions] if args.key?(:valid_node_versions)
+ @missing_zones = args[:missing_zones] if args.key?(:missing_zones)
+ @operations = args[:operations] if args.key?(:operations)
end
end
# The authentication information for accessing the master endpoint.
# Authentication can be done using HTTP basic auth or using client
@@ -551,25 +875,10 @@
# authenticate to the cluster endpoint.
# Corresponds to the JSON property `clientCertificate`
# @return [String]
attr_accessor :client_certificate
- # The username to use for HTTP basic authentication to the master endpoint.
- # For clusters v1.6.0 and later, you can disable basic authentication by
- # providing an empty username.
- # Corresponds to the JSON property `username`
- # @return [String]
- attr_accessor :username
-
- # The password to use for HTTP basic authentication to the master endpoint.
- # Because the master endpoint is open to the Internet, you should create a
- # strong password. If a password is provided for cluster creation, username
- # must be non-empty.
- # Corresponds to the JSON property `password`
- # @return [String]
- attr_accessor :password
-
# Configuration for client certificates on the cluster.
# Corresponds to the JSON property `clientCertificateConfig`
# @return [Google::Apis::ContainerV1::ClientCertificateConfig]
attr_accessor :client_certificate_config
@@ -583,37 +892,122 @@
# trust for the cluster.
# Corresponds to the JSON property `clusterCaCertificate`
# @return [String]
attr_accessor :cluster_ca_certificate
+ # The password to use for HTTP basic authentication to the master endpoint.
+ # Because the master endpoint is open to the Internet, you should create a
+ # strong password. If a password is provided for cluster creation, username
+ # must be non-empty.
+ # Corresponds to the JSON property `password`
+ # @return [String]
+ attr_accessor :password
+
+ # The username to use for HTTP basic authentication to the master endpoint.
+ # For clusters v1.6.0 and later, you can disable basic authentication by
+ # providing an empty username.
+ # Corresponds to the JSON property `username`
+ # @return [String]
+ attr_accessor :username
+
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@client_certificate = args[:client_certificate] if args.key?(:client_certificate)
- @username = args[:username] if args.key?(:username)
- @password = args[:password] if args.key?(:password)
@client_certificate_config = args[:client_certificate_config] if args.key?(:client_certificate_config)
@client_key = args[:client_key] if args.key?(:client_key)
@cluster_ca_certificate = args[:cluster_ca_certificate] if args.key?(:cluster_ca_certificate)
+ @password = args[:password] if args.key?(:password)
+ @username = args[:username] if args.key?(:username)
end
end
+ # Master authorized networks is a Beta feature.
+ # Configuration options for the master authorized networks feature. Enabled
+ # master authorized networks will disallow all external traffic to access
+ # Kubernetes master through HTTPS except traffic from the given CIDR blocks,
+ # Google Compute Engine Public IPs and Google Prod IPs.
+ class MasterAuthorizedNetworksConfig
+ include Google::Apis::Core::Hashable
+
+ # cidr_blocks define up to 10 external networks that could access
+ # Kubernetes master through HTTPS.
+ # Corresponds to the JSON property `cidrBlocks`
+ # @return [Array<Google::Apis::ContainerV1::CidrBlock>]
+ attr_accessor :cidr_blocks
+
+ # Whether or not master authorized networks is enabled.
+ # Corresponds to the JSON property `enabled`
+ # @return [Boolean]
+ attr_accessor :enabled
+ alias_method :enabled?, :enabled
+
+ def initialize(**args)
+ update!(**args)
+ end
+
+ # Update properties of this object
+ def update!(**args)
+ @cidr_blocks = args[:cidr_blocks] if args.key?(:cidr_blocks)
+ @enabled = args[:enabled] if args.key?(:enabled)
+ end
+ end
+
+ # Configuration options for the NetworkPolicy feature.
+ # https://kubernetes.io/docs/concepts/services-networking/networkpolicies/
+ class NetworkPolicy
+ include Google::Apis::Core::Hashable
+
+ # Whether network policy is enabled on the cluster.
+ # Corresponds to the JSON property `enabled`
+ # @return [Boolean]
+ attr_accessor :enabled
+ alias_method :enabled?, :enabled
+
+ # The selected network policy provider.
+ # Corresponds to the JSON property `provider`
+ # @return [String]
+ attr_accessor :provider
+
+ def initialize(**args)
+ update!(**args)
+ end
+
+ # Update properties of this object
+ def update!(**args)
+ @enabled = args[:enabled] if args.key?(:enabled)
+ @provider = args[:provider] if args.key?(:provider)
+ end
+ end
+
# Parameters that describe the nodes in a cluster.
class NodeConfig
include Google::Apis::Core::Hashable
- # Whether the nodes are created as preemptible VM instances. See:
- # https://cloud.google.com/compute/docs/instances/preemptible for more
- # information about preemptible VM instances.
- # Corresponds to the JSON property `preemptible`
- # @return [Boolean]
- attr_accessor :preemptible
- alias_method :preemptible?, :preemptible
+ # A list of hardware accelerators to be attached to each node.
+ # See https://cloud.google.com/compute/docs/gpus for more information about
+ # support for GPUs.
+ # Corresponds to the JSON property `accelerators`
+ # @return [Array<Google::Apis::ContainerV1::AcceleratorConfig>]
+ attr_accessor :accelerators
+ # Size of the disk attached to each node, specified in GB.
+ # The smallest allowed disk size is 10GB.
+ # If unspecified, the default disk size is 100GB.
+ # Corresponds to the JSON property `diskSizeGb`
+ # @return [Fixnum]
+ attr_accessor :disk_size_gb
+
+ # The image type to use for this node. Note that for a given image type,
+ # the latest version of it will be used.
+ # Corresponds to the JSON property `imageType`
+ # @return [String]
+ attr_accessor :image_type
+
# The map of Kubernetes labels (key/value pairs) to be applied to each node.
# These will added in addition to any default label(s) that
# Kubernetes may apply to the node.
# In case of conflict in label keys, the applied set may differ depending on
# the Kubernetes version -- it's best to assume the behavior is undefined
@@ -631,10 +1025,19 @@
# for more information.
# Corresponds to the JSON property `localSsdCount`
# @return [Fixnum]
attr_accessor :local_ssd_count
+ # The name of a Google Compute Engine [machine
+ # type](/compute/docs/machine-types) (e.g.
+ # `n1-standard-1`).
+ # If unspecified, the default machine type is
+ # `n1-standard-1`.
+ # Corresponds to the JSON property `machineType`
+ # @return [String]
+ attr_accessor :machine_type
+
# The metadata key/value pairs assigned to instances in the cluster.
# Keys must conform to the regexp [a-zA-Z0-9-_]+ and be less than 128 bytes
# in length. These are reflected as part of a URL in the metadata server.
# Additionally, to avoid ambiguity, keys must not conflict with any other
# metadata keys for the project or be one of the four reserved keys:
@@ -645,46 +1048,10 @@
# The total size of all keys and values must be less than 512 KB.
# Corresponds to the JSON property `metadata`
# @return [Hash<String,String>]
attr_accessor :metadata
- # Size of the disk attached to each node, specified in GB.
- # The smallest allowed disk size is 10GB.
- # If unspecified, the default disk size is 100GB.
- # Corresponds to the JSON property `diskSizeGb`
- # @return [Fixnum]
- attr_accessor :disk_size_gb
-
- # The list of instance tags applied to all nodes. Tags are used to identify
- # valid sources or targets for network firewalls and are specified by
- # the client during cluster or node pool creation. Each tag within the list
- # must comply with RFC1035.
- # Corresponds to the JSON property `tags`
- # @return [Array<String>]
- attr_accessor :tags
-
- # The Google Cloud Platform Service Account to be used by the node VMs. If
- # no Service Account is specified, the "default" service account is used.
- # Corresponds to the JSON property `serviceAccount`
- # @return [String]
- attr_accessor :service_account
-
- # The name of a Google Compute Engine [machine
- # type](/compute/docs/machine-types) (e.g.
- # `n1-standard-1`).
- # If unspecified, the default machine type is
- # `n1-standard-1`.
- # Corresponds to the JSON property `machineType`
- # @return [String]
- attr_accessor :machine_type
-
- # The image type to use for this node. Note that for a given image type,
- # the latest version of it will be used.
- # Corresponds to the JSON property `imageType`
- # @return [String]
- attr_accessor :image_type
-
# The set of Google API scopes to be made available on all of the
# node VMs under the "default" service account.
# The following scopes are recommended, but not required, and by default are
# not included:
# * `https://www.googleapis.com/auth/compute` is required for mounting
@@ -696,133 +1063,189 @@
# Monitoring are enabled, in which case their required scopes will be added.
# Corresponds to the JSON property `oauthScopes`
# @return [Array<String>]
attr_accessor :oauth_scopes
+ # Whether the nodes are created as preemptible VM instances. See:
+ # https://cloud.google.com/compute/docs/instances/preemptible for more
+ # information about preemptible VM instances.
+ # Corresponds to the JSON property `preemptible`
+ # @return [Boolean]
+ attr_accessor :preemptible
+ alias_method :preemptible?, :preemptible
+
+ # The Google Cloud Platform Service Account to be used by the node VMs. If
+ # no Service Account is specified, the "default" service account is used.
+ # Corresponds to the JSON property `serviceAccount`
+ # @return [String]
+ attr_accessor :service_account
+
+ # The list of instance tags applied to all nodes. Tags are used to identify
+ # valid sources or targets for network firewalls and are specified by
+ # the client during cluster or node pool creation. Each tag within the list
+ # must comply with RFC1035.
+ # Corresponds to the JSON property `tags`
+ # @return [Array<String>]
+ attr_accessor :tags
+
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @preemptible = args[:preemptible] if args.key?(:preemptible)
+ @accelerators = args[:accelerators] if args.key?(:accelerators)
+ @disk_size_gb = args[:disk_size_gb] if args.key?(:disk_size_gb)
+ @image_type = args[:image_type] if args.key?(:image_type)
@labels = args[:labels] if args.key?(:labels)
@local_ssd_count = args[:local_ssd_count] if args.key?(:local_ssd_count)
- @metadata = args[:metadata] if args.key?(:metadata)
- @disk_size_gb = args[:disk_size_gb] if args.key?(:disk_size_gb)
- @tags = args[:tags] if args.key?(:tags)
- @service_account = args[:service_account] if args.key?(:service_account)
@machine_type = args[:machine_type] if args.key?(:machine_type)
- @image_type = args[:image_type] if args.key?(:image_type)
+ @metadata = args[:metadata] if args.key?(:metadata)
@oauth_scopes = args[:oauth_scopes] if args.key?(:oauth_scopes)
+ @preemptible = args[:preemptible] if args.key?(:preemptible)
+ @service_account = args[:service_account] if args.key?(:service_account)
+ @tags = args[:tags] if args.key?(:tags)
end
end
- # AutoUpgradeOptions defines the set of options for the user to control how
- # the Auto Upgrades will proceed.
- class AutoUpgradeOptions
+ # NodeManagement defines the set of node management services turned on for the
+ # node pool.
+ class NodeManagement
include Google::Apis::Core::Hashable
- # [Output only] This field is set when upgrades are about to commence
- # with the description of the upgrade.
- # Corresponds to the JSON property `description`
- # @return [String]
- attr_accessor :description
+ # A flag that specifies whether the node auto-repair is enabled for the node
+ # pool. If enabled, the nodes in this node pool will be monitored and, if
+ # they fail health checks too many times, an automatic repair action will be
+ # triggered.
+ # Corresponds to the JSON property `autoRepair`
+ # @return [Boolean]
+ attr_accessor :auto_repair
+ alias_method :auto_repair?, :auto_repair
- # [Output only] This field is set when upgrades are about to commence
- # with the approximate start time for the upgrades, in
- # [RFC3339](https://www.ietf.org/rfc/rfc3339.txt) text format.
- # Corresponds to the JSON property `autoUpgradeStartTime`
- # @return [String]
- attr_accessor :auto_upgrade_start_time
+ # A flag that specifies whether node auto-upgrade is enabled for the node
+ # pool. If enabled, node auto-upgrade helps keep the nodes in your node pool
+ # up to date with the latest release version of Kubernetes.
+ # Corresponds to the JSON property `autoUpgrade`
+ # @return [Boolean]
+ attr_accessor :auto_upgrade
+ alias_method :auto_upgrade?, :auto_upgrade
+ # AutoUpgradeOptions defines the set of options for the user to control how
+ # the Auto Upgrades will proceed.
+ # Corresponds to the JSON property `upgradeOptions`
+ # @return [Google::Apis::ContainerV1::AutoUpgradeOptions]
+ attr_accessor :upgrade_options
+
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @description = args[:description] if args.key?(:description)
- @auto_upgrade_start_time = args[:auto_upgrade_start_time] if args.key?(:auto_upgrade_start_time)
+ @auto_repair = args[:auto_repair] if args.key?(:auto_repair)
+ @auto_upgrade = args[:auto_upgrade] if args.key?(:auto_upgrade)
+ @upgrade_options = args[:upgrade_options] if args.key?(:upgrade_options)
end
end
- # ListClustersResponse is the result of ListClustersRequest.
- class ListClustersResponse
+ # NodePool contains the name and configuration for a cluster's node pool.
+ # Node pools are a set of nodes (i.e. VM's), with a common configuration and
+ # specification, under the control of the cluster master. They may have a set
+ # of Kubernetes labels applied to them, which may be used to reference them
+ # during pod scheduling. They may also be resized up or down, to accommodate
+ # the workload.
+ class NodePool
include Google::Apis::Core::Hashable
- # A list of clusters in the project in the specified zone, or
- # across all ones.
- # Corresponds to the JSON property `clusters`
- # @return [Array<Google::Apis::ContainerV1::Cluster>]
- attr_accessor :clusters
+ # NodePoolAutoscaling contains information required by cluster autoscaler to
+ # adjust the size of the node pool to the current cluster usage.
+ # Corresponds to the JSON property `autoscaling`
+ # @return [Google::Apis::ContainerV1::NodePoolAutoscaling]
+ attr_accessor :autoscaling
- # If any zones are listed here, the list of clusters returned
- # may be missing those zones.
- # Corresponds to the JSON property `missingZones`
- # @return [Array<String>]
- attr_accessor :missing_zones
+ # Parameters that describe the nodes in a cluster.
+ # Corresponds to the JSON property `config`
+ # @return [Google::Apis::ContainerV1::NodeConfig]
+ attr_accessor :config
- def initialize(**args)
- update!(**args)
- end
+ # The initial node count for the pool. You must ensure that your
+ # Compute Engine <a href="/compute/docs/resource-quotas">resource quota</a>
+ # is sufficient for this number of instances. You must also have available
+ # firewall and routes quota.
+ # Corresponds to the JSON property `initialNodeCount`
+ # @return [Fixnum]
+ attr_accessor :initial_node_count
- # Update properties of this object
- def update!(**args)
- @clusters = args[:clusters] if args.key?(:clusters)
- @missing_zones = args[:missing_zones] if args.key?(:missing_zones)
- end
- end
+ # [Output only] The resource URLs of [instance
+ # groups](/compute/docs/instance-groups/) associated with this
+ # node pool.
+ # Corresponds to the JSON property `instanceGroupUrls`
+ # @return [Array<String>]
+ attr_accessor :instance_group_urls
- # Configuration options for the HTTP (L7) load balancing controller addon,
- # which makes it easy to set up HTTP load balancers for services in a cluster.
- class HttpLoadBalancing
- include Google::Apis::Core::Hashable
+ # NodeManagement defines the set of node management services turned on for the
+ # node pool.
+ # Corresponds to the JSON property `management`
+ # @return [Google::Apis::ContainerV1::NodeManagement]
+ attr_accessor :management
- # Whether the HTTP Load Balancing controller is enabled in the cluster.
- # When enabled, it runs a small pod in the cluster that manages the load
- # balancers.
- # Corresponds to the JSON property `disabled`
- # @return [Boolean]
- attr_accessor :disabled
- alias_method :disabled?, :disabled
+ # The name of the node pool.
+ # Corresponds to the JSON property `name`
+ # @return [String]
+ attr_accessor :name
- def initialize(**args)
- update!(**args)
- end
+ # [Output only] Server-defined URL for the resource.
+ # Corresponds to the JSON property `selfLink`
+ # @return [String]
+ attr_accessor :self_link
- # Update properties of this object
- def update!(**args)
- @disabled = args[:disabled] if args.key?(:disabled)
- end
- end
+ # [Output only] The status of the nodes in this pool instance.
+ # Corresponds to the JSON property `status`
+ # @return [String]
+ attr_accessor :status
- # Configuration for client certificates on the cluster.
- class ClientCertificateConfig
- include Google::Apis::Core::Hashable
+ # [Output only] Additional information about the current status of this
+ # node pool instance, if available.
+ # Corresponds to the JSON property `statusMessage`
+ # @return [String]
+ attr_accessor :status_message
- # Issue a client certificate.
- # Corresponds to the JSON property `issueClientCertificate`
- # @return [Boolean]
- attr_accessor :issue_client_certificate
- alias_method :issue_client_certificate?, :issue_client_certificate
+ # [Output only] The version of the Kubernetes of this node.
+ # Corresponds to the JSON property `version`
+ # @return [String]
+ attr_accessor :version
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @issue_client_certificate = args[:issue_client_certificate] if args.key?(:issue_client_certificate)
+ @autoscaling = args[:autoscaling] if args.key?(:autoscaling)
+ @config = args[:config] if args.key?(:config)
+ @initial_node_count = args[:initial_node_count] if args.key?(:initial_node_count)
+ @instance_group_urls = args[:instance_group_urls] if args.key?(:instance_group_urls)
+ @management = args[:management] if args.key?(:management)
+ @name = args[:name] if args.key?(:name)
+ @self_link = args[:self_link] if args.key?(:self_link)
+ @status = args[:status] if args.key?(:status)
+ @status_message = args[:status_message] if args.key?(:status_message)
+ @version = args[:version] if args.key?(:version)
end
end
# NodePoolAutoscaling contains information required by cluster autoscaler to
# adjust the size of the node pool to the current cluster usage.
class NodePoolAutoscaling
include Google::Apis::Core::Hashable
+ # Is autoscaling enabled for this node pool.
+ # Corresponds to the JSON property `enabled`
+ # @return [Boolean]
+ attr_accessor :enabled
+ alias_method :enabled?, :enabled
+
# Maximum number of nodes in the NodePool. Must be >= min_node_count. There
# has to enough quota to scale up the cluster.
# Corresponds to the JSON property `maxNodeCount`
# @return [Fixnum]
attr_accessor :max_node_count
@@ -831,638 +1254,396 @@
# max_node_count.
# Corresponds to the JSON property `minNodeCount`
# @return [Fixnum]
attr_accessor :min_node_count
- # Is autoscaling enabled for this node pool.
- # Corresponds to the JSON property `enabled`
- # @return [Boolean]
- attr_accessor :enabled
- alias_method :enabled?, :enabled
-
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
+ @enabled = args[:enabled] if args.key?(:enabled)
@max_node_count = args[:max_node_count] if args.key?(:max_node_count)
@min_node_count = args[:min_node_count] if args.key?(:min_node_count)
- @enabled = args[:enabled] if args.key?(:enabled)
end
end
- # SetMasterAuthRequest updates the admin password of a cluster.
- class SetMasterAuthRequest
+ # This operation resource represents operations that may have happened or are
+ # happening on the cluster. All fields are output only.
+ class Operation
include Google::Apis::Core::Hashable
- # The authentication information for accessing the master endpoint.
- # Authentication can be done using HTTP basic auth or using client
- # certificates.
- # Corresponds to the JSON property `update`
- # @return [Google::Apis::ContainerV1::MasterAuth]
- attr_accessor :update
+ # Detailed operation progress, if available.
+ # Corresponds to the JSON property `detail`
+ # @return [String]
+ attr_accessor :detail
- # The exact form of action to be taken on the master auth
- # Corresponds to the JSON property `action`
+ # The server-assigned ID for the operation.
+ # Corresponds to the JSON property `name`
# @return [String]
- attr_accessor :action
+ attr_accessor :name
- def initialize(**args)
- update!(**args)
- end
+ # The operation type.
+ # Corresponds to the JSON property `operationType`
+ # @return [String]
+ attr_accessor :operation_type
- # Update properties of this object
- def update!(**args)
- @update = args[:update] if args.key?(:update)
- @action = args[:action] if args.key?(:action)
- end
- end
-
- # SetNetworkPolicyRequest enables/disables network policy for a cluster.
- class SetNetworkPolicyRequest
- include Google::Apis::Core::Hashable
-
- # Configuration options for the NetworkPolicy feature.
- # https://kubernetes.io/docs/concepts/services-networking/networkpolicies/
- # Corresponds to the JSON property `networkPolicy`
- # @return [Google::Apis::ContainerV1::NetworkPolicy]
- attr_accessor :network_policy
-
- def initialize(**args)
- update!(**args)
- end
-
- # Update properties of this object
- def update!(**args)
- @network_policy = args[:network_policy] if args.key?(:network_policy)
- end
- end
-
- # ClusterUpdate describes an update to the cluster. Exactly one update can
- # be applied to a cluster with each request, so at most one field can be
- # provided.
- class ClusterUpdate
- include Google::Apis::Core::Hashable
-
- # The desired list of Google Compute Engine
- # [locations](/compute/docs/zones#available) in which the cluster's nodes
- # should be located. Changing the locations a cluster is in will result
- # in nodes being either created or removed from the cluster, depending on
- # whether locations are being added or removed.
- # This list must always include the cluster's primary zone.
- # Corresponds to the JSON property `desiredLocations`
- # @return [Array<String>]
- attr_accessor :desired_locations
-
- # NodePoolAutoscaling contains information required by cluster autoscaler to
- # adjust the size of the node pool to the current cluster usage.
- # Corresponds to the JSON property `desiredNodePoolAutoscaling`
- # @return [Google::Apis::ContainerV1::NodePoolAutoscaling]
- attr_accessor :desired_node_pool_autoscaling
-
- # The monitoring service the cluster should use to write metrics.
- # Currently available options:
- # * "monitoring.googleapis.com" - the Google Cloud Monitoring service
- # * "none" - no metrics will be exported from the cluster
- # Corresponds to the JSON property `desiredMonitoringService`
+ # Server-defined URL for the resource.
+ # Corresponds to the JSON property `selfLink`
# @return [String]
- attr_accessor :desired_monitoring_service
+ attr_accessor :self_link
- # The desired image type for the node pool.
- # NOTE: Set the "desired_node_pool" field as well.
- # Corresponds to the JSON property `desiredImageType`
+ # The current status of the operation.
+ # Corresponds to the JSON property `status`
# @return [String]
- attr_accessor :desired_image_type
+ attr_accessor :status
- # Configuration for the addons that can be automatically spun up in the
- # cluster, enabling additional functionality.
- # Corresponds to the JSON property `desiredAddonsConfig`
- # @return [Google::Apis::ContainerV1::AddonsConfig]
- attr_accessor :desired_addons_config
-
- # The node pool to be upgraded. This field is mandatory if
- # "desired_node_version", "desired_image_family" or
- # "desired_node_pool_autoscaling" is specified and there is more than one
- # node pool on the cluster.
- # Corresponds to the JSON property `desiredNodePoolId`
+ # If an error has occurred, a textual description of the error.
+ # Corresponds to the JSON property `statusMessage`
# @return [String]
- attr_accessor :desired_node_pool_id
+ attr_accessor :status_message
- # The Kubernetes version to change the nodes to (typically an
- # upgrade). Use `-` to upgrade to the latest version supported by
- # the server.
- # Corresponds to the JSON property `desiredNodeVersion`
+ # Server-defined URL for the target of the operation.
+ # Corresponds to the JSON property `targetLink`
# @return [String]
- attr_accessor :desired_node_version
+ attr_accessor :target_link
- # The Kubernetes version to change the master to. The only valid value is the
- # latest supported version. Use "-" to have the server automatically select
- # the latest version.
- # Corresponds to the JSON property `desiredMasterVersion`
+ # The name of the Google Compute Engine
+ # [zone](/compute/docs/zones#available) in which the operation
+ # is taking place.
+ # Corresponds to the JSON property `zone`
# @return [String]
- attr_accessor :desired_master_version
+ attr_accessor :zone
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @desired_locations = args[:desired_locations] if args.key?(:desired_locations)
- @desired_node_pool_autoscaling = args[:desired_node_pool_autoscaling] if args.key?(:desired_node_pool_autoscaling)
- @desired_monitoring_service = args[:desired_monitoring_service] if args.key?(:desired_monitoring_service)
- @desired_image_type = args[:desired_image_type] if args.key?(:desired_image_type)
- @desired_addons_config = args[:desired_addons_config] if args.key?(:desired_addons_config)
- @desired_node_pool_id = args[:desired_node_pool_id] if args.key?(:desired_node_pool_id)
- @desired_node_version = args[:desired_node_version] if args.key?(:desired_node_version)
- @desired_master_version = args[:desired_master_version] if args.key?(:desired_master_version)
+ @detail = args[:detail] if args.key?(:detail)
+ @name = args[:name] if args.key?(:name)
+ @operation_type = args[:operation_type] if args.key?(:operation_type)
+ @self_link = args[:self_link] if args.key?(:self_link)
+ @status = args[:status] if args.key?(:status)
+ @status_message = args[:status_message] if args.key?(:status_message)
+ @target_link = args[:target_link] if args.key?(:target_link)
+ @zone = args[:zone] if args.key?(:zone)
end
end
- # Configuration for controlling how IPs are allocated in the cluster.
- class IpAllocationPolicy
+ # RollbackNodePoolUpgradeRequest rollbacks the previously Aborted or Failed
+ # NodePool upgrade. This will be an no-op if the last upgrade successfully
+ # completed.
+ class RollbackNodePoolUpgradeRequest
include Google::Apis::Core::Hashable
- # Whether a new subnetwork will be created automatically for the cluster.
- # This field is only applicable when `use_ip_aliases` is true.
- # Corresponds to the JSON property `createSubnetwork`
- # @return [Boolean]
- attr_accessor :create_subnetwork
- alias_method :create_subnetwork?, :create_subnetwork
-
- # Whether alias IPs will be used for pod IPs in the cluster.
- # Corresponds to the JSON property `useIpAliases`
- # @return [Boolean]
- attr_accessor :use_ip_aliases
- alias_method :use_ip_aliases?, :use_ip_aliases
-
- # A custom subnetwork name to be used if `create_subnetwork` is true. If
- # this field is empty, then an automatic name will choosen for the new
- # subnetwork.
- # Corresponds to the JSON property `subnetworkName`
- # @return [String]
- attr_accessor :subnetwork_name
-
- # The IP address range for the cluster pod IPs. If this field is set, then
- # `cluster.cluster_ipv4_cidr` must be left blank.
- # This field is only applicable when `use_ip_aliases` is true.
- # Set to blank to have a range will be chosen with the default size.
- # Set to /netmask (e.g. `/14`) to have a range be chosen with a specific
- # netmask.
- # Set to a [CIDR](http://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing)
- # notation (e.g. `10.96.0.0/14`) from the RFC-1918 private networks (e.g.
- # `10.0.0.0/8`, `172.16.0.0/12`, `192.168.0.0/16`) to pick a specific range
- # to use.
- # Corresponds to the JSON property `clusterIpv4Cidr`
- # @return [String]
- attr_accessor :cluster_ipv4_cidr
-
- # The IP address range of the instance IPs in this cluster.
- # This is applicable only if `create_subnetwork` is true.
- # Set to blank to have a range will be chosen with the default size.
- # Set to /netmask (e.g. `/14`) to have a range be chosen with a specific
- # netmask.
- # Set to a [CIDR](http://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing)
- # notation (e.g. `10.96.0.0/14`) from the RFC-1918 private networks (e.g.
- # `10.0.0.0/8`, `172.16.0.0/12`, `192.168.0.0/16`) to pick a specific range
- # to use.
- # Corresponds to the JSON property `nodeIpv4Cidr`
- # @return [String]
- attr_accessor :node_ipv4_cidr
-
- # The IP address range of the services IPs in this cluster. If blank, a range
- # will be automatically chosen with the default size.
- # This field is only applicable when `use_ip_aliases` is true.
- # Set to blank to have a range will be chosen with the default size.
- # Set to /netmask (e.g. `/14`) to have a range be chosen with a specific
- # netmask.
- # Set to a [CIDR](http://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing)
- # notation (e.g. `10.96.0.0/14`) from the RFC-1918 private networks (e.g.
- # `10.0.0.0/8`, `172.16.0.0/12`, `192.168.0.0/16`) to pick a specific range
- # to use.
- # Corresponds to the JSON property `servicesIpv4Cidr`
- # @return [String]
- attr_accessor :services_ipv4_cidr
-
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @create_subnetwork = args[:create_subnetwork] if args.key?(:create_subnetwork)
- @use_ip_aliases = args[:use_ip_aliases] if args.key?(:use_ip_aliases)
- @subnetwork_name = args[:subnetwork_name] if args.key?(:subnetwork_name)
- @cluster_ipv4_cidr = args[:cluster_ipv4_cidr] if args.key?(:cluster_ipv4_cidr)
- @node_ipv4_cidr = args[:node_ipv4_cidr] if args.key?(:node_ipv4_cidr)
- @services_ipv4_cidr = args[:services_ipv4_cidr] if args.key?(:services_ipv4_cidr)
end
end
- # SetLoggingServiceRequest sets the logging service of a cluster.
- class SetLoggingServiceRequest
+ # Container Engine service configuration.
+ class ServerConfig
include Google::Apis::Core::Hashable
- # The logging service the cluster should use to write metrics.
- # Currently available options:
- # * "logging.googleapis.com" - the Google Cloud Logging service
- # * "none" - no metrics will be exported from the cluster
- # Corresponds to the JSON property `loggingService`
+ # Version of Kubernetes the service deploys by default.
+ # Corresponds to the JSON property `defaultClusterVersion`
# @return [String]
- attr_accessor :logging_service
+ attr_accessor :default_cluster_version
- def initialize(**args)
- update!(**args)
- end
+ # Default image type.
+ # Corresponds to the JSON property `defaultImageType`
+ # @return [String]
+ attr_accessor :default_image_type
- # Update properties of this object
- def update!(**args)
- @logging_service = args[:logging_service] if args.key?(:logging_service)
- end
- end
+ # List of valid image types.
+ # Corresponds to the JSON property `validImageTypes`
+ # @return [Array<String>]
+ attr_accessor :valid_image_types
- # Configuration options for the horizontal pod autoscaling feature, which
- # increases or decreases the number of replica pods a replication controller
- # has based on the resource usage of the existing pods.
- class HorizontalPodAutoscaling
- include Google::Apis::Core::Hashable
+ # List of valid master versions.
+ # Corresponds to the JSON property `validMasterVersions`
+ # @return [Array<String>]
+ attr_accessor :valid_master_versions
- # Whether the Horizontal Pod Autoscaling feature is enabled in the cluster.
- # When enabled, it ensures that a Heapster pod is running in the cluster,
- # which is also used by the Cloud Monitoring service.
- # Corresponds to the JSON property `disabled`
- # @return [Boolean]
- attr_accessor :disabled
- alias_method :disabled?, :disabled
+ # List of valid node upgrade target versions.
+ # Corresponds to the JSON property `validNodeVersions`
+ # @return [Array<String>]
+ attr_accessor :valid_node_versions
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @disabled = args[:disabled] if args.key?(:disabled)
+ @default_cluster_version = args[:default_cluster_version] if args.key?(:default_cluster_version)
+ @default_image_type = args[:default_image_type] if args.key?(:default_image_type)
+ @valid_image_types = args[:valid_image_types] if args.key?(:valid_image_types)
+ @valid_master_versions = args[:valid_master_versions] if args.key?(:valid_master_versions)
+ @valid_node_versions = args[:valid_node_versions] if args.key?(:valid_node_versions)
end
end
- # A generic empty message that you can re-use to avoid defining duplicated
- # empty messages in your APIs. A typical example is to use it as the request
- # or the response type of an API method. For instance:
- # service Foo `
- # rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty);
- # `
- # The JSON representation for `Empty` is empty JSON object ````.
- class Empty
+ # SetAddonsConfigRequest sets the addons associated with the cluster.
+ class SetAddonsConfigRequest
include Google::Apis::Core::Hashable
- def initialize(**args)
- update!(**args)
- end
+ # Configuration for the addons that can be automatically spun up in the
+ # cluster, enabling additional functionality.
+ # Corresponds to the JSON property `addonsConfig`
+ # @return [Google::Apis::ContainerV1::AddonsConfig]
+ attr_accessor :addons_config
- # Update properties of this object
- def update!(**args)
- end
- end
-
- # SetNodePoolManagementRequest sets the node management properties of a node
- # pool.
- class SetNodePoolManagementRequest
- include Google::Apis::Core::Hashable
-
- # NodeManagement defines the set of node management services turned on for the
- # node pool.
- # Corresponds to the JSON property `management`
- # @return [Google::Apis::ContainerV1::NodeManagement]
- attr_accessor :management
-
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @management = args[:management] if args.key?(:management)
+ @addons_config = args[:addons_config] if args.key?(:addons_config)
end
end
- # SetNodePoolAutoscalingRequest sets the autoscaler settings of a node pool.
- class SetNodePoolAutoscalingRequest
+ # SetLabelsRequest sets the Google Cloud Platform labels on a Google Container
+ # Engine cluster, which will in turn set them for Google Compute Engine
+ # resources used by that cluster
+ class SetLabelsRequest
include Google::Apis::Core::Hashable
- # NodePoolAutoscaling contains information required by cluster autoscaler to
- # adjust the size of the node pool to the current cluster usage.
- # Corresponds to the JSON property `autoscaling`
- # @return [Google::Apis::ContainerV1::NodePoolAutoscaling]
- attr_accessor :autoscaling
+ # The fingerprint of the previous set of labels for this resource,
+ # used to detect conflicts. The fingerprint is initially generated by
+ # Container Engine and changes after every request to modify or update
+ # labels. You must always provide an up-to-date fingerprint hash when
+ # updating or changing labels. Make a <code>get()</code> request to the
+ # resource to get the latest fingerprint.
+ # Corresponds to the JSON property `labelFingerprint`
+ # @return [String]
+ attr_accessor :label_fingerprint
+ # The labels to set for that cluster.
+ # Corresponds to the JSON property `resourceLabels`
+ # @return [Hash<String,String>]
+ attr_accessor :resource_labels
+
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @autoscaling = args[:autoscaling] if args.key?(:autoscaling)
+ @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
+ @resource_labels = args[:resource_labels] if args.key?(:resource_labels)
end
end
- # CreateClusterRequest creates a cluster.
- class CreateClusterRequest
+ # SetLegacyAbacRequest enables or disables the ABAC authorization mechanism for
+ # a cluster.
+ class SetLegacyAbacRequest
include Google::Apis::Core::Hashable
- # A Google Container Engine cluster.
- # Corresponds to the JSON property `cluster`
- # @return [Google::Apis::ContainerV1::Cluster]
- attr_accessor :cluster
+ # Whether ABAC authorization will be enabled in the cluster.
+ # Corresponds to the JSON property `enabled`
+ # @return [Boolean]
+ attr_accessor :enabled
+ alias_method :enabled?, :enabled
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @cluster = args[:cluster] if args.key?(:cluster)
+ @enabled = args[:enabled] if args.key?(:enabled)
end
end
- # ListNodePoolsResponse is the result of ListNodePoolsRequest.
- class ListNodePoolsResponse
+ # SetLocationsRequest sets the locations of the cluster.
+ class SetLocationsRequest
include Google::Apis::Core::Hashable
- # A list of node pools for a cluster.
- # Corresponds to the JSON property `nodePools`
- # @return [Array<Google::Apis::ContainerV1::NodePool>]
- attr_accessor :node_pools
+ # The desired list of Google Compute Engine
+ # [locations](/compute/docs/zones#available) in which the cluster's nodes
+ # should be located. Changing the locations a cluster is in will result
+ # in nodes being either created or removed from the cluster, depending on
+ # whether locations are being added or removed.
+ # This list must always include the cluster's primary zone.
+ # Corresponds to the JSON property `locations`
+ # @return [Array<String>]
+ attr_accessor :locations
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @node_pools = args[:node_pools] if args.key?(:node_pools)
+ @locations = args[:locations] if args.key?(:locations)
end
end
- # CompleteIPRotationRequest moves the cluster master back into single-IP mode.
- class CompleteIpRotationRequest
+ # SetLoggingServiceRequest sets the logging service of a cluster.
+ class SetLoggingServiceRequest
include Google::Apis::Core::Hashable
- def initialize(**args)
- update!(**args)
- end
+ # The logging service the cluster should use to write metrics.
+ # Currently available options:
+ # * "logging.googleapis.com" - the Google Cloud Logging service
+ # * "none" - no metrics will be exported from the cluster
+ # Corresponds to the JSON property `loggingService`
+ # @return [String]
+ attr_accessor :logging_service
- # Update properties of this object
- def update!(**args)
- end
- end
-
- # StartIPRotationRequest creates a new IP for the cluster and then performs
- # a node upgrade on each node pool to point to the new IP.
- class StartIpRotationRequest
- include Google::Apis::Core::Hashable
-
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
+ @logging_service = args[:logging_service] if args.key?(:logging_service)
end
end
- # UpdateNodePoolRequests update a node pool's image and/or version.
- class UpdateNodePoolRequest
+ # SetMasterAuthRequest updates the admin password of a cluster.
+ class SetMasterAuthRequest
include Google::Apis::Core::Hashable
- # The desired image type for the node pool.
- # Corresponds to the JSON property `imageType`
+ # The exact form of action to be taken on the master auth
+ # Corresponds to the JSON property `action`
# @return [String]
- attr_accessor :image_type
+ attr_accessor :action
- # The Kubernetes version to change the nodes to (typically an
- # upgrade). Use `-` to upgrade to the latest version supported by
- # the server.
- # Corresponds to the JSON property `nodeVersion`
- # @return [String]
- attr_accessor :node_version
+ # The authentication information for accessing the master endpoint.
+ # Authentication can be done using HTTP basic auth or using client
+ # certificates.
+ # Corresponds to the JSON property `update`
+ # @return [Google::Apis::ContainerV1::MasterAuth]
+ attr_accessor :update
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @image_type = args[:image_type] if args.key?(:image_type)
- @node_version = args[:node_version] if args.key?(:node_version)
+ @action = args[:action] if args.key?(:action)
+ @update = args[:update] if args.key?(:update)
end
end
- # Configuration for the legacy Attribute Based Access Control authorization
- # mode.
- class LegacyAbac
+ # SetMonitoringServiceRequest sets the monitoring service of a cluster.
+ class SetMonitoringServiceRequest
include Google::Apis::Core::Hashable
- # Whether the ABAC authorizer is enabled for this cluster. When enabled,
- # identities in the system, including service accounts, nodes, and
- # controllers, will have statically granted permissions beyond those
- # provided by the RBAC configuration or IAM.
- # Corresponds to the JSON property `enabled`
- # @return [Boolean]
- attr_accessor :enabled
- alias_method :enabled?, :enabled
+ # The monitoring service the cluster should use to write metrics.
+ # Currently available options:
+ # * "monitoring.googleapis.com" - the Google Cloud Monitoring service
+ # * "none" - no metrics will be exported from the cluster
+ # Corresponds to the JSON property `monitoringService`
+ # @return [String]
+ attr_accessor :monitoring_service
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @enabled = args[:enabled] if args.key?(:enabled)
+ @monitoring_service = args[:monitoring_service] if args.key?(:monitoring_service)
end
end
- # SetAddonsConfigRequest sets the addons associated with the cluster.
- class SetAddonsConfigRequest
+ # SetNetworkPolicyRequest enables/disables network policy for a cluster.
+ class SetNetworkPolicyRequest
include Google::Apis::Core::Hashable
- # Configuration for the addons that can be automatically spun up in the
- # cluster, enabling additional functionality.
- # Corresponds to the JSON property `addonsConfig`
- # @return [Google::Apis::ContainerV1::AddonsConfig]
- attr_accessor :addons_config
+ # Configuration options for the NetworkPolicy feature.
+ # https://kubernetes.io/docs/concepts/services-networking/networkpolicies/
+ # Corresponds to the JSON property `networkPolicy`
+ # @return [Google::Apis::ContainerV1::NetworkPolicy]
+ attr_accessor :network_policy
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @addons_config = args[:addons_config] if args.key?(:addons_config)
+ @network_policy = args[:network_policy] if args.key?(:network_policy)
end
end
- # NodePool contains the name and configuration for a cluster's node pool.
- # Node pools are a set of nodes (i.e. VM's), with a common configuration and
- # specification, under the control of the cluster master. They may have a set
- # of Kubernetes labels applied to them, which may be used to reference them
- # during pod scheduling. They may also be resized up or down, to accommodate
- # the workload.
- class NodePool
+ # SetNodePoolAutoscalingRequest sets the autoscaler settings of a node pool.
+ class SetNodePoolAutoscalingRequest
include Google::Apis::Core::Hashable
- # The name of the node pool.
- # Corresponds to the JSON property `name`
- # @return [String]
- attr_accessor :name
-
- # [Output only] Additional information about the current status of this
- # node pool instance, if available.
- # Corresponds to the JSON property `statusMessage`
- # @return [String]
- attr_accessor :status_message
-
# NodePoolAutoscaling contains information required by cluster autoscaler to
# adjust the size of the node pool to the current cluster usage.
# Corresponds to the JSON property `autoscaling`
# @return [Google::Apis::ContainerV1::NodePoolAutoscaling]
attr_accessor :autoscaling
- # NodeManagement defines the set of node management services turned on for the
- # node pool.
- # Corresponds to the JSON property `management`
- # @return [Google::Apis::ContainerV1::NodeManagement]
- attr_accessor :management
-
- # The initial node count for the pool. You must ensure that your
- # Compute Engine <a href="/compute/docs/resource-quotas">resource quota</a>
- # is sufficient for this number of instances. You must also have available
- # firewall and routes quota.
- # Corresponds to the JSON property `initialNodeCount`
- # @return [Fixnum]
- attr_accessor :initial_node_count
-
- # [Output only] Server-defined URL for the resource.
- # Corresponds to the JSON property `selfLink`
- # @return [String]
- attr_accessor :self_link
-
- # [Output only] The version of the Kubernetes of this node.
- # Corresponds to the JSON property `version`
- # @return [String]
- attr_accessor :version
-
- # [Output only] The resource URLs of [instance
- # groups](/compute/docs/instance-groups/) associated with this
- # node pool.
- # Corresponds to the JSON property `instanceGroupUrls`
- # @return [Array<String>]
- attr_accessor :instance_group_urls
-
- # [Output only] The status of the nodes in this pool instance.
- # Corresponds to the JSON property `status`
- # @return [String]
- attr_accessor :status
-
- # Parameters that describe the nodes in a cluster.
- # Corresponds to the JSON property `config`
- # @return [Google::Apis::ContainerV1::NodeConfig]
- attr_accessor :config
-
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @name = args[:name] if args.key?(:name)
- @status_message = args[:status_message] if args.key?(:status_message)
@autoscaling = args[:autoscaling] if args.key?(:autoscaling)
- @management = args[:management] if args.key?(:management)
- @initial_node_count = args[:initial_node_count] if args.key?(:initial_node_count)
- @self_link = args[:self_link] if args.key?(:self_link)
- @version = args[:version] if args.key?(:version)
- @instance_group_urls = args[:instance_group_urls] if args.key?(:instance_group_urls)
- @status = args[:status] if args.key?(:status)
- @config = args[:config] if args.key?(:config)
end
end
- # SetLabelsRequest sets the Google Cloud Platform labels on a Google Container
- # Engine cluster, which will in turn set them for Google Compute Engine
- # resources used by that cluster
- class SetLabelsRequest
+ # SetNodePoolManagementRequest sets the node management properties of a node
+ # pool.
+ class SetNodePoolManagementRequest
include Google::Apis::Core::Hashable
- # The fingerprint of the previous set of labels for this resource,
- # used to detect conflicts. The fingerprint is initially generated by
- # Container Engine and changes after every request to modify or update
- # labels. You must always provide an up-to-date fingerprint hash when
- # updating or changing labels. Make a <code>get()</code> request to the
- # resource to get the latest fingerprint.
- # Corresponds to the JSON property `labelFingerprint`
- # @return [String]
- attr_accessor :label_fingerprint
+ # NodeManagement defines the set of node management services turned on for the
+ # node pool.
+ # Corresponds to the JSON property `management`
+ # @return [Google::Apis::ContainerV1::NodeManagement]
+ attr_accessor :management
- # The labels to set for that cluster.
- # Corresponds to the JSON property `resourceLabels`
- # @return [Hash<String,String>]
- attr_accessor :resource_labels
-
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint)
- @resource_labels = args[:resource_labels] if args.key?(:resource_labels)
+ @management = args[:management] if args.key?(:management)
end
end
- # NodeManagement defines the set of node management services turned on for the
- # node pool.
- class NodeManagement
+ # SetNodePoolSizeRequest sets the size a node
+ # pool.
+ class SetNodePoolSizeRequest
include Google::Apis::Core::Hashable
- # A flag that specifies whether the node auto-repair is enabled for the node
- # pool. If enabled, the nodes in this node pool will be monitored and, if
- # they fail health checks too many times, an automatic repair action will be
- # triggered.
- # Corresponds to the JSON property `autoRepair`
- # @return [Boolean]
- attr_accessor :auto_repair
- alias_method :auto_repair?, :auto_repair
+ # The desired node count for the pool.
+ # Corresponds to the JSON property `nodeCount`
+ # @return [Fixnum]
+ attr_accessor :node_count
- # A flag that specifies whether node auto-upgrade is enabled for the node
- # pool. If enabled, node auto-upgrade helps keep the nodes in your node pool
- # up to date with the latest release version of Kubernetes.
- # Corresponds to the JSON property `autoUpgrade`
- # @return [Boolean]
- attr_accessor :auto_upgrade
- alias_method :auto_upgrade?, :auto_upgrade
-
- # AutoUpgradeOptions defines the set of options for the user to control how
- # the Auto Upgrades will proceed.
- # Corresponds to the JSON property `upgradeOptions`
- # @return [Google::Apis::ContainerV1::AutoUpgradeOptions]
- attr_accessor :upgrade_options
-
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @auto_repair = args[:auto_repair] if args.key?(:auto_repair)
- @auto_upgrade = args[:auto_upgrade] if args.key?(:auto_upgrade)
- @upgrade_options = args[:upgrade_options] if args.key?(:upgrade_options)
+ @node_count = args[:node_count] if args.key?(:node_count)
end
end
- # CancelOperationRequest cancels a single operation.
- class CancelOperationRequest
+ # StartIPRotationRequest creates a new IP for the cluster and then performs
+ # a node upgrade on each node pool to point to the new IP.
+ class StartIpRotationRequest
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
@@ -1470,120 +1651,75 @@
# Update properties of this object
def update!(**args)
end
end
- # SetLegacyAbacRequest enables or disables the ABAC authorization mechanism for
- # a cluster.
- class SetLegacyAbacRequest
+ # UpdateClusterRequest updates the settings of a cluster.
+ class UpdateClusterRequest
include Google::Apis::Core::Hashable
- # Whether ABAC authorization will be enabled in the cluster.
- # Corresponds to the JSON property `enabled`
- # @return [Boolean]
- attr_accessor :enabled
- alias_method :enabled?, :enabled
+ # ClusterUpdate describes an update to the cluster. Exactly one update can
+ # be applied to a cluster with each request, so at most one field can be
+ # provided.
+ # Corresponds to the JSON property `update`
+ # @return [Google::Apis::ContainerV1::ClusterUpdate]
+ attr_accessor :update
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @enabled = args[:enabled] if args.key?(:enabled)
+ @update = args[:update] if args.key?(:update)
end
end
- # This operation resource represents operations that may have happened or are
- # happening on the cluster. All fields are output only.
- class Operation
+ # UpdateMasterRequest updates the master of the cluster.
+ class UpdateMasterRequest
include Google::Apis::Core::Hashable
- # The name of the Google Compute Engine
- # [zone](/compute/docs/zones#available) in which the operation
- # is taking place.
- # Corresponds to the JSON property `zone`
+ # The Kubernetes version to change the master to. The only valid value is the
+ # latest supported version. Use "-" to have the server automatically select
+ # the latest version.
+ # Corresponds to the JSON property `masterVersion`
# @return [String]
- attr_accessor :zone
+ attr_accessor :master_version
- # The current status of the operation.
- # Corresponds to the JSON property `status`
- # @return [String]
- attr_accessor :status
-
- # If an error has occurred, a textual description of the error.
- # Corresponds to the JSON property `statusMessage`
- # @return [String]
- attr_accessor :status_message
-
- # The server-assigned ID for the operation.
- # Corresponds to the JSON property `name`
- # @return [String]
- attr_accessor :name
-
- # Server-defined URL for the resource.
- # Corresponds to the JSON property `selfLink`
- # @return [String]
- attr_accessor :self_link
-
- # Server-defined URL for the target of the operation.
- # Corresponds to the JSON property `targetLink`
- # @return [String]
- attr_accessor :target_link
-
- # Detailed operation progress, if available.
- # Corresponds to the JSON property `detail`
- # @return [String]
- attr_accessor :detail
-
- # The operation type.
- # Corresponds to the JSON property `operationType`
- # @return [String]
- attr_accessor :operation_type
-
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @zone = args[:zone] if args.key?(:zone)
- @status = args[:status] if args.key?(:status)
- @status_message = args[:status_message] if args.key?(:status_message)
- @name = args[:name] if args.key?(:name)
- @self_link = args[:self_link] if args.key?(:self_link)
- @target_link = args[:target_link] if args.key?(:target_link)
- @detail = args[:detail] if args.key?(:detail)
- @operation_type = args[:operation_type] if args.key?(:operation_type)
+ @master_version = args[:master_version] if args.key?(:master_version)
end
end
- # Configuration for the addons that can be automatically spun up in the
- # cluster, enabling additional functionality.
- class AddonsConfig
+ # UpdateNodePoolRequests update a node pool's image and/or version.
+ class UpdateNodePoolRequest
include Google::Apis::Core::Hashable
- # Configuration options for the horizontal pod autoscaling feature, which
- # increases or decreases the number of replica pods a replication controller
- # has based on the resource usage of the existing pods.
- # Corresponds to the JSON property `horizontalPodAutoscaling`
- # @return [Google::Apis::ContainerV1::HorizontalPodAutoscaling]
- attr_accessor :horizontal_pod_autoscaling
+ # The desired image type for the node pool.
+ # Corresponds to the JSON property `imageType`
+ # @return [String]
+ attr_accessor :image_type
- # Configuration options for the HTTP (L7) load balancing controller addon,
- # which makes it easy to set up HTTP load balancers for services in a cluster.
- # Corresponds to the JSON property `httpLoadBalancing`
- # @return [Google::Apis::ContainerV1::HttpLoadBalancing]
- attr_accessor :http_load_balancing
+ # The Kubernetes version to change the nodes to (typically an
+ # upgrade). Use `-` to upgrade to the latest version supported by
+ # the server.
+ # Corresponds to the JSON property `nodeVersion`
+ # @return [String]
+ attr_accessor :node_version
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
- @horizontal_pod_autoscaling = args[:horizontal_pod_autoscaling] if args.key?(:horizontal_pod_autoscaling)
- @http_load_balancing = args[:http_load_balancing] if args.key?(:http_load_balancing)
+ @image_type = args[:image_type] if args.key?(:image_type)
+ @node_version = args[:node_version] if args.key?(:node_version)
end
end
end
end
end