All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.pulumi.kubernetes.apiextensions.v1beta1.kotlin.inputs.CustomResourceConversionArgs.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.

The newest version!
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.kubernetes.apiextensions.v1beta1.kotlin.inputs

import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiNullFieldException
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.applySuspend
import com.pulumi.kubernetes.apiextensions.v1beta1.inputs.CustomResourceConversionArgs.builder
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.List
import kotlin.jvm.JvmName

/**
 * CustomResourceConversion describes how to convert different versions of a CR.
 * @property conversionReviewVersions conversionReviewVersions is an ordered list of preferred `ConversionReview` versions the Webhook expects. The API server will use the first version in the list which it supports. If none of the versions specified in this list are supported by API server, conversion will fail for the custom resource. If a persisted Webhook configuration specifies allowed versions and does not include any versions known to the API Server, calls to the webhook will fail. Defaults to `["v1beta1"]`.
 * @property strategy strategy specifies how custom resources are converted between versions. Allowed values are: - `None`: The converter only change the apiVersion and would not touch any other field in the custom resource. - `Webhook`: API Server will call to an external webhook to do the conversion. Additional information
 *   is needed for this option. This requires spec.preserveUnknownFields to be false, and spec.conversion.webhookClientConfig to be set.
 * @property webhookClientConfig webhookClientConfig is the instructions for how to call the webhook if strategy is `Webhook`. Required when `strategy` is set to `Webhook`.
 */
public data class CustomResourceConversionArgs(
    public val conversionReviewVersions: Output>? = null,
    public val strategy: Output,
    public val webhookClientConfig: Output? = null,
) :
    ConvertibleToJava {
    override fun toJava(): com.pulumi.kubernetes.apiextensions.v1beta1.inputs.CustomResourceConversionArgs =
        com.pulumi.kubernetes.apiextensions.v1beta1.inputs.CustomResourceConversionArgs.builder()
            .conversionReviewVersions(
                conversionReviewVersions?.applyValue({ args0 ->
                    args0.map({ args0 ->
                        args0
                    })
                }),
            )
            .strategy(strategy.applyValue({ args0 -> args0 }))
            .webhookClientConfig(
                webhookClientConfig?.applyValue({ args0 ->
                    args0.let({ args0 ->
                        args0.toJava()
                    })
                }),
            ).build()
}

/**
 * Builder for [CustomResourceConversionArgs].
 */
@PulumiTagMarker
public class CustomResourceConversionArgsBuilder internal constructor() {
    private var conversionReviewVersions: Output>? = null

    private var strategy: Output? = null

    private var webhookClientConfig: Output? = null

    /**
     * @param value conversionReviewVersions is an ordered list of preferred `ConversionReview` versions the Webhook expects. The API server will use the first version in the list which it supports. If none of the versions specified in this list are supported by API server, conversion will fail for the custom resource. If a persisted Webhook configuration specifies allowed versions and does not include any versions known to the API Server, calls to the webhook will fail. Defaults to `["v1beta1"]`.
     */
    @JvmName("ejtbtgjneuudnahr")
    public suspend fun conversionReviewVersions(`value`: Output>) {
        this.conversionReviewVersions = value
    }

    @JvmName("pdvwdxdgjruqcsml")
    public suspend fun conversionReviewVersions(vararg values: Output) {
        this.conversionReviewVersions = Output.all(values.asList())
    }

    /**
     * @param values conversionReviewVersions is an ordered list of preferred `ConversionReview` versions the Webhook expects. The API server will use the first version in the list which it supports. If none of the versions specified in this list are supported by API server, conversion will fail for the custom resource. If a persisted Webhook configuration specifies allowed versions and does not include any versions known to the API Server, calls to the webhook will fail. Defaults to `["v1beta1"]`.
     */
    @JvmName("nlsuqwbxxoqjifdj")
    public suspend fun conversionReviewVersions(values: List>) {
        this.conversionReviewVersions = Output.all(values)
    }

    /**
     * @param value strategy specifies how custom resources are converted between versions. Allowed values are: - `None`: The converter only change the apiVersion and would not touch any other field in the custom resource. - `Webhook`: API Server will call to an external webhook to do the conversion. Additional information
     *   is needed for this option. This requires spec.preserveUnknownFields to be false, and spec.conversion.webhookClientConfig to be set.
     */
    @JvmName("hheqreuwbrfvupgy")
    public suspend fun strategy(`value`: Output) {
        this.strategy = value
    }

    /**
     * @param value webhookClientConfig is the instructions for how to call the webhook if strategy is `Webhook`. Required when `strategy` is set to `Webhook`.
     */
    @JvmName("ovnbfnnrqbjfvtds")
    public suspend fun webhookClientConfig(`value`: Output) {
        this.webhookClientConfig = value
    }

    /**
     * @param value conversionReviewVersions is an ordered list of preferred `ConversionReview` versions the Webhook expects. The API server will use the first version in the list which it supports. If none of the versions specified in this list are supported by API server, conversion will fail for the custom resource. If a persisted Webhook configuration specifies allowed versions and does not include any versions known to the API Server, calls to the webhook will fail. Defaults to `["v1beta1"]`.
     */
    @JvmName("xvihahardcmvxmla")
    public suspend fun conversionReviewVersions(`value`: List?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.conversionReviewVersions = mapped
    }

    /**
     * @param values conversionReviewVersions is an ordered list of preferred `ConversionReview` versions the Webhook expects. The API server will use the first version in the list which it supports. If none of the versions specified in this list are supported by API server, conversion will fail for the custom resource. If a persisted Webhook configuration specifies allowed versions and does not include any versions known to the API Server, calls to the webhook will fail. Defaults to `["v1beta1"]`.
     */
    @JvmName("ruhtkjrujibdosla")
    public suspend fun conversionReviewVersions(vararg values: String) {
        val toBeMapped = values.toList()
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.conversionReviewVersions = mapped
    }

    /**
     * @param value strategy specifies how custom resources are converted between versions. Allowed values are: - `None`: The converter only change the apiVersion and would not touch any other field in the custom resource. - `Webhook`: API Server will call to an external webhook to do the conversion. Additional information
     *   is needed for this option. This requires spec.preserveUnknownFields to be false, and spec.conversion.webhookClientConfig to be set.
     */
    @JvmName("mnkdpuobcexkmlpe")
    public suspend fun strategy(`value`: String) {
        val toBeMapped = value
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.strategy = mapped
    }

    /**
     * @param value webhookClientConfig is the instructions for how to call the webhook if strategy is `Webhook`. Required when `strategy` is set to `Webhook`.
     */
    @JvmName("tqmbadigacmbcarb")
    public suspend fun webhookClientConfig(`value`: WebhookClientConfigArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.webhookClientConfig = mapped
    }

    /**
     * @param argument webhookClientConfig is the instructions for how to call the webhook if strategy is `Webhook`. Required when `strategy` is set to `Webhook`.
     */
    @JvmName("xqrhdoufhknhdpgv")
    public suspend fun webhookClientConfig(argument: suspend WebhookClientConfigArgsBuilder.() -> Unit) {
        val toBeMapped = WebhookClientConfigArgsBuilder().applySuspend { argument() }.build()
        val mapped = of(toBeMapped)
        this.webhookClientConfig = mapped
    }

    internal fun build(): CustomResourceConversionArgs = CustomResourceConversionArgs(
        conversionReviewVersions = conversionReviewVersions,
        strategy = strategy ?: throw PulumiNullFieldException("strategy"),
        webhookClientConfig = webhookClientConfig,
    )
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy