com.pulumi.kubernetes.admissionregistration.v1beta1.kotlin.inputs.WebhookClientConfigArgs.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pulumi-kubernetes-kotlin Show documentation
Show all versions of pulumi-kubernetes-kotlin Show documentation
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.kubernetes.admissionregistration.v1beta1.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.admissionregistration.v1beta1.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.admissionregistration.v1beta1.inputs.WebhookClientConfigArgs =
com.pulumi.kubernetes.admissionregistration.v1beta1.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("emypnsnumxwhxtrq")
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("jcqyvcmqaviplxya")
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("xanwhysuvlumiaim")
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("mtxuwyvpciwkbhgg")
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("xfafirapqhnutuhd")
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("dainhxwkkpjbvtqm")
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("dympotbwcdldayha")
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