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

com.pulumi.gcp.compute.kotlin.inputs.URLMapPathMatcherDefaultRouteActionArgs.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.

There is a newer version: 8.10.0.0
Show newest version
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.gcp.compute.kotlin.inputs

import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.gcp.compute.inputs.URLMapPathMatcherDefaultRouteActionArgs.builder
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.applySuspend
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.List
import kotlin.jvm.JvmName

/**
 *
 * @property corsPolicy The specification for allowing client side cross-origin requests. Please see
 * [W3C Recommendation for Cross Origin Resource Sharing](https://www.w3.org/TR/cors/)
 * Structure is documented below.
 * @property faultInjectionPolicy The specification for fault injection introduced into traffic to test the resiliency of clients to backend service failure.
 * As part of fault injection, when clients send requests to a backend service, delays can be introduced by Loadbalancer on a
 * percentage of requests before sending those request to the backend service. Similarly requests from clients can be aborted
 * by the Loadbalancer for a percentage of requests.
 * timeout and retryPolicy will be ignored by clients that are configured with a faultInjectionPolicy.
 * Structure is documented below.
 * @property requestMirrorPolicy Specifies the policy on how requests intended for the route's backends are shadowed to a separate mirrored backend service.
 * Loadbalancer does not wait for responses from the shadow service. Prior to sending traffic to the shadow service,
 * the host / authority header is suffixed with -shadow.
 * Structure is documented below.
 * @property retryPolicy Specifies the retry policy associated with this route.
 * Structure is documented below.
 * @property timeout Specifies the timeout for the selected route. Timeout is computed from the time the request has been
 * fully processed (i.e. end-of-stream) up until the response has been completely processed. Timeout includes all retries.
 * If not specified, will use the largest timeout among all backend services associated with the route.
 * Structure is documented below.
 * @property urlRewrite The spec to modify the URL of the request, prior to forwarding the request to the matched service.
 * Structure is documented below.
 * @property weightedBackendServices A list of weighted backend services to send traffic to when a route match occurs.
 * The weights determine the fraction of traffic that flows to their corresponding backend service.
 * If all traffic needs to go to a single backend service, there must be one weightedBackendService
 * with weight set to a non 0 number.
 * Once a backendService is identified and before forwarding the request to the backend service,
 * advanced routing actions like Url rewrites and header transformations are applied depending on
 * additional settings specified in this HttpRouteAction.
 * Structure is documented below.
 */
public data class URLMapPathMatcherDefaultRouteActionArgs(
    public val corsPolicy: Output? = null,
    public val faultInjectionPolicy: Output? = null,
    public val requestMirrorPolicy: Output? = null,
    public val retryPolicy: Output? = null,
    public val timeout: Output? = null,
    public val urlRewrite: Output? = null,
    public val weightedBackendServices: Output>? = null,
) : ConvertibleToJava {
    override fun toJava(): com.pulumi.gcp.compute.inputs.URLMapPathMatcherDefaultRouteActionArgs =
        com.pulumi.gcp.compute.inputs.URLMapPathMatcherDefaultRouteActionArgs.builder()
            .corsPolicy(corsPolicy?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
            .faultInjectionPolicy(
                faultInjectionPolicy?.applyValue({ args0 ->
                    args0.let({ args0 ->
                        args0.toJava()
                    })
                }),
            )
            .requestMirrorPolicy(
                requestMirrorPolicy?.applyValue({ args0 ->
                    args0.let({ args0 ->
                        args0.toJava()
                    })
                }),
            )
            .retryPolicy(retryPolicy?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
            .timeout(timeout?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
            .urlRewrite(urlRewrite?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
            .weightedBackendServices(
                weightedBackendServices?.applyValue({ args0 ->
                    args0.map({ args0 ->
                        args0.let({ args0 -> args0.toJava() })
                    })
                }),
            ).build()
}

/**
 * Builder for [URLMapPathMatcherDefaultRouteActionArgs].
 */
@PulumiTagMarker
public class URLMapPathMatcherDefaultRouteActionArgsBuilder internal constructor() {
    private var corsPolicy: Output? = null

    private var faultInjectionPolicy:
        Output? = null

    private var requestMirrorPolicy:
        Output? = null

    private var retryPolicy: Output? = null

    private var timeout: Output? = null

    private var urlRewrite: Output? = null

    private var weightedBackendServices:
        Output>? = null

    /**
     * @param value The specification for allowing client side cross-origin requests. Please see
     * [W3C Recommendation for Cross Origin Resource Sharing](https://www.w3.org/TR/cors/)
     * Structure is documented below.
     */
    @JvmName("gylpapqeajlhforb")
    public suspend fun corsPolicy(`value`: Output) {
        this.corsPolicy = value
    }

    /**
     * @param value The specification for fault injection introduced into traffic to test the resiliency of clients to backend service failure.
     * As part of fault injection, when clients send requests to a backend service, delays can be introduced by Loadbalancer on a
     * percentage of requests before sending those request to the backend service. Similarly requests from clients can be aborted
     * by the Loadbalancer for a percentage of requests.
     * timeout and retryPolicy will be ignored by clients that are configured with a faultInjectionPolicy.
     * Structure is documented below.
     */
    @JvmName("cticocityptpagpq")
    public suspend fun faultInjectionPolicy(`value`: Output) {
        this.faultInjectionPolicy = value
    }

    /**
     * @param value Specifies the policy on how requests intended for the route's backends are shadowed to a separate mirrored backend service.
     * Loadbalancer does not wait for responses from the shadow service. Prior to sending traffic to the shadow service,
     * the host / authority header is suffixed with -shadow.
     * Structure is documented below.
     */
    @JvmName("hpsftccysolmurty")
    public suspend fun requestMirrorPolicy(`value`: Output) {
        this.requestMirrorPolicy = value
    }

    /**
     * @param value Specifies the retry policy associated with this route.
     * Structure is documented below.
     */
    @JvmName("gmsdafnbvtkaonlm")
    public suspend fun retryPolicy(`value`: Output) {
        this.retryPolicy = value
    }

    /**
     * @param value Specifies the timeout for the selected route. Timeout is computed from the time the request has been
     * fully processed (i.e. end-of-stream) up until the response has been completely processed. Timeout includes all retries.
     * If not specified, will use the largest timeout among all backend services associated with the route.
     * Structure is documented below.
     */
    @JvmName("sttmcafnkqbbgnol")
    public suspend fun timeout(`value`: Output) {
        this.timeout = value
    }

    /**
     * @param value The spec to modify the URL of the request, prior to forwarding the request to the matched service.
     * Structure is documented below.
     */
    @JvmName("hmvevlogpacqoftj")
    public suspend fun urlRewrite(`value`: Output) {
        this.urlRewrite = value
    }

    /**
     * @param value A list of weighted backend services to send traffic to when a route match occurs.
     * The weights determine the fraction of traffic that flows to their corresponding backend service.
     * If all traffic needs to go to a single backend service, there must be one weightedBackendService
     * with weight set to a non 0 number.
     * Once a backendService is identified and before forwarding the request to the backend service,
     * advanced routing actions like Url rewrites and header transformations are applied depending on
     * additional settings specified in this HttpRouteAction.
     * Structure is documented below.
     */
    @JvmName("nvsavcehaxfmmccl")
    public suspend fun weightedBackendServices(`value`: Output>) {
        this.weightedBackendServices = value
    }

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

    /**
     * @param values A list of weighted backend services to send traffic to when a route match occurs.
     * The weights determine the fraction of traffic that flows to their corresponding backend service.
     * If all traffic needs to go to a single backend service, there must be one weightedBackendService
     * with weight set to a non 0 number.
     * Once a backendService is identified and before forwarding the request to the backend service,
     * advanced routing actions like Url rewrites and header transformations are applied depending on
     * additional settings specified in this HttpRouteAction.
     * Structure is documented below.
     */
    @JvmName("owjtxufgbmfhwjyg")
    public suspend fun weightedBackendServices(values: List>) {
        this.weightedBackendServices = Output.all(values)
    }

    /**
     * @param value The specification for allowing client side cross-origin requests. Please see
     * [W3C Recommendation for Cross Origin Resource Sharing](https://www.w3.org/TR/cors/)
     * Structure is documented below.
     */
    @JvmName("xbqxasdkiasdufym")
    public suspend fun corsPolicy(`value`: URLMapPathMatcherDefaultRouteActionCorsPolicyArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.corsPolicy = mapped
    }

    /**
     * @param argument The specification for allowing client side cross-origin requests. Please see
     * [W3C Recommendation for Cross Origin Resource Sharing](https://www.w3.org/TR/cors/)
     * Structure is documented below.
     */
    @JvmName("rtdukcsukwdsjjue")
    public suspend fun corsPolicy(argument: suspend URLMapPathMatcherDefaultRouteActionCorsPolicyArgsBuilder.() -> Unit) {
        val toBeMapped = URLMapPathMatcherDefaultRouteActionCorsPolicyArgsBuilder().applySuspend {
            argument()
        }.build()
        val mapped = of(toBeMapped)
        this.corsPolicy = mapped
    }

    /**
     * @param value The specification for fault injection introduced into traffic to test the resiliency of clients to backend service failure.
     * As part of fault injection, when clients send requests to a backend service, delays can be introduced by Loadbalancer on a
     * percentage of requests before sending those request to the backend service. Similarly requests from clients can be aborted
     * by the Loadbalancer for a percentage of requests.
     * timeout and retryPolicy will be ignored by clients that are configured with a faultInjectionPolicy.
     * Structure is documented below.
     */
    @JvmName("mpupoyepajxkyope")
    public suspend fun faultInjectionPolicy(`value`: URLMapPathMatcherDefaultRouteActionFaultInjectionPolicyArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.faultInjectionPolicy = mapped
    }

    /**
     * @param argument The specification for fault injection introduced into traffic to test the resiliency of clients to backend service failure.
     * As part of fault injection, when clients send requests to a backend service, delays can be introduced by Loadbalancer on a
     * percentage of requests before sending those request to the backend service. Similarly requests from clients can be aborted
     * by the Loadbalancer for a percentage of requests.
     * timeout and retryPolicy will be ignored by clients that are configured with a faultInjectionPolicy.
     * Structure is documented below.
     */
    @JvmName("frctorespkxnhiys")
    public suspend fun faultInjectionPolicy(argument: suspend URLMapPathMatcherDefaultRouteActionFaultInjectionPolicyArgsBuilder.() -> Unit) {
        val toBeMapped =
            URLMapPathMatcherDefaultRouteActionFaultInjectionPolicyArgsBuilder().applySuspend {
                argument()
            }.build()
        val mapped = of(toBeMapped)
        this.faultInjectionPolicy = mapped
    }

    /**
     * @param value Specifies the policy on how requests intended for the route's backends are shadowed to a separate mirrored backend service.
     * Loadbalancer does not wait for responses from the shadow service. Prior to sending traffic to the shadow service,
     * the host / authority header is suffixed with -shadow.
     * Structure is documented below.
     */
    @JvmName("xbylfddnftludhtn")
    public suspend fun requestMirrorPolicy(`value`: URLMapPathMatcherDefaultRouteActionRequestMirrorPolicyArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.requestMirrorPolicy = mapped
    }

    /**
     * @param argument Specifies the policy on how requests intended for the route's backends are shadowed to a separate mirrored backend service.
     * Loadbalancer does not wait for responses from the shadow service. Prior to sending traffic to the shadow service,
     * the host / authority header is suffixed with -shadow.
     * Structure is documented below.
     */
    @JvmName("nuilhxmfatmuotup")
    public suspend fun requestMirrorPolicy(argument: suspend URLMapPathMatcherDefaultRouteActionRequestMirrorPolicyArgsBuilder.() -> Unit) {
        val toBeMapped =
            URLMapPathMatcherDefaultRouteActionRequestMirrorPolicyArgsBuilder().applySuspend {
                argument()
            }.build()
        val mapped = of(toBeMapped)
        this.requestMirrorPolicy = mapped
    }

    /**
     * @param value Specifies the retry policy associated with this route.
     * Structure is documented below.
     */
    @JvmName("ljfoegdhybhlpfgq")
    public suspend fun retryPolicy(`value`: URLMapPathMatcherDefaultRouteActionRetryPolicyArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.retryPolicy = mapped
    }

    /**
     * @param argument Specifies the retry policy associated with this route.
     * Structure is documented below.
     */
    @JvmName("mprhcnblrcsnwukw")
    public suspend fun retryPolicy(argument: suspend URLMapPathMatcherDefaultRouteActionRetryPolicyArgsBuilder.() -> Unit) {
        val toBeMapped = URLMapPathMatcherDefaultRouteActionRetryPolicyArgsBuilder().applySuspend {
            argument()
        }.build()
        val mapped = of(toBeMapped)
        this.retryPolicy = mapped
    }

    /**
     * @param value Specifies the timeout for the selected route. Timeout is computed from the time the request has been
     * fully processed (i.e. end-of-stream) up until the response has been completely processed. Timeout includes all retries.
     * If not specified, will use the largest timeout among all backend services associated with the route.
     * Structure is documented below.
     */
    @JvmName("sbccljmgfkpgkbms")
    public suspend fun timeout(`value`: URLMapPathMatcherDefaultRouteActionTimeoutArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.timeout = mapped
    }

    /**
     * @param argument Specifies the timeout for the selected route. Timeout is computed from the time the request has been
     * fully processed (i.e. end-of-stream) up until the response has been completely processed. Timeout includes all retries.
     * If not specified, will use the largest timeout among all backend services associated with the route.
     * Structure is documented below.
     */
    @JvmName("axvsucvbfuucryhp")
    public suspend fun timeout(argument: suspend URLMapPathMatcherDefaultRouteActionTimeoutArgsBuilder.() -> Unit) {
        val toBeMapped = URLMapPathMatcherDefaultRouteActionTimeoutArgsBuilder().applySuspend {
            argument()
        }.build()
        val mapped = of(toBeMapped)
        this.timeout = mapped
    }

    /**
     * @param value The spec to modify the URL of the request, prior to forwarding the request to the matched service.
     * Structure is documented below.
     */
    @JvmName("vxvtishwcilgthcf")
    public suspend fun urlRewrite(`value`: URLMapPathMatcherDefaultRouteActionUrlRewriteArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.urlRewrite = mapped
    }

    /**
     * @param argument The spec to modify the URL of the request, prior to forwarding the request to the matched service.
     * Structure is documented below.
     */
    @JvmName("qpjsfifqnncefycn")
    public suspend fun urlRewrite(argument: suspend URLMapPathMatcherDefaultRouteActionUrlRewriteArgsBuilder.() -> Unit) {
        val toBeMapped = URLMapPathMatcherDefaultRouteActionUrlRewriteArgsBuilder().applySuspend {
            argument()
        }.build()
        val mapped = of(toBeMapped)
        this.urlRewrite = mapped
    }

    /**
     * @param value A list of weighted backend services to send traffic to when a route match occurs.
     * The weights determine the fraction of traffic that flows to their corresponding backend service.
     * If all traffic needs to go to a single backend service, there must be one weightedBackendService
     * with weight set to a non 0 number.
     * Once a backendService is identified and before forwarding the request to the backend service,
     * advanced routing actions like Url rewrites and header transformations are applied depending on
     * additional settings specified in this HttpRouteAction.
     * Structure is documented below.
     */
    @JvmName("kgedawdqbltejwej")
    public suspend fun weightedBackendServices(`value`: List?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.weightedBackendServices = mapped
    }

    /**
     * @param argument A list of weighted backend services to send traffic to when a route match occurs.
     * The weights determine the fraction of traffic that flows to their corresponding backend service.
     * If all traffic needs to go to a single backend service, there must be one weightedBackendService
     * with weight set to a non 0 number.
     * Once a backendService is identified and before forwarding the request to the backend service,
     * advanced routing actions like Url rewrites and header transformations are applied depending on
     * additional settings specified in this HttpRouteAction.
     * Structure is documented below.
     */
    @JvmName("juofajxmssnwyxem")
    public suspend fun weightedBackendServices(argument: List Unit>) {
        val toBeMapped = argument.toList().map {
            URLMapPathMatcherDefaultRouteActionWeightedBackendServiceArgsBuilder().applySuspend {
                it()
            }.build()
        }
        val mapped = of(toBeMapped)
        this.weightedBackendServices = mapped
    }

    /**
     * @param argument A list of weighted backend services to send traffic to when a route match occurs.
     * The weights determine the fraction of traffic that flows to their corresponding backend service.
     * If all traffic needs to go to a single backend service, there must be one weightedBackendService
     * with weight set to a non 0 number.
     * Once a backendService is identified and before forwarding the request to the backend service,
     * advanced routing actions like Url rewrites and header transformations are applied depending on
     * additional settings specified in this HttpRouteAction.
     * Structure is documented below.
     */
    @JvmName("vwvqncgltyxskcll")
    public suspend fun weightedBackendServices(vararg argument: suspend URLMapPathMatcherDefaultRouteActionWeightedBackendServiceArgsBuilder.() -> Unit) {
        val toBeMapped = argument.toList().map {
            URLMapPathMatcherDefaultRouteActionWeightedBackendServiceArgsBuilder().applySuspend {
                it()
            }.build()
        }
        val mapped = of(toBeMapped)
        this.weightedBackendServices = mapped
    }

    /**
     * @param argument A list of weighted backend services to send traffic to when a route match occurs.
     * The weights determine the fraction of traffic that flows to their corresponding backend service.
     * If all traffic needs to go to a single backend service, there must be one weightedBackendService
     * with weight set to a non 0 number.
     * Once a backendService is identified and before forwarding the request to the backend service,
     * advanced routing actions like Url rewrites and header transformations are applied depending on
     * additional settings specified in this HttpRouteAction.
     * Structure is documented below.
     */
    @JvmName("osgpsrkjmgakixtd")
    public suspend fun weightedBackendServices(argument: suspend URLMapPathMatcherDefaultRouteActionWeightedBackendServiceArgsBuilder.() -> Unit) {
        val toBeMapped =
            listOf(
                URLMapPathMatcherDefaultRouteActionWeightedBackendServiceArgsBuilder().applySuspend {
                    argument()
                }.build(),
            )
        val mapped = of(toBeMapped)
        this.weightedBackendServices = mapped
    }

    /**
     * @param values A list of weighted backend services to send traffic to when a route match occurs.
     * The weights determine the fraction of traffic that flows to their corresponding backend service.
     * If all traffic needs to go to a single backend service, there must be one weightedBackendService
     * with weight set to a non 0 number.
     * Once a backendService is identified and before forwarding the request to the backend service,
     * advanced routing actions like Url rewrites and header transformations are applied depending on
     * additional settings specified in this HttpRouteAction.
     * Structure is documented below.
     */
    @JvmName("swjjvknjjaqwfcdn")
    public suspend fun weightedBackendServices(vararg values: URLMapPathMatcherDefaultRouteActionWeightedBackendServiceArgs) {
        val toBeMapped = values.toList()
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.weightedBackendServices = mapped
    }

    internal fun build(): URLMapPathMatcherDefaultRouteActionArgs =
        URLMapPathMatcherDefaultRouteActionArgs(
            corsPolicy = corsPolicy,
            faultInjectionPolicy = faultInjectionPolicy,
            requestMirrorPolicy = requestMirrorPolicy,
            retryPolicy = retryPolicy,
            timeout = timeout,
            urlRewrite = urlRewrite,
            weightedBackendServices = weightedBackendServices,
        )
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy