Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
com.pulumi.gcp.container.kotlin.inputs.ClusterNodeConfigArgs.kt Maven / Gradle / Ivy
Go to download
Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.
@file:Suppress("NAME_SHADOWING", "DEPRECATION")
package com.pulumi.gcp.container.kotlin.inputs
import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.gcp.container.inputs.ClusterNodeConfigArgs.builder
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.applySuspend
import kotlin.Any
import kotlin.Boolean
import kotlin.Int
import kotlin.Pair
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.List
import kotlin.collections.Map
import kotlin.jvm.JvmName
/**
*
* @property advancedMachineFeatures Specifies options for controlling
* advanced machine features. Structure is documented below.
* @property bootDiskKmsKey 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:
* @property confidentialNodes Configuration for [Confidential Nodes](https://cloud.google.com/kubernetes-engine/docs/how-to/confidential-gke-nodes) feature. Structure is documented below documented below.
* @property diskSizeGb Size of the disk attached to each node, specified
* in GB. The smallest allowed disk size is 10GB. Defaults to 100GB.
* @property diskType Type of the disk attached to each node
* (e.g. 'pd-standard', 'pd-balanced' or 'pd-ssd'). If unspecified, the default disk type is 'pd-standard'
* @property effectiveTaints List of kubernetes taints applied to each node. Structure is documented above.
* @property enableConfidentialStorage Enabling Confidential Storage will create boot disk with confidential mode. It is disabled by default.
* @property ephemeralStorageConfig Parameters for the ephemeral storage filesystem. If unspecified, ephemeral storage is backed by the boot disk. Structure is documented below.
* @property ephemeralStorageLocalSsdConfig Parameters for the ephemeral storage filesystem. If unspecified, ephemeral storage is backed by the boot disk. Structure is documented below.
* @property fastSocket Parameters for the NCCL Fast Socket feature. If unspecified, NCCL Fast Socket will not be enabled on the node pool.
* Node Pool must enable gvnic.
* GKE version 1.25.2-gke.1700 or later.
* Structure is documented below.
* @property gcfsConfig Parameters for the Google Container Filesystem (GCFS).
* If unspecified, GCFS will not be enabled on the node pool. When enabling this feature you must specify `image_type = "COS_CONTAINERD"` and `node_version` from GKE versions 1.19 or later to use it.
* For GKE versions 1.19, 1.20, and 1.21, the recommended minimum `node_version` would be 1.19.15-gke.1300, 1.20.11-gke.1300, and 1.21.5-gke.1300 respectively.
* A `machine_type` that has more than 16 GiB of memory is also recommended.
* GCFS must be enabled in order to use [image streaming](https://cloud.google.com/kubernetes-engine/docs/how-to/image-streaming).
* Structure is documented below.
* @property guestAccelerators List of the type and count of accelerator cards attached to the instance.
* Structure documented below.
* @property gvnic Google Virtual NIC (gVNIC) is a virtual network interface.
* Installing the gVNIC driver allows for more efficient traffic transmission across the Google network infrastructure.
* gVNIC is an alternative to the virtIO-based ethernet driver. GKE nodes must use a Container-Optimized OS node image.
* GKE node version 1.15.11-gke.15 or later
* Structure is documented below.
* @property hostMaintenancePolicy The maintenance policy for the hosts on which the GKE VMs run on.
* @property imageType The image type to use for this node. Note that changing the image type
* will delete and recreate all nodes in the node pool.
* @property kubeletConfig Kubelet configuration, currently supported attributes can be found [here](https://cloud.google.com/sdk/gcloud/reference/beta/container/node-pools/create#--system-config-from-file).
* Structure is documented below.
* ```
* kubelet_config {
* cpu_manager_policy = "static"
* cpu_cfs_quota = true
* cpu_cfs_quota_period = "100us"
* pod_pids_limit = 1024
* }
* ```
* @property labels The Kubernetes labels (key/value pairs) to be applied to each node. The kubernetes.io/ and k8s.io/ prefixes are
* reserved by Kubernetes Core components and cannot be specified.
* @property linuxNodeConfig Parameters that can be configured on Linux nodes. Structure is documented below.
* @property localNvmeSsdBlockConfig Parameters for the local NVMe SSDs. Structure is documented below.
* @property localSsdCount The amount of local SSD disks that will be
* attached to each cluster node. Defaults to 0.
* @property loggingVariant Parameter for specifying the type of logging agent used in a node pool. This will override any cluster-wide default value. Valid values include DEFAULT and MAX_THROUGHPUT. See [Increasing logging agent throughput](https://cloud.google.com/stackdriver/docs/solutions/gke/managing-logs#throughput) for more information.
* @property machineType The name of a Google Compute Engine machine type.
* Defaults to `e2-medium`. To create a custom machine type, value should be set as specified
* [here](https://cloud.google.com/compute/docs/reference/latest/instances#machineType).
* @property metadata The metadata key/value pairs assigned to instances in
* the cluster. From GKE `1.12` onwards, `disable-legacy-endpoints` is set to
* `true` by the API; if `metadata` is set but that default value is not
* included, the provider will attempt to unset the value. To avoid this, set the
* value in your config.
* @property minCpuPlatform 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 `Intel Haswell`. See the
* [official documentation](https://cloud.google.com/compute/docs/instances/specify-min-cpu-platform)
* for more information.
* @property nodeGroup 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).
* @property oauthScopes The set of Google API scopes to be made available
* on all of the node VMs under the "default" service account.
* Use the "https://www.googleapis.com/auth/cloud-platform" scope to grant access to all APIs. It is recommended that you set `service_account` to a non-default service account and grant IAM roles to that service account for only the resources that it needs.
* See the [official documentation](https://cloud.google.com/kubernetes-engine/docs/how-to/access-scopes) for information on migrating off of legacy access scopes.
* @property preemptible A boolean that represents whether or not the underlying node VMs
* are preemptible. See the [official documentation](https://cloud.google.com/container-engine/docs/preemptible-vm)
* for more information. Defaults to false.
* @property reservationAffinity The configuration of the desired reservation which instances could take capacity from. Structure is documented below.
* @property resourceLabels The GCP labels (key/value pairs) to be applied to each node. Refer [here](https://cloud.google.com/kubernetes-engine/docs/how-to/creating-managing-labels)
* for how these labels are applied to clusters, node pools and nodes.
* @property resourceManagerTags A map of resource manager tag keys and values to be attached to the nodes for managing Compute Engine firewalls using Network Firewall Policies. Tags must be according to specifications found [here](https://cloud.google.com/vpc/docs/tags-firewalls-overview#specifications). A maximum of 5 tag key-value pairs can be specified. Existing tags will be replaced with new values. Tags must be in one of the following formats ([KEY]=[VALUE]) 1. `tagKeys/{tag_key_id}=tagValues/{tag_value_id}` 2. `{org_id}/{tag_key_name}={tag_value_name}` 3. `{project_id}/{tag_key_name}={tag_value_name}`.
* @property sandboxConfig Sandbox configuration for this node.
* @property secondaryBootDisks Parameters for secondary boot disks to preload container images and data on new nodes. Structure is documented below. `gcfs_config` must be `enabled=true` for this feature to work. `min_master_version` must also be set to use GKE 1.28.3-gke.106700 or later versions.
* @property serviceAccount The service account to be used by the Node VMs.
* If not specified, the "default" service account is used.
* @property shieldedInstanceConfig Shielded Instance options. Structure is documented below.
* @property soleTenantConfig Allows specifying multiple [node affinities](https://cloud.google.com/compute/docs/nodes/sole-tenant-nodes#node_affinity_and_anti-affinity) useful for running workloads on [sole tenant nodes](https://cloud.google.com/kubernetes-engine/docs/how-to/sole-tenancy). `node_affinity` structure is documented below.
* @property spot A boolean that represents whether the underlying node VMs are spot.
* See the [official documentation](https://cloud.google.com/kubernetes-engine/docs/concepts/spot-vms)
* for more information. Defaults to false.
* @property tags The list of instance tags applied to all nodes. Tags are used to identify
* valid sources or targets for network firewalls.
* @property taints A list of [Kubernetes taints](https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/)
* to apply to nodes. GKE's API can only set this field on cluster creation.
* However, GKE will add taints to your nodes if you enable certain features such
* as GPUs. If this field is set, any diffs on this field will cause the provider to
* recreate the underlying resource. Taint values can be updated safely in
* Kubernetes (eg. through `kubectl`), and it's recommended that you do not use
* this field to manage taints. If you do, `lifecycle.ignore_changes` is
* recommended. Structure is documented below.
* @property workloadMetadataConfig Metadata configuration to expose to workloads on the node pool.
* Structure is documented below.
*/
public data class ClusterNodeConfigArgs(
public val advancedMachineFeatures: Output? = null,
public val bootDiskKmsKey: Output? = null,
public val confidentialNodes: Output? = null,
public val diskSizeGb: Output? = null,
public val diskType: Output? = null,
public val effectiveTaints: Output>? = null,
public val enableConfidentialStorage: Output? = null,
public val ephemeralStorageConfig: Output? = null,
public val ephemeralStorageLocalSsdConfig: Output? = null,
public val fastSocket: Output? = null,
public val gcfsConfig: Output? = null,
public val guestAccelerators: Output>? = null,
public val gvnic: Output? = null,
public val hostMaintenancePolicy: Output? = null,
public val imageType: Output? = null,
public val kubeletConfig: Output? = null,
public val labels: Output>? = null,
public val linuxNodeConfig: Output? = null,
public val localNvmeSsdBlockConfig: Output? = null,
public val localSsdCount: Output? = null,
public val loggingVariant: Output? = null,
public val machineType: Output? = null,
public val metadata: Output>? = null,
public val minCpuPlatform: Output? = null,
public val nodeGroup: Output? = null,
public val oauthScopes: Output>? = null,
public val preemptible: Output? = null,
public val reservationAffinity: Output? = null,
public val resourceLabels: Output>? = null,
public val resourceManagerTags: Output>? = null,
public val sandboxConfig: Output? = null,
public val secondaryBootDisks: Output>? = null,
public val serviceAccount: Output? = null,
public val shieldedInstanceConfig: Output? = null,
public val soleTenantConfig: Output? = null,
public val spot: Output? = null,
public val tags: Output>? = null,
public val taints: Output>? = null,
public val workloadMetadataConfig: Output? = null,
) : ConvertibleToJava {
override fun toJava(): com.pulumi.gcp.container.inputs.ClusterNodeConfigArgs =
com.pulumi.gcp.container.inputs.ClusterNodeConfigArgs.builder()
.advancedMachineFeatures(
advancedMachineFeatures?.applyValue({ args0 ->
args0.let({ args0 ->
args0.toJava()
})
}),
)
.bootDiskKmsKey(bootDiskKmsKey?.applyValue({ args0 -> args0 }))
.confidentialNodes(confidentialNodes?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
.diskSizeGb(diskSizeGb?.applyValue({ args0 -> args0 }))
.diskType(diskType?.applyValue({ args0 -> args0 }))
.effectiveTaints(
effectiveTaints?.applyValue({ args0 ->
args0.map({ args0 ->
args0.let({ args0 ->
args0.toJava()
})
})
}),
)
.enableConfidentialStorage(enableConfidentialStorage?.applyValue({ args0 -> args0 }))
.ephemeralStorageConfig(
ephemeralStorageConfig?.applyValue({ args0 ->
args0.let({ args0 ->
args0.toJava()
})
}),
)
.ephemeralStorageLocalSsdConfig(
ephemeralStorageLocalSsdConfig?.applyValue({ args0 ->
args0.let({ args0 -> args0.toJava() })
}),
)
.fastSocket(fastSocket?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
.gcfsConfig(gcfsConfig?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
.guestAccelerators(
guestAccelerators?.applyValue({ args0 ->
args0.map({ args0 ->
args0.let({ args0 ->
args0.toJava()
})
})
}),
)
.gvnic(gvnic?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
.hostMaintenancePolicy(
hostMaintenancePolicy?.applyValue({ args0 ->
args0.let({ args0 ->
args0.toJava()
})
}),
)
.imageType(imageType?.applyValue({ args0 -> args0 }))
.kubeletConfig(kubeletConfig?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
.labels(labels?.applyValue({ args0 -> args0.map({ args0 -> args0.key.to(args0.value) }).toMap() }))
.linuxNodeConfig(linuxNodeConfig?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
.localNvmeSsdBlockConfig(
localNvmeSsdBlockConfig?.applyValue({ args0 ->
args0.let({ args0 ->
args0.toJava()
})
}),
)
.localSsdCount(localSsdCount?.applyValue({ args0 -> args0 }))
.loggingVariant(loggingVariant?.applyValue({ args0 -> args0 }))
.machineType(machineType?.applyValue({ args0 -> args0 }))
.metadata(
metadata?.applyValue({ args0 ->
args0.map({ args0 ->
args0.key.to(args0.value)
}).toMap()
}),
)
.minCpuPlatform(minCpuPlatform?.applyValue({ args0 -> args0 }))
.nodeGroup(nodeGroup?.applyValue({ args0 -> args0 }))
.oauthScopes(oauthScopes?.applyValue({ args0 -> args0.map({ args0 -> args0 }) }))
.preemptible(preemptible?.applyValue({ args0 -> args0 }))
.reservationAffinity(
reservationAffinity?.applyValue({ args0 ->
args0.let({ args0 ->
args0.toJava()
})
}),
)
.resourceLabels(
resourceLabels?.applyValue({ args0 ->
args0.map({ args0 ->
args0.key.to(args0.value)
}).toMap()
}),
)
.resourceManagerTags(
resourceManagerTags?.applyValue({ args0 ->
args0.map({ args0 ->
args0.key.to(args0.value)
}).toMap()
}),
)
.sandboxConfig(sandboxConfig?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
.secondaryBootDisks(
secondaryBootDisks?.applyValue({ args0 ->
args0.map({ args0 ->
args0.let({ args0 -> args0.toJava() })
})
}),
)
.serviceAccount(serviceAccount?.applyValue({ args0 -> args0 }))
.shieldedInstanceConfig(
shieldedInstanceConfig?.applyValue({ args0 ->
args0.let({ args0 ->
args0.toJava()
})
}),
)
.soleTenantConfig(soleTenantConfig?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
.spot(spot?.applyValue({ args0 -> args0 }))
.tags(tags?.applyValue({ args0 -> args0.map({ args0 -> args0 }) }))
.taints(taints?.applyValue({ args0 -> args0.map({ args0 -> args0.let({ args0 -> args0.toJava() }) }) }))
.workloadMetadataConfig(
workloadMetadataConfig?.applyValue({ args0 ->
args0.let({ args0 ->
args0.toJava()
})
}),
).build()
}
/**
* Builder for [ClusterNodeConfigArgs].
*/
@PulumiTagMarker
public class ClusterNodeConfigArgsBuilder internal constructor() {
private var advancedMachineFeatures: Output? = null
private var bootDiskKmsKey: Output? = null
private var confidentialNodes: Output? = null
private var diskSizeGb: Output? = null
private var diskType: Output? = null
private var effectiveTaints: Output>? = null
private var enableConfidentialStorage: Output? = null
private var ephemeralStorageConfig: Output? = null
private var ephemeralStorageLocalSsdConfig:
Output? = null
private var fastSocket: Output? = null
private var gcfsConfig: Output? = null
private var guestAccelerators: Output>? = null
private var gvnic: Output? = null
private var hostMaintenancePolicy: Output? = null
private var imageType: Output? = null
private var kubeletConfig: Output? = null
private var labels: Output>? = null
private var linuxNodeConfig: Output? = null
private var localNvmeSsdBlockConfig: Output? = null
private var localSsdCount: Output? = null
private var loggingVariant: Output? = null
private var machineType: Output? = null
private var metadata: Output>? = null
private var minCpuPlatform: Output? = null
private var nodeGroup: Output? = null
private var oauthScopes: Output>? = null
private var preemptible: Output? = null
private var reservationAffinity: Output? = null
private var resourceLabels: Output>? = null
private var resourceManagerTags: Output>? = null
private var sandboxConfig: Output? = null
private var secondaryBootDisks: Output>? = null
private var serviceAccount: Output? = null
private var shieldedInstanceConfig: Output? = null
private var soleTenantConfig: Output? = null
private var spot: Output? = null
private var tags: Output>? = null
private var taints: Output>? = null
private var workloadMetadataConfig: Output? = null
/**
* @param value Specifies options for controlling
* advanced machine features. Structure is documented below.
*/
@JvmName("ecyuoutegtjxsgee")
public suspend fun advancedMachineFeatures(`value`: Output) {
this.advancedMachineFeatures = value
}
/**
* @param value 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:
*/
@JvmName("spiaxxqnmeuvrtsp")
public suspend fun bootDiskKmsKey(`value`: Output) {
this.bootDiskKmsKey = value
}
/**
* @param value Configuration for [Confidential Nodes](https://cloud.google.com/kubernetes-engine/docs/how-to/confidential-gke-nodes) feature. Structure is documented below documented below.
*/
@JvmName("iqyuypfiqppsgdsw")
public suspend fun confidentialNodes(`value`: Output) {
this.confidentialNodes = value
}
/**
* @param value Size of the disk attached to each node, specified
* in GB. The smallest allowed disk size is 10GB. Defaults to 100GB.
*/
@JvmName("eadqxsiyygnnafwl")
public suspend fun diskSizeGb(`value`: Output) {
this.diskSizeGb = value
}
/**
* @param value Type of the disk attached to each node
* (e.g. 'pd-standard', 'pd-balanced' or 'pd-ssd'). If unspecified, the default disk type is 'pd-standard'
*/
@JvmName("cailmwtgiywqadmy")
public suspend fun diskType(`value`: Output) {
this.diskType = value
}
/**
* @param value List of kubernetes taints applied to each node. Structure is documented above.
*/
@JvmName("fhdluggshonqnckx")
public suspend fun effectiveTaints(`value`: Output>) {
this.effectiveTaints = value
}
@JvmName("drvxsjpqdhrmuhmc")
public suspend fun effectiveTaints(vararg values: Output) {
this.effectiveTaints = Output.all(values.asList())
}
/**
* @param values List of kubernetes taints applied to each node. Structure is documented above.
*/
@JvmName("kkrlpoodyammusan")
public suspend fun effectiveTaints(values: List>) {
this.effectiveTaints = Output.all(values)
}
/**
* @param value Enabling Confidential Storage will create boot disk with confidential mode. It is disabled by default.
*/
@JvmName("vlbmdfsxejaphvri")
public suspend fun enableConfidentialStorage(`value`: Output) {
this.enableConfidentialStorage = value
}
/**
* @param value Parameters for the ephemeral storage filesystem. If unspecified, ephemeral storage is backed by the boot disk. Structure is documented below.
*/
@JvmName("kuglbntvkrfnhkbr")
public suspend fun ephemeralStorageConfig(`value`: Output) {
this.ephemeralStorageConfig = value
}
/**
* @param value Parameters for the ephemeral storage filesystem. If unspecified, ephemeral storage is backed by the boot disk. Structure is documented below.
*/
@JvmName("jyrggbcfdtwmemdr")
public suspend fun ephemeralStorageLocalSsdConfig(`value`: Output) {
this.ephemeralStorageLocalSsdConfig = value
}
/**
* @param value Parameters for the NCCL Fast Socket feature. If unspecified, NCCL Fast Socket will not be enabled on the node pool.
* Node Pool must enable gvnic.
* GKE version 1.25.2-gke.1700 or later.
* Structure is documented below.
*/
@JvmName("lyqwcuedyecvbusc")
public suspend fun fastSocket(`value`: Output) {
this.fastSocket = value
}
/**
* @param value Parameters for the Google Container Filesystem (GCFS).
* If unspecified, GCFS will not be enabled on the node pool. When enabling this feature you must specify `image_type = "COS_CONTAINERD"` and `node_version` from GKE versions 1.19 or later to use it.
* For GKE versions 1.19, 1.20, and 1.21, the recommended minimum `node_version` would be 1.19.15-gke.1300, 1.20.11-gke.1300, and 1.21.5-gke.1300 respectively.
* A `machine_type` that has more than 16 GiB of memory is also recommended.
* GCFS must be enabled in order to use [image streaming](https://cloud.google.com/kubernetes-engine/docs/how-to/image-streaming).
* Structure is documented below.
*/
@JvmName("ptxqacwqmipoggyr")
public suspend fun gcfsConfig(`value`: Output) {
this.gcfsConfig = value
}
/**
* @param value List of the type and count of accelerator cards attached to the instance.
* Structure documented below.
*/
@JvmName("mhupwbdryitovkvn")
public suspend fun guestAccelerators(`value`: Output>) {
this.guestAccelerators = value
}
@JvmName("suuhqthagrbyyrjk")
public suspend fun guestAccelerators(vararg values: Output) {
this.guestAccelerators = Output.all(values.asList())
}
/**
* @param values List of the type and count of accelerator cards attached to the instance.
* Structure documented below.
*/
@JvmName("avdhhbfkjebviups")
public suspend fun guestAccelerators(values: List>) {
this.guestAccelerators = Output.all(values)
}
/**
* @param value Google Virtual NIC (gVNIC) is a virtual network interface.
* Installing the gVNIC driver allows for more efficient traffic transmission across the Google network infrastructure.
* gVNIC is an alternative to the virtIO-based ethernet driver. GKE nodes must use a Container-Optimized OS node image.
* GKE node version 1.15.11-gke.15 or later
* Structure is documented below.
*/
@JvmName("recmbghbfrdniyiv")
public suspend fun gvnic(`value`: Output) {
this.gvnic = value
}
/**
* @param value The maintenance policy for the hosts on which the GKE VMs run on.
*/
@JvmName("umnwbihvvwgmvefv")
public suspend fun hostMaintenancePolicy(`value`: Output) {
this.hostMaintenancePolicy = value
}
/**
* @param value The image type to use for this node. Note that changing the image type
* will delete and recreate all nodes in the node pool.
*/
@JvmName("fnbjmlqffnqslyua")
public suspend fun imageType(`value`: Output) {
this.imageType = value
}
/**
* @param value Kubelet configuration, currently supported attributes can be found [here](https://cloud.google.com/sdk/gcloud/reference/beta/container/node-pools/create#--system-config-from-file).
* Structure is documented below.
* ```
* kubelet_config {
* cpu_manager_policy = "static"
* cpu_cfs_quota = true
* cpu_cfs_quota_period = "100us"
* pod_pids_limit = 1024
* }
* ```
*/
@JvmName("shjyfdjwodlgpoll")
public suspend fun kubeletConfig(`value`: Output) {
this.kubeletConfig = value
}
/**
* @param value The Kubernetes labels (key/value pairs) to be applied to each node. The kubernetes.io/ and k8s.io/ prefixes are
* reserved by Kubernetes Core components and cannot be specified.
*/
@JvmName("ifweubvqlyaqmdyb")
public suspend fun labels(`value`: Output>) {
this.labels = value
}
/**
* @param value Parameters that can be configured on Linux nodes. Structure is documented below.
*/
@JvmName("cgfkxsalbtlkgghd")
public suspend fun linuxNodeConfig(`value`: Output) {
this.linuxNodeConfig = value
}
/**
* @param value Parameters for the local NVMe SSDs. Structure is documented below.
*/
@JvmName("ikuarggmsrteatpo")
public suspend fun localNvmeSsdBlockConfig(`value`: Output) {
this.localNvmeSsdBlockConfig = value
}
/**
* @param value The amount of local SSD disks that will be
* attached to each cluster node. Defaults to 0.
*/
@JvmName("prexognkhnyjdjgs")
public suspend fun localSsdCount(`value`: Output) {
this.localSsdCount = value
}
/**
* @param value Parameter for specifying the type of logging agent used in a node pool. This will override any cluster-wide default value. Valid values include DEFAULT and MAX_THROUGHPUT. See [Increasing logging agent throughput](https://cloud.google.com/stackdriver/docs/solutions/gke/managing-logs#throughput) for more information.
*/
@JvmName("hcxrqxugjsiqmvaf")
public suspend fun loggingVariant(`value`: Output) {
this.loggingVariant = value
}
/**
* @param value The name of a Google Compute Engine machine type.
* Defaults to `e2-medium`. To create a custom machine type, value should be set as specified
* [here](https://cloud.google.com/compute/docs/reference/latest/instances#machineType).
*/
@JvmName("udiavygbkfxdeica")
public suspend fun machineType(`value`: Output) {
this.machineType = value
}
/**
* @param value The metadata key/value pairs assigned to instances in
* the cluster. From GKE `1.12` onwards, `disable-legacy-endpoints` is set to
* `true` by the API; if `metadata` is set but that default value is not
* included, the provider will attempt to unset the value. To avoid this, set the
* value in your config.
*/
@JvmName("xsjkqgxclxtfdkhx")
public suspend fun metadata(`value`: Output>) {
this.metadata = value
}
/**
* @param value 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 `Intel Haswell`. See the
* [official documentation](https://cloud.google.com/compute/docs/instances/specify-min-cpu-platform)
* for more information.
*/
@JvmName("aledqyukgdjbnifq")
public suspend fun minCpuPlatform(`value`: Output) {
this.minCpuPlatform = value
}
/**
* @param value 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).
*/
@JvmName("mmdayybbyurjexge")
public suspend fun nodeGroup(`value`: Output) {
this.nodeGroup = value
}
/**
* @param value The set of Google API scopes to be made available
* on all of the node VMs under the "default" service account.
* Use the "https://www.googleapis.com/auth/cloud-platform" scope to grant access to all APIs. It is recommended that you set `service_account` to a non-default service account and grant IAM roles to that service account for only the resources that it needs.
* See the [official documentation](https://cloud.google.com/kubernetes-engine/docs/how-to/access-scopes) for information on migrating off of legacy access scopes.
*/
@JvmName("kvevctfdxvshvudp")
public suspend fun oauthScopes(`value`: Output>) {
this.oauthScopes = value
}
@JvmName("fgahaphchqiolfee")
public suspend fun oauthScopes(vararg values: Output) {
this.oauthScopes = Output.all(values.asList())
}
/**
* @param values The set of Google API scopes to be made available
* on all of the node VMs under the "default" service account.
* Use the "https://www.googleapis.com/auth/cloud-platform" scope to grant access to all APIs. It is recommended that you set `service_account` to a non-default service account and grant IAM roles to that service account for only the resources that it needs.
* See the [official documentation](https://cloud.google.com/kubernetes-engine/docs/how-to/access-scopes) for information on migrating off of legacy access scopes.
*/
@JvmName("srkokxbqimxqqcsr")
public suspend fun oauthScopes(values: List>) {
this.oauthScopes = Output.all(values)
}
/**
* @param value A boolean that represents whether or not the underlying node VMs
* are preemptible. See the [official documentation](https://cloud.google.com/container-engine/docs/preemptible-vm)
* for more information. Defaults to false.
*/
@JvmName("cvsxdqrvujtxpqft")
public suspend fun preemptible(`value`: Output) {
this.preemptible = value
}
/**
* @param value The configuration of the desired reservation which instances could take capacity from. Structure is documented below.
*/
@JvmName("gvshegfckcfmsxqj")
public suspend fun reservationAffinity(`value`: Output) {
this.reservationAffinity = value
}
/**
* @param value The GCP labels (key/value pairs) to be applied to each node. Refer [here](https://cloud.google.com/kubernetes-engine/docs/how-to/creating-managing-labels)
* for how these labels are applied to clusters, node pools and nodes.
*/
@JvmName("tsqbehnonnjtgmgp")
public suspend fun resourceLabels(`value`: Output>) {
this.resourceLabels = value
}
/**
* @param value A map of resource manager tag keys and values to be attached to the nodes for managing Compute Engine firewalls using Network Firewall Policies. Tags must be according to specifications found [here](https://cloud.google.com/vpc/docs/tags-firewalls-overview#specifications). A maximum of 5 tag key-value pairs can be specified. Existing tags will be replaced with new values. Tags must be in one of the following formats ([KEY]=[VALUE]) 1. `tagKeys/{tag_key_id}=tagValues/{tag_value_id}` 2. `{org_id}/{tag_key_name}={tag_value_name}` 3. `{project_id}/{tag_key_name}={tag_value_name}`.
*/
@JvmName("brnygjjxfugiwjip")
public suspend fun resourceManagerTags(`value`: Output>) {
this.resourceManagerTags = value
}
/**
* @param value Sandbox configuration for this node.
*/
@JvmName("qdfleggbfoldxudw")
public suspend fun sandboxConfig(`value`: Output) {
this.sandboxConfig = value
}
/**
* @param value Parameters for secondary boot disks to preload container images and data on new nodes. Structure is documented below. `gcfs_config` must be `enabled=true` for this feature to work. `min_master_version` must also be set to use GKE 1.28.3-gke.106700 or later versions.
*/
@JvmName("jdmhcecbsoeuknqa")
public suspend fun secondaryBootDisks(`value`: Output>) {
this.secondaryBootDisks = value
}
@JvmName("dckplfulvnlhnhhe")
public suspend fun secondaryBootDisks(vararg values: Output) {
this.secondaryBootDisks = Output.all(values.asList())
}
/**
* @param values Parameters for secondary boot disks to preload container images and data on new nodes. Structure is documented below. `gcfs_config` must be `enabled=true` for this feature to work. `min_master_version` must also be set to use GKE 1.28.3-gke.106700 or later versions.
*/
@JvmName("qeotbtgeliapnmpn")
public suspend fun secondaryBootDisks(values: List>) {
this.secondaryBootDisks = Output.all(values)
}
/**
* @param value The service account to be used by the Node VMs.
* If not specified, the "default" service account is used.
*/
@JvmName("tsoytybkdsnaxtbo")
public suspend fun serviceAccount(`value`: Output) {
this.serviceAccount = value
}
/**
* @param value Shielded Instance options. Structure is documented below.
*/
@JvmName("poohqhlyvkhodwql")
public suspend fun shieldedInstanceConfig(`value`: Output) {
this.shieldedInstanceConfig = value
}
/**
* @param value Allows specifying multiple [node affinities](https://cloud.google.com/compute/docs/nodes/sole-tenant-nodes#node_affinity_and_anti-affinity) useful for running workloads on [sole tenant nodes](https://cloud.google.com/kubernetes-engine/docs/how-to/sole-tenancy). `node_affinity` structure is documented below.
*/
@JvmName("tvucivoeghhbucft")
public suspend fun soleTenantConfig(`value`: Output) {
this.soleTenantConfig = value
}
/**
* @param value A boolean that represents whether the underlying node VMs are spot.
* See the [official documentation](https://cloud.google.com/kubernetes-engine/docs/concepts/spot-vms)
* for more information. Defaults to false.
*/
@JvmName("xdqmuwguhtldqbfb")
public suspend fun spot(`value`: Output) {
this.spot = value
}
/**
* @param value The list of instance tags applied to all nodes. Tags are used to identify
* valid sources or targets for network firewalls.
*/
@JvmName("qlsnfyqqjoqbprug")
public suspend fun tags(`value`: Output>) {
this.tags = value
}
@JvmName("sjiftmxqiacpmjoa")
public suspend fun tags(vararg values: Output) {
this.tags = Output.all(values.asList())
}
/**
* @param values The list of instance tags applied to all nodes. Tags are used to identify
* valid sources or targets for network firewalls.
*/
@JvmName("ubekpfyrcaxdbycf")
public suspend fun tags(values: List>) {
this.tags = Output.all(values)
}
/**
* @param value A list of [Kubernetes taints](https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/)
* to apply to nodes. GKE's API can only set this field on cluster creation.
* However, GKE will add taints to your nodes if you enable certain features such
* as GPUs. If this field is set, any diffs on this field will cause the provider to
* recreate the underlying resource. Taint values can be updated safely in
* Kubernetes (eg. through `kubectl`), and it's recommended that you do not use
* this field to manage taints. If you do, `lifecycle.ignore_changes` is
* recommended. Structure is documented below.
*/
@JvmName("immpnwhcbdahgjvv")
public suspend fun taints(`value`: Output>) {
this.taints = value
}
@JvmName("dtdlhwuojlmicqnq")
public suspend fun taints(vararg values: Output) {
this.taints = Output.all(values.asList())
}
/**
* @param values A list of [Kubernetes taints](https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/)
* to apply to nodes. GKE's API can only set this field on cluster creation.
* However, GKE will add taints to your nodes if you enable certain features such
* as GPUs. If this field is set, any diffs on this field will cause the provider to
* recreate the underlying resource. Taint values can be updated safely in
* Kubernetes (eg. through `kubectl`), and it's recommended that you do not use
* this field to manage taints. If you do, `lifecycle.ignore_changes` is
* recommended. Structure is documented below.
*/
@JvmName("vmfsxkgyojpgaufb")
public suspend fun taints(values: List>) {
this.taints = Output.all(values)
}
/**
* @param value Metadata configuration to expose to workloads on the node pool.
* Structure is documented below.
*/
@JvmName("ghvuiaeieywgfyfk")
public suspend fun workloadMetadataConfig(`value`: Output) {
this.workloadMetadataConfig = value
}
/**
* @param value Specifies options for controlling
* advanced machine features. Structure is documented below.
*/
@JvmName("muiliuakuagtuqwv")
public suspend fun advancedMachineFeatures(`value`: ClusterNodeConfigAdvancedMachineFeaturesArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.advancedMachineFeatures = mapped
}
/**
* @param argument Specifies options for controlling
* advanced machine features. Structure is documented below.
*/
@JvmName("efrxrkqsxokaydpy")
public suspend fun advancedMachineFeatures(argument: suspend ClusterNodeConfigAdvancedMachineFeaturesArgsBuilder.() -> Unit) {
val toBeMapped = ClusterNodeConfigAdvancedMachineFeaturesArgsBuilder().applySuspend {
argument()
}.build()
val mapped = of(toBeMapped)
this.advancedMachineFeatures = mapped
}
/**
* @param value 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:
*/
@JvmName("lbtkqbdbqmlejvvb")
public suspend fun bootDiskKmsKey(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.bootDiskKmsKey = mapped
}
/**
* @param value Configuration for [Confidential Nodes](https://cloud.google.com/kubernetes-engine/docs/how-to/confidential-gke-nodes) feature. Structure is documented below documented below.
*/
@JvmName("pqwlyvcjmnnebtxi")
public suspend fun confidentialNodes(`value`: ClusterNodeConfigConfidentialNodesArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.confidentialNodes = mapped
}
/**
* @param argument Configuration for [Confidential Nodes](https://cloud.google.com/kubernetes-engine/docs/how-to/confidential-gke-nodes) feature. Structure is documented below documented below.
*/
@JvmName("ddjgqavntnxnagsx")
public suspend fun confidentialNodes(argument: suspend ClusterNodeConfigConfidentialNodesArgsBuilder.() -> Unit) {
val toBeMapped = ClusterNodeConfigConfidentialNodesArgsBuilder().applySuspend {
argument()
}.build()
val mapped = of(toBeMapped)
this.confidentialNodes = mapped
}
/**
* @param value Size of the disk attached to each node, specified
* in GB. The smallest allowed disk size is 10GB. Defaults to 100GB.
*/
@JvmName("okmfhjlnwmoyaevy")
public suspend fun diskSizeGb(`value`: Int?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.diskSizeGb = mapped
}
/**
* @param value Type of the disk attached to each node
* (e.g. 'pd-standard', 'pd-balanced' or 'pd-ssd'). If unspecified, the default disk type is 'pd-standard'
*/
@JvmName("idyyohdkxpinxqca")
public suspend fun diskType(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.diskType = mapped
}
/**
* @param value List of kubernetes taints applied to each node. Structure is documented above.
*/
@JvmName("bepucjrwiwvftmtk")
public suspend fun effectiveTaints(`value`: List?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.effectiveTaints = mapped
}
/**
* @param argument List of kubernetes taints applied to each node. Structure is documented above.
*/
@JvmName("jhokycqlcfbdndma")
public suspend fun effectiveTaints(argument: List Unit>) {
val toBeMapped = argument.toList().map {
ClusterNodeConfigEffectiveTaintArgsBuilder().applySuspend { it() }.build()
}
val mapped = of(toBeMapped)
this.effectiveTaints = mapped
}
/**
* @param argument List of kubernetes taints applied to each node. Structure is documented above.
*/
@JvmName("cugjidjdwewidsjw")
public suspend fun effectiveTaints(vararg argument: suspend ClusterNodeConfigEffectiveTaintArgsBuilder.() -> Unit) {
val toBeMapped = argument.toList().map {
ClusterNodeConfigEffectiveTaintArgsBuilder().applySuspend { it() }.build()
}
val mapped = of(toBeMapped)
this.effectiveTaints = mapped
}
/**
* @param argument List of kubernetes taints applied to each node. Structure is documented above.
*/
@JvmName("yumqjsicmxpmqglq")
public suspend fun effectiveTaints(argument: suspend ClusterNodeConfigEffectiveTaintArgsBuilder.() -> Unit) {
val toBeMapped = listOf(
ClusterNodeConfigEffectiveTaintArgsBuilder().applySuspend {
argument()
}.build(),
)
val mapped = of(toBeMapped)
this.effectiveTaints = mapped
}
/**
* @param values List of kubernetes taints applied to each node. Structure is documented above.
*/
@JvmName("sarbgcoymrxlfest")
public suspend fun effectiveTaints(vararg values: ClusterNodeConfigEffectiveTaintArgs) {
val toBeMapped = values.toList()
val mapped = toBeMapped.let({ args0 -> of(args0) })
this.effectiveTaints = mapped
}
/**
* @param value Enabling Confidential Storage will create boot disk with confidential mode. It is disabled by default.
*/
@JvmName("kbgnqxygqhlfoxyr")
public suspend fun enableConfidentialStorage(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.enableConfidentialStorage = mapped
}
/**
* @param value Parameters for the ephemeral storage filesystem. If unspecified, ephemeral storage is backed by the boot disk. Structure is documented below.
*/
@JvmName("agnvplfmtfcrcijj")
public suspend fun ephemeralStorageConfig(`value`: ClusterNodeConfigEphemeralStorageConfigArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.ephemeralStorageConfig = mapped
}
/**
* @param argument Parameters for the ephemeral storage filesystem. If unspecified, ephemeral storage is backed by the boot disk. Structure is documented below.
*/
@JvmName("yxcqmudddfwyccpv")
public suspend fun ephemeralStorageConfig(argument: suspend ClusterNodeConfigEphemeralStorageConfigArgsBuilder.() -> Unit) {
val toBeMapped = ClusterNodeConfigEphemeralStorageConfigArgsBuilder().applySuspend {
argument()
}.build()
val mapped = of(toBeMapped)
this.ephemeralStorageConfig = mapped
}
/**
* @param value Parameters for the ephemeral storage filesystem. If unspecified, ephemeral storage is backed by the boot disk. Structure is documented below.
*/
@JvmName("lmnejygcdlrectfj")
public suspend fun ephemeralStorageLocalSsdConfig(`value`: ClusterNodeConfigEphemeralStorageLocalSsdConfigArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.ephemeralStorageLocalSsdConfig = mapped
}
/**
* @param argument Parameters for the ephemeral storage filesystem. If unspecified, ephemeral storage is backed by the boot disk. Structure is documented below.
*/
@JvmName("ysrdjrpjyisjgxbl")
public suspend fun ephemeralStorageLocalSsdConfig(argument: suspend ClusterNodeConfigEphemeralStorageLocalSsdConfigArgsBuilder.() -> Unit) {
val toBeMapped = ClusterNodeConfigEphemeralStorageLocalSsdConfigArgsBuilder().applySuspend {
argument()
}.build()
val mapped = of(toBeMapped)
this.ephemeralStorageLocalSsdConfig = mapped
}
/**
* @param value Parameters for the NCCL Fast Socket feature. If unspecified, NCCL Fast Socket will not be enabled on the node pool.
* Node Pool must enable gvnic.
* GKE version 1.25.2-gke.1700 or later.
* Structure is documented below.
*/
@JvmName("weofsuexaexcobvq")
public suspend fun fastSocket(`value`: ClusterNodeConfigFastSocketArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.fastSocket = mapped
}
/**
* @param argument Parameters for the NCCL Fast Socket feature. If unspecified, NCCL Fast Socket will not be enabled on the node pool.
* Node Pool must enable gvnic.
* GKE version 1.25.2-gke.1700 or later.
* Structure is documented below.
*/
@JvmName("jwjpdnbdcqffewmi")
public suspend fun fastSocket(argument: suspend ClusterNodeConfigFastSocketArgsBuilder.() -> Unit) {
val toBeMapped = ClusterNodeConfigFastSocketArgsBuilder().applySuspend { argument() }.build()
val mapped = of(toBeMapped)
this.fastSocket = mapped
}
/**
* @param value Parameters for the Google Container Filesystem (GCFS).
* If unspecified, GCFS will not be enabled on the node pool. When enabling this feature you must specify `image_type = "COS_CONTAINERD"` and `node_version` from GKE versions 1.19 or later to use it.
* For GKE versions 1.19, 1.20, and 1.21, the recommended minimum `node_version` would be 1.19.15-gke.1300, 1.20.11-gke.1300, and 1.21.5-gke.1300 respectively.
* A `machine_type` that has more than 16 GiB of memory is also recommended.
* GCFS must be enabled in order to use [image streaming](https://cloud.google.com/kubernetes-engine/docs/how-to/image-streaming).
* Structure is documented below.
*/
@JvmName("bojjieehnstuteco")
public suspend fun gcfsConfig(`value`: ClusterNodeConfigGcfsConfigArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.gcfsConfig = mapped
}
/**
* @param argument Parameters for the Google Container Filesystem (GCFS).
* If unspecified, GCFS will not be enabled on the node pool. When enabling this feature you must specify `image_type = "COS_CONTAINERD"` and `node_version` from GKE versions 1.19 or later to use it.
* For GKE versions 1.19, 1.20, and 1.21, the recommended minimum `node_version` would be 1.19.15-gke.1300, 1.20.11-gke.1300, and 1.21.5-gke.1300 respectively.
* A `machine_type` that has more than 16 GiB of memory is also recommended.
* GCFS must be enabled in order to use [image streaming](https://cloud.google.com/kubernetes-engine/docs/how-to/image-streaming).
* Structure is documented below.
*/
@JvmName("oybkonjblrbnorqg")
public suspend fun gcfsConfig(argument: suspend ClusterNodeConfigGcfsConfigArgsBuilder.() -> Unit) {
val toBeMapped = ClusterNodeConfigGcfsConfigArgsBuilder().applySuspend { argument() }.build()
val mapped = of(toBeMapped)
this.gcfsConfig = mapped
}
/**
* @param value List of the type and count of accelerator cards attached to the instance.
* Structure documented below.
*/
@JvmName("gsncbxsddpiunpch")
public suspend fun guestAccelerators(`value`: List?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.guestAccelerators = mapped
}
/**
* @param argument List of the type and count of accelerator cards attached to the instance.
* Structure documented below.
*/
@JvmName("rldioaoehrshwbbm")
public suspend fun guestAccelerators(argument: List Unit>) {
val toBeMapped = argument.toList().map {
ClusterNodeConfigGuestAcceleratorArgsBuilder().applySuspend { it() }.build()
}
val mapped = of(toBeMapped)
this.guestAccelerators = mapped
}
/**
* @param argument List of the type and count of accelerator cards attached to the instance.
* Structure documented below.
*/
@JvmName("snqkopmwbfaqjtmi")
public suspend fun guestAccelerators(vararg argument: suspend ClusterNodeConfigGuestAcceleratorArgsBuilder.() -> Unit) {
val toBeMapped = argument.toList().map {
ClusterNodeConfigGuestAcceleratorArgsBuilder().applySuspend { it() }.build()
}
val mapped = of(toBeMapped)
this.guestAccelerators = mapped
}
/**
* @param argument List of the type and count of accelerator cards attached to the instance.
* Structure documented below.
*/
@JvmName("pueixkparfvukuug")
public suspend fun guestAccelerators(argument: suspend ClusterNodeConfigGuestAcceleratorArgsBuilder.() -> Unit) {
val toBeMapped = listOf(
ClusterNodeConfigGuestAcceleratorArgsBuilder().applySuspend {
argument()
}.build(),
)
val mapped = of(toBeMapped)
this.guestAccelerators = mapped
}
/**
* @param values List of the type and count of accelerator cards attached to the instance.
* Structure documented below.
*/
@JvmName("yjixepmlqpfelakl")
public suspend fun guestAccelerators(vararg values: ClusterNodeConfigGuestAcceleratorArgs) {
val toBeMapped = values.toList()
val mapped = toBeMapped.let({ args0 -> of(args0) })
this.guestAccelerators = mapped
}
/**
* @param value Google Virtual NIC (gVNIC) is a virtual network interface.
* Installing the gVNIC driver allows for more efficient traffic transmission across the Google network infrastructure.
* gVNIC is an alternative to the virtIO-based ethernet driver. GKE nodes must use a Container-Optimized OS node image.
* GKE node version 1.15.11-gke.15 or later
* Structure is documented below.
*/
@JvmName("hxldxnifgcnswnsi")
public suspend fun gvnic(`value`: ClusterNodeConfigGvnicArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.gvnic = mapped
}
/**
* @param argument Google Virtual NIC (gVNIC) is a virtual network interface.
* Installing the gVNIC driver allows for more efficient traffic transmission across the Google network infrastructure.
* gVNIC is an alternative to the virtIO-based ethernet driver. GKE nodes must use a Container-Optimized OS node image.
* GKE node version 1.15.11-gke.15 or later
* Structure is documented below.
*/
@JvmName("ixdbjebugxltnfkr")
public suspend fun gvnic(argument: suspend ClusterNodeConfigGvnicArgsBuilder.() -> Unit) {
val toBeMapped = ClusterNodeConfigGvnicArgsBuilder().applySuspend { argument() }.build()
val mapped = of(toBeMapped)
this.gvnic = mapped
}
/**
* @param value The maintenance policy for the hosts on which the GKE VMs run on.
*/
@JvmName("qxffpxsmhhbdnkdm")
public suspend fun hostMaintenancePolicy(`value`: ClusterNodeConfigHostMaintenancePolicyArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.hostMaintenancePolicy = mapped
}
/**
* @param argument The maintenance policy for the hosts on which the GKE VMs run on.
*/
@JvmName("ftxyokywolitlfrj")
public suspend fun hostMaintenancePolicy(argument: suspend ClusterNodeConfigHostMaintenancePolicyArgsBuilder.() -> Unit) {
val toBeMapped = ClusterNodeConfigHostMaintenancePolicyArgsBuilder().applySuspend {
argument()
}.build()
val mapped = of(toBeMapped)
this.hostMaintenancePolicy = mapped
}
/**
* @param value The image type to use for this node. Note that changing the image type
* will delete and recreate all nodes in the node pool.
*/
@JvmName("elacevonahliwydv")
public suspend fun imageType(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.imageType = mapped
}
/**
* @param value Kubelet configuration, currently supported attributes can be found [here](https://cloud.google.com/sdk/gcloud/reference/beta/container/node-pools/create#--system-config-from-file).
* Structure is documented below.
* ```
* kubelet_config {
* cpu_manager_policy = "static"
* cpu_cfs_quota = true
* cpu_cfs_quota_period = "100us"
* pod_pids_limit = 1024
* }
* ```
*/
@JvmName("cajrdxaxiiysofwb")
public suspend fun kubeletConfig(`value`: ClusterNodeConfigKubeletConfigArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.kubeletConfig = mapped
}
/**
* @param argument Kubelet configuration, currently supported attributes can be found [here](https://cloud.google.com/sdk/gcloud/reference/beta/container/node-pools/create#--system-config-from-file).
* Structure is documented below.
* ```
* kubelet_config {
* cpu_manager_policy = "static"
* cpu_cfs_quota = true
* cpu_cfs_quota_period = "100us"
* pod_pids_limit = 1024
* }
* ```
*/
@JvmName("fupddpivfysreeno")
public suspend fun kubeletConfig(argument: suspend ClusterNodeConfigKubeletConfigArgsBuilder.() -> Unit) {
val toBeMapped = ClusterNodeConfigKubeletConfigArgsBuilder().applySuspend { argument() }.build()
val mapped = of(toBeMapped)
this.kubeletConfig = mapped
}
/**
* @param value The Kubernetes labels (key/value pairs) to be applied to each node. The kubernetes.io/ and k8s.io/ prefixes are
* reserved by Kubernetes Core components and cannot be specified.
*/
@JvmName("nscmemhwxhcdbpdu")
public suspend fun labels(`value`: Map?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.labels = mapped
}
/**
* @param values The Kubernetes labels (key/value pairs) to be applied to each node. The kubernetes.io/ and k8s.io/ prefixes are
* reserved by Kubernetes Core components and cannot be specified.
*/
@JvmName("ljtluvutuedpvdnw")
public fun labels(vararg values: Pair) {
val toBeMapped = values.toMap()
val mapped = toBeMapped.let({ args0 -> of(args0) })
this.labels = mapped
}
/**
* @param value Parameters that can be configured on Linux nodes. Structure is documented below.
*/
@JvmName("uclcjdupfvwxiuia")
public suspend fun linuxNodeConfig(`value`: ClusterNodeConfigLinuxNodeConfigArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.linuxNodeConfig = mapped
}
/**
* @param argument Parameters that can be configured on Linux nodes. Structure is documented below.
*/
@JvmName("eswpmljbhcntouwg")
public suspend fun linuxNodeConfig(argument: suspend ClusterNodeConfigLinuxNodeConfigArgsBuilder.() -> Unit) {
val toBeMapped = ClusterNodeConfigLinuxNodeConfigArgsBuilder().applySuspend {
argument()
}.build()
val mapped = of(toBeMapped)
this.linuxNodeConfig = mapped
}
/**
* @param value Parameters for the local NVMe SSDs. Structure is documented below.
*/
@JvmName("nsfpfcqfqwtuqwls")
public suspend fun localNvmeSsdBlockConfig(`value`: ClusterNodeConfigLocalNvmeSsdBlockConfigArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.localNvmeSsdBlockConfig = mapped
}
/**
* @param argument Parameters for the local NVMe SSDs. Structure is documented below.
*/
@JvmName("fmmacneoxfyvreqn")
public suspend fun localNvmeSsdBlockConfig(argument: suspend ClusterNodeConfigLocalNvmeSsdBlockConfigArgsBuilder.() -> Unit) {
val toBeMapped = ClusterNodeConfigLocalNvmeSsdBlockConfigArgsBuilder().applySuspend {
argument()
}.build()
val mapped = of(toBeMapped)
this.localNvmeSsdBlockConfig = mapped
}
/**
* @param value The amount of local SSD disks that will be
* attached to each cluster node. Defaults to 0.
*/
@JvmName("rnkqulrqwyduqoos")
public suspend fun localSsdCount(`value`: Int?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.localSsdCount = mapped
}
/**
* @param value Parameter for specifying the type of logging agent used in a node pool. This will override any cluster-wide default value. Valid values include DEFAULT and MAX_THROUGHPUT. See [Increasing logging agent throughput](https://cloud.google.com/stackdriver/docs/solutions/gke/managing-logs#throughput) for more information.
*/
@JvmName("trahxtjhmcygbjhr")
public suspend fun loggingVariant(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.loggingVariant = mapped
}
/**
* @param value The name of a Google Compute Engine machine type.
* Defaults to `e2-medium`. To create a custom machine type, value should be set as specified
* [here](https://cloud.google.com/compute/docs/reference/latest/instances#machineType).
*/
@JvmName("oudcwqtudiqhxqxk")
public suspend fun machineType(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.machineType = mapped
}
/**
* @param value The metadata key/value pairs assigned to instances in
* the cluster. From GKE `1.12` onwards, `disable-legacy-endpoints` is set to
* `true` by the API; if `metadata` is set but that default value is not
* included, the provider will attempt to unset the value. To avoid this, set the
* value in your config.
*/
@JvmName("bdnrnrlcfdseyuxg")
public suspend fun metadata(`value`: Map?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.metadata = mapped
}
/**
* @param values The metadata key/value pairs assigned to instances in
* the cluster. From GKE `1.12` onwards, `disable-legacy-endpoints` is set to
* `true` by the API; if `metadata` is set but that default value is not
* included, the provider will attempt to unset the value. To avoid this, set the
* value in your config.
*/
@JvmName("nxbrtelnqstfydbh")
public fun metadata(vararg values: Pair) {
val toBeMapped = values.toMap()
val mapped = toBeMapped.let({ args0 -> of(args0) })
this.metadata = mapped
}
/**
* @param value 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 `Intel Haswell`. See the
* [official documentation](https://cloud.google.com/compute/docs/instances/specify-min-cpu-platform)
* for more information.
*/
@JvmName("xhbxwpfrgaxykypu")
public suspend fun minCpuPlatform(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.minCpuPlatform = mapped
}
/**
* @param value 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).
*/
@JvmName("ooyqjyvafnjldbcg")
public suspend fun nodeGroup(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.nodeGroup = mapped
}
/**
* @param value The set of Google API scopes to be made available
* on all of the node VMs under the "default" service account.
* Use the "https://www.googleapis.com/auth/cloud-platform" scope to grant access to all APIs. It is recommended that you set `service_account` to a non-default service account and grant IAM roles to that service account for only the resources that it needs.
* See the [official documentation](https://cloud.google.com/kubernetes-engine/docs/how-to/access-scopes) for information on migrating off of legacy access scopes.
*/
@JvmName("tocletpevmecacnu")
public suspend fun oauthScopes(`value`: List?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.oauthScopes = mapped
}
/**
* @param values The set of Google API scopes to be made available
* on all of the node VMs under the "default" service account.
* Use the "https://www.googleapis.com/auth/cloud-platform" scope to grant access to all APIs. It is recommended that you set `service_account` to a non-default service account and grant IAM roles to that service account for only the resources that it needs.
* See the [official documentation](https://cloud.google.com/kubernetes-engine/docs/how-to/access-scopes) for information on migrating off of legacy access scopes.
*/
@JvmName("tceqvbdbmilndmqc")
public suspend fun oauthScopes(vararg values: String) {
val toBeMapped = values.toList()
val mapped = toBeMapped.let({ args0 -> of(args0) })
this.oauthScopes = mapped
}
/**
* @param value A boolean that represents whether or not the underlying node VMs
* are preemptible. See the [official documentation](https://cloud.google.com/container-engine/docs/preemptible-vm)
* for more information. Defaults to false.
*/
@JvmName("ytiymuytvyydpovm")
public suspend fun preemptible(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.preemptible = mapped
}
/**
* @param value The configuration of the desired reservation which instances could take capacity from. Structure is documented below.
*/
@JvmName("bshjjjyhsdysycfh")
public suspend fun reservationAffinity(`value`: ClusterNodeConfigReservationAffinityArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.reservationAffinity = mapped
}
/**
* @param argument The configuration of the desired reservation which instances could take capacity from. Structure is documented below.
*/
@JvmName("ovbjpnvauhqcfbwm")
public suspend fun reservationAffinity(argument: suspend ClusterNodeConfigReservationAffinityArgsBuilder.() -> Unit) {
val toBeMapped = ClusterNodeConfigReservationAffinityArgsBuilder().applySuspend {
argument()
}.build()
val mapped = of(toBeMapped)
this.reservationAffinity = mapped
}
/**
* @param value The GCP labels (key/value pairs) to be applied to each node. Refer [here](https://cloud.google.com/kubernetes-engine/docs/how-to/creating-managing-labels)
* for how these labels are applied to clusters, node pools and nodes.
*/
@JvmName("sdyefkskisjsfchy")
public suspend fun resourceLabels(`value`: Map?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.resourceLabels = mapped
}
/**
* @param values The GCP labels (key/value pairs) to be applied to each node. Refer [here](https://cloud.google.com/kubernetes-engine/docs/how-to/creating-managing-labels)
* for how these labels are applied to clusters, node pools and nodes.
*/
@JvmName("flfghsgieddclaxd")
public fun resourceLabels(vararg values: Pair) {
val toBeMapped = values.toMap()
val mapped = toBeMapped.let({ args0 -> of(args0) })
this.resourceLabels = mapped
}
/**
* @param value A map of resource manager tag keys and values to be attached to the nodes for managing Compute Engine firewalls using Network Firewall Policies. Tags must be according to specifications found [here](https://cloud.google.com/vpc/docs/tags-firewalls-overview#specifications). A maximum of 5 tag key-value pairs can be specified. Existing tags will be replaced with new values. Tags must be in one of the following formats ([KEY]=[VALUE]) 1. `tagKeys/{tag_key_id}=tagValues/{tag_value_id}` 2. `{org_id}/{tag_key_name}={tag_value_name}` 3. `{project_id}/{tag_key_name}={tag_value_name}`.
*/
@JvmName("rmeneucxlgfagiti")
public suspend fun resourceManagerTags(`value`: Map?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.resourceManagerTags = mapped
}
/**
* @param values A map of resource manager tag keys and values to be attached to the nodes for managing Compute Engine firewalls using Network Firewall Policies. Tags must be according to specifications found [here](https://cloud.google.com/vpc/docs/tags-firewalls-overview#specifications). A maximum of 5 tag key-value pairs can be specified. Existing tags will be replaced with new values. Tags must be in one of the following formats ([KEY]=[VALUE]) 1. `tagKeys/{tag_key_id}=tagValues/{tag_value_id}` 2. `{org_id}/{tag_key_name}={tag_value_name}` 3. `{project_id}/{tag_key_name}={tag_value_name}`.
*/
@JvmName("iqfgadsfqxatsgrc")
public fun resourceManagerTags(vararg values: Pair) {
val toBeMapped = values.toMap()
val mapped = toBeMapped.let({ args0 -> of(args0) })
this.resourceManagerTags = mapped
}
/**
* @param value Sandbox configuration for this node.
*/
@JvmName("jduwnsxcdxtwtrwk")
public suspend fun sandboxConfig(`value`: ClusterNodeConfigSandboxConfigArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.sandboxConfig = mapped
}
/**
* @param argument Sandbox configuration for this node.
*/
@JvmName("awnisrtomtjlpfhj")
public suspend fun sandboxConfig(argument: suspend ClusterNodeConfigSandboxConfigArgsBuilder.() -> Unit) {
val toBeMapped = ClusterNodeConfigSandboxConfigArgsBuilder().applySuspend { argument() }.build()
val mapped = of(toBeMapped)
this.sandboxConfig = mapped
}
/**
* @param value Parameters for secondary boot disks to preload container images and data on new nodes. Structure is documented below. `gcfs_config` must be `enabled=true` for this feature to work. `min_master_version` must also be set to use GKE 1.28.3-gke.106700 or later versions.
*/
@JvmName("sbnmrfbalrmcuoad")
public suspend fun secondaryBootDisks(`value`: List?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.secondaryBootDisks = mapped
}
/**
* @param argument Parameters for secondary boot disks to preload container images and data on new nodes. Structure is documented below. `gcfs_config` must be `enabled=true` for this feature to work. `min_master_version` must also be set to use GKE 1.28.3-gke.106700 or later versions.
*/
@JvmName("sqlselhwttrufcvq")
public suspend fun secondaryBootDisks(argument: List Unit>) {
val toBeMapped = argument.toList().map {
ClusterNodeConfigSecondaryBootDiskArgsBuilder().applySuspend { it() }.build()
}
val mapped = of(toBeMapped)
this.secondaryBootDisks = mapped
}
/**
* @param argument Parameters for secondary boot disks to preload container images and data on new nodes. Structure is documented below. `gcfs_config` must be `enabled=true` for this feature to work. `min_master_version` must also be set to use GKE 1.28.3-gke.106700 or later versions.
*/
@JvmName("huwlrxyoahrwrjti")
public suspend fun secondaryBootDisks(vararg argument: suspend ClusterNodeConfigSecondaryBootDiskArgsBuilder.() -> Unit) {
val toBeMapped = argument.toList().map {
ClusterNodeConfigSecondaryBootDiskArgsBuilder().applySuspend { it() }.build()
}
val mapped = of(toBeMapped)
this.secondaryBootDisks = mapped
}
/**
* @param argument Parameters for secondary boot disks to preload container images and data on new nodes. Structure is documented below. `gcfs_config` must be `enabled=true` for this feature to work. `min_master_version` must also be set to use GKE 1.28.3-gke.106700 or later versions.
*/
@JvmName("afxyihlkefesamep")
public suspend fun secondaryBootDisks(argument: suspend ClusterNodeConfigSecondaryBootDiskArgsBuilder.() -> Unit) {
val toBeMapped = listOf(
ClusterNodeConfigSecondaryBootDiskArgsBuilder().applySuspend {
argument()
}.build(),
)
val mapped = of(toBeMapped)
this.secondaryBootDisks = mapped
}
/**
* @param values Parameters for secondary boot disks to preload container images and data on new nodes. Structure is documented below. `gcfs_config` must be `enabled=true` for this feature to work. `min_master_version` must also be set to use GKE 1.28.3-gke.106700 or later versions.
*/
@JvmName("sdchenbtsiyioxck")
public suspend fun secondaryBootDisks(vararg values: ClusterNodeConfigSecondaryBootDiskArgs) {
val toBeMapped = values.toList()
val mapped = toBeMapped.let({ args0 -> of(args0) })
this.secondaryBootDisks = mapped
}
/**
* @param value The service account to be used by the Node VMs.
* If not specified, the "default" service account is used.
*/
@JvmName("flybuwfdcowstrdg")
public suspend fun serviceAccount(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.serviceAccount = mapped
}
/**
* @param value Shielded Instance options. Structure is documented below.
*/
@JvmName("asqmwcrmbbyfqnks")
public suspend fun shieldedInstanceConfig(`value`: ClusterNodeConfigShieldedInstanceConfigArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.shieldedInstanceConfig = mapped
}
/**
* @param argument Shielded Instance options. Structure is documented below.
*/
@JvmName("fpksrgtitclsmkjd")
public suspend fun shieldedInstanceConfig(argument: suspend ClusterNodeConfigShieldedInstanceConfigArgsBuilder.() -> Unit) {
val toBeMapped = ClusterNodeConfigShieldedInstanceConfigArgsBuilder().applySuspend {
argument()
}.build()
val mapped = of(toBeMapped)
this.shieldedInstanceConfig = mapped
}
/**
* @param value Allows specifying multiple [node affinities](https://cloud.google.com/compute/docs/nodes/sole-tenant-nodes#node_affinity_and_anti-affinity) useful for running workloads on [sole tenant nodes](https://cloud.google.com/kubernetes-engine/docs/how-to/sole-tenancy). `node_affinity` structure is documented below.
*/
@JvmName("jcddahpeaawgxxir")
public suspend fun soleTenantConfig(`value`: ClusterNodeConfigSoleTenantConfigArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.soleTenantConfig = mapped
}
/**
* @param argument Allows specifying multiple [node affinities](https://cloud.google.com/compute/docs/nodes/sole-tenant-nodes#node_affinity_and_anti-affinity) useful for running workloads on [sole tenant nodes](https://cloud.google.com/kubernetes-engine/docs/how-to/sole-tenancy). `node_affinity` structure is documented below.
*/
@JvmName("ocinsmdyaixsuusq")
public suspend fun soleTenantConfig(argument: suspend ClusterNodeConfigSoleTenantConfigArgsBuilder.() -> Unit) {
val toBeMapped = ClusterNodeConfigSoleTenantConfigArgsBuilder().applySuspend {
argument()
}.build()
val mapped = of(toBeMapped)
this.soleTenantConfig = mapped
}
/**
* @param value A boolean that represents whether the underlying node VMs are spot.
* See the [official documentation](https://cloud.google.com/kubernetes-engine/docs/concepts/spot-vms)
* for more information. Defaults to false.
*/
@JvmName("djxcogpvjccyxsua")
public suspend fun spot(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.spot = mapped
}
/**
* @param value The list of instance tags applied to all nodes. Tags are used to identify
* valid sources or targets for network firewalls.
*/
@JvmName("tehbtvwohudonlcq")
public suspend fun tags(`value`: List?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.tags = mapped
}
/**
* @param values The list of instance tags applied to all nodes. Tags are used to identify
* valid sources or targets for network firewalls.
*/
@JvmName("qimcxffwpsggqevu")
public suspend fun tags(vararg values: String) {
val toBeMapped = values.toList()
val mapped = toBeMapped.let({ args0 -> of(args0) })
this.tags = mapped
}
/**
* @param value A list of [Kubernetes taints](https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/)
* to apply to nodes. GKE's API can only set this field on cluster creation.
* However, GKE will add taints to your nodes if you enable certain features such
* as GPUs. If this field is set, any diffs on this field will cause the provider to
* recreate the underlying resource. Taint values can be updated safely in
* Kubernetes (eg. through `kubectl`), and it's recommended that you do not use
* this field to manage taints. If you do, `lifecycle.ignore_changes` is
* recommended. Structure is documented below.
*/
@JvmName("nmcbwvhjsisehsyi")
public suspend fun taints(`value`: List?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.taints = mapped
}
/**
* @param argument A list of [Kubernetes taints](https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/)
* to apply to nodes. GKE's API can only set this field on cluster creation.
* However, GKE will add taints to your nodes if you enable certain features such
* as GPUs. If this field is set, any diffs on this field will cause the provider to
* recreate the underlying resource. Taint values can be updated safely in
* Kubernetes (eg. through `kubectl`), and it's recommended that you do not use
* this field to manage taints. If you do, `lifecycle.ignore_changes` is
* recommended. Structure is documented below.
*/
@JvmName("eolokvgjtkxwfueu")
public suspend fun taints(argument: List Unit>) {
val toBeMapped = argument.toList().map {
ClusterNodeConfigTaintArgsBuilder().applySuspend {
it()
}.build()
}
val mapped = of(toBeMapped)
this.taints = mapped
}
/**
* @param argument A list of [Kubernetes taints](https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/)
* to apply to nodes. GKE's API can only set this field on cluster creation.
* However, GKE will add taints to your nodes if you enable certain features such
* as GPUs. If this field is set, any diffs on this field will cause the provider to
* recreate the underlying resource. Taint values can be updated safely in
* Kubernetes (eg. through `kubectl`), and it's recommended that you do not use
* this field to manage taints. If you do, `lifecycle.ignore_changes` is
* recommended. Structure is documented below.
*/
@JvmName("bwajpojdeiksijgk")
public suspend fun taints(vararg argument: suspend ClusterNodeConfigTaintArgsBuilder.() -> Unit) {
val toBeMapped = argument.toList().map {
ClusterNodeConfigTaintArgsBuilder().applySuspend {
it()
}.build()
}
val mapped = of(toBeMapped)
this.taints = mapped
}
/**
* @param argument A list of [Kubernetes taints](https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/)
* to apply to nodes. GKE's API can only set this field on cluster creation.
* However, GKE will add taints to your nodes if you enable certain features such
* as GPUs. If this field is set, any diffs on this field will cause the provider to
* recreate the underlying resource. Taint values can be updated safely in
* Kubernetes (eg. through `kubectl`), and it's recommended that you do not use
* this field to manage taints. If you do, `lifecycle.ignore_changes` is
* recommended. Structure is documented below.
*/
@JvmName("uxowttawpahncycn")
public suspend fun taints(argument: suspend ClusterNodeConfigTaintArgsBuilder.() -> Unit) {
val toBeMapped = listOf(ClusterNodeConfigTaintArgsBuilder().applySuspend { argument() }.build())
val mapped = of(toBeMapped)
this.taints = mapped
}
/**
* @param values A list of [Kubernetes taints](https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/)
* to apply to nodes. GKE's API can only set this field on cluster creation.
* However, GKE will add taints to your nodes if you enable certain features such
* as GPUs. If this field is set, any diffs on this field will cause the provider to
* recreate the underlying resource. Taint values can be updated safely in
* Kubernetes (eg. through `kubectl`), and it's recommended that you do not use
* this field to manage taints. If you do, `lifecycle.ignore_changes` is
* recommended. Structure is documented below.
*/
@JvmName("jobeukdjwcvbcovh")
public suspend fun taints(vararg values: ClusterNodeConfigTaintArgs) {
val toBeMapped = values.toList()
val mapped = toBeMapped.let({ args0 -> of(args0) })
this.taints = mapped
}
/**
* @param value Metadata configuration to expose to workloads on the node pool.
* Structure is documented below.
*/
@JvmName("hrkdgkiybwrsfovp")
public suspend fun workloadMetadataConfig(`value`: ClusterNodeConfigWorkloadMetadataConfigArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.workloadMetadataConfig = mapped
}
/**
* @param argument Metadata configuration to expose to workloads on the node pool.
* Structure is documented below.
*/
@JvmName("pddnwhodekvtarhf")
public suspend fun workloadMetadataConfig(argument: suspend ClusterNodeConfigWorkloadMetadataConfigArgsBuilder.() -> Unit) {
val toBeMapped = ClusterNodeConfigWorkloadMetadataConfigArgsBuilder().applySuspend {
argument()
}.build()
val mapped = of(toBeMapped)
this.workloadMetadataConfig = mapped
}
internal fun build(): ClusterNodeConfigArgs = ClusterNodeConfigArgs(
advancedMachineFeatures = advancedMachineFeatures,
bootDiskKmsKey = bootDiskKmsKey,
confidentialNodes = confidentialNodes,
diskSizeGb = diskSizeGb,
diskType = diskType,
effectiveTaints = effectiveTaints,
enableConfidentialStorage = enableConfidentialStorage,
ephemeralStorageConfig = ephemeralStorageConfig,
ephemeralStorageLocalSsdConfig = ephemeralStorageLocalSsdConfig,
fastSocket = fastSocket,
gcfsConfig = gcfsConfig,
guestAccelerators = guestAccelerators,
gvnic = gvnic,
hostMaintenancePolicy = hostMaintenancePolicy,
imageType = imageType,
kubeletConfig = kubeletConfig,
labels = labels,
linuxNodeConfig = linuxNodeConfig,
localNvmeSsdBlockConfig = localNvmeSsdBlockConfig,
localSsdCount = localSsdCount,
loggingVariant = loggingVariant,
machineType = machineType,
metadata = metadata,
minCpuPlatform = minCpuPlatform,
nodeGroup = nodeGroup,
oauthScopes = oauthScopes,
preemptible = preemptible,
reservationAffinity = reservationAffinity,
resourceLabels = resourceLabels,
resourceManagerTags = resourceManagerTags,
sandboxConfig = sandboxConfig,
secondaryBootDisks = secondaryBootDisks,
serviceAccount = serviceAccount,
shieldedInstanceConfig = shieldedInstanceConfig,
soleTenantConfig = soleTenantConfig,
spot = spot,
tags = tags,
taints = taints,
workloadMetadataConfig = workloadMetadataConfig,
)
}