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

com.pulumi.awsnative.wafv2.kotlin.inputs.WebAclFieldToMatchArgs.kt Maven / Gradle / Ivy

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

package com.pulumi.awsnative.wafv2.kotlin.inputs

import com.pulumi.awsnative.wafv2.inputs.WebAclFieldToMatchArgs.builder
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 kotlin.Any
import kotlin.Suppress
import kotlin.Unit
import kotlin.jvm.JvmName

/**
 * Field of the request to match.
 * @property allQueryArguments All query arguments of a web request.
 * @property body Inspect the request body as plain text. The request body immediately follows the request headers. This is the part of a request that contains any additional data that you want to send to your web server as the HTTP request body, such as data from a form.
 * AWS WAF does not support inspecting the entire contents of the web request body if the body exceeds the limit for the resource type. When a web request body is larger than the limit, the underlying host service only forwards the contents that are within the limit to AWS WAF for inspection.
 * - For Application Load Balancer and AWS AppSync , the limit is fixed at 8 KB (8,192 bytes).
 * - For CloudFront, API Gateway, Amazon Cognito, App Runner, and Verified Access, the default limit is 16 KB (16,384 bytes), and you can increase the limit for each resource type in the web ACL `AssociationConfig` , for additional processing fees.
 * For information about how to handle oversized request bodies, see the `Body` object configuration.
 * @property cookies Inspect the request cookies. You must configure scope and pattern matching filters in the `Cookies` object, to define the set of cookies and the parts of the cookies that AWS WAF inspects.
 * Only the first 8 KB (8192 bytes) of a request's cookies and only the first 200 cookies are forwarded to AWS WAF for inspection by the underlying host service. You must configure how to handle any oversize cookie content in the `Cookies` object. AWS WAF applies the pattern matching filters to the cookies that it receives from the underlying host service.
 * @property headers Inspect the request headers. You must configure scope and pattern matching filters in the `Headers` object, to define the set of headers to and the parts of the headers that AWS WAF inspects.
 * Only the first 8 KB (8192 bytes) of a request's headers and only the first 200 headers are forwarded to AWS WAF for inspection by the underlying host service. You must configure how to handle any oversize header content in the `Headers` object. AWS WAF applies the pattern matching filters to the headers that it receives from the underlying host service.
 * @property ja3Fingerprint Available for use with Amazon CloudFront distributions and Application Load Balancers. Match against the request's JA3 fingerprint. The JA3 fingerprint is a 32-character hash derived from the TLS Client Hello of an incoming request. This fingerprint serves as a unique identifier for the client's TLS configuration. AWS WAF calculates and logs this fingerprint for each request that has enough TLS Client Hello information for the calculation. Almost all web requests include this information.
 * > You can use this choice only with a string match `ByteMatchStatement` with the `PositionalConstraint` set to `EXACTLY` .
 * You can obtain the JA3 fingerprint for client requests from the web ACL logs. If AWS WAF is able to calculate the fingerprint, it includes it in the logs. For information about the logging fields, see [Log fields](https://docs.aws.amazon.com/waf/latest/developerguide/logging-fields.html) in the *AWS WAF Developer Guide* .
 * Provide the JA3 fingerprint string from the logs in your string match statement specification, to match with any future requests that have the same TLS configuration.
 * @property jsonBody Inspect the request body as JSON. The request body immediately follows the request headers. This is the part of a request that contains any additional data that you want to send to your web server as the HTTP request body, such as data from a form.
 * AWS WAF does not support inspecting the entire contents of the web request body if the body exceeds the limit for the resource type. When a web request body is larger than the limit, the underlying host service only forwards the contents that are within the limit to AWS WAF for inspection.
 * - For Application Load Balancer and AWS AppSync , the limit is fixed at 8 KB (8,192 bytes).
 * - For CloudFront, API Gateway, Amazon Cognito, App Runner, and Verified Access, the default limit is 16 KB (16,384 bytes), and you can increase the limit for each resource type in the web ACL `AssociationConfig` , for additional processing fees.
 * For information about how to handle oversized request bodies, see the `JsonBody` object configuration.
 * @property method The HTTP method of a web request. The method indicates the type of operation that the request is asking the origin to perform.
 * @property queryString The query string of a web request. This is the part of a URL that appears after a ? character, if any.
 * @property singleHeader Inspect a single header. Provide the name of the header to inspect, for example, `User-Agent` or `Referer` . This setting isn't case sensitive.
 * Example JSON: `"SingleHeader": { "Name": "haystack" }`
 * Alternately, you can filter and inspect all headers with the `Headers` `FieldToMatch` setting.
 * @property singleQueryArgument One query argument in a web request, identified by name, for example UserName or SalesRegion. The name can be up to 30 characters long and isn't case sensitive.
 * @property uriPath The path component of the URI of a web request. This is the part of a web request that identifies a resource, for example, /images/daily-ad.jpg.
 */
public data class WebAclFieldToMatchArgs(
    public val allQueryArguments: Output? = null,
    public val body: Output? = null,
    public val cookies: Output? = null,
    public val headers: Output? = null,
    public val ja3Fingerprint: Output? = null,
    public val jsonBody: Output? = null,
    public val method: Output? = null,
    public val queryString: Output? = null,
    public val singleHeader: Output? = null,
    public val singleQueryArgument: Output? =
        null,
    public val uriPath: Output? = null,
) : ConvertibleToJava {
    override fun toJava(): com.pulumi.awsnative.wafv2.inputs.WebAclFieldToMatchArgs =
        com.pulumi.awsnative.wafv2.inputs.WebAclFieldToMatchArgs.builder()
            .allQueryArguments(allQueryArguments?.applyValue({ args0 -> args0 }))
            .body(body?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
            .cookies(cookies?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
            .headers(headers?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
            .ja3Fingerprint(ja3Fingerprint?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
            .jsonBody(jsonBody?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
            .method(method?.applyValue({ args0 -> args0 }))
            .queryString(queryString?.applyValue({ args0 -> args0 }))
            .singleHeader(singleHeader?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
            .singleQueryArgument(
                singleQueryArgument?.applyValue({ args0 ->
                    args0.let({ args0 ->
                        args0.toJava()
                    })
                }),
            )
            .uriPath(uriPath?.applyValue({ args0 -> args0 })).build()
}

/**
 * Builder for [WebAclFieldToMatchArgs].
 */
@PulumiTagMarker
public class WebAclFieldToMatchArgsBuilder internal constructor() {
    private var allQueryArguments: Output? = null

    private var body: Output? = null

    private var cookies: Output? = null

    private var headers: Output? = null

    private var ja3Fingerprint: Output? = null

    private var jsonBody: Output? = null

    private var method: Output? = null

    private var queryString: Output? = null

    private var singleHeader: Output? = null

    private var singleQueryArgument: Output? =
        null

    private var uriPath: Output? = null

    /**
     * @param value All query arguments of a web request.
     */
    @JvmName("valrevfhpdxouchg")
    public suspend fun allQueryArguments(`value`: Output) {
        this.allQueryArguments = value
    }

    /**
     * @param value Inspect the request body as plain text. The request body immediately follows the request headers. This is the part of a request that contains any additional data that you want to send to your web server as the HTTP request body, such as data from a form.
     * AWS WAF does not support inspecting the entire contents of the web request body if the body exceeds the limit for the resource type. When a web request body is larger than the limit, the underlying host service only forwards the contents that are within the limit to AWS WAF for inspection.
     * - For Application Load Balancer and AWS AppSync , the limit is fixed at 8 KB (8,192 bytes).
     * - For CloudFront, API Gateway, Amazon Cognito, App Runner, and Verified Access, the default limit is 16 KB (16,384 bytes), and you can increase the limit for each resource type in the web ACL `AssociationConfig` , for additional processing fees.
     * For information about how to handle oversized request bodies, see the `Body` object configuration.
     */
    @JvmName("ugbcllyblryvxlnr")
    public suspend fun body(`value`: Output) {
        this.body = value
    }

    /**
     * @param value Inspect the request cookies. You must configure scope and pattern matching filters in the `Cookies` object, to define the set of cookies and the parts of the cookies that AWS WAF inspects.
     * Only the first 8 KB (8192 bytes) of a request's cookies and only the first 200 cookies are forwarded to AWS WAF for inspection by the underlying host service. You must configure how to handle any oversize cookie content in the `Cookies` object. AWS WAF applies the pattern matching filters to the cookies that it receives from the underlying host service.
     */
    @JvmName("tgmrtctrfchlqbfv")
    public suspend fun cookies(`value`: Output) {
        this.cookies = value
    }

    /**
     * @param value Inspect the request headers. You must configure scope and pattern matching filters in the `Headers` object, to define the set of headers to and the parts of the headers that AWS WAF inspects.
     * Only the first 8 KB (8192 bytes) of a request's headers and only the first 200 headers are forwarded to AWS WAF for inspection by the underlying host service. You must configure how to handle any oversize header content in the `Headers` object. AWS WAF applies the pattern matching filters to the headers that it receives from the underlying host service.
     */
    @JvmName("msnigcqqwilvisib")
    public suspend fun headers(`value`: Output) {
        this.headers = value
    }

    /**
     * @param value Available for use with Amazon CloudFront distributions and Application Load Balancers. Match against the request's JA3 fingerprint. The JA3 fingerprint is a 32-character hash derived from the TLS Client Hello of an incoming request. This fingerprint serves as a unique identifier for the client's TLS configuration. AWS WAF calculates and logs this fingerprint for each request that has enough TLS Client Hello information for the calculation. Almost all web requests include this information.
     * > You can use this choice only with a string match `ByteMatchStatement` with the `PositionalConstraint` set to `EXACTLY` .
     * You can obtain the JA3 fingerprint for client requests from the web ACL logs. If AWS WAF is able to calculate the fingerprint, it includes it in the logs. For information about the logging fields, see [Log fields](https://docs.aws.amazon.com/waf/latest/developerguide/logging-fields.html) in the *AWS WAF Developer Guide* .
     * Provide the JA3 fingerprint string from the logs in your string match statement specification, to match with any future requests that have the same TLS configuration.
     */
    @JvmName("ssmedlwhnftisucj")
    public suspend fun ja3Fingerprint(`value`: Output) {
        this.ja3Fingerprint = value
    }

    /**
     * @param value Inspect the request body as JSON. The request body immediately follows the request headers. This is the part of a request that contains any additional data that you want to send to your web server as the HTTP request body, such as data from a form.
     * AWS WAF does not support inspecting the entire contents of the web request body if the body exceeds the limit for the resource type. When a web request body is larger than the limit, the underlying host service only forwards the contents that are within the limit to AWS WAF for inspection.
     * - For Application Load Balancer and AWS AppSync , the limit is fixed at 8 KB (8,192 bytes).
     * - For CloudFront, API Gateway, Amazon Cognito, App Runner, and Verified Access, the default limit is 16 KB (16,384 bytes), and you can increase the limit for each resource type in the web ACL `AssociationConfig` , for additional processing fees.
     * For information about how to handle oversized request bodies, see the `JsonBody` object configuration.
     */
    @JvmName("rhjijktdivuhuajb")
    public suspend fun jsonBody(`value`: Output) {
        this.jsonBody = value
    }

    /**
     * @param value The HTTP method of a web request. The method indicates the type of operation that the request is asking the origin to perform.
     */
    @JvmName("wbrsgoemumyksbie")
    public suspend fun method(`value`: Output) {
        this.method = value
    }

    /**
     * @param value The query string of a web request. This is the part of a URL that appears after a ? character, if any.
     */
    @JvmName("ufvixtmmnpubmhgj")
    public suspend fun queryString(`value`: Output) {
        this.queryString = value
    }

    /**
     * @param value Inspect a single header. Provide the name of the header to inspect, for example, `User-Agent` or `Referer` . This setting isn't case sensitive.
     * Example JSON: `"SingleHeader": { "Name": "haystack" }`
     * Alternately, you can filter and inspect all headers with the `Headers` `FieldToMatch` setting.
     */
    @JvmName("rxlurgtswhvscsyf")
    public suspend fun singleHeader(`value`: Output) {
        this.singleHeader = value
    }

    /**
     * @param value One query argument in a web request, identified by name, for example UserName or SalesRegion. The name can be up to 30 characters long and isn't case sensitive.
     */
    @JvmName("eiahirumhdatrdnp")
    public suspend fun singleQueryArgument(`value`: Output) {
        this.singleQueryArgument = value
    }

    /**
     * @param value The path component of the URI of a web request. This is the part of a web request that identifies a resource, for example, /images/daily-ad.jpg.
     */
    @JvmName("quiumcoxjcouomig")
    public suspend fun uriPath(`value`: Output) {
        this.uriPath = value
    }

    /**
     * @param value All query arguments of a web request.
     */
    @JvmName("vmlpvixahshokuqq")
    public suspend fun allQueryArguments(`value`: Any?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.allQueryArguments = mapped
    }

    /**
     * @param value Inspect the request body as plain text. The request body immediately follows the request headers. This is the part of a request that contains any additional data that you want to send to your web server as the HTTP request body, such as data from a form.
     * AWS WAF does not support inspecting the entire contents of the web request body if the body exceeds the limit for the resource type. When a web request body is larger than the limit, the underlying host service only forwards the contents that are within the limit to AWS WAF for inspection.
     * - For Application Load Balancer and AWS AppSync , the limit is fixed at 8 KB (8,192 bytes).
     * - For CloudFront, API Gateway, Amazon Cognito, App Runner, and Verified Access, the default limit is 16 KB (16,384 bytes), and you can increase the limit for each resource type in the web ACL `AssociationConfig` , for additional processing fees.
     * For information about how to handle oversized request bodies, see the `Body` object configuration.
     */
    @JvmName("eclacljhvkosxmru")
    public suspend fun body(`value`: WebAclBodyArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.body = mapped
    }

    /**
     * @param argument Inspect the request body as plain text. The request body immediately follows the request headers. This is the part of a request that contains any additional data that you want to send to your web server as the HTTP request body, such as data from a form.
     * AWS WAF does not support inspecting the entire contents of the web request body if the body exceeds the limit for the resource type. When a web request body is larger than the limit, the underlying host service only forwards the contents that are within the limit to AWS WAF for inspection.
     * - For Application Load Balancer and AWS AppSync , the limit is fixed at 8 KB (8,192 bytes).
     * - For CloudFront, API Gateway, Amazon Cognito, App Runner, and Verified Access, the default limit is 16 KB (16,384 bytes), and you can increase the limit for each resource type in the web ACL `AssociationConfig` , for additional processing fees.
     * For information about how to handle oversized request bodies, see the `Body` object configuration.
     */
    @JvmName("uxsssnjxnfoqnrdo")
    public suspend fun body(argument: suspend WebAclBodyArgsBuilder.() -> Unit) {
        val toBeMapped = WebAclBodyArgsBuilder().applySuspend { argument() }.build()
        val mapped = of(toBeMapped)
        this.body = mapped
    }

    /**
     * @param value Inspect the request cookies. You must configure scope and pattern matching filters in the `Cookies` object, to define the set of cookies and the parts of the cookies that AWS WAF inspects.
     * Only the first 8 KB (8192 bytes) of a request's cookies and only the first 200 cookies are forwarded to AWS WAF for inspection by the underlying host service. You must configure how to handle any oversize cookie content in the `Cookies` object. AWS WAF applies the pattern matching filters to the cookies that it receives from the underlying host service.
     */
    @JvmName("omkvpecbwnsknhsq")
    public suspend fun cookies(`value`: WebAclCookiesArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.cookies = mapped
    }

    /**
     * @param argument Inspect the request cookies. You must configure scope and pattern matching filters in the `Cookies` object, to define the set of cookies and the parts of the cookies that AWS WAF inspects.
     * Only the first 8 KB (8192 bytes) of a request's cookies and only the first 200 cookies are forwarded to AWS WAF for inspection by the underlying host service. You must configure how to handle any oversize cookie content in the `Cookies` object. AWS WAF applies the pattern matching filters to the cookies that it receives from the underlying host service.
     */
    @JvmName("tcgpedwxpskxsyee")
    public suspend fun cookies(argument: suspend WebAclCookiesArgsBuilder.() -> Unit) {
        val toBeMapped = WebAclCookiesArgsBuilder().applySuspend { argument() }.build()
        val mapped = of(toBeMapped)
        this.cookies = mapped
    }

    /**
     * @param value Inspect the request headers. You must configure scope and pattern matching filters in the `Headers` object, to define the set of headers to and the parts of the headers that AWS WAF inspects.
     * Only the first 8 KB (8192 bytes) of a request's headers and only the first 200 headers are forwarded to AWS WAF for inspection by the underlying host service. You must configure how to handle any oversize header content in the `Headers` object. AWS WAF applies the pattern matching filters to the headers that it receives from the underlying host service.
     */
    @JvmName("xjqnuxtppkxfgtem")
    public suspend fun headers(`value`: WebAclHeadersArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.headers = mapped
    }

    /**
     * @param argument Inspect the request headers. You must configure scope and pattern matching filters in the `Headers` object, to define the set of headers to and the parts of the headers that AWS WAF inspects.
     * Only the first 8 KB (8192 bytes) of a request's headers and only the first 200 headers are forwarded to AWS WAF for inspection by the underlying host service. You must configure how to handle any oversize header content in the `Headers` object. AWS WAF applies the pattern matching filters to the headers that it receives from the underlying host service.
     */
    @JvmName("imnycwfeboghhnek")
    public suspend fun headers(argument: suspend WebAclHeadersArgsBuilder.() -> Unit) {
        val toBeMapped = WebAclHeadersArgsBuilder().applySuspend { argument() }.build()
        val mapped = of(toBeMapped)
        this.headers = mapped
    }

    /**
     * @param value Available for use with Amazon CloudFront distributions and Application Load Balancers. Match against the request's JA3 fingerprint. The JA3 fingerprint is a 32-character hash derived from the TLS Client Hello of an incoming request. This fingerprint serves as a unique identifier for the client's TLS configuration. AWS WAF calculates and logs this fingerprint for each request that has enough TLS Client Hello information for the calculation. Almost all web requests include this information.
     * > You can use this choice only with a string match `ByteMatchStatement` with the `PositionalConstraint` set to `EXACTLY` .
     * You can obtain the JA3 fingerprint for client requests from the web ACL logs. If AWS WAF is able to calculate the fingerprint, it includes it in the logs. For information about the logging fields, see [Log fields](https://docs.aws.amazon.com/waf/latest/developerguide/logging-fields.html) in the *AWS WAF Developer Guide* .
     * Provide the JA3 fingerprint string from the logs in your string match statement specification, to match with any future requests that have the same TLS configuration.
     */
    @JvmName("vjvpibxdqetnejlj")
    public suspend fun ja3Fingerprint(`value`: WebAclJa3FingerprintArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.ja3Fingerprint = mapped
    }

    /**
     * @param argument Available for use with Amazon CloudFront distributions and Application Load Balancers. Match against the request's JA3 fingerprint. The JA3 fingerprint is a 32-character hash derived from the TLS Client Hello of an incoming request. This fingerprint serves as a unique identifier for the client's TLS configuration. AWS WAF calculates and logs this fingerprint for each request that has enough TLS Client Hello information for the calculation. Almost all web requests include this information.
     * > You can use this choice only with a string match `ByteMatchStatement` with the `PositionalConstraint` set to `EXACTLY` .
     * You can obtain the JA3 fingerprint for client requests from the web ACL logs. If AWS WAF is able to calculate the fingerprint, it includes it in the logs. For information about the logging fields, see [Log fields](https://docs.aws.amazon.com/waf/latest/developerguide/logging-fields.html) in the *AWS WAF Developer Guide* .
     * Provide the JA3 fingerprint string from the logs in your string match statement specification, to match with any future requests that have the same TLS configuration.
     */
    @JvmName("ilmcjbvocfgyfswb")
    public suspend fun ja3Fingerprint(argument: suspend WebAclJa3FingerprintArgsBuilder.() -> Unit) {
        val toBeMapped = WebAclJa3FingerprintArgsBuilder().applySuspend { argument() }.build()
        val mapped = of(toBeMapped)
        this.ja3Fingerprint = mapped
    }

    /**
     * @param value Inspect the request body as JSON. The request body immediately follows the request headers. This is the part of a request that contains any additional data that you want to send to your web server as the HTTP request body, such as data from a form.
     * AWS WAF does not support inspecting the entire contents of the web request body if the body exceeds the limit for the resource type. When a web request body is larger than the limit, the underlying host service only forwards the contents that are within the limit to AWS WAF for inspection.
     * - For Application Load Balancer and AWS AppSync , the limit is fixed at 8 KB (8,192 bytes).
     * - For CloudFront, API Gateway, Amazon Cognito, App Runner, and Verified Access, the default limit is 16 KB (16,384 bytes), and you can increase the limit for each resource type in the web ACL `AssociationConfig` , for additional processing fees.
     * For information about how to handle oversized request bodies, see the `JsonBody` object configuration.
     */
    @JvmName("gtxodllvqwcppfwa")
    public suspend fun jsonBody(`value`: WebAclJsonBodyArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.jsonBody = mapped
    }

    /**
     * @param argument Inspect the request body as JSON. The request body immediately follows the request headers. This is the part of a request that contains any additional data that you want to send to your web server as the HTTP request body, such as data from a form.
     * AWS WAF does not support inspecting the entire contents of the web request body if the body exceeds the limit for the resource type. When a web request body is larger than the limit, the underlying host service only forwards the contents that are within the limit to AWS WAF for inspection.
     * - For Application Load Balancer and AWS AppSync , the limit is fixed at 8 KB (8,192 bytes).
     * - For CloudFront, API Gateway, Amazon Cognito, App Runner, and Verified Access, the default limit is 16 KB (16,384 bytes), and you can increase the limit for each resource type in the web ACL `AssociationConfig` , for additional processing fees.
     * For information about how to handle oversized request bodies, see the `JsonBody` object configuration.
     */
    @JvmName("ebhosaqenmbewojy")
    public suspend fun jsonBody(argument: suspend WebAclJsonBodyArgsBuilder.() -> Unit) {
        val toBeMapped = WebAclJsonBodyArgsBuilder().applySuspend { argument() }.build()
        val mapped = of(toBeMapped)
        this.jsonBody = mapped
    }

    /**
     * @param value The HTTP method of a web request. The method indicates the type of operation that the request is asking the origin to perform.
     */
    @JvmName("knqbvgsuimgvakom")
    public suspend fun method(`value`: Any?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.method = mapped
    }

    /**
     * @param value The query string of a web request. This is the part of a URL that appears after a ? character, if any.
     */
    @JvmName("ilfkubjnlaxdeevh")
    public suspend fun queryString(`value`: Any?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.queryString = mapped
    }

    /**
     * @param value Inspect a single header. Provide the name of the header to inspect, for example, `User-Agent` or `Referer` . This setting isn't case sensitive.
     * Example JSON: `"SingleHeader": { "Name": "haystack" }`
     * Alternately, you can filter and inspect all headers with the `Headers` `FieldToMatch` setting.
     */
    @JvmName("fxogjwldcacaypvi")
    public suspend fun singleHeader(`value`: WebAclFieldToMatchSingleHeaderPropertiesArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.singleHeader = mapped
    }

    /**
     * @param argument Inspect a single header. Provide the name of the header to inspect, for example, `User-Agent` or `Referer` . This setting isn't case sensitive.
     * Example JSON: `"SingleHeader": { "Name": "haystack" }`
     * Alternately, you can filter and inspect all headers with the `Headers` `FieldToMatch` setting.
     */
    @JvmName("olkoycvtvakanbwv")
    public suspend fun singleHeader(argument: suspend WebAclFieldToMatchSingleHeaderPropertiesArgsBuilder.() -> Unit) {
        val toBeMapped = WebAclFieldToMatchSingleHeaderPropertiesArgsBuilder().applySuspend {
            argument()
        }.build()
        val mapped = of(toBeMapped)
        this.singleHeader = mapped
    }

    /**
     * @param value One query argument in a web request, identified by name, for example UserName or SalesRegion. The name can be up to 30 characters long and isn't case sensitive.
     */
    @JvmName("piwvdxnvxbbvminu")
    public suspend fun singleQueryArgument(`value`: WebAclFieldToMatchSingleQueryArgumentPropertiesArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.singleQueryArgument = mapped
    }

    /**
     * @param argument One query argument in a web request, identified by name, for example UserName or SalesRegion. The name can be up to 30 characters long and isn't case sensitive.
     */
    @JvmName("djgbfqgtygglugkj")
    public suspend fun singleQueryArgument(argument: suspend WebAclFieldToMatchSingleQueryArgumentPropertiesArgsBuilder.() -> Unit) {
        val toBeMapped = WebAclFieldToMatchSingleQueryArgumentPropertiesArgsBuilder().applySuspend {
            argument()
        }.build()
        val mapped = of(toBeMapped)
        this.singleQueryArgument = mapped
    }

    /**
     * @param value The path component of the URI of a web request. This is the part of a web request that identifies a resource, for example, /images/daily-ad.jpg.
     */
    @JvmName("fmfcoarbodmkybma")
    public suspend fun uriPath(`value`: Any?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.uriPath = mapped
    }

    internal fun build(): WebAclFieldToMatchArgs = WebAclFieldToMatchArgs(
        allQueryArguments = allQueryArguments,
        body = body,
        cookies = cookies,
        headers = headers,
        ja3Fingerprint = ja3Fingerprint,
        jsonBody = jsonBody,
        method = method,
        queryString = queryString,
        singleHeader = singleHeader,
        singleQueryArgument = singleQueryArgument,
        uriPath = uriPath,
    )
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy