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