# Copyright 2015 Google Inc. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. require 'date' require 'google/apis/core/base_service' require 'google/apis/core/json_representation' require 'google/apis/core/hashable' require 'google/apis/errors' module Google module Apis module ContainerV1beta1 # AcceleratorConfig represents a Hardware Accelerator request. class AcceleratorConfig include Google::Apis::Core::Hashable # 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]( # https://cloud.google.com/compute/docs/gpus) # 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) @accelerator_count = args[:accelerator_count] if args.key?(:accelerator_count) @accelerator_type = args[:accelerator_type] if args.key?(:accelerator_type) end end # 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 Cloud Run feature. # Corresponds to the JSON property `cloudRunConfig` # @return [Google::Apis::ContainerV1beta1::CloudRunConfig] attr_accessor :cloud_run_config # Configuration options for the Config Connector add-on. # Corresponds to the JSON property `configConnectorConfig` # @return [Google::Apis::ContainerV1beta1::ConfigConnectorConfig] attr_accessor :config_connector_config # Configuration for NodeLocal DNSCache # Corresponds to the JSON property `dnsCacheConfig` # @return [Google::Apis::ContainerV1beta1::DnsCacheConfig] attr_accessor :dns_cache_config # Configuration for the Compute Engine PD CSI driver. This option can only be # enabled at cluster creation time. # Corresponds to the JSON property `gcePersistentDiskCsiDriverConfig` # @return [Google::Apis::ContainerV1beta1::GcePersistentDiskCsiDriverConfig] attr_accessor :gce_persistent_disk_csi_driver_config # 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::ContainerV1beta1::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::ContainerV1beta1::HttpLoadBalancing] attr_accessor :http_load_balancing # Configuration options for Istio addon. # Corresponds to the JSON property `istioConfig` # @return [Google::Apis::ContainerV1beta1::IstioConfig] attr_accessor :istio_config # Configuration options for the KALM addon. # Corresponds to the JSON property `kalmConfig` # @return [Google::Apis::ContainerV1beta1::KalmConfig] attr_accessor :kalm_config # Configuration for the Kubernetes Dashboard. # Corresponds to the JSON property `kubernetesDashboard` # @return [Google::Apis::ContainerV1beta1::KubernetesDashboard] attr_accessor :kubernetes_dashboard # Configuration for NetworkPolicy. This only tracks whether the addon is enabled # or not on the Master, it does not track whether network policy is enabled for # the nodes. # Corresponds to the JSON property `networkPolicyConfig` # @return [Google::Apis::ContainerV1beta1::NetworkPolicyConfig] attr_accessor :network_policy_config def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @cloud_run_config = args[:cloud_run_config] if args.key?(:cloud_run_config) @config_connector_config = args[:config_connector_config] if args.key?(:config_connector_config) @dns_cache_config = args[:dns_cache_config] if args.key?(:dns_cache_config) @gce_persistent_disk_csi_driver_config = args[:gce_persistent_disk_csi_driver_config] if args.key?(:gce_persistent_disk_csi_driver_config) @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) @istio_config = args[:istio_config] if args.key?(:istio_config) @kalm_config = args[:kalm_config] if args.key?(:kalm_config) @kubernetes_dashboard = args[:kubernetes_dashboard] if args.key?(:kubernetes_dashboard) @network_policy_config = args[:network_policy_config] if args.key?(:network_policy_config) end end # Configuration for returning group information from authenticators. class AuthenticatorGroupsConfig include Google::Apis::Core::Hashable # Whether this cluster should return group membership lookups during # authentication using a group of security groups. # Corresponds to the JSON property `enabled` # @return [Boolean] attr_accessor :enabled alias_method :enabled?, :enabled # The name of the security group-of-groups to be used. Only relevant if enabled = # true. # Corresponds to the JSON property `securityGroup` # @return [String] attr_accessor :security_group def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @enabled = args[:enabled] if args.key?(:enabled) @security_group = args[:security_group] if args.key?(:security_group) end end # AutoUpgradeOptions defines the set of options for the user to control how the # Auto Upgrades will proceed. class AutoUpgradeOptions include Google::Apis::Core::Hashable # [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) @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 # AutoprovisioningNodePoolDefaults contains defaults for a node pool created by # NAP. class AutoprovisioningNodePoolDefaults include Google::Apis::Core::Hashable # The Customer Managed Encryption Key used to encrypt the boot disk attached to # each node in the node pool. This should be of the form projects/[ # KEY_PROJECT_ID]/locations/[LOCATION]/keyRings/[RING_NAME]/cryptoKeys/[KEY_NAME] # . For more information about protecting resources with Cloud KMS Keys please # see: https://cloud.google.com/compute/docs/disks/customer-managed-encryption # Corresponds to the JSON property `bootDiskKmsKey` # @return [String] attr_accessor :boot_disk_kms_key # 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 # Type of the disk attached to each node (e.g. 'pd-standard' or 'pd-ssd') If # unspecified, the default disk type is 'pd-standard' # Corresponds to the JSON property `diskType` # @return [String] attr_accessor :disk_type # NodeManagement defines the set of node management services turned on for the # node pool. # Corresponds to the JSON property `management` # @return [Google::Apis::ContainerV1beta1::NodeManagement] attr_accessor :management # Minimum CPU platform to be used by this instance. The instance may be # scheduled on the specified or newer CPU platform. Applicable values are the # friendly names of CPU platforms, such as `minCpuPlatform: "Intel Haswell"` or ` # minCpuPlatform: "Intel Sandy Bridge"`. For more information, read [how to # specify min CPU platform](https://cloud.google.com/compute/docs/instances/ # specify-min-cpu-platform) To unset the min cpu platform field pass "automatic" # as field value. # Corresponds to the JSON property `minCpuPlatform` # @return [String] attr_accessor :min_cpu_platform # 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 persistent storage on your nodes. * `https:// # www.googleapis.com/auth/devstorage.read_only` is required for communicating # with **gcr.io** (the [Google Container Registry](https://cloud.google.com/ # container-registry/)). If unspecified, no scopes are added, unless Cloud # Logging or Cloud Monitoring are enabled, in which case their required scopes # will be added. # Corresponds to the JSON property `oauthScopes` # @return [Array] attr_accessor :oauth_scopes # The Google Cloud Platform Service Account to be used by the node VMs. Specify # the email address of the Service Account; otherwise, if no Service Account is # specified, the "default" service account is used. # Corresponds to the JSON property `serviceAccount` # @return [String] attr_accessor :service_account # A set of Shielded Instance options. # Corresponds to the JSON property `shieldedInstanceConfig` # @return [Google::Apis::ContainerV1beta1::ShieldedInstanceConfig] attr_accessor :shielded_instance_config # These upgrade settings control the level of parallelism and the level of # disruption caused by an upgrade. maxUnavailable controls the number of nodes # that can be simultaneously unavailable. maxSurge controls the number of # additional nodes that can be added to the node pool temporarily for the time # of the upgrade to increase the number of available nodes. (maxUnavailable + # maxSurge) determines the level of parallelism (how many nodes are being # upgraded at the same time). Note: upgrades inevitably introduce some # disruption since workloads need to be moved from old nodes to new, upgraded # ones. Even if maxUnavailable=0, this holds true. (Disruption stays within the # limits of PodDisruptionBudget, if it is configured.) Consider a hypothetical # node pool with 5 nodes having maxSurge=2, maxUnavailable=1. This means the # upgrade process upgrades 3 nodes simultaneously. It creates 2 additional ( # upgraded) nodes, then it brings down 3 old (not yet upgraded) nodes at the # same time. This ensures that there are always at least 4 nodes available. # Corresponds to the JSON property `upgradeSettings` # @return [Google::Apis::ContainerV1beta1::UpgradeSettings] attr_accessor :upgrade_settings def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @boot_disk_kms_key = args[:boot_disk_kms_key] if args.key?(:boot_disk_kms_key) @disk_size_gb = args[:disk_size_gb] if args.key?(:disk_size_gb) @disk_type = args[:disk_type] if args.key?(:disk_type) @management = args[:management] if args.key?(:management) @min_cpu_platform = args[:min_cpu_platform] if args.key?(:min_cpu_platform) @oauth_scopes = args[:oauth_scopes] if args.key?(:oauth_scopes) @service_account = args[:service_account] if args.key?(:service_account) @shielded_instance_config = args[:shielded_instance_config] if args.key?(:shielded_instance_config) @upgrade_settings = args[:upgrade_settings] if args.key?(:upgrade_settings) end end # Deprecated. class AvailableVersion include Google::Apis::Core::Hashable # Reason for availability. # Corresponds to the JSON property `reason` # @return [String] attr_accessor :reason # Kubernetes version. # 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) @reason = args[:reason] if args.key?(:reason) @version = args[:version] if args.key?(:version) end end # Parameters for using BigQuery as the destination of resource usage export. class BigQueryDestination include Google::Apis::Core::Hashable # The ID of a BigQuery Dataset. # Corresponds to the JSON property `datasetId` # @return [String] attr_accessor :dataset_id def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @dataset_id = args[:dataset_id] if args.key?(:dataset_id) end end # Configuration for Binary Authorization. class BinaryAuthorization include Google::Apis::Core::Hashable # Enable Binary Authorization for this cluster. If enabled, all container images # will be validated by Google Binauthz. # 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 # CancelOperationRequest cancels a single operation. class CancelOperationRequest include Google::Apis::Core::Hashable # The name (project, location, operation id) of the operation to cancel. # Specified in the format `projects/*/locations/*/operations/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. Deprecated. The server-assigned `name` of the operation. This field # has been deprecated and replaced by the name field. # Corresponds to the JSON property `operationId` # @return [String] attr_accessor :operation_id # Required. Deprecated. The Google Developers Console [project ID or project # number](https://support.google.com/cloud/answer/6158840). This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the operation resides. # This field has been deprecated and replaced by the name field. # 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) @name = args[:name] if args.key?(:name) @operation_id = args[:operation_id] if args.key?(:operation_id) @project_id = args[:project_id] if args.key?(:project_id) @zone = args[:zone] if args.key?(:zone) end end # CidrBlock contains an optional name and one CIDR block. class CidrBlock include Google::Apis::Core::Hashable # cidr_block must be specified in CIDR notation. # Corresponds to the JSON property `cidrBlock` # @return [String] attr_accessor :cidr_block # display_name is an optional field for users to identify CIDR blocks. # Corresponds to the JSON property `displayName` # @return [String] attr_accessor :display_name def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @cidr_block = args[:cidr_block] if args.key?(:cidr_block) @display_name = args[:display_name] if args.key?(:display_name) end end # Configuration for client certificates on the cluster. class ClientCertificateConfig include Google::Apis::Core::Hashable # 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) @issue_client_certificate = args[:issue_client_certificate] if args.key?(:issue_client_certificate) end end # Configuration options for the Cloud Run feature. class CloudRunConfig include Google::Apis::Core::Hashable # Whether Cloud Run addon is enabled for this cluster. # Corresponds to the JSON property `disabled` # @return [Boolean] attr_accessor :disabled alias_method :disabled?, :disabled # Which load balancer type is installed for Cloud Run. # Corresponds to the JSON property `loadBalancerType` # @return [String] attr_accessor :load_balancer_type def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @disabled = args[:disabled] if args.key?(:disabled) @load_balancer_type = args[:load_balancer_type] if args.key?(:load_balancer_type) end end # A Google Kubernetes Engine cluster. class Cluster 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::ContainerV1beta1::AddonsConfig] attr_accessor :addons_config # Configuration for returning group information from authenticators. # Corresponds to the JSON property `authenticatorGroupsConfig` # @return [Google::Apis::ContainerV1beta1::AuthenticatorGroupsConfig] attr_accessor :authenticator_groups_config # ClusterAutoscaling contains global, per-cluster information required by # Cluster Autoscaler to automatically adjust the size of the cluster and create/ # delete node pools based on the current needs. # Corresponds to the JSON property `autoscaling` # @return [Google::Apis::ContainerV1beta1::ClusterAutoscaling] attr_accessor :autoscaling # Configuration for Binary Authorization. # Corresponds to the JSON property `binaryAuthorization` # @return [Google::Apis::ContainerV1beta1::BinaryAuthorization] attr_accessor :binary_authorization # 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 :cluster_ipv4_cidr # Telemetry integration for the cluster. # Corresponds to the JSON property `clusterTelemetry` # @return [Google::Apis::ContainerV1beta1::ClusterTelemetry] attr_accessor :cluster_telemetry # Which conditions caused the current cluster state. # Corresponds to the JSON property `conditions` # @return [Array] attr_accessor :conditions # ConfidentialNodes is configuration for the confidential nodes feature, which # makes nodes run on confidential VMs. # Corresponds to the JSON property `confidentialNodes` # @return [Google::Apis::ContainerV1beta1::ConfidentialNodes] attr_accessor :confidential_nodes # [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. Deprecated. Call # Kubernetes API directly to retrieve node information. # Corresponds to the JSON property `currentNodeCount` # @return [Fixnum] attr_accessor :current_node_count # [Output only] Deprecated, use [NodePool.version](https://cloud.google.com/ # kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters. # nodePools) instead. 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 # Configuration of etcd encryption. # Corresponds to the JSON property `databaseEncryption` # @return [Google::Apis::ContainerV1beta1::DatabaseEncryption] attr_accessor :database_encryption # Constraints applied to pods. # Corresponds to the JSON property `defaultMaxPodsConstraint` # @return [Google::Apis::ContainerV1beta1::MaxPodsConstraint] attr_accessor :default_max_pods_constraint # An optional description of this cluster. # Corresponds to the JSON property `description` # @return [String] attr_accessor :description # Kubernetes alpha features are enabled on this cluster. This includes alpha API # groups (e.g. v1beta1) 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 # Enable the ability to use Cloud TPUs in this cluster. This field is deprecated, # use tpu_config.enabled instead. # Corresponds to the JSON property `enableTpu` # @return [Boolean] attr_accessor :enable_tpu alias_method :enable_tpu?, :enable_tpu # [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 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 :expire_time # 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. Users may specify either explicit versions offered by # Kubernetes Engine or version aliases, which have the following behavior: - " # latest": picks the highest valid Kubernetes version - "1.X": picks the highest # valid patch+gke.N patch in the 1.X version - "1.X.Y": picks the highest valid # gke.N patch in the 1.X.Y version - "1.X.Y-gke.N": picks an explicit Kubernetes # version - "","-": picks the default Kubernetes version # Corresponds to the JSON property `initialClusterVersion` # @return [String] attr_accessor :initial_cluster_version # The number of nodes to create in this cluster. You must ensure that your # Compute Engine [resource quota](https://cloud.google.com/compute/quotas) is # sufficient for this number of instances. You must also have available firewall # and routes quota. For requests, this field should only be used in lieu of a " # node_pool" object, since this configuration (along with the "node_config") # will be used to create a "NodePool" object with an auto-generated name. Do not # use this and a node_pool at the same time. This field is deprecated, use # node_pool.initial_node_count instead. # Corresponds to the JSON property `initialNodeCount` # @return [Fixnum] attr_accessor :initial_node_count # Deprecated. Use node_pools.instance_group_urls. # Corresponds to the JSON property `instanceGroupUrls` # @return [Array] attr_accessor :instance_group_urls # Configuration for controlling how IPs are allocated in the cluster. # Corresponds to the JSON property `ipAllocationPolicy` # @return [Google::Apis::ContainerV1beta1::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 :label_fingerprint # Configuration for the legacy Attribute Based Access Control authorization mode. # Corresponds to the JSON property `legacyAbac` # @return [Google::Apis::ContainerV1beta1::LegacyAbac] attr_accessor :legacy_abac # [Output only] The name of the Google Compute Engine [zone](https://cloud. # google.com/compute/docs/regions-zones/regions-zones#available) or [region]( # https://cloud.google.com/compute/docs/regions-zones/regions-zones#available) # in which the cluster resides. # Corresponds to the JSON property `location` # @return [String] attr_accessor :location # The list of Google Compute Engine [zones](https://cloud.google.com/compute/ # docs/zones#available) in which the cluster's nodes should be located. This # field provides a default value if [NodePool.Locations](https://cloud.google. # com/kubernetes-engine/docs/reference/rest/v1/projects.locations.clusters. # nodePools#NodePool.FIELDS.locations) are not specified during node pool # creation. Warning: changing cluster locations will update the [NodePool. # Locations](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1/ # projects.locations.clusters.nodePools#NodePool.FIELDS.locations) of all node # pools and will result in nodes being added and/or removed. # Corresponds to the JSON property `locations` # @return [Array] attr_accessor :locations # The logging service the cluster should use to write logs. Currently available # options: * `logging.googleapis.com/kubernetes` - The Cloud Logging service # with a Kubernetes-native resource model * `logging.googleapis.com` - The # legacy Cloud Logging service (no longer available as of GKE 1.15). * `none` - # no logs will be exported from the cluster. If left as an empty string,`logging. # googleapis.com/kubernetes` will be used for GKE 1.14+ or `logging.googleapis. # com` for earlier versions. # Corresponds to the JSON property `loggingService` # @return [String] attr_accessor :logging_service # MaintenancePolicy defines the maintenance policy to be used for the cluster. # Corresponds to the JSON property `maintenancePolicy` # @return [Google::Apis::ContainerV1beta1::MaintenancePolicy] attr_accessor :maintenance_policy # Master is the configuration for components on master. # Corresponds to the JSON property `master` # @return [Google::Apis::ContainerV1beta1::Master] attr_accessor :master # 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::ContainerV1beta1::MasterAuth] attr_accessor :master_auth # 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::ContainerV1beta1::MasterAuthorizedNetworksConfig] attr_accessor :master_authorized_networks_config # The IP prefix in CIDR notation to use for the hosted master network. This # prefix will be used for assigning private IP addresses to the master or set of # masters, as well as the ILB VIP. This field is deprecated, use # private_cluster_config.master_ipv4_cidr_block instead. # Corresponds to the JSON property `masterIpv4CidrBlock` # @return [String] attr_accessor :master_ipv4_cidr_block # The monitoring service the cluster should use to write metrics. Currently # available options: * "monitoring.googleapis.com/kubernetes" - The Cloud # Monitoring service with a Kubernetes-native resource model * `monitoring. # googleapis.com` - The legacy Cloud Monitoring service (no longer available as # of GKE 1.15). * `none` - No metrics will be exported from the cluster. If left # as an empty string,`monitoring.googleapis.com/kubernetes` will be used for GKE # 1.14+ or `monitoring.googleapis.com` for earlier versions. # 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 # location (e.g. zone or region), 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](https://cloud.google.com/ # compute/docs/networks-and-firewalls#networks) to which the cluster is # connected. If left unspecified, the `default` network will be used. On output # this shows the network ID instead of the name. # Corresponds to the JSON property `network` # @return [String] attr_accessor :network # NetworkConfig reports the relative names of network & subnetwork. # Corresponds to the JSON property `networkConfig` # @return [Google::Apis::ContainerV1beta1::NetworkConfig] attr_accessor :network_config # Configuration options for the NetworkPolicy feature. https://kubernetes.io/ # docs/concepts/services-networking/networkpolicies/ # Corresponds to the JSON property `networkPolicy` # @return [Google::Apis::ContainerV1beta1::NetworkPolicy] attr_accessor :network_policy # Parameters that describe the nodes in a cluster. # Corresponds to the JSON property `nodeConfig` # @return [Google::Apis::ContainerV1beta1::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. # This field will only be set when cluster is in route-based network mode. # Corresponds to the JSON property `nodeIpv4CidrSize` # @return [Fixnum] attr_accessor :node_ipv4_cidr_size # 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] attr_accessor :node_pools # NotificationConfig is the configuration of notifications. # Corresponds to the JSON property `notificationConfig` # @return [Google::Apis::ContainerV1beta1::NotificationConfig] attr_accessor :notification_config # Configuration for the PodSecurityPolicy feature. # Corresponds to the JSON property `podSecurityPolicyConfig` # @return [Google::Apis::ContainerV1beta1::PodSecurityPolicyConfig] attr_accessor :pod_security_policy_config # If this is a private cluster setup. Private clusters are clusters that, by # default have no external IP addresses on the nodes and where nodes and the # master communicate over private IP addresses. This field is deprecated, use # private_cluster_config.enable_private_nodes instead. # Corresponds to the JSON property `privateCluster` # @return [Boolean] attr_accessor :private_cluster alias_method :private_cluster?, :private_cluster # Configuration options for private clusters. # Corresponds to the JSON property `privateClusterConfig` # @return [Google::Apis::ContainerV1beta1::PrivateClusterConfig] attr_accessor :private_cluster_config # ReleaseChannel indicates which release channel a cluster is subscribed to. # Release channels are arranged in order of risk. When a cluster is subscribed # to a release channel, Google maintains both the master version and the node # version. Node auto-upgrade defaults to true and cannot be disabled. # Corresponds to the JSON property `releaseChannel` # @return [Google::Apis::ContainerV1beta1::ReleaseChannel] attr_accessor :release_channel # The resource labels for the cluster to use to annotate any related Google # Compute Engine resources. # Corresponds to the JSON property `resourceLabels` # @return [Hash] attr_accessor :resource_labels # Configuration for exporting cluster resource usages. # Corresponds to the JSON property `resourceUsageExportConfig` # @return [Google::Apis::ContainerV1beta1::ResourceUsageExportConfig] attr_accessor :resource_usage_export_config # [Output only] Server-defined URL for the resource. # Corresponds to the JSON property `selfLink` # @return [String] attr_accessor :self_link # [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 :services_ipv4_cidr # Configuration of Shielded Nodes feature. # Corresponds to the JSON property `shieldedNodes` # @return [Google::Apis::ContainerV1beta1::ShieldedNodes] attr_accessor :shielded_nodes # [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 name of the Google Compute Engine [subnetwork](https://cloud.google.com/ # compute/docs/subnetworks) to which the cluster is connected. On output this # shows the subnetwork ID instead of the name. # Corresponds to the JSON property `subnetwork` # @return [String] attr_accessor :subnetwork # Configuration for Cloud TPU. # Corresponds to the JSON property `tpuConfig` # @return [Google::Apis::ContainerV1beta1::TpuConfig] attr_accessor :tpu_config # [Output only] The IP address range of the Cloud TPUs in this cluster, in [CIDR] # (http://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing) notation (e.g. ` # 1.2.3.4/29`). # Corresponds to the JSON property `tpuIpv4CidrBlock` # @return [String] attr_accessor :tpu_ipv4_cidr_block # VerticalPodAutoscaling contains global, per-cluster information required by # Vertical Pod Autoscaler to automatically adjust the resources of pods # controlled by it. # Corresponds to the JSON property `verticalPodAutoscaling` # @return [Google::Apis::ContainerV1beta1::VerticalPodAutoscaling] attr_accessor :vertical_pod_autoscaling # Configuration for the use of Kubernetes Service Accounts in GCP IAM policies. # Corresponds to the JSON property `workloadIdentityConfig` # @return [Google::Apis::ContainerV1beta1::WorkloadIdentityConfig] attr_accessor :workload_identity_config # [Output only] The name of the Google Compute Engine [zone](https://cloud. # google.com/compute/docs/zones#available) in which the cluster resides. This # field is deprecated, use location instead. # 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) @addons_config = args[:addons_config] if args.key?(:addons_config) @authenticator_groups_config = args[:authenticator_groups_config] if args.key?(:authenticator_groups_config) @autoscaling = args[:autoscaling] if args.key?(:autoscaling) @binary_authorization = args[:binary_authorization] if args.key?(:binary_authorization) @cluster_ipv4_cidr = args[:cluster_ipv4_cidr] if args.key?(:cluster_ipv4_cidr) @cluster_telemetry = args[:cluster_telemetry] if args.key?(:cluster_telemetry) @conditions = args[:conditions] if args.key?(:conditions) @confidential_nodes = args[:confidential_nodes] if args.key?(:confidential_nodes) @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) @database_encryption = args[:database_encryption] if args.key?(:database_encryption) @default_max_pods_constraint = args[:default_max_pods_constraint] if args.key?(:default_max_pods_constraint) @description = args[:description] if args.key?(:description) @enable_kubernetes_alpha = args[:enable_kubernetes_alpha] if args.key?(:enable_kubernetes_alpha) @enable_tpu = args[:enable_tpu] if args.key?(:enable_tpu) @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) @location = args[:location] if args.key?(:location) @locations = args[:locations] if args.key?(:locations) @logging_service = args[:logging_service] if args.key?(:logging_service) @maintenance_policy = args[:maintenance_policy] if args.key?(:maintenance_policy) @master = args[:master] if args.key?(:master) @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) @master_ipv4_cidr_block = args[:master_ipv4_cidr_block] if args.key?(:master_ipv4_cidr_block) @monitoring_service = args[:monitoring_service] if args.key?(:monitoring_service) @name = args[:name] if args.key?(:name) @network = args[:network] if args.key?(:network) @network_config = args[:network_config] if args.key?(:network_config) @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) @node_pools = args[:node_pools] if args.key?(:node_pools) @notification_config = args[:notification_config] if args.key?(:notification_config) @pod_security_policy_config = args[:pod_security_policy_config] if args.key?(:pod_security_policy_config) @private_cluster = args[:private_cluster] if args.key?(:private_cluster) @private_cluster_config = args[:private_cluster_config] if args.key?(:private_cluster_config) @release_channel = args[:release_channel] if args.key?(:release_channel) @resource_labels = args[:resource_labels] if args.key?(:resource_labels) @resource_usage_export_config = args[:resource_usage_export_config] if args.key?(:resource_usage_export_config) @self_link = args[:self_link] if args.key?(:self_link) @services_ipv4_cidr = args[:services_ipv4_cidr] if args.key?(:services_ipv4_cidr) @shielded_nodes = args[:shielded_nodes] if args.key?(:shielded_nodes) @status = args[:status] if args.key?(:status) @status_message = args[:status_message] if args.key?(:status_message) @subnetwork = args[:subnetwork] if args.key?(:subnetwork) @tpu_config = args[:tpu_config] if args.key?(:tpu_config) @tpu_ipv4_cidr_block = args[:tpu_ipv4_cidr_block] if args.key?(:tpu_ipv4_cidr_block) @vertical_pod_autoscaling = args[:vertical_pod_autoscaling] if args.key?(:vertical_pod_autoscaling) @workload_identity_config = args[:workload_identity_config] if args.key?(:workload_identity_config) @zone = args[:zone] if args.key?(:zone) end end # ClusterAutoscaling contains global, per-cluster information required by # Cluster Autoscaler to automatically adjust the size of the cluster and create/ # delete node pools based on the current needs. class ClusterAutoscaling include Google::Apis::Core::Hashable # The list of Google Compute Engine [zones](https://cloud.google.com/compute/ # docs/zones#available) in which the NodePool's nodes can be created by NAP. # Corresponds to the JSON property `autoprovisioningLocations` # @return [Array] attr_accessor :autoprovisioning_locations # AutoprovisioningNodePoolDefaults contains defaults for a node pool created by # NAP. # Corresponds to the JSON property `autoprovisioningNodePoolDefaults` # @return [Google::Apis::ContainerV1beta1::AutoprovisioningNodePoolDefaults] attr_accessor :autoprovisioning_node_pool_defaults # Defines autoscaling behaviour. # Corresponds to the JSON property `autoscalingProfile` # @return [String] attr_accessor :autoscaling_profile # Enables automatic node pool creation and deletion. # Corresponds to the JSON property `enableNodeAutoprovisioning` # @return [Boolean] attr_accessor :enable_node_autoprovisioning alias_method :enable_node_autoprovisioning?, :enable_node_autoprovisioning # Contains global constraints regarding minimum and maximum amount of resources # in the cluster. # Corresponds to the JSON property `resourceLimits` # @return [Array] attr_accessor :resource_limits def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @autoprovisioning_locations = args[:autoprovisioning_locations] if args.key?(:autoprovisioning_locations) @autoprovisioning_node_pool_defaults = args[:autoprovisioning_node_pool_defaults] if args.key?(:autoprovisioning_node_pool_defaults) @autoscaling_profile = args[:autoscaling_profile] if args.key?(:autoscaling_profile) @enable_node_autoprovisioning = args[:enable_node_autoprovisioning] if args.key?(:enable_node_autoprovisioning) @resource_limits = args[:resource_limits] if args.key?(:resource_limits) end end # Telemetry integration for the cluster. class ClusterTelemetry include Google::Apis::Core::Hashable # Type of the integration. # Corresponds to the JSON property `type` # @return [String] attr_accessor :type def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @type = args[:type] if args.key?(:type) 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::ContainerV1beta1::AddonsConfig] attr_accessor :desired_addons_config # Configuration for Binary Authorization. # Corresponds to the JSON property `desiredBinaryAuthorization` # @return [Google::Apis::ContainerV1beta1::BinaryAuthorization] attr_accessor :desired_binary_authorization # ClusterAutoscaling contains global, per-cluster information required by # Cluster Autoscaler to automatically adjust the size of the cluster and create/ # delete node pools based on the current needs. # Corresponds to the JSON property `desiredClusterAutoscaling` # @return [Google::Apis::ContainerV1beta1::ClusterAutoscaling] attr_accessor :desired_cluster_autoscaling # Telemetry integration for the cluster. # Corresponds to the JSON property `desiredClusterTelemetry` # @return [Google::Apis::ContainerV1beta1::ClusterTelemetry] attr_accessor :desired_cluster_telemetry # Configuration of etcd encryption. # Corresponds to the JSON property `desiredDatabaseEncryption` # @return [Google::Apis::ContainerV1beta1::DatabaseEncryption] attr_accessor :desired_database_encryption # The desired datapath provider for the cluster. # Corresponds to the JSON property `desiredDatapathProvider` # @return [String] attr_accessor :desired_datapath_provider # DefaultSnatStatus contains the desired state of whether default sNAT should be # disabled on the cluster. # Corresponds to the JSON property `desiredDefaultSnatStatus` # @return [Google::Apis::ContainerV1beta1::DefaultSnatStatus] attr_accessor :desired_default_snat_status # 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 # IntraNodeVisibilityConfig contains the desired config of the intra-node # visibility on this cluster. # Corresponds to the JSON property `desiredIntraNodeVisibilityConfig` # @return [Google::Apis::ContainerV1beta1::IntraNodeVisibilityConfig] attr_accessor :desired_intra_node_visibility_config # The desired list of Google Compute Engine [zones](https://cloud.google.com/ # compute/docs/zones#available) in which the cluster's nodes should be located. # This list must always include the cluster's primary zone. Warning: changing # cluster locations will update the locations of all node pools and will result # in nodes being added and/or removed. # Corresponds to the JSON property `desiredLocations` # @return [Array] attr_accessor :desired_locations # The logging service the cluster should use to write logs. Currently available # options: * `logging.googleapis.com/kubernetes` - The Cloud Logging service # with a Kubernetes-native resource model * `logging.googleapis.com` - The # legacy Cloud Logging service (no longer available as of GKE 1.15). * `none` - # no logs will be exported from the cluster. If left as an empty string,`logging. # googleapis.com/kubernetes` will be used for GKE 1.14+ or `logging.googleapis. # com` for earlier versions. # Corresponds to the JSON property `desiredLoggingService` # @return [String] attr_accessor :desired_logging_service # Master is the configuration for components on master. # Corresponds to the JSON property `desiredMaster` # @return [Google::Apis::ContainerV1beta1::Master] attr_accessor :desired_master # 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::ContainerV1beta1::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. Users may specify either explicit versions offered # by Kubernetes Engine or version aliases, which have the following behavior: - " # latest": picks the highest valid Kubernetes version - "1.X": picks the highest # valid patch+gke.N patch in the 1.X version - "1.X.Y": picks the highest valid # gke.N patch in the 1.X.Y version - "1.X.Y-gke.N": picks an explicit Kubernetes # version - "-": picks the default Kubernetes 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/kubernetes" - The Cloud # Monitoring service with a Kubernetes-native resource model * `monitoring. # googleapis.com` - The legacy Cloud Monitoring service (no longer available as # of GKE 1.15). * `none` - No metrics will be exported from the cluster. If left # as an empty string,`monitoring.googleapis.com/kubernetes` will be used for GKE # 1.14+ or `monitoring.googleapis.com` for earlier versions. # 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::ContainerV1beta1::NodePoolAutoscaling] attr_accessor :desired_node_pool_autoscaling # The node pool to be upgraded. This field is mandatory if "desired_node_version" # , "desired_image_family", "desired_node_pool_autoscaling", or " # desired_workload_metadata_config" 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). Users # may specify either explicit versions offered by Kubernetes Engine or version # aliases, which have the following behavior: - "latest": picks the highest # valid Kubernetes version - "1.X": picks the highest valid patch+gke.N patch in # the 1.X version - "1.X.Y": picks the highest valid gke.N patch in the 1.X.Y # version - "1.X.Y-gke.N": picks an explicit Kubernetes version - "-": picks the # Kubernetes master version # Corresponds to the JSON property `desiredNodeVersion` # @return [String] attr_accessor :desired_node_version # NotificationConfig is the configuration of notifications. # Corresponds to the JSON property `desiredNotificationConfig` # @return [Google::Apis::ContainerV1beta1::NotificationConfig] attr_accessor :desired_notification_config # Configuration for the PodSecurityPolicy feature. # Corresponds to the JSON property `desiredPodSecurityPolicyConfig` # @return [Google::Apis::ContainerV1beta1::PodSecurityPolicyConfig] attr_accessor :desired_pod_security_policy_config # Configuration options for private clusters. # Corresponds to the JSON property `desiredPrivateClusterConfig` # @return [Google::Apis::ContainerV1beta1::PrivateClusterConfig] attr_accessor :desired_private_cluster_config # ReleaseChannel indicates which release channel a cluster is subscribed to. # Release channels are arranged in order of risk. When a cluster is subscribed # to a release channel, Google maintains both the master version and the node # version. Node auto-upgrade defaults to true and cannot be disabled. # Corresponds to the JSON property `desiredReleaseChannel` # @return [Google::Apis::ContainerV1beta1::ReleaseChannel] attr_accessor :desired_release_channel # Configuration for exporting cluster resource usages. # Corresponds to the JSON property `desiredResourceUsageExportConfig` # @return [Google::Apis::ContainerV1beta1::ResourceUsageExportConfig] attr_accessor :desired_resource_usage_export_config # Configuration of Shielded Nodes feature. # Corresponds to the JSON property `desiredShieldedNodes` # @return [Google::Apis::ContainerV1beta1::ShieldedNodes] attr_accessor :desired_shielded_nodes # Configuration for Cloud TPU. # Corresponds to the JSON property `desiredTpuConfig` # @return [Google::Apis::ContainerV1beta1::TpuConfig] attr_accessor :desired_tpu_config # VerticalPodAutoscaling contains global, per-cluster information required by # Vertical Pod Autoscaler to automatically adjust the resources of pods # controlled by it. # Corresponds to the JSON property `desiredVerticalPodAutoscaling` # @return [Google::Apis::ContainerV1beta1::VerticalPodAutoscaling] attr_accessor :desired_vertical_pod_autoscaling # Configuration for the use of Kubernetes Service Accounts in GCP IAM policies. # Corresponds to the JSON property `desiredWorkloadIdentityConfig` # @return [Google::Apis::ContainerV1beta1::WorkloadIdentityConfig] attr_accessor :desired_workload_identity_config 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_binary_authorization = args[:desired_binary_authorization] if args.key?(:desired_binary_authorization) @desired_cluster_autoscaling = args[:desired_cluster_autoscaling] if args.key?(:desired_cluster_autoscaling) @desired_cluster_telemetry = args[:desired_cluster_telemetry] if args.key?(:desired_cluster_telemetry) @desired_database_encryption = args[:desired_database_encryption] if args.key?(:desired_database_encryption) @desired_datapath_provider = args[:desired_datapath_provider] if args.key?(:desired_datapath_provider) @desired_default_snat_status = args[:desired_default_snat_status] if args.key?(:desired_default_snat_status) @desired_image_type = args[:desired_image_type] if args.key?(:desired_image_type) @desired_intra_node_visibility_config = args[:desired_intra_node_visibility_config] if args.key?(:desired_intra_node_visibility_config) @desired_locations = args[:desired_locations] if args.key?(:desired_locations) @desired_logging_service = args[:desired_logging_service] if args.key?(:desired_logging_service) @desired_master = args[:desired_master] if args.key?(:desired_master) @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) @desired_notification_config = args[:desired_notification_config] if args.key?(:desired_notification_config) @desired_pod_security_policy_config = args[:desired_pod_security_policy_config] if args.key?(:desired_pod_security_policy_config) @desired_private_cluster_config = args[:desired_private_cluster_config] if args.key?(:desired_private_cluster_config) @desired_release_channel = args[:desired_release_channel] if args.key?(:desired_release_channel) @desired_resource_usage_export_config = args[:desired_resource_usage_export_config] if args.key?(:desired_resource_usage_export_config) @desired_shielded_nodes = args[:desired_shielded_nodes] if args.key?(:desired_shielded_nodes) @desired_tpu_config = args[:desired_tpu_config] if args.key?(:desired_tpu_config) @desired_vertical_pod_autoscaling = args[:desired_vertical_pod_autoscaling] if args.key?(:desired_vertical_pod_autoscaling) @desired_workload_identity_config = args[:desired_workload_identity_config] if args.key?(:desired_workload_identity_config) end end # CompleteIPRotationRequest moves the cluster master back into single-IP mode. class CompleteIpRotationRequest include Google::Apis::Core::Hashable # Required. Deprecated. The name of the cluster. This field has been deprecated # and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # The name (project, location, cluster id) of the cluster to complete IP # rotation. Specified in the format `projects/*/locations/*/clusters/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. Deprecated. The Google Developers Console [project ID or project # number](https://developers.google.com/console/help/new/#projectnumber). This # field has been deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @name = args[:name] if args.key?(:name) @project_id = args[:project_id] if args.key?(:project_id) @zone = args[:zone] if args.key?(:zone) end end # ConfidentialNodes is configuration for the confidential nodes feature, which # makes nodes run on confidential VMs. class ConfidentialNodes include Google::Apis::Core::Hashable # Whether Confidential Nodes feature is enabled for all nodes in this 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) @enabled = args[:enabled] if args.key?(:enabled) end end # Configuration options for the Config Connector add-on. class ConfigConnectorConfig include Google::Apis::Core::Hashable # Whether Cloud Connector is enabled for this 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) @enabled = args[:enabled] if args.key?(:enabled) end end # Parameters for controlling consumption metering. class ConsumptionMeteringConfig include Google::Apis::Core::Hashable # Whether to enable consumption metering for this cluster. If enabled, a second # BigQuery table will be created to hold resource consumption records. # 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 # CreateClusterRequest creates a cluster. class CreateClusterRequest include Google::Apis::Core::Hashable # A Google Kubernetes Engine cluster. # Corresponds to the JSON property `cluster` # @return [Google::Apis::ContainerV1beta1::Cluster] attr_accessor :cluster # The parent (project and location) where the cluster will be created. Specified # in the format `projects/*/locations/*`. # Corresponds to the JSON property `parent` # @return [String] attr_accessor :parent # Required. Deprecated. The Google Developers Console [project ID or project # number](https://support.google.com/cloud/answer/6158840). This field has been # deprecated and replaced by the parent field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the parent field. # 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) @cluster = args[:cluster] if args.key?(:cluster) @parent = args[:parent] if args.key?(:parent) @project_id = args[:project_id] if args.key?(:project_id) @zone = args[:zone] if args.key?(:zone) end end # CreateNodePoolRequest creates a node pool for a cluster. class CreateNodePoolRequest include Google::Apis::Core::Hashable # Required. Deprecated. The name of the cluster. This field has been deprecated # and replaced by the parent field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # 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. # Corresponds to the JSON property `nodePool` # @return [Google::Apis::ContainerV1beta1::NodePool] attr_accessor :node_pool # The parent (project, location, cluster id) where the node pool will be created. # Specified in the format `projects/*/locations/*/clusters/*`. # Corresponds to the JSON property `parent` # @return [String] attr_accessor :parent # Required. Deprecated. The Google Developers Console [project ID or project # number](https://developers.google.com/console/help/new/#projectnumber). This # field has been deprecated and replaced by the parent field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the parent field. # 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) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @node_pool = args[:node_pool] if args.key?(:node_pool) @parent = args[:parent] if args.key?(:parent) @project_id = args[:project_id] if args.key?(:project_id) @zone = args[:zone] if args.key?(:zone) end end # Time window specified for daily maintenance operations. class DailyMaintenanceWindow include Google::Apis::Core::Hashable # [Output only] Duration of the time window, automatically chosen to be smallest # possible in the given scenario. # Corresponds to the JSON property `duration` # @return [String] attr_accessor :duration # Time within the maintenance window to start the maintenance operations. It # must be in format "HH:MM", where HH : [00-23] and MM : [00-59] GMT. # Corresponds to the JSON property `startTime` # @return [String] attr_accessor :start_time def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @duration = args[:duration] if args.key?(:duration) @start_time = args[:start_time] if args.key?(:start_time) end end # Configuration of etcd encryption. class DatabaseEncryption include Google::Apis::Core::Hashable # Name of CloudKMS key to use for the encryption of secrets in etcd. Ex. # projects/my-project/locations/global/keyRings/my-ring/cryptoKeys/my-key # Corresponds to the JSON property `keyName` # @return [String] attr_accessor :key_name # Denotes the state of etcd encryption. # Corresponds to the JSON property `state` # @return [String] attr_accessor :state def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @key_name = args[:key_name] if args.key?(:key_name) @state = args[:state] if args.key?(:state) end end # DefaultSnatStatus contains the desired state of whether default sNAT should be # disabled on the cluster. class DefaultSnatStatus include Google::Apis::Core::Hashable # Disables cluster default sNAT rules. # 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 NodeLocal DNSCache class DnsCacheConfig include Google::Apis::Core::Hashable # Whether NodeLocal DNSCache is enabled for this 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) @enabled = args[:enabled] if args.key?(:enabled) 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 include Google::Apis::Core::Hashable def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) end end # EphemeralStorageConfig contains configuration for the ephemeral storage # filesystem. class EphemeralStorageConfig include Google::Apis::Core::Hashable # Number of local SSDs to use to back ephemeral storage. Uses NVMe interfaces. # Each local SSD is 375 GB in size. If zero, it means to disable using local # SSDs as ephemeral storage. # Corresponds to the JSON property `localSsdCount` # @return [Fixnum] attr_accessor :local_ssd_count def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @local_ssd_count = args[:local_ssd_count] if args.key?(:local_ssd_count) end end # Configuration for the Compute Engine PD CSI driver. This option can only be # enabled at cluster creation time. class GcePersistentDiskCsiDriverConfig include Google::Apis::Core::Hashable # Whether the Compute Engine PD CSI driver is enabled for this 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) @enabled = args[:enabled] if args.key?(:enabled) end end # GetJSONWebKeysResponse is a valid JSON Web Key Set as specififed in rfc 7517 class GetJsonWebKeysResponse include Google::Apis::Core::Hashable # RFC-2616: cache control support # Corresponds to the JSON property `cacheHeader` # @return [Google::Apis::ContainerV1beta1::HttpCacheControlResponseHeader] attr_accessor :cache_header # The public component of the keys used by the cluster to sign token requests. # Corresponds to the JSON property `keys` # @return [Array] attr_accessor :keys def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @cache_header = args[:cache_header] if args.key?(:cache_header) @keys = args[:keys] if args.key?(:keys) end end # GetOpenIDConfigResponse is an OIDC discovery document for the cluster. See the # OpenID Connect Discovery 1.0 specification for details. class GetOpenIdConfigResponse include Google::Apis::Core::Hashable # RFC-2616: cache control support # Corresponds to the JSON property `cacheHeader` # @return [Google::Apis::ContainerV1beta1::HttpCacheControlResponseHeader] attr_accessor :cache_header # Supported claims. # Corresponds to the JSON property `claims_supported` # @return [Array] attr_accessor :claims_supported # Supported grant types. # Corresponds to the JSON property `grant_types` # @return [Array] attr_accessor :grant_types # supported ID Token signing Algorithms. # Corresponds to the JSON property `id_token_signing_alg_values_supported` # @return [Array] attr_accessor :id_token_signing_alg_values_supported # OIDC Issuer. # Corresponds to the JSON property `issuer` # @return [String] attr_accessor :issuer # JSON Web Key uri. # Corresponds to the JSON property `jwks_uri` # @return [String] attr_accessor :jwks_uri # Supported response types. # Corresponds to the JSON property `response_types_supported` # @return [Array] attr_accessor :response_types_supported # Supported subject types. # Corresponds to the JSON property `subject_types_supported` # @return [Array] attr_accessor :subject_types_supported def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @cache_header = args[:cache_header] if args.key?(:cache_header) @claims_supported = args[:claims_supported] if args.key?(:claims_supported) @grant_types = args[:grant_types] if args.key?(:grant_types) @id_token_signing_alg_values_supported = args[:id_token_signing_alg_values_supported] if args.key?(:id_token_signing_alg_values_supported) @issuer = args[:issuer] if args.key?(:issuer) @jwks_uri = args[:jwks_uri] if args.key?(:jwks_uri) @response_types_supported = args[:response_types_supported] if args.key?(:response_types_supported) @subject_types_supported = args[:subject_types_supported] if args.key?(:subject_types_supported) 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 metrics are collected into Stackdriver Monitoring. # 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 # RFC-2616: cache control support class HttpCacheControlResponseHeader include Google::Apis::Core::Hashable # 14.6 response cache age, in seconds since the response is generated # Corresponds to the JSON property `age` # @return [Fixnum] attr_accessor :age # 14.9 request and response directives # Corresponds to the JSON property `directive` # @return [String] attr_accessor :directive # 14.21 response cache expires, in RFC 1123 date format # Corresponds to the JSON property `expires` # @return [String] attr_accessor :expires def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @age = args[:age] if args.key?(:age) @directive = args[:directive] if args.key?(:directive) @expires = args[:expires] if args.key?(:expires) end end # 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 # 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) @disabled = args[:disabled] if args.key?(:disabled) end end # Configuration for controlling how IPs are allocated in the cluster. class IpAllocationPolicy include Google::Apis::Core::Hashable # If true, allow allocation of cluster CIDR ranges that overlap with certain # kinds of network routes. By default we do not allow cluster CIDR ranges to # intersect with any user declared routes. With allow_route_overlap == true, we # allow overlapping with CIDR ranges that are larger than the cluster CIDR range. # If this field is set to true, then cluster and services CIDRs must be fully- # specified (e.g. `10.96.0.0/14`, but not `/14`), which means: 1) When ` # use_ip_aliases` is true, `cluster_ipv4_cidr_block` and ` # services_ipv4_cidr_block` must be fully-specified. 2) When `use_ip_aliases` is # false, `cluster.cluster_ipv4_cidr` muse be fully-specified. # Corresponds to the JSON property `allowRouteOverlap` # @return [Boolean] attr_accessor :allow_route_overlap alias_method :allow_route_overlap?, :allow_route_overlap # This field is deprecated, use cluster_ipv4_cidr_block. # Corresponds to the JSON property `clusterIpv4Cidr` # @return [String] attr_accessor :cluster_ipv4_cidr # 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 chosen with the # default size. Set to /netmask (e.g. `/14`) to have a range 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 `clusterIpv4CidrBlock` # @return [String] attr_accessor :cluster_ipv4_cidr_block # The name of the secondary range to be used for the cluster CIDR block. The # secondary range will be used for pod IP addresses. This must be an existing # secondary range associated with the cluster subnetwork. This field is only # applicable with use_ip_aliases and create_subnetwork is false. # Corresponds to the JSON property `clusterSecondaryRangeName` # @return [String] attr_accessor :cluster_secondary_range_name # 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 # This field is deprecated, use node_ipv4_cidr_block. # Corresponds to the JSON property `nodeIpv4Cidr` # @return [String] attr_accessor :node_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 chosen with # the default size. Set to /netmask (e.g. `/14`) to have a range 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 `nodeIpv4CidrBlock` # @return [String] attr_accessor :node_ipv4_cidr_block # This field is deprecated, use services_ipv4_cidr_block. # Corresponds to the JSON property `servicesIpv4Cidr` # @return [String] attr_accessor :services_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 chosen # with the default size. Set to /netmask (e.g. `/14`) to have a range 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 `servicesIpv4CidrBlock` # @return [String] attr_accessor :services_ipv4_cidr_block # The name of the secondary range to be used as for the services CIDR block. The # secondary range will be used for service ClusterIPs. This must be an existing # secondary range associated with the cluster subnetwork. This field is only # applicable with use_ip_aliases and create_subnetwork is false. # Corresponds to the JSON property `servicesSecondaryRangeName` # @return [String] attr_accessor :services_secondary_range_name # 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 # The IP address range of the Cloud TPUs in this cluster. If unspecified, a # range will be automatically chosen with the default size. This field is only # applicable when `use_ip_aliases` is true. If unspecified, the range will use # the default size. Set to /netmask (e.g. `/14`) to have a range 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. This field is deprecated, use cluster.tpu_config. # ipv4_cidr_block instead. # Corresponds to the JSON property `tpuIpv4CidrBlock` # @return [String] attr_accessor :tpu_ipv4_cidr_block # Whether alias IPs will be used for pod IPs in the cluster. This is used in # conjunction with use_routes. It cannot be true if use_routes is true. If both # use_ip_aliases and use_routes are false, then the server picks the default IP # allocation mode # Corresponds to the JSON property `useIpAliases` # @return [Boolean] attr_accessor :use_ip_aliases alias_method :use_ip_aliases?, :use_ip_aliases # Whether routes will be used for pod IPs in the cluster. This is used in # conjunction with use_ip_aliases. It cannot be true if use_ip_aliases is true. # If both use_ip_aliases and use_routes are false, then the server picks the # default IP allocation mode # Corresponds to the JSON property `useRoutes` # @return [Boolean] attr_accessor :use_routes alias_method :use_routes?, :use_routes def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @allow_route_overlap = args[:allow_route_overlap] if args.key?(:allow_route_overlap) @cluster_ipv4_cidr = args[:cluster_ipv4_cidr] if args.key?(:cluster_ipv4_cidr) @cluster_ipv4_cidr_block = args[:cluster_ipv4_cidr_block] if args.key?(:cluster_ipv4_cidr_block) @cluster_secondary_range_name = args[:cluster_secondary_range_name] if args.key?(:cluster_secondary_range_name) @create_subnetwork = args[:create_subnetwork] if args.key?(:create_subnetwork) @node_ipv4_cidr = args[:node_ipv4_cidr] if args.key?(:node_ipv4_cidr) @node_ipv4_cidr_block = args[:node_ipv4_cidr_block] if args.key?(:node_ipv4_cidr_block) @services_ipv4_cidr = args[:services_ipv4_cidr] if args.key?(:services_ipv4_cidr) @services_ipv4_cidr_block = args[:services_ipv4_cidr_block] if args.key?(:services_ipv4_cidr_block) @services_secondary_range_name = args[:services_secondary_range_name] if args.key?(:services_secondary_range_name) @subnetwork_name = args[:subnetwork_name] if args.key?(:subnetwork_name) @tpu_ipv4_cidr_block = args[:tpu_ipv4_cidr_block] if args.key?(:tpu_ipv4_cidr_block) @use_ip_aliases = args[:use_ip_aliases] if args.key?(:use_ip_aliases) @use_routes = args[:use_routes] if args.key?(:use_routes) end end # IntraNodeVisibilityConfig contains the desired config of the intra-node # visibility on this cluster. class IntraNodeVisibilityConfig include Google::Apis::Core::Hashable # Enables intra node visibility for this 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) @enabled = args[:enabled] if args.key?(:enabled) end end # Configuration options for Istio addon. class IstioConfig include Google::Apis::Core::Hashable # The specified Istio auth mode, either none, or mutual TLS. # Corresponds to the JSON property `auth` # @return [String] attr_accessor :auth # Whether Istio 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) @auth = args[:auth] if args.key?(:auth) @disabled = args[:disabled] if args.key?(:disabled) end end # Jwk is a JSON Web Key as specified in RFC 7517 class Jwk include Google::Apis::Core::Hashable # Algorithm. # Corresponds to the JSON property `alg` # @return [String] attr_accessor :alg # Used for ECDSA keys. # Corresponds to the JSON property `crv` # @return [String] attr_accessor :crv # Used for RSA keys. # Corresponds to the JSON property `e` # @return [String] attr_accessor :e # Key ID. # Corresponds to the JSON property `kid` # @return [String] attr_accessor :kid # Key Type. # Corresponds to the JSON property `kty` # @return [String] attr_accessor :kty # Used for RSA keys. # Corresponds to the JSON property `n` # @return [String] attr_accessor :n # Permitted uses for the public keys. # Corresponds to the JSON property `use` # @return [String] attr_accessor :use # Used for ECDSA keys. # Corresponds to the JSON property `x` # @return [String] attr_accessor :x # Used for ECDSA keys. # Corresponds to the JSON property `y` # @return [String] attr_accessor :y def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @alg = args[:alg] if args.key?(:alg) @crv = args[:crv] if args.key?(:crv) @e = args[:e] if args.key?(:e) @kid = args[:kid] if args.key?(:kid) @kty = args[:kty] if args.key?(:kty) @n = args[:n] if args.key?(:n) @use = args[:use] if args.key?(:use) @x = args[:x] if args.key?(:x) @y = args[:y] if args.key?(:y) end end # Configuration options for the KALM addon. class KalmConfig include Google::Apis::Core::Hashable # Whether KALM is enabled for this 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) @enabled = args[:enabled] if args.key?(:enabled) 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 # Parameters that can be configured on Linux nodes. class LinuxNodeConfig include Google::Apis::Core::Hashable # The Linux kernel parameters to be applied to the nodes and all pods running on # the nodes. The following parameters are supported. net.core.netdev_max_backlog # net.core.rmem_max net.core.wmem_default net.core.wmem_max net.core.optmem_max # net.core.somaxconn net.ipv4.tcp_rmem net.ipv4.tcp_wmem net.ipv4.tcp_tw_reuse # Corresponds to the JSON property `sysctls` # @return [Hash] attr_accessor :sysctls def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @sysctls = args[:sysctls] if args.key?(:sysctls) 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] 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] attr_accessor :missing_zones 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 # ListLocationsResponse returns the list of all GKE locations and their # recommendation state. class ListLocationsResponse include Google::Apis::Core::Hashable # A full list of GKE locations. # Corresponds to the JSON property `locations` # @return [Array] attr_accessor :locations # Only return ListLocationsResponse that occur after the page_token. This value # should be populated from the ListLocationsResponse.next_page_token if that # response token was set (which happens when listing more Locations than fit in # a single ListLocationsResponse). # Corresponds to the JSON property `nextPageToken` # @return [String] attr_accessor :next_page_token def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @locations = args[:locations] if args.key?(:locations) @next_page_token = args[:next_page_token] if args.key?(:next_page_token) 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] 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] attr_accessor :missing_zones # A list of operations in the project in the specified zone. # Corresponds to the JSON property `operations` # @return [Array] attr_accessor :operations def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @missing_zones = args[:missing_zones] if args.key?(:missing_zones) @operations = args[:operations] if args.key?(:operations) end end # ListUsableSubnetworksResponse is the response of ListUsableSubnetworksRequest. class ListUsableSubnetworksResponse include Google::Apis::Core::Hashable # This token allows you to get the next page of results for list requests. If # the number of results is larger than `page_size`, use the `next_page_token` as # a value for the query parameter `page_token` in the next request. The value # will become empty when there are no more pages. # Corresponds to the JSON property `nextPageToken` # @return [String] attr_accessor :next_page_token # A list of usable subnetworks in the specified network project. # Corresponds to the JSON property `subnetworks` # @return [Array] attr_accessor :subnetworks def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @next_page_token = args[:next_page_token] if args.key?(:next_page_token) @subnetworks = args[:subnetworks] if args.key?(:subnetworks) end end # Location returns the location name, and if the location is recommended for GKE # cluster scheduling. class Location include Google::Apis::Core::Hashable # Contains the name of the resource requested. Specified in the format `projects/ # */locations/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Whether the location is recomended for GKE cluster scheduling. # Corresponds to the JSON property `recommended` # @return [Boolean] attr_accessor :recommended alias_method :recommended?, :recommended # Contains the type of location this Location is for. Regional or Zonal. # Corresponds to the JSON property `type` # @return [String] attr_accessor :type def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @name = args[:name] if args.key?(:name) @recommended = args[:recommended] if args.key?(:recommended) @type = args[:type] if args.key?(:type) end end # MaintenancePolicy defines the maintenance policy to be used for the cluster. class MaintenancePolicy include Google::Apis::Core::Hashable # A hash identifying the version of this policy, so that updates to fields of # the policy won't accidentally undo intermediate changes (and so that users of # the API unaware of some fields won't accidentally remove other fields). Make a # `get()` request to the cluster to get the current resource version and include # it with requests to set the policy. # Corresponds to the JSON property `resourceVersion` # @return [String] attr_accessor :resource_version # MaintenanceWindow defines the maintenance window to be used for the cluster. # Corresponds to the JSON property `window` # @return [Google::Apis::ContainerV1beta1::MaintenanceWindow] attr_accessor :window def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @resource_version = args[:resource_version] if args.key?(:resource_version) @window = args[:window] if args.key?(:window) end end # MaintenanceWindow defines the maintenance window to be used for the cluster. class MaintenanceWindow include Google::Apis::Core::Hashable # Time window specified for daily maintenance operations. # Corresponds to the JSON property `dailyMaintenanceWindow` # @return [Google::Apis::ContainerV1beta1::DailyMaintenanceWindow] attr_accessor :daily_maintenance_window # Exceptions to maintenance window. Non-emergency maintenance should not occur # in these windows. # Corresponds to the JSON property `maintenanceExclusions` # @return [Hash] attr_accessor :maintenance_exclusions # Represents an arbitrary window of time that recurs. # Corresponds to the JSON property `recurringWindow` # @return [Google::Apis::ContainerV1beta1::RecurringTimeWindow] attr_accessor :recurring_window def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @daily_maintenance_window = args[:daily_maintenance_window] if args.key?(:daily_maintenance_window) @maintenance_exclusions = args[:maintenance_exclusions] if args.key?(:maintenance_exclusions) @recurring_window = args[:recurring_window] if args.key?(:recurring_window) end end # Master is the configuration for components on master. class Master include Google::Apis::Core::Hashable def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) end end # The authentication information for accessing the master endpoint. # Authentication can be done using HTTP basic auth or using client certificates. class MasterAuth include Google::Apis::Core::Hashable # [Output only] Base64-encoded public certificate used by clients to # authenticate to the cluster endpoint. # Corresponds to the JSON property `clientCertificate` # @return [String] attr_accessor :client_certificate # Configuration for client certificates on the cluster. # Corresponds to the JSON property `clientCertificateConfig` # @return [Google::Apis::ContainerV1beta1::ClientCertificateConfig] attr_accessor :client_certificate_config # [Output only] Base64-encoded private key used by clients to authenticate to # the cluster endpoint. # Corresponds to the JSON property `clientKey` # @return [String] attr_accessor :client_key # # 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. Warning: basic authentication is deprecated, and will be removed # in GKE control plane versions 1.19 and newer. For a list of recommended # authentication methods, see: https://cloud.google.com/kubernetes-engine/docs/ # how-to/api-server-authentication # 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, basic authentication can be disabled by leaving # username unspecified (or setting it to the empty string). Warning: basic # authentication is deprecated, and will be removed in GKE control plane # versions 1.19 and newer. For a list of recommended authentication methods, see: # https://cloud.google.com/kubernetes-engine/docs/how-to/api-server- # authentication # 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) @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 # 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] 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 # Constraints applied to pods. class MaxPodsConstraint include Google::Apis::Core::Hashable # Constraint enforced on the max num of pods per node. # Corresponds to the JSON property `maxPodsPerNode` # @return [Fixnum] attr_accessor :max_pods_per_node def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @max_pods_per_node = args[:max_pods_per_node] if args.key?(:max_pods_per_node) end end # Progress metric is (string, int|float|string) pair. class Metric include Google::Apis::Core::Hashable # For metrics with floating point value. # Corresponds to the JSON property `doubleValue` # @return [Float] attr_accessor :double_value # For metrics with integer value. # Corresponds to the JSON property `intValue` # @return [Fixnum] attr_accessor :int_value # Required. Metric name, e.g., "nodes total", "percent done". # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # For metrics with custom values (ratios, visual progress, etc.). # Corresponds to the JSON property `stringValue` # @return [String] attr_accessor :string_value def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @double_value = args[:double_value] if args.key?(:double_value) @int_value = args[:int_value] if args.key?(:int_value) @name = args[:name] if args.key?(:name) @string_value = args[:string_value] if args.key?(:string_value) end end # NetworkConfig reports the relative names of network & subnetwork. class NetworkConfig include Google::Apis::Core::Hashable # The desired datapath provider for this cluster. By default, uses the IPTables- # based kube-proxy implementation. # Corresponds to the JSON property `datapathProvider` # @return [String] attr_accessor :datapath_provider # DefaultSnatStatus contains the desired state of whether default sNAT should be # disabled on the cluster. # Corresponds to the JSON property `defaultSnatStatus` # @return [Google::Apis::ContainerV1beta1::DefaultSnatStatus] attr_accessor :default_snat_status # Whether Intra-node visibility is enabled for this cluster. This makes same # node pod to pod traffic visible for VPC network. # Corresponds to the JSON property `enableIntraNodeVisibility` # @return [Boolean] attr_accessor :enable_intra_node_visibility alias_method :enable_intra_node_visibility?, :enable_intra_node_visibility # Output only. The relative name of the Google Compute Engine network(https:// # cloud.google.com/compute/docs/networks-and-firewalls#networks) to which the # cluster is connected. Example: projects/my-project/global/networks/my-network # Corresponds to the JSON property `network` # @return [String] attr_accessor :network # Output only. The relative name of the Google Compute Engine [subnetwork](https: # //cloud.google.com/compute/docs/vpc) to which the cluster is connected. # Example: projects/my-project/regions/us-central1/subnetworks/my-subnet # Corresponds to the JSON property `subnetwork` # @return [String] attr_accessor :subnetwork def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @datapath_provider = args[:datapath_provider] if args.key?(:datapath_provider) @default_snat_status = args[:default_snat_status] if args.key?(:default_snat_status) @enable_intra_node_visibility = args[:enable_intra_node_visibility] if args.key?(:enable_intra_node_visibility) @network = args[:network] if args.key?(:network) @subnetwork = args[:subnetwork] if args.key?(:subnetwork) 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 # Configuration for NetworkPolicy. This only tracks whether the addon is enabled # or not on the Master, it does not track whether network policy is enabled for # the nodes. class NetworkPolicyConfig include Google::Apis::Core::Hashable # Whether NetworkPolicy 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 # Parameters that describe the nodes in a cluster. class NodeConfig include Google::Apis::Core::Hashable # 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] attr_accessor :accelerators # The Customer Managed Encryption Key used to encrypt the boot disk attached to # each node in the node pool. This should be of the form projects/[ # KEY_PROJECT_ID]/locations/[LOCATION]/keyRings/[RING_NAME]/cryptoKeys/[KEY_NAME] # . For more information about protecting resources with Cloud KMS Keys please # see: https://cloud.google.com/compute/docs/disks/customer-managed-encryption # Corresponds to the JSON property `bootDiskKmsKey` # @return [String] attr_accessor :boot_disk_kms_key # 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 # Type of the disk attached to each node (e.g. 'pd-standard' or 'pd-ssd') If # unspecified, the default disk type is 'pd-standard' # Corresponds to the JSON property `diskType` # @return [String] attr_accessor :disk_type # EphemeralStorageConfig contains configuration for the ephemeral storage # filesystem. # Corresponds to the JSON property `ephemeralStorageConfig` # @return [Google::Apis::ContainerV1beta1::EphemeralStorageConfig] attr_accessor :ephemeral_storage_config # 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 # Node kubelet configs. # Corresponds to the JSON property `kubeletConfig` # @return [Google::Apis::ContainerV1beta1::NodeKubeletConfig] attr_accessor :kubelet_config # 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 and conflicts should be avoided. For more information, including # usage and the valid values, see: https://kubernetes.io/docs/concepts/overview/ # working-with-objects/labels/ # Corresponds to the JSON property `labels` # @return [Hash] attr_accessor :labels # Parameters that can be configured on Linux nodes. # Corresponds to the JSON property `linuxNodeConfig` # @return [Google::Apis::ContainerV1beta1::LinuxNodeConfig] attr_accessor :linux_node_config # The number of local SSD disks to be attached to the node. The limit for this # value is dependent upon the maximum number of disks available on a machine per # zone. See: https://cloud.google.com/compute/docs/disks/local-ssd 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](https://cloud.google.com/ # compute/docs/machine-types). If unspecified, the default machine type is `e2- # medium`. # 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 reserved keys: - "cluster-location" - "cluster-name" - # "cluster-uid" - "configure-sh" - "containerd-configure-sh" - "enable-oslogin" # - "gci-ensure-gke-docker" - "gci-metrics-enabled" - "gci-update-strategy" - " # instance-template" - "kube-env" - "startup-script" - "user-data" - "disable- # address-manager" - "windows-startup-script-ps1" - "common-psm1" - "k8s-node- # setup-psm1" - "install-ssh-psm1" - "user-profile-psm1" The following keys are # reserved for Windows nodes: - "serial-port-logging-enable" Values are free- # form strings, and only have meaning as interpreted by the image running in the # instance. The only restriction placed on them is that each value's size must # be less than or equal to 32 KB. The total size of all keys and values must be # less than 512 KB. # Corresponds to the JSON property `metadata` # @return [Hash] attr_accessor :metadata # Minimum CPU platform to be used by this instance. The instance may be # scheduled on the specified or newer CPU platform. Applicable values are the # friendly names of CPU platforms, such as `minCpuPlatform: "Intel Haswell"` or ` # minCpuPlatform: "Intel Sandy Bridge"`. For more information, read [how to # specify min CPU platform](https://cloud.google.com/compute/docs/instances/ # specify-min-cpu-platform) # Corresponds to the JSON property `minCpuPlatform` # @return [String] attr_accessor :min_cpu_platform # Setting this field will assign instances of this pool to run on the specified # node group. This is useful for running workloads on [sole tenant nodes](https:/ # /cloud.google.com/compute/docs/nodes/sole-tenant-nodes). # Corresponds to the JSON property `nodeGroup` # @return [String] attr_accessor :node_group # 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 persistent storage on your nodes. * `https:// # www.googleapis.com/auth/devstorage.read_only` is required for communicating # with **gcr.io** (the [Google Container Registry](https://cloud.google.com/ # container-registry/)). If unspecified, no scopes are added, unless Cloud # Logging or Cloud Monitoring are enabled, in which case their required scopes # will be added. # Corresponds to the JSON property `oauthScopes` # @return [Array] attr_accessor :oauth_scopes # Whether the nodes are created as preemptible VM instances. See: https://cloud. # google.com/compute/docs/instances/preemptible for more inforamtion about # preemptible VM instances. # Corresponds to the JSON property `preemptible` # @return [Boolean] attr_accessor :preemptible alias_method :preemptible?, :preemptible # [ReservationAffinity](https://cloud.google.com/compute/docs/instances/ # reserving-zonal-resources) is the configuration of desired reservation which # instances could take capacity from. # Corresponds to the JSON property `reservationAffinity` # @return [Google::Apis::ContainerV1beta1::ReservationAffinity] attr_accessor :reservation_affinity # SandboxConfig contains configurations of the sandbox to use for the node. # Corresponds to the JSON property `sandboxConfig` # @return [Google::Apis::ContainerV1beta1::SandboxConfig] attr_accessor :sandbox_config # The Google Cloud Platform Service Account to be used by the node VMs. Specify # the email address of the Service Account; otherwise, if no Service Account is # specified, the "default" service account is used. # Corresponds to the JSON property `serviceAccount` # @return [String] attr_accessor :service_account # A set of Shielded Instance options. # Corresponds to the JSON property `shieldedInstanceConfig` # @return [Google::Apis::ContainerV1beta1::ShieldedInstanceConfig] attr_accessor :shielded_instance_config # 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] attr_accessor :tags # List of kubernetes taints to be applied to each node. For more information, # including usage and the valid values, see: https://kubernetes.io/docs/concepts/ # configuration/taint-and-toleration/ # Corresponds to the JSON property `taints` # @return [Array] attr_accessor :taints # WorkloadMetadataConfig defines the metadata configuration to expose to # workloads on the node pool. # Corresponds to the JSON property `workloadMetadataConfig` # @return [Google::Apis::ContainerV1beta1::WorkloadMetadataConfig] attr_accessor :workload_metadata_config def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @accelerators = args[:accelerators] if args.key?(:accelerators) @boot_disk_kms_key = args[:boot_disk_kms_key] if args.key?(:boot_disk_kms_key) @disk_size_gb = args[:disk_size_gb] if args.key?(:disk_size_gb) @disk_type = args[:disk_type] if args.key?(:disk_type) @ephemeral_storage_config = args[:ephemeral_storage_config] if args.key?(:ephemeral_storage_config) @image_type = args[:image_type] if args.key?(:image_type) @kubelet_config = args[:kubelet_config] if args.key?(:kubelet_config) @labels = args[:labels] if args.key?(:labels) @linux_node_config = args[:linux_node_config] if args.key?(:linux_node_config) @local_ssd_count = args[:local_ssd_count] if args.key?(:local_ssd_count) @machine_type = args[:machine_type] if args.key?(:machine_type) @metadata = args[:metadata] if args.key?(:metadata) @min_cpu_platform = args[:min_cpu_platform] if args.key?(:min_cpu_platform) @node_group = args[:node_group] if args.key?(:node_group) @oauth_scopes = args[:oauth_scopes] if args.key?(:oauth_scopes) @preemptible = args[:preemptible] if args.key?(:preemptible) @reservation_affinity = args[:reservation_affinity] if args.key?(:reservation_affinity) @sandbox_config = args[:sandbox_config] if args.key?(:sandbox_config) @service_account = args[:service_account] if args.key?(:service_account) @shielded_instance_config = args[:shielded_instance_config] if args.key?(:shielded_instance_config) @tags = args[:tags] if args.key?(:tags) @taints = args[:taints] if args.key?(:taints) @workload_metadata_config = args[:workload_metadata_config] if args.key?(:workload_metadata_config) end end # Node kubelet configs. class NodeKubeletConfig include Google::Apis::Core::Hashable # Enable CPU CFS quota enforcement for containers that specify CPU limits. This # option is enabled by default which makes kubelet use CFS quota (https://www. # kernel.org/doc/Documentation/scheduler/sched-bwc.txt) to enforce container CPU # limits. Otherwise, CPU limits will not be enforced at all. Disable this option # to mitigate CPU throttling problems while still having your pods to be in # Guaranteed QoS class by specifying the CPU limits. The default value is 'true' # if unspecified. # Corresponds to the JSON property `cpuCfsQuota` # @return [Boolean] attr_accessor :cpu_cfs_quota alias_method :cpu_cfs_quota?, :cpu_cfs_quota # Set the CPU CFS quota period value 'cpu.cfs_period_us'. The string must be a # sequence of decimal numbers, each with optional fraction and a unit suffix, # such as "300ms". Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h" # . The value must be a positive duration. # Corresponds to the JSON property `cpuCfsQuotaPeriod` # @return [String] attr_accessor :cpu_cfs_quota_period # Control the CPU management policy on the node. See https://kubernetes.io/docs/ # tasks/administer-cluster/cpu-management-policies/ The following values are # allowed. - "none": the default, which represents the existing scheduling # behavior. - "static": allows pods with certain resource characteristics to be # granted increased CPU affinity and exclusivity on the node. The default value # is 'none' if unspecified. # Corresponds to the JSON property `cpuManagerPolicy` # @return [String] attr_accessor :cpu_manager_policy def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @cpu_cfs_quota = args[:cpu_cfs_quota] if args.key?(:cpu_cfs_quota) @cpu_cfs_quota_period = args[:cpu_cfs_quota_period] if args.key?(:cpu_cfs_quota_period) @cpu_manager_policy = args[:cpu_manager_policy] if args.key?(:cpu_manager_policy) end end # NodeManagement defines the set of node management services turned on for the # node pool. class NodeManagement include Google::Apis::Core::Hashable # Whether the nodes will be automatically repaired. # Corresponds to the JSON property `autoRepair` # @return [Boolean] attr_accessor :auto_repair alias_method :auto_repair?, :auto_repair # Whether the nodes will be automatically upgraded. # 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::ContainerV1beta1::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) 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 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::ContainerV1beta1::NodePoolAutoscaling] attr_accessor :autoscaling # Which conditions caused the current node pool state. # Corresponds to the JSON property `conditions` # @return [Array] attr_accessor :conditions # Parameters that describe the nodes in a cluster. # Corresponds to the JSON property `config` # @return [Google::Apis::ContainerV1beta1::NodeConfig] attr_accessor :config # The initial node count for the pool. You must ensure that your Compute Engine [ # resource quota](https://cloud.google.com/compute/quotas) 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] The resource URLs of the [managed instance groups](https://cloud. # google.com/compute/docs/instance-groups/creating-groups-of-managed-instances) # associated with this node pool. # Corresponds to the JSON property `instanceGroupUrls` # @return [Array] attr_accessor :instance_group_urls # The list of Google Compute Engine [zones](https://cloud.google.com/compute/ # docs/zones#available) in which the NodePool's nodes should be located. If this # value is unspecified during node pool creation, the [Cluster.Locations](https:/ # /cloud.google.com/kubernetes-engine/docs/reference/rest/v1/projects.locations. # clusters#Cluster.FIELDS.locations) value will be used, instead. Warning: # changing node pool locations will result in nodes being added and/or removed. # Corresponds to the JSON property `locations` # @return [Array] attr_accessor :locations # NodeManagement defines the set of node management services turned on for the # node pool. # Corresponds to the JSON property `management` # @return [Google::Apis::ContainerV1beta1::NodeManagement] attr_accessor :management # Constraints applied to pods. # Corresponds to the JSON property `maxPodsConstraint` # @return [Google::Apis::ContainerV1beta1::MaxPodsConstraint] attr_accessor :max_pods_constraint # The name of the node pool. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # [Output only] The pod CIDR block size per node in this node pool. # Corresponds to the JSON property `podIpv4CidrSize` # @return [Fixnum] attr_accessor :pod_ipv4_cidr_size # [Output only] Server-defined URL for the resource. # Corresponds to the JSON property `selfLink` # @return [String] attr_accessor :self_link # [Output only] The status of the nodes in this pool instance. # Corresponds to the JSON property `status` # @return [String] attr_accessor :status # [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 # These upgrade settings control the level of parallelism and the level of # disruption caused by an upgrade. maxUnavailable controls the number of nodes # that can be simultaneously unavailable. maxSurge controls the number of # additional nodes that can be added to the node pool temporarily for the time # of the upgrade to increase the number of available nodes. (maxUnavailable + # maxSurge) determines the level of parallelism (how many nodes are being # upgraded at the same time). Note: upgrades inevitably introduce some # disruption since workloads need to be moved from old nodes to new, upgraded # ones. Even if maxUnavailable=0, this holds true. (Disruption stays within the # limits of PodDisruptionBudget, if it is configured.) Consider a hypothetical # node pool with 5 nodes having maxSurge=2, maxUnavailable=1. This means the # upgrade process upgrades 3 nodes simultaneously. It creates 2 additional ( # upgraded) nodes, then it brings down 3 old (not yet upgraded) nodes at the # same time. This ensures that there are always at least 4 nodes available. # Corresponds to the JSON property `upgradeSettings` # @return [Google::Apis::ContainerV1beta1::UpgradeSettings] attr_accessor :upgrade_settings # 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) @autoscaling = args[:autoscaling] if args.key?(:autoscaling) @conditions = args[:conditions] if args.key?(:conditions) @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) @locations = args[:locations] if args.key?(:locations) @management = args[:management] if args.key?(:management) @max_pods_constraint = args[:max_pods_constraint] if args.key?(:max_pods_constraint) @name = args[:name] if args.key?(:name) @pod_ipv4_cidr_size = args[:pod_ipv4_cidr_size] if args.key?(:pod_ipv4_cidr_size) @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) @upgrade_settings = args[:upgrade_settings] if args.key?(:upgrade_settings) @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 # Can this node pool be deleted automatically. # Corresponds to the JSON property `autoprovisioned` # @return [Boolean] attr_accessor :autoprovisioned alias_method :autoprovisioned?, :autoprovisioned # 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 # Minimum number of nodes in the NodePool. Must be >= 1 and <= max_node_count. # Corresponds to the JSON property `minNodeCount` # @return [Fixnum] attr_accessor :min_node_count def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @autoprovisioned = args[:autoprovisioned] if args.key?(:autoprovisioned) @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) end end # Kubernetes taint is comprised of three fields: key, value, and effect. Effect # can only be one of three types: NoSchedule, PreferNoSchedule or NoExecute. See # [here](https://kubernetes.io/docs/concepts/configuration/taint-and-toleration) # for more information, including usage and the valid values. class NodeTaint include Google::Apis::Core::Hashable # Effect for taint. # Corresponds to the JSON property `effect` # @return [String] attr_accessor :effect # Key for taint. # Corresponds to the JSON property `key` # @return [String] attr_accessor :key # Value for taint. # Corresponds to the JSON property `value` # @return [String] attr_accessor :value def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @effect = args[:effect] if args.key?(:effect) @key = args[:key] if args.key?(:key) @value = args[:value] if args.key?(:value) end end # NotificationConfig is the configuration of notifications. class NotificationConfig include Google::Apis::Core::Hashable # Pub/Sub specific notification config. # Corresponds to the JSON property `pubsub` # @return [Google::Apis::ContainerV1beta1::PubSub] attr_accessor :pubsub def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @pubsub = args[:pubsub] if args.key?(:pubsub) end end # 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 # Which conditions caused the current cluster state. Deprecated. Use field error # instead. # Corresponds to the JSON property `clusterConditions` # @return [Array] attr_accessor :cluster_conditions # Detailed operation progress, if available. # Corresponds to the JSON property `detail` # @return [String] attr_accessor :detail # [Output only] The time the operation completed, in [RFC3339](https://www.ietf. # org/rfc/rfc3339.txt) text format. # Corresponds to the JSON property `endTime` # @return [String] attr_accessor :end_time # The `Status` type defines a logical error model that is suitable for different # programming environments, including REST APIs and RPC APIs. It is used by [ # gRPC](https://github.com/grpc). Each `Status` message contains three pieces of # data: error code, error message, and error details. You can find out more # about this error model and how to work with it in the [API Design Guide](https: # //cloud.google.com/apis/design/errors). # Corresponds to the JSON property `error` # @return [Google::Apis::ContainerV1beta1::Status] attr_accessor :error # [Output only] The name of the Google Compute Engine [zone](https://cloud. # google.com/compute/docs/regions-zones/regions-zones#available) or [region]( # https://cloud.google.com/compute/docs/regions-zones/regions-zones#available) # in which the cluster resides. # Corresponds to the JSON property `location` # @return [String] attr_accessor :location # The server-assigned ID for the operation. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Which conditions caused the current node pool state. Deprecated. Use field # error instead. # Corresponds to the JSON property `nodepoolConditions` # @return [Array] attr_accessor :nodepool_conditions # The operation type. # Corresponds to the JSON property `operationType` # @return [String] attr_accessor :operation_type # Information about operation (or operation stage) progress. # Corresponds to the JSON property `progress` # @return [Google::Apis::ContainerV1beta1::OperationProgress] attr_accessor :progress # Server-defined URL for the resource. # Corresponds to the JSON property `selfLink` # @return [String] attr_accessor :self_link # [Output only] The time the operation started, in [RFC3339](https://www.ietf. # org/rfc/rfc3339.txt) text format. # Corresponds to the JSON property `startTime` # @return [String] attr_accessor :start_time # The current status of the operation. # Corresponds to the JSON property `status` # @return [String] attr_accessor :status # Output only. If an error has occurred, a textual description of the error. # Deprecated. Use field error instead. # Corresponds to the JSON property `statusMessage` # @return [String] attr_accessor :status_message # Server-defined URL for the target of the operation. # Corresponds to the JSON property `targetLink` # @return [String] attr_accessor :target_link # The name of the Google Compute Engine [zone](https://cloud.google.com/compute/ # docs/zones#available) in which the operation is taking place. This field is # deprecated, use location instead. # 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) @cluster_conditions = args[:cluster_conditions] if args.key?(:cluster_conditions) @detail = args[:detail] if args.key?(:detail) @end_time = args[:end_time] if args.key?(:end_time) @error = args[:error] if args.key?(:error) @location = args[:location] if args.key?(:location) @name = args[:name] if args.key?(:name) @nodepool_conditions = args[:nodepool_conditions] if args.key?(:nodepool_conditions) @operation_type = args[:operation_type] if args.key?(:operation_type) @progress = args[:progress] if args.key?(:progress) @self_link = args[:self_link] if args.key?(:self_link) @start_time = args[:start_time] if args.key?(:start_time) @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 # Information about operation (or operation stage) progress. class OperationProgress include Google::Apis::Core::Hashable # Progress metric bundle, for example: metrics: [`name: "nodes done", int_value: # 15`, `name: "nodes total", int_value: 32`] or metrics: [`name: "progress", # double_value: 0.56`, `name: "progress scale", double_value: 1.0`] # Corresponds to the JSON property `metrics` # @return [Array] attr_accessor :metrics # A non-parameterized string describing an operation stage. Unset for single- # stage operations. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Substages of an operation or a stage. # Corresponds to the JSON property `stages` # @return [Array] attr_accessor :stages # Status of an operation stage. Unset for single-stage operations. # Corresponds to the JSON property `status` # @return [String] attr_accessor :status def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @metrics = args[:metrics] if args.key?(:metrics) @name = args[:name] if args.key?(:name) @stages = args[:stages] if args.key?(:stages) @status = args[:status] if args.key?(:status) end end # Configuration for the PodSecurityPolicy feature. class PodSecurityPolicyConfig include Google::Apis::Core::Hashable # Enable the PodSecurityPolicy controller for this cluster. If enabled, pods # must be valid under a PodSecurityPolicy to be created. # 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 # Configuration options for private clusters. class PrivateClusterConfig include Google::Apis::Core::Hashable # Whether the master's internal IP address is used as the cluster endpoint. # Corresponds to the JSON property `enablePrivateEndpoint` # @return [Boolean] attr_accessor :enable_private_endpoint alias_method :enable_private_endpoint?, :enable_private_endpoint # Whether nodes have internal IP addresses only. If enabled, all nodes are given # only RFC 1918 private addresses and communicate with the master via private # networking. # Corresponds to the JSON property `enablePrivateNodes` # @return [Boolean] attr_accessor :enable_private_nodes alias_method :enable_private_nodes?, :enable_private_nodes # Configuration for controlling master global access settings. # Corresponds to the JSON property `masterGlobalAccessConfig` # @return [Google::Apis::ContainerV1beta1::PrivateClusterMasterGlobalAccessConfig] attr_accessor :master_global_access_config # The IP range in CIDR notation to use for the hosted master network. This range # will be used for assigning internal IP addresses to the master or set of # masters, as well as the ILB VIP. This range must not overlap with any other # ranges in use within the cluster's network. # Corresponds to the JSON property `masterIpv4CidrBlock` # @return [String] attr_accessor :master_ipv4_cidr_block # Output only. The peering name in the customer VPC used by this cluster. # Corresponds to the JSON property `peeringName` # @return [String] attr_accessor :peering_name # Output only. The internal IP address of this cluster's master endpoint. # Corresponds to the JSON property `privateEndpoint` # @return [String] attr_accessor :private_endpoint # Output only. The external IP address of this cluster's master endpoint. # Corresponds to the JSON property `publicEndpoint` # @return [String] attr_accessor :public_endpoint def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @enable_private_endpoint = args[:enable_private_endpoint] if args.key?(:enable_private_endpoint) @enable_private_nodes = args[:enable_private_nodes] if args.key?(:enable_private_nodes) @master_global_access_config = args[:master_global_access_config] if args.key?(:master_global_access_config) @master_ipv4_cidr_block = args[:master_ipv4_cidr_block] if args.key?(:master_ipv4_cidr_block) @peering_name = args[:peering_name] if args.key?(:peering_name) @private_endpoint = args[:private_endpoint] if args.key?(:private_endpoint) @public_endpoint = args[:public_endpoint] if args.key?(:public_endpoint) end end # Configuration for controlling master global access settings. class PrivateClusterMasterGlobalAccessConfig include Google::Apis::Core::Hashable # Whenever master is accessible globally or not. # 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 # Pub/Sub specific notification config. class PubSub include Google::Apis::Core::Hashable # Enable notifications for Pub/Sub. # Corresponds to the JSON property `enabled` # @return [Boolean] attr_accessor :enabled alias_method :enabled?, :enabled # The desired Pub/Sub topic to which notifications will be sent by GKE. Format # is `projects/`project`/topics/`topic``. # Corresponds to the JSON property `topic` # @return [String] attr_accessor :topic def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @enabled = args[:enabled] if args.key?(:enabled) @topic = args[:topic] if args.key?(:topic) end end # Represents an arbitrary window of time that recurs. class RecurringTimeWindow include Google::Apis::Core::Hashable # An RRULE (https://tools.ietf.org/html/rfc5545#section-3.8.5.3) for how this # window reccurs. They go on for the span of time between the start and end time. # For example, to have something repeat every weekday, you'd use: `FREQ=WEEKLY; # BYDAY=MO,TU,WE,TH,FR` To repeat some window daily (equivalent to the # DailyMaintenanceWindow): `FREQ=DAILY` For the first weekend of every month: ` # FREQ=MONTHLY;BYSETPOS=1;BYDAY=SA,SU` This specifies how frequently the window # starts. Eg, if you wanted to have a 9-5 UTC-4 window every weekday, you'd use # something like: ``` start time = 2019-01-01T09:00:00-0400 end time = 2019-01- # 01T17:00:00-0400 recurrence = FREQ=WEEKLY;BYDAY=MO,TU,WE,TH,FR ``` Windows can # span multiple days. Eg, to make the window encompass every weekend from # midnight Saturday till the last minute of Sunday UTC: ``` start time = 2019-01- # 05T00:00:00Z end time = 2019-01-07T23:59:00Z recurrence = FREQ=WEEKLY;BYDAY=SA # ``` Note the start and end time's specific dates are largely arbitrary except # to specify duration of the window and when it first starts. The FREQ values of # HOURLY, MINUTELY, and SECONDLY are not supported. # Corresponds to the JSON property `recurrence` # @return [String] attr_accessor :recurrence # Represents an arbitrary window of time. # Corresponds to the JSON property `window` # @return [Google::Apis::ContainerV1beta1::TimeWindow] attr_accessor :window def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @recurrence = args[:recurrence] if args.key?(:recurrence) @window = args[:window] if args.key?(:window) end end # ReleaseChannel indicates which release channel a cluster is subscribed to. # Release channels are arranged in order of risk. When a cluster is subscribed # to a release channel, Google maintains both the master version and the node # version. Node auto-upgrade defaults to true and cannot be disabled. class ReleaseChannel include Google::Apis::Core::Hashable # channel specifies which release channel the cluster is subscribed to. # Corresponds to the JSON property `channel` # @return [String] attr_accessor :channel def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @channel = args[:channel] if args.key?(:channel) end end # ReleaseChannelConfig exposes configuration for a release channel. class ReleaseChannelConfig include Google::Apis::Core::Hashable # Deprecated. This field has been deprecated and replaced with the # valid_versions field. # Corresponds to the JSON property `availableVersions` # @return [Array] attr_accessor :available_versions # The release channel this configuration applies to. # Corresponds to the JSON property `channel` # @return [String] attr_accessor :channel # The default version for newly created clusters on the channel. # Corresponds to the JSON property `defaultVersion` # @return [String] attr_accessor :default_version # List of valid versions for the channel. # Corresponds to the JSON property `validVersions` # @return [Array] attr_accessor :valid_versions def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @available_versions = args[:available_versions] if args.key?(:available_versions) @channel = args[:channel] if args.key?(:channel) @default_version = args[:default_version] if args.key?(:default_version) @valid_versions = args[:valid_versions] if args.key?(:valid_versions) end end # [ReservationAffinity](https://cloud.google.com/compute/docs/instances/ # reserving-zonal-resources) is the configuration of desired reservation which # instances could take capacity from. class ReservationAffinity include Google::Apis::Core::Hashable # Corresponds to the type of reservation consumption. # Corresponds to the JSON property `consumeReservationType` # @return [String] attr_accessor :consume_reservation_type # Corresponds to the label key of a reservation resource. To target a # SPECIFIC_RESERVATION by name, specify "googleapis.com/reservation-name" as the # key and specify the name of your reservation as its value. # Corresponds to the JSON property `key` # @return [String] attr_accessor :key # Corresponds to the label value(s) of reservation resource(s). # Corresponds to the JSON property `values` # @return [Array] attr_accessor :values def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @consume_reservation_type = args[:consume_reservation_type] if args.key?(:consume_reservation_type) @key = args[:key] if args.key?(:key) @values = args[:values] if args.key?(:values) end end # Contains information about amount of some resource in the cluster. For memory, # value should be in GB. class ResourceLimit include Google::Apis::Core::Hashable # Maximum amount of the resource in the cluster. # Corresponds to the JSON property `maximum` # @return [Fixnum] attr_accessor :maximum # Minimum amount of the resource in the cluster. # Corresponds to the JSON property `minimum` # @return [Fixnum] attr_accessor :minimum # Resource name "cpu", "memory" or gpu-specific string. # Corresponds to the JSON property `resourceType` # @return [String] attr_accessor :resource_type def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @maximum = args[:maximum] if args.key?(:maximum) @minimum = args[:minimum] if args.key?(:minimum) @resource_type = args[:resource_type] if args.key?(:resource_type) end end # Configuration for exporting cluster resource usages. class ResourceUsageExportConfig include Google::Apis::Core::Hashable # Parameters for using BigQuery as the destination of resource usage export. # Corresponds to the JSON property `bigqueryDestination` # @return [Google::Apis::ContainerV1beta1::BigQueryDestination] attr_accessor :bigquery_destination # Parameters for controlling consumption metering. # Corresponds to the JSON property `consumptionMeteringConfig` # @return [Google::Apis::ContainerV1beta1::ConsumptionMeteringConfig] attr_accessor :consumption_metering_config # Whether to enable network egress metering for this cluster. If enabled, a # daemonset will be created in the cluster to meter network egress traffic. # Corresponds to the JSON property `enableNetworkEgressMetering` # @return [Boolean] attr_accessor :enable_network_egress_metering alias_method :enable_network_egress_metering?, :enable_network_egress_metering def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @bigquery_destination = args[:bigquery_destination] if args.key?(:bigquery_destination) @consumption_metering_config = args[:consumption_metering_config] if args.key?(:consumption_metering_config) @enable_network_egress_metering = args[:enable_network_egress_metering] if args.key?(:enable_network_egress_metering) 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 include Google::Apis::Core::Hashable # Required. Deprecated. The name of the cluster to rollback. This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # The name (project, location, cluster, node pool id) of the node poll to # rollback upgrade. Specified in the format `projects/*/locations/*/clusters/*/ # nodePools/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. Deprecated. The name of the node pool to rollback. This field has # been deprecated and replaced by the name field. # Corresponds to the JSON property `nodePoolId` # @return [String] attr_accessor :node_pool_id # Required. Deprecated. The Google Developers Console [project ID or project # number](https://support.google.com/cloud/answer/6158840). This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @name = args[:name] if args.key?(:name) @node_pool_id = args[:node_pool_id] if args.key?(:node_pool_id) @project_id = args[:project_id] if args.key?(:project_id) @zone = args[:zone] if args.key?(:zone) end end # SandboxConfig contains configurations of the sandbox to use for the node. class SandboxConfig include Google::Apis::Core::Hashable # Type of the sandbox to use for the node (e.g. 'gvisor') # Corresponds to the JSON property `sandboxType` # @return [String] attr_accessor :sandbox_type # Type of the sandbox to use for the node. # Corresponds to the JSON property `type` # @return [String] attr_accessor :type def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @sandbox_type = args[:sandbox_type] if args.key?(:sandbox_type) @type = args[:type] if args.key?(:type) end end # Kubernetes Engine service configuration. class ServerConfig include Google::Apis::Core::Hashable # List of release channel configurations. # Corresponds to the JSON property `channels` # @return [Array] attr_accessor :channels # Version of Kubernetes the service deploys by default. # Corresponds to the JSON property `defaultClusterVersion` # @return [String] attr_accessor :default_cluster_version # Default image type. # Corresponds to the JSON property `defaultImageType` # @return [String] attr_accessor :default_image_type # List of valid image types. # Corresponds to the JSON property `validImageTypes` # @return [Array] attr_accessor :valid_image_types # List of valid master versions, in descending order. # Corresponds to the JSON property `validMasterVersions` # @return [Array] attr_accessor :valid_master_versions # List of valid node upgrade target versions, in descending order. # Corresponds to the JSON property `validNodeVersions` # @return [Array] attr_accessor :valid_node_versions def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @channels = args[:channels] if args.key?(:channels) @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 # SetAddonsRequest sets the addons associated with the cluster. class SetAddonsConfigRequest 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::ContainerV1beta1::AddonsConfig] attr_accessor :addons_config # Required. Deprecated. The name of the cluster to upgrade. This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # The name (project, location, cluster) of the cluster to set addons. Specified # in the format `projects/*/locations/*/clusters/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. Deprecated. The Google Developers Console [project ID or project # number](https://support.google.com/cloud/answer/6158840). This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @addons_config = args[:addons_config] if args.key?(:addons_config) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @name = args[:name] if args.key?(:name) @project_id = args[:project_id] if args.key?(:project_id) @zone = args[:zone] if args.key?(:zone) 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 include Google::Apis::Core::Hashable # Required. Deprecated. The name of the cluster. This field has been deprecated # and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # Required. The fingerprint of the previous set of labels for this resource, # used to detect conflicts. The fingerprint is initially generated by Kubernetes # 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 `get()` request to the resource to get the latest fingerprint. # Corresponds to the JSON property `labelFingerprint` # @return [String] attr_accessor :label_fingerprint # The name (project, location, cluster id) of the cluster to set labels. # Specified in the format `projects/*/locations/*/clusters/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. Deprecated. The Google Developers Console [project ID or project # number](https://developers.google.com/console/help/new/#projectnumber). This # field has been deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. The labels to set for that cluster. # Corresponds to the JSON property `resourceLabels` # @return [Hash] attr_accessor :resource_labels # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint) @name = args[:name] if args.key?(:name) @project_id = args[:project_id] if args.key?(:project_id) @resource_labels = args[:resource_labels] if args.key?(:resource_labels) @zone = args[:zone] if args.key?(:zone) end end # SetLegacyAbacRequest enables or disables the ABAC authorization mechanism for # a cluster. class SetLegacyAbacRequest include Google::Apis::Core::Hashable # Required. Deprecated. The name of the cluster to update. This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # Required. Whether ABAC authorization will be enabled in the cluster. # Corresponds to the JSON property `enabled` # @return [Boolean] attr_accessor :enabled alias_method :enabled?, :enabled # The name (project, location, cluster id) of the cluster to set legacy abac. # Specified in the format `projects/*/locations/*/clusters/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. Deprecated. The Google Developers Console [project ID or project # number](https://support.google.com/cloud/answer/6158840). This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @enabled = args[:enabled] if args.key?(:enabled) @name = args[:name] if args.key?(:name) @project_id = args[:project_id] if args.key?(:project_id) @zone = args[:zone] if args.key?(:zone) end end # SetLocationsRequest sets the locations of the cluster. class SetLocationsRequest include Google::Apis::Core::Hashable # Required. Deprecated. The name of the cluster to upgrade. This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # Required. The desired list of Google Compute Engine [zones](https://cloud. # google.com/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] attr_accessor :locations # The name (project, location, cluster) of the cluster to set locations. # Specified in the format `projects/*/locations/*/clusters/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. Deprecated. The Google Developers Console [project ID or project # number](https://support.google.com/cloud/answer/6158840). This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @locations = args[:locations] if args.key?(:locations) @name = args[:name] if args.key?(:name) @project_id = args[:project_id] if args.key?(:project_id) @zone = args[:zone] if args.key?(:zone) end end # SetLoggingServiceRequest sets the logging service of a cluster. class SetLoggingServiceRequest include Google::Apis::Core::Hashable # Required. Deprecated. The name of the cluster to upgrade. This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # Required. The logging service the cluster should use to write logs. Currently # available options: * `logging.googleapis.com/kubernetes` - The Cloud Logging # service with a Kubernetes-native resource model * `logging.googleapis.com` - # The legacy Cloud Logging service (no longer available as of GKE 1.15). * `none` # - no logs will be exported from the cluster. If left as an empty string,` # logging.googleapis.com/kubernetes` will be used for GKE 1.14+ or `logging. # googleapis.com` for earlier versions. # Corresponds to the JSON property `loggingService` # @return [String] attr_accessor :logging_service # The name (project, location, cluster) of the cluster to set logging. Specified # in the format `projects/*/locations/*/clusters/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. Deprecated. The Google Developers Console [project ID or project # number](https://support.google.com/cloud/answer/6158840). This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @logging_service = args[:logging_service] if args.key?(:logging_service) @name = args[:name] if args.key?(:name) @project_id = args[:project_id] if args.key?(:project_id) @zone = args[:zone] if args.key?(:zone) end end # SetMaintenancePolicyRequest sets the maintenance policy for a cluster. class SetMaintenancePolicyRequest include Google::Apis::Core::Hashable # Required. The name of the cluster to update. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # MaintenancePolicy defines the maintenance policy to be used for the cluster. # Corresponds to the JSON property `maintenancePolicy` # @return [Google::Apis::ContainerV1beta1::MaintenancePolicy] attr_accessor :maintenance_policy # The name (project, location, cluster id) of the cluster to set maintenance # policy. Specified in the format `projects/*/locations/*/clusters/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. The Google Developers Console [project ID or project number](https:// # support.google.com/cloud/answer/6158840). # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. The name of the Google Compute Engine [zone](https://cloud.google. # com/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) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @maintenance_policy = args[:maintenance_policy] if args.key?(:maintenance_policy) @name = args[:name] if args.key?(:name) @project_id = args[:project_id] if args.key?(:project_id) @zone = args[:zone] if args.key?(:zone) end end # SetMasterAuthRequest updates the admin password of a cluster. class SetMasterAuthRequest include Google::Apis::Core::Hashable # Required. The exact form of action to be taken on the master auth. # Corresponds to the JSON property `action` # @return [String] attr_accessor :action # Required. Deprecated. The name of the cluster to upgrade. This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # The name (project, location, cluster) of the cluster to set auth. Specified in # the format `projects/*/locations/*/clusters/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. Deprecated. The Google Developers Console [project ID or project # number](https://support.google.com/cloud/answer/6158840). This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # 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::ContainerV1beta1::MasterAuth] attr_accessor :update # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @action = args[:action] if args.key?(:action) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @name = args[:name] if args.key?(:name) @project_id = args[:project_id] if args.key?(:project_id) @update = args[:update] if args.key?(:update) @zone = args[:zone] if args.key?(:zone) end end # SetMonitoringServiceRequest sets the monitoring service of a cluster. class SetMonitoringServiceRequest include Google::Apis::Core::Hashable # Required. Deprecated. The name of the cluster to upgrade. This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # Required. The monitoring service the cluster should use to write metrics. # Currently available options: * "monitoring.googleapis.com/kubernetes" - The # Cloud Monitoring service with a Kubernetes-native resource model * `monitoring. # googleapis.com` - The legacy Cloud Monitoring service (no longer available as # of GKE 1.15). * `none` - No metrics will be exported from the cluster. If left # as an empty string,`monitoring.googleapis.com/kubernetes` will be used for GKE # 1.14+ or `monitoring.googleapis.com` for earlier versions. # Corresponds to the JSON property `monitoringService` # @return [String] attr_accessor :monitoring_service # The name (project, location, cluster) of the cluster to set monitoring. # Specified in the format `projects/*/locations/*/clusters/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. Deprecated. The Google Developers Console [project ID or project # number](https://support.google.com/cloud/answer/6158840). This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @monitoring_service = args[:monitoring_service] if args.key?(:monitoring_service) @name = args[:name] if args.key?(:name) @project_id = args[:project_id] if args.key?(:project_id) @zone = args[:zone] if args.key?(:zone) end end # SetNetworkPolicyRequest enables/disables network policy for a cluster. class SetNetworkPolicyRequest include Google::Apis::Core::Hashable # Required. Deprecated. The name of the cluster. This field has been deprecated # and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # The name (project, location, cluster id) of the cluster to set networking # policy. Specified in the format `projects/*/locations/*/clusters/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Configuration options for the NetworkPolicy feature. https://kubernetes.io/ # docs/concepts/services-networking/networkpolicies/ # Corresponds to the JSON property `networkPolicy` # @return [Google::Apis::ContainerV1beta1::NetworkPolicy] attr_accessor :network_policy # Required. Deprecated. The Google Developers Console [project ID or project # number](https://developers.google.com/console/help/new/#projectnumber). This # field has been deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @name = args[:name] if args.key?(:name) @network_policy = args[:network_policy] if args.key?(:network_policy) @project_id = args[:project_id] if args.key?(:project_id) @zone = args[:zone] if args.key?(:zone) end end # SetNodePoolAutoscalingRequest sets the autoscaler settings of a node pool. class SetNodePoolAutoscalingRequest 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::ContainerV1beta1::NodePoolAutoscaling] attr_accessor :autoscaling # Required. Deprecated. The name of the cluster to upgrade. This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # The name (project, location, cluster, node pool) of the node pool to set # autoscaler settings. Specified in the format `projects/*/locations/*/clusters/* # /nodePools/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. Deprecated. The name of the node pool to upgrade. This field has # been deprecated and replaced by the name field. # Corresponds to the JSON property `nodePoolId` # @return [String] attr_accessor :node_pool_id # Required. Deprecated. The Google Developers Console [project ID or project # number](https://support.google.com/cloud/answer/6158840). This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @autoscaling = args[:autoscaling] if args.key?(:autoscaling) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @name = args[:name] if args.key?(:name) @node_pool_id = args[:node_pool_id] if args.key?(:node_pool_id) @project_id = args[:project_id] if args.key?(:project_id) @zone = args[:zone] if args.key?(:zone) end end # SetNodePoolManagementRequest sets the node management properties of a node # pool. class SetNodePoolManagementRequest include Google::Apis::Core::Hashable # Required. Deprecated. The name of the cluster to update. This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # NodeManagement defines the set of node management services turned on for the # node pool. # Corresponds to the JSON property `management` # @return [Google::Apis::ContainerV1beta1::NodeManagement] attr_accessor :management # The name (project, location, cluster, node pool id) of the node pool to set # management properties. Specified in the format `projects/*/locations/*/ # clusters/*/nodePools/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. Deprecated. The name of the node pool to update. This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `nodePoolId` # @return [String] attr_accessor :node_pool_id # Required. Deprecated. The Google Developers Console [project ID or project # number](https://support.google.com/cloud/answer/6158840). This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @management = args[:management] if args.key?(:management) @name = args[:name] if args.key?(:name) @node_pool_id = args[:node_pool_id] if args.key?(:node_pool_id) @project_id = args[:project_id] if args.key?(:project_id) @zone = args[:zone] if args.key?(:zone) end end # SetNodePoolSizeRequest sets the size a node pool. class SetNodePoolSizeRequest include Google::Apis::Core::Hashable # Required. Deprecated. The name of the cluster to update. This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # The name (project, location, cluster, node pool id) of the node pool to set # size. Specified in the format `projects/*/locations/*/clusters/*/nodePools/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. The desired node count for the pool. # Corresponds to the JSON property `nodeCount` # @return [Fixnum] attr_accessor :node_count # Required. Deprecated. The name of the node pool to update. This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `nodePoolId` # @return [String] attr_accessor :node_pool_id # Required. Deprecated. The Google Developers Console [project ID or project # number](https://support.google.com/cloud/answer/6158840). This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @name = args[:name] if args.key?(:name) @node_count = args[:node_count] if args.key?(:node_count) @node_pool_id = args[:node_pool_id] if args.key?(:node_pool_id) @project_id = args[:project_id] if args.key?(:project_id) @zone = args[:zone] if args.key?(:zone) end end # A set of Shielded Instance options. class ShieldedInstanceConfig include Google::Apis::Core::Hashable # Defines whether the instance has integrity monitoring enabled. Enables # monitoring and attestation of the boot integrity of the instance. The # attestation is performed against the integrity policy baseline. This baseline # is initially derived from the implicitly trusted boot image when the instance # is created. # Corresponds to the JSON property `enableIntegrityMonitoring` # @return [Boolean] attr_accessor :enable_integrity_monitoring alias_method :enable_integrity_monitoring?, :enable_integrity_monitoring # Defines whether the instance has Secure Boot enabled. Secure Boot helps ensure # that the system only runs authentic software by verifying the digital # signature of all boot components, and halting the boot process if signature # verification fails. # Corresponds to the JSON property `enableSecureBoot` # @return [Boolean] attr_accessor :enable_secure_boot alias_method :enable_secure_boot?, :enable_secure_boot def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @enable_integrity_monitoring = args[:enable_integrity_monitoring] if args.key?(:enable_integrity_monitoring) @enable_secure_boot = args[:enable_secure_boot] if args.key?(:enable_secure_boot) end end # Configuration of Shielded Nodes feature. class ShieldedNodes include Google::Apis::Core::Hashable # Whether Shielded Nodes features are enabled on all nodes in this 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) @enabled = args[:enabled] if args.key?(:enabled) 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 # Required. Deprecated. The name of the cluster. This field has been deprecated # and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # The name (project, location, cluster id) of the cluster to start IP rotation. # Specified in the format `projects/*/locations/*/clusters/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. Deprecated. The Google Developers Console [project ID or project # number](https://developers.google.com/console/help/new/#projectnumber). This # field has been deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Whether to rotate credentials during IP rotation. # Corresponds to the JSON property `rotateCredentials` # @return [Boolean] attr_accessor :rotate_credentials alias_method :rotate_credentials?, :rotate_credentials # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @name = args[:name] if args.key?(:name) @project_id = args[:project_id] if args.key?(:project_id) @rotate_credentials = args[:rotate_credentials] if args.key?(:rotate_credentials) @zone = args[:zone] if args.key?(:zone) end end # The `Status` type defines a logical error model that is suitable for different # programming environments, including REST APIs and RPC APIs. It is used by [ # gRPC](https://github.com/grpc). Each `Status` message contains three pieces of # data: error code, error message, and error details. You can find out more # about this error model and how to work with it in the [API Design Guide](https: # //cloud.google.com/apis/design/errors). class Status include Google::Apis::Core::Hashable # The status code, which should be an enum value of google.rpc.Code. # Corresponds to the JSON property `code` # @return [Fixnum] attr_accessor :code # A list of messages that carry the error details. There is a common set of # message types for APIs to use. # Corresponds to the JSON property `details` # @return [Array>] attr_accessor :details # A developer-facing error message, which should be in English. Any user-facing # error message should be localized and sent in the google.rpc.Status.details # field, or localized by the client. # Corresponds to the JSON property `message` # @return [String] attr_accessor :message def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @code = args[:code] if args.key?(:code) @details = args[:details] if args.key?(:details) @message = args[:message] if args.key?(:message) end end # StatusCondition describes why a cluster or a node pool has a certain status (e. # g., ERROR or DEGRADED). class StatusCondition include Google::Apis::Core::Hashable # Canonical code of the condition. # Corresponds to the JSON property `canonicalCode` # @return [String] attr_accessor :canonical_code # Machine-friendly representation of the condition Deprecated. Use # canonical_code instead. # Corresponds to the JSON property `code` # @return [String] attr_accessor :code # Human-friendly representation of the condition # Corresponds to the JSON property `message` # @return [String] attr_accessor :message def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @canonical_code = args[:canonical_code] if args.key?(:canonical_code) @code = args[:code] if args.key?(:code) @message = args[:message] if args.key?(:message) end end # Represents an arbitrary window of time. class TimeWindow include Google::Apis::Core::Hashable # The time that the window ends. The end time should take place after the start # time. # Corresponds to the JSON property `endTime` # @return [String] attr_accessor :end_time # The time that the window first starts. # Corresponds to the JSON property `startTime` # @return [String] attr_accessor :start_time def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @end_time = args[:end_time] if args.key?(:end_time) @start_time = args[:start_time] if args.key?(:start_time) end end # Configuration for Cloud TPU. class TpuConfig include Google::Apis::Core::Hashable # Whether Cloud TPU integration is enabled or not. # Corresponds to the JSON property `enabled` # @return [Boolean] attr_accessor :enabled alias_method :enabled?, :enabled # IPv4 CIDR block reserved for Cloud TPU in the VPC. # Corresponds to the JSON property `ipv4CidrBlock` # @return [String] attr_accessor :ipv4_cidr_block # Whether to use service networking for Cloud TPU or not. # Corresponds to the JSON property `useServiceNetworking` # @return [Boolean] attr_accessor :use_service_networking alias_method :use_service_networking?, :use_service_networking def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @enabled = args[:enabled] if args.key?(:enabled) @ipv4_cidr_block = args[:ipv4_cidr_block] if args.key?(:ipv4_cidr_block) @use_service_networking = args[:use_service_networking] if args.key?(:use_service_networking) end end # UpdateClusterRequest updates the settings of a cluster. class UpdateClusterRequest include Google::Apis::Core::Hashable # Required. Deprecated. The name of the cluster to upgrade. This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # The name (project, location, cluster) of the cluster to update. Specified in # the format `projects/*/locations/*/clusters/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. Deprecated. The Google Developers Console [project ID or project # number](https://support.google.com/cloud/answer/6158840). This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # 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::ContainerV1beta1::ClusterUpdate] attr_accessor :update # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @name = args[:name] if args.key?(:name) @project_id = args[:project_id] if args.key?(:project_id) @update = args[:update] if args.key?(:update) @zone = args[:zone] if args.key?(:zone) end end # UpdateMasterRequest updates the master of the cluster. class UpdateMasterRequest include Google::Apis::Core::Hashable # Required. Deprecated. The name of the cluster to upgrade. This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # Required. The Kubernetes version to change the master to. Users may specify # either explicit versions offered by Kubernetes Engine or version aliases, # which have the following behavior: - "latest": picks the highest valid # Kubernetes version - "1.X": picks the highest valid patch+gke.N patch in the 1. # X version - "1.X.Y": picks the highest valid gke.N patch in the 1.X.Y version - # "1.X.Y-gke.N": picks an explicit Kubernetes version - "-": picks the default # Kubernetes version # Corresponds to the JSON property `masterVersion` # @return [String] attr_accessor :master_version # The name (project, location, cluster) of the cluster to update. Specified in # the format `projects/*/locations/*/clusters/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. Deprecated. The Google Developers Console [project ID or project # number](https://support.google.com/cloud/answer/6158840). This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @master_version = args[:master_version] if args.key?(:master_version) @name = args[:name] if args.key?(:name) @project_id = args[:project_id] if args.key?(:project_id) @zone = args[:zone] if args.key?(:zone) end end # SetNodePoolVersionRequest updates the version of a node pool. class UpdateNodePoolRequest include Google::Apis::Core::Hashable # Required. Deprecated. The name of the cluster to upgrade. This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `clusterId` # @return [String] attr_accessor :cluster_id # Required. The desired image type for the node pool. # Corresponds to the JSON property `imageType` # @return [String] attr_accessor :image_type # Node kubelet configs. # Corresponds to the JSON property `kubeletConfig` # @return [Google::Apis::ContainerV1beta1::NodeKubeletConfig] attr_accessor :kubelet_config # Parameters that can be configured on Linux nodes. # Corresponds to the JSON property `linuxNodeConfig` # @return [Google::Apis::ContainerV1beta1::LinuxNodeConfig] attr_accessor :linux_node_config # The desired list of Google Compute Engine [zones](https://cloud.google.com/ # compute/docs/zones#available) in which the node pool's nodes should be located. # Changing the locations for a node pool will result in nodes being either # created or removed from the node pool, depending on whether locations are # being added or removed. # Corresponds to the JSON property `locations` # @return [Array] attr_accessor :locations # The name (project, location, cluster, node pool) of the node pool to update. # Specified in the format `projects/*/locations/*/clusters/*/nodePools/*`. # Corresponds to the JSON property `name` # @return [String] attr_accessor :name # Required. Deprecated. The name of the node pool to upgrade. This field has # been deprecated and replaced by the name field. # Corresponds to the JSON property `nodePoolId` # @return [String] attr_accessor :node_pool_id # Required. The Kubernetes version to change the nodes to (typically an upgrade). # Users may specify either explicit versions offered by Kubernetes Engine or # version aliases, which have the following behavior: - "latest": picks the # highest valid Kubernetes version - "1.X": picks the highest valid patch+gke.N # patch in the 1.X version - "1.X.Y": picks the highest valid gke.N patch in the # 1.X.Y version - "1.X.Y-gke.N": picks an explicit Kubernetes version - "-": # picks the Kubernetes master version # Corresponds to the JSON property `nodeVersion` # @return [String] attr_accessor :node_version # Required. Deprecated. The Google Developers Console [project ID or project # number](https://support.google.com/cloud/answer/6158840). This field has been # deprecated and replaced by the name field. # Corresponds to the JSON property `projectId` # @return [String] attr_accessor :project_id # These upgrade settings control the level of parallelism and the level of # disruption caused by an upgrade. maxUnavailable controls the number of nodes # that can be simultaneously unavailable. maxSurge controls the number of # additional nodes that can be added to the node pool temporarily for the time # of the upgrade to increase the number of available nodes. (maxUnavailable + # maxSurge) determines the level of parallelism (how many nodes are being # upgraded at the same time). Note: upgrades inevitably introduce some # disruption since workloads need to be moved from old nodes to new, upgraded # ones. Even if maxUnavailable=0, this holds true. (Disruption stays within the # limits of PodDisruptionBudget, if it is configured.) Consider a hypothetical # node pool with 5 nodes having maxSurge=2, maxUnavailable=1. This means the # upgrade process upgrades 3 nodes simultaneously. It creates 2 additional ( # upgraded) nodes, then it brings down 3 old (not yet upgraded) nodes at the # same time. This ensures that there are always at least 4 nodes available. # Corresponds to the JSON property `upgradeSettings` # @return [Google::Apis::ContainerV1beta1::UpgradeSettings] attr_accessor :upgrade_settings # WorkloadMetadataConfig defines the metadata configuration to expose to # workloads on the node pool. # Corresponds to the JSON property `workloadMetadataConfig` # @return [Google::Apis::ContainerV1beta1::WorkloadMetadataConfig] attr_accessor :workload_metadata_config # Required. Deprecated. The name of the Google Compute Engine [zone](https:// # cloud.google.com/compute/docs/zones#available) in which the cluster resides. # This field has been deprecated and replaced by the name field. # 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) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @image_type = args[:image_type] if args.key?(:image_type) @kubelet_config = args[:kubelet_config] if args.key?(:kubelet_config) @linux_node_config = args[:linux_node_config] if args.key?(:linux_node_config) @locations = args[:locations] if args.key?(:locations) @name = args[:name] if args.key?(:name) @node_pool_id = args[:node_pool_id] if args.key?(:node_pool_id) @node_version = args[:node_version] if args.key?(:node_version) @project_id = args[:project_id] if args.key?(:project_id) @upgrade_settings = args[:upgrade_settings] if args.key?(:upgrade_settings) @workload_metadata_config = args[:workload_metadata_config] if args.key?(:workload_metadata_config) @zone = args[:zone] if args.key?(:zone) end end # UpgradeEvent is a notification sent to customers by the cluster server when a # resource is upgrading. class UpgradeEvent include Google::Apis::Core::Hashable # Required. The current version before the upgrade. # Corresponds to the JSON property `currentVersion` # @return [String] attr_accessor :current_version # Required. The operation associated with this upgrade. # Corresponds to the JSON property `operation` # @return [String] attr_accessor :operation # Required. The time when the operation was started. # Corresponds to the JSON property `operationStartTime` # @return [String] attr_accessor :operation_start_time # Optional. Optional relative path to the resource. For example in node pool # upgrades, the relative path of the node pool. # Corresponds to the JSON property `resource` # @return [String] attr_accessor :resource # Required. The resource type that is upgrading. # Corresponds to the JSON property `resourceType` # @return [String] attr_accessor :resource_type # Required. The target version for the upgrade. # Corresponds to the JSON property `targetVersion` # @return [String] attr_accessor :target_version def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @current_version = args[:current_version] if args.key?(:current_version) @operation = args[:operation] if args.key?(:operation) @operation_start_time = args[:operation_start_time] if args.key?(:operation_start_time) @resource = args[:resource] if args.key?(:resource) @resource_type = args[:resource_type] if args.key?(:resource_type) @target_version = args[:target_version] if args.key?(:target_version) end end # These upgrade settings control the level of parallelism and the level of # disruption caused by an upgrade. maxUnavailable controls the number of nodes # that can be simultaneously unavailable. maxSurge controls the number of # additional nodes that can be added to the node pool temporarily for the time # of the upgrade to increase the number of available nodes. (maxUnavailable + # maxSurge) determines the level of parallelism (how many nodes are being # upgraded at the same time). Note: upgrades inevitably introduce some # disruption since workloads need to be moved from old nodes to new, upgraded # ones. Even if maxUnavailable=0, this holds true. (Disruption stays within the # limits of PodDisruptionBudget, if it is configured.) Consider a hypothetical # node pool with 5 nodes having maxSurge=2, maxUnavailable=1. This means the # upgrade process upgrades 3 nodes simultaneously. It creates 2 additional ( # upgraded) nodes, then it brings down 3 old (not yet upgraded) nodes at the # same time. This ensures that there are always at least 4 nodes available. class UpgradeSettings include Google::Apis::Core::Hashable # The maximum number of nodes that can be created beyond the current size of the # node pool during the upgrade process. # Corresponds to the JSON property `maxSurge` # @return [Fixnum] attr_accessor :max_surge # The maximum number of nodes that can be simultaneously unavailable during the # upgrade process. A node is considered available if its status is Ready. # Corresponds to the JSON property `maxUnavailable` # @return [Fixnum] attr_accessor :max_unavailable def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @max_surge = args[:max_surge] if args.key?(:max_surge) @max_unavailable = args[:max_unavailable] if args.key?(:max_unavailable) end end # UsableSubnetwork resource returns the subnetwork name, its associated network # and the primary CIDR range. class UsableSubnetwork include Google::Apis::Core::Hashable # The range of internal addresses that are owned by this subnetwork. # Corresponds to the JSON property `ipCidrRange` # @return [String] attr_accessor :ip_cidr_range # Network Name. Example: projects/my-project/global/networks/my-network # Corresponds to the JSON property `network` # @return [String] attr_accessor :network # Secondary IP ranges. # Corresponds to the JSON property `secondaryIpRanges` # @return [Array] attr_accessor :secondary_ip_ranges # A human readable status message representing the reasons for cases where the # caller cannot use the secondary ranges under the subnet. For example if the # secondary_ip_ranges is empty due to a permission issue, an insufficient # permission message will be given by status_message. # Corresponds to the JSON property `statusMessage` # @return [String] attr_accessor :status_message # Subnetwork Name. Example: projects/my-project/regions/us-central1/subnetworks/ # my-subnet # Corresponds to the JSON property `subnetwork` # @return [String] attr_accessor :subnetwork def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @ip_cidr_range = args[:ip_cidr_range] if args.key?(:ip_cidr_range) @network = args[:network] if args.key?(:network) @secondary_ip_ranges = args[:secondary_ip_ranges] if args.key?(:secondary_ip_ranges) @status_message = args[:status_message] if args.key?(:status_message) @subnetwork = args[:subnetwork] if args.key?(:subnetwork) end end # Secondary IP range of a usable subnetwork. class UsableSubnetworkSecondaryRange include Google::Apis::Core::Hashable # The range of IP addresses belonging to this subnetwork secondary range. # Corresponds to the JSON property `ipCidrRange` # @return [String] attr_accessor :ip_cidr_range # The name associated with this subnetwork secondary range, used when adding an # alias IP range to a VM instance. # Corresponds to the JSON property `rangeName` # @return [String] attr_accessor :range_name # This field is to determine the status of the secondary range programmably. # Corresponds to the JSON property `status` # @return [String] attr_accessor :status def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @ip_cidr_range = args[:ip_cidr_range] if args.key?(:ip_cidr_range) @range_name = args[:range_name] if args.key?(:range_name) @status = args[:status] if args.key?(:status) end end # VerticalPodAutoscaling contains global, per-cluster information required by # Vertical Pod Autoscaler to automatically adjust the resources of pods # controlled by it. class VerticalPodAutoscaling include Google::Apis::Core::Hashable # Enables vertical pod autoscaling. # 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 # Configuration for the use of Kubernetes Service Accounts in GCP IAM policies. class WorkloadIdentityConfig include Google::Apis::Core::Hashable # IAM Identity Namespace to attach all Kubernetes Service Accounts to. # Corresponds to the JSON property `identityNamespace` # @return [String] attr_accessor :identity_namespace # identity provider is the third party identity provider. # Corresponds to the JSON property `identityProvider` # @return [String] attr_accessor :identity_provider # The workload pool to attach all Kubernetes service accounts to. # Corresponds to the JSON property `workloadPool` # @return [String] attr_accessor :workload_pool def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @identity_namespace = args[:identity_namespace] if args.key?(:identity_namespace) @identity_provider = args[:identity_provider] if args.key?(:identity_provider) @workload_pool = args[:workload_pool] if args.key?(:workload_pool) end end # WorkloadMetadataConfig defines the metadata configuration to expose to # workloads on the node pool. class WorkloadMetadataConfig include Google::Apis::Core::Hashable # Mode is the configuration for how to expose metadata to workloads running on # the node pool. # Corresponds to the JSON property `mode` # @return [String] attr_accessor :mode # NodeMetadata is the configuration for how to expose metadata to the workloads # running on the node. # Corresponds to the JSON property `nodeMetadata` # @return [String] attr_accessor :node_metadata def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @mode = args[:mode] if args.key?(:mode) @node_metadata = args[:node_metadata] if args.key?(:node_metadata) end end end end end