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

com.pulumi.azurenative.network.kotlin.inputs.ApplicationGatewayWebApplicationFirewallConfigurationArgs.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: 2.82.0.0
Show newest version
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.azurenative.network.kotlin.inputs

import com.pulumi.azurenative.network.inputs.ApplicationGatewayWebApplicationFirewallConfigurationArgs.builder
import com.pulumi.azurenative.network.kotlin.enums.ApplicationGatewayFirewallMode
import com.pulumi.core.Either
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 kotlin.Boolean
import kotlin.Int
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.List
import kotlin.jvm.JvmName

/**
 * Application gateway web application firewall configuration.
 * @property disabledRuleGroups The disabled rule groups.
 * @property enabled Whether the web application firewall is enabled or not.
 * @property exclusions The exclusion list.
 * @property fileUploadLimitInMb Maximum file upload size in Mb for WAF.
 * @property firewallMode Web application firewall mode.
 * @property maxRequestBodySize Maximum request body size for WAF.
 * @property maxRequestBodySizeInKb Maximum request body size in Kb for WAF.
 * @property requestBodyCheck Whether allow WAF to check request Body.
 * @property ruleSetType The type of the web application firewall rule set. Possible values are: 'OWASP'.
 * @property ruleSetVersion The version of the rule set type.
 */
public data class ApplicationGatewayWebApplicationFirewallConfigurationArgs(
    public val disabledRuleGroups: Output>? =
        null,
    public val enabled: Output,
    public val exclusions: Output>? = null,
    public val fileUploadLimitInMb: Output? = null,
    public val firewallMode: Output>,
    public val maxRequestBodySize: Output? = null,
    public val maxRequestBodySizeInKb: Output? = null,
    public val requestBodyCheck: Output? = null,
    public val ruleSetType: Output,
    public val ruleSetVersion: Output,
) :
    ConvertibleToJava {
    override fun toJava(): com.pulumi.azurenative.network.inputs.ApplicationGatewayWebApplicationFirewallConfigurationArgs =
        com.pulumi.azurenative.network.inputs.ApplicationGatewayWebApplicationFirewallConfigurationArgs.builder()
            .disabledRuleGroups(
                disabledRuleGroups?.applyValue({ args0 ->
                    args0.map({ args0 ->
                        args0.let({ args0 -> args0.toJava() })
                    })
                }),
            )
            .enabled(enabled.applyValue({ args0 -> args0 }))
            .exclusions(
                exclusions?.applyValue({ args0 ->
                    args0.map({ args0 ->
                        args0.let({ args0 ->
                            args0.toJava()
                        })
                    })
                }),
            )
            .fileUploadLimitInMb(fileUploadLimitInMb?.applyValue({ args0 -> args0 }))
            .firewallMode(
                firewallMode.applyValue({ args0 ->
                    args0.transform({ args0 -> args0 }, { args0 ->
                        args0.let({ args0 -> args0.toJava() })
                    })
                }),
            )
            .maxRequestBodySize(maxRequestBodySize?.applyValue({ args0 -> args0 }))
            .maxRequestBodySizeInKb(maxRequestBodySizeInKb?.applyValue({ args0 -> args0 }))
            .requestBodyCheck(requestBodyCheck?.applyValue({ args0 -> args0 }))
            .ruleSetType(ruleSetType.applyValue({ args0 -> args0 }))
            .ruleSetVersion(ruleSetVersion.applyValue({ args0 -> args0 })).build()
}

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

    private var enabled: Output? = null

    private var exclusions: Output>? = null

    private var fileUploadLimitInMb: Output? = null

    private var firewallMode: Output>? = null

    private var maxRequestBodySize: Output? = null

    private var maxRequestBodySizeInKb: Output? = null

    private var requestBodyCheck: Output? = null

    private var ruleSetType: Output? = null

    private var ruleSetVersion: Output? = null

    /**
     * @param value The disabled rule groups.
     */
    @JvmName("pncqkmgfjkfwvubn")
    public suspend fun disabledRuleGroups(`value`: Output>) {
        this.disabledRuleGroups = value
    }

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

    /**
     * @param values The disabled rule groups.
     */
    @JvmName("jpyvsbjwyqvnlkdx")
    public suspend fun disabledRuleGroups(values: List>) {
        this.disabledRuleGroups = Output.all(values)
    }

    /**
     * @param value Whether the web application firewall is enabled or not.
     */
    @JvmName("vyhkiawunecaveej")
    public suspend fun enabled(`value`: Output) {
        this.enabled = value
    }

    /**
     * @param value The exclusion list.
     */
    @JvmName("bmtvysybxalcsvki")
    public suspend fun exclusions(`value`: Output>) {
        this.exclusions = value
    }

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

    /**
     * @param values The exclusion list.
     */
    @JvmName("jgixkemlinekapgk")
    public suspend fun exclusions(values: List>) {
        this.exclusions = Output.all(values)
    }

    /**
     * @param value Maximum file upload size in Mb for WAF.
     */
    @JvmName("wndqskfgbnwhplqw")
    public suspend fun fileUploadLimitInMb(`value`: Output) {
        this.fileUploadLimitInMb = value
    }

    /**
     * @param value Web application firewall mode.
     */
    @JvmName("jbmnpxbefnxmfswl")
    public suspend fun firewallMode(`value`: Output>) {
        this.firewallMode = value
    }

    /**
     * @param value Maximum request body size for WAF.
     */
    @JvmName("dwrcgibvwckiiodk")
    public suspend fun maxRequestBodySize(`value`: Output) {
        this.maxRequestBodySize = value
    }

    /**
     * @param value Maximum request body size in Kb for WAF.
     */
    @JvmName("clticmxetxgxtikl")
    public suspend fun maxRequestBodySizeInKb(`value`: Output) {
        this.maxRequestBodySizeInKb = value
    }

    /**
     * @param value Whether allow WAF to check request Body.
     */
    @JvmName("scyorckmvsiifcjd")
    public suspend fun requestBodyCheck(`value`: Output) {
        this.requestBodyCheck = value
    }

    /**
     * @param value The type of the web application firewall rule set. Possible values are: 'OWASP'.
     */
    @JvmName("geiwwohigrdgafyb")
    public suspend fun ruleSetType(`value`: Output) {
        this.ruleSetType = value
    }

    /**
     * @param value The version of the rule set type.
     */
    @JvmName("lajworiqtvlpwsyg")
    public suspend fun ruleSetVersion(`value`: Output) {
        this.ruleSetVersion = value
    }

    /**
     * @param value The disabled rule groups.
     */
    @JvmName("beoygpadexhsevey")
    public suspend fun disabledRuleGroups(`value`: List?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.disabledRuleGroups = mapped
    }

    /**
     * @param argument The disabled rule groups.
     */
    @JvmName("kocbaayxofxefkor")
    public suspend fun disabledRuleGroups(argument: List Unit>) {
        val toBeMapped = argument.toList().map {
            ApplicationGatewayFirewallDisabledRuleGroupArgsBuilder().applySuspend { it() }.build()
        }
        val mapped = of(toBeMapped)
        this.disabledRuleGroups = mapped
    }

    /**
     * @param argument The disabled rule groups.
     */
    @JvmName("iklsnkrwjdygofsp")
    public suspend fun disabledRuleGroups(vararg argument: suspend ApplicationGatewayFirewallDisabledRuleGroupArgsBuilder.() -> Unit) {
        val toBeMapped = argument.toList().map {
            ApplicationGatewayFirewallDisabledRuleGroupArgsBuilder().applySuspend { it() }.build()
        }
        val mapped = of(toBeMapped)
        this.disabledRuleGroups = mapped
    }

    /**
     * @param argument The disabled rule groups.
     */
    @JvmName("aghjpfrdqetpdpes")
    public suspend fun disabledRuleGroups(argument: suspend ApplicationGatewayFirewallDisabledRuleGroupArgsBuilder.() -> Unit) {
        val toBeMapped = listOf(
            ApplicationGatewayFirewallDisabledRuleGroupArgsBuilder().applySuspend {
                argument()
            }.build(),
        )
        val mapped = of(toBeMapped)
        this.disabledRuleGroups = mapped
    }

    /**
     * @param values The disabled rule groups.
     */
    @JvmName("gsxedjdmvecdfkkh")
    public suspend fun disabledRuleGroups(vararg values: ApplicationGatewayFirewallDisabledRuleGroupArgs) {
        val toBeMapped = values.toList()
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.disabledRuleGroups = mapped
    }

    /**
     * @param value Whether the web application firewall is enabled or not.
     */
    @JvmName("rsnhpjsjkoecbxnl")
    public suspend fun enabled(`value`: Boolean) {
        val toBeMapped = value
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.enabled = mapped
    }

    /**
     * @param value The exclusion list.
     */
    @JvmName("oefkypcvqrfpvsec")
    public suspend fun exclusions(`value`: List?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.exclusions = mapped
    }

    /**
     * @param argument The exclusion list.
     */
    @JvmName("woahlxyxdoydylmr")
    public suspend fun exclusions(argument: List Unit>) {
        val toBeMapped = argument.toList().map {
            ApplicationGatewayFirewallExclusionArgsBuilder().applySuspend { it() }.build()
        }
        val mapped = of(toBeMapped)
        this.exclusions = mapped
    }

    /**
     * @param argument The exclusion list.
     */
    @JvmName("xfiaetgxlywkitww")
    public suspend fun exclusions(vararg argument: suspend ApplicationGatewayFirewallExclusionArgsBuilder.() -> Unit) {
        val toBeMapped = argument.toList().map {
            ApplicationGatewayFirewallExclusionArgsBuilder().applySuspend { it() }.build()
        }
        val mapped = of(toBeMapped)
        this.exclusions = mapped
    }

    /**
     * @param argument The exclusion list.
     */
    @JvmName("ooxrnlfyecfdewij")
    public suspend fun exclusions(argument: suspend ApplicationGatewayFirewallExclusionArgsBuilder.() -> Unit) {
        val toBeMapped = listOf(
            ApplicationGatewayFirewallExclusionArgsBuilder().applySuspend {
                argument()
            }.build(),
        )
        val mapped = of(toBeMapped)
        this.exclusions = mapped
    }

    /**
     * @param values The exclusion list.
     */
    @JvmName("lgjcgttdxqquxpcw")
    public suspend fun exclusions(vararg values: ApplicationGatewayFirewallExclusionArgs) {
        val toBeMapped = values.toList()
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.exclusions = mapped
    }

    /**
     * @param value Maximum file upload size in Mb for WAF.
     */
    @JvmName("tqhpmcjyicaywefr")
    public suspend fun fileUploadLimitInMb(`value`: Int?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.fileUploadLimitInMb = mapped
    }

    /**
     * @param value Web application firewall mode.
     */
    @JvmName("oqfjjolxbwkeqcgj")
    public suspend fun firewallMode(`value`: Either) {
        val toBeMapped = value
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.firewallMode = mapped
    }

    /**
     * @param value Web application firewall mode.
     */
    @JvmName("uxekikjpkaiueckn")
    public fun firewallMode(`value`: String) {
        val toBeMapped = Either.ofLeft(value)
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.firewallMode = mapped
    }

    /**
     * @param value Web application firewall mode.
     */
    @JvmName("opuuwefgefpysifx")
    public fun firewallMode(`value`: ApplicationGatewayFirewallMode) {
        val toBeMapped = Either.ofRight(value)
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.firewallMode = mapped
    }

    /**
     * @param value Maximum request body size for WAF.
     */
    @JvmName("gjrlwekcoivbiprr")
    public suspend fun maxRequestBodySize(`value`: Int?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.maxRequestBodySize = mapped
    }

    /**
     * @param value Maximum request body size in Kb for WAF.
     */
    @JvmName("nlarexeulhkhsdiv")
    public suspend fun maxRequestBodySizeInKb(`value`: Int?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.maxRequestBodySizeInKb = mapped
    }

    /**
     * @param value Whether allow WAF to check request Body.
     */
    @JvmName("lkvvdyfpnecrktle")
    public suspend fun requestBodyCheck(`value`: Boolean?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.requestBodyCheck = mapped
    }

    /**
     * @param value The type of the web application firewall rule set. Possible values are: 'OWASP'.
     */
    @JvmName("yaeanfqnqbqtowik")
    public suspend fun ruleSetType(`value`: String) {
        val toBeMapped = value
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.ruleSetType = mapped
    }

    /**
     * @param value The version of the rule set type.
     */
    @JvmName("kovbyfdeuxntegxu")
    public suspend fun ruleSetVersion(`value`: String) {
        val toBeMapped = value
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.ruleSetVersion = mapped
    }

    internal fun build(): ApplicationGatewayWebApplicationFirewallConfigurationArgs =
        ApplicationGatewayWebApplicationFirewallConfigurationArgs(
            disabledRuleGroups = disabledRuleGroups,
            enabled = enabled ?: throw PulumiNullFieldException("enabled"),
            exclusions = exclusions,
            fileUploadLimitInMb = fileUploadLimitInMb,
            firewallMode = firewallMode ?: throw PulumiNullFieldException("firewallMode"),
            maxRequestBodySize = maxRequestBodySize,
            maxRequestBodySizeInKb = maxRequestBodySizeInKb,
            requestBodyCheck = requestBodyCheck,
            ruleSetType = ruleSetType ?: throw PulumiNullFieldException("ruleSetType"),
            ruleSetVersion = ruleSetVersion ?: throw PulumiNullFieldException("ruleSetVersion"),
        )
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy