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

com.pulumi.kubernetes.apiextensions.v1.kotlin.inputs.WebhookClientConfigArgs.kt Maven / Gradle / Ivy

@file:Suppress("NAME_SHADOWING", "DEPRECATION")

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

import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.applySuspend
import com.pulumi.kubernetes.apiextensions.v1.inputs.WebhookClientConfigArgs.builder
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.jvm.JvmName

/**
 * WebhookClientConfig contains the information to make a TLS connection with the webhook.
 * @property caBundle caBundle is a PEM encoded CA bundle which will be used to validate the webhook's server certificate. If unspecified, system trust roots on the apiserver are used.
 * @property service service is a reference to the service for this webhook. Either service or url must be specified.
 * If the webhook is running within the cluster, then you should use `service`.
 * @property url url gives the location of the webhook, in standard URL form (`scheme://host:port/path`). Exactly one of `url` or `service` must be specified.
 * The `host` should not refer to a service running in the cluster; use the `service` field instead. The host might be resolved via external DNS in some apiservers (e.g., `kube-apiserver` cannot resolve in-cluster DNS as that would be a layering violation). `host` may also be an IP address.
 * Please note that using `localhost` or `127.0.0.1` as a `host` is risky unless you take great care to run this webhook on all hosts which run an apiserver which might need to make calls to this webhook. Such installs are likely to be non-portable, i.e., not easy to turn up in a new cluster.
 * The scheme must be "https"; the URL must begin with "https://".
 * A path is optional, and if present may be any string permissible in a URL. You may use the path to pass an arbitrary string to the webhook, for example, a cluster identifier.
 * Attempting to use a user or basic auth e.g. "user:password@" is not allowed. Fragments ("#...") and query parameters ("?...") are not allowed, either.
 */
public data class WebhookClientConfigArgs(
    public val caBundle: Output? = null,
    public val service: Output? = null,
    public val url: Output? = null,
) : ConvertibleToJava {
    override fun toJava(): com.pulumi.kubernetes.apiextensions.v1.inputs.WebhookClientConfigArgs =
        com.pulumi.kubernetes.apiextensions.v1.inputs.WebhookClientConfigArgs.builder()
            .caBundle(caBundle?.applyValue({ args0 -> args0 }))
            .service(service?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
            .url(url?.applyValue({ args0 -> args0 })).build()
}

/**
 * Builder for [WebhookClientConfigArgs].
 */
@PulumiTagMarker
public class WebhookClientConfigArgsBuilder internal constructor() {
    private var caBundle: Output? = null

    private var service: Output? = null

    private var url: Output? = null

    /**
     * @param value caBundle is a PEM encoded CA bundle which will be used to validate the webhook's server certificate. If unspecified, system trust roots on the apiserver are used.
     */
    @JvmName("cdngedjspcjffapf")
    public suspend fun caBundle(`value`: Output) {
        this.caBundle = value
    }

    /**
     * @param value service is a reference to the service for this webhook. Either service or url must be specified.
     * If the webhook is running within the cluster, then you should use `service`.
     */
    @JvmName("flnvirdbfwnilbil")
    public suspend fun service(`value`: Output) {
        this.service = value
    }

    /**
     * @param value url gives the location of the webhook, in standard URL form (`scheme://host:port/path`). Exactly one of `url` or `service` must be specified.
     * The `host` should not refer to a service running in the cluster; use the `service` field instead. The host might be resolved via external DNS in some apiservers (e.g., `kube-apiserver` cannot resolve in-cluster DNS as that would be a layering violation). `host` may also be an IP address.
     * Please note that using `localhost` or `127.0.0.1` as a `host` is risky unless you take great care to run this webhook on all hosts which run an apiserver which might need to make calls to this webhook. Such installs are likely to be non-portable, i.e., not easy to turn up in a new cluster.
     * The scheme must be "https"; the URL must begin with "https://".
     * A path is optional, and if present may be any string permissible in a URL. You may use the path to pass an arbitrary string to the webhook, for example, a cluster identifier.
     * Attempting to use a user or basic auth e.g. "user:password@" is not allowed. Fragments ("#...") and query parameters ("?...") are not allowed, either.
     */
    @JvmName("ecriuadchyexirgs")
    public suspend fun url(`value`: Output) {
        this.url = value
    }

    /**
     * @param value caBundle is a PEM encoded CA bundle which will be used to validate the webhook's server certificate. If unspecified, system trust roots on the apiserver are used.
     */
    @JvmName("srcavwjxbahyjrys")
    public suspend fun caBundle(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.caBundle = mapped
    }

    /**
     * @param value service is a reference to the service for this webhook. Either service or url must be specified.
     * If the webhook is running within the cluster, then you should use `service`.
     */
    @JvmName("duendwtsasnqqorp")
    public suspend fun service(`value`: ServiceReferenceArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.service = mapped
    }

    /**
     * @param argument service is a reference to the service for this webhook. Either service or url must be specified.
     * If the webhook is running within the cluster, then you should use `service`.
     */
    @JvmName("rmmxwvfxkmbtwqwt")
    public suspend fun service(argument: suspend ServiceReferenceArgsBuilder.() -> Unit) {
        val toBeMapped = ServiceReferenceArgsBuilder().applySuspend { argument() }.build()
        val mapped = of(toBeMapped)
        this.service = mapped
    }

    /**
     * @param value url gives the location of the webhook, in standard URL form (`scheme://host:port/path`). Exactly one of `url` or `service` must be specified.
     * The `host` should not refer to a service running in the cluster; use the `service` field instead. The host might be resolved via external DNS in some apiservers (e.g., `kube-apiserver` cannot resolve in-cluster DNS as that would be a layering violation). `host` may also be an IP address.
     * Please note that using `localhost` or `127.0.0.1` as a `host` is risky unless you take great care to run this webhook on all hosts which run an apiserver which might need to make calls to this webhook. Such installs are likely to be non-portable, i.e., not easy to turn up in a new cluster.
     * The scheme must be "https"; the URL must begin with "https://".
     * A path is optional, and if present may be any string permissible in a URL. You may use the path to pass an arbitrary string to the webhook, for example, a cluster identifier.
     * Attempting to use a user or basic auth e.g. "user:password@" is not allowed. Fragments ("#...") and query parameters ("?...") are not allowed, either.
     */
    @JvmName("purkjwxjqqjxmjdn")
    public suspend fun url(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.url = mapped
    }

    internal fun build(): WebhookClientConfigArgs = WebhookClientConfigArgs(
        caBundle = caBundle,
        service = service,
        url = url,
    )
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy