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

com.pulumi.googlenative.apigateway.v1.kotlin.inputs.ApigatewayAuditConfigArgs.kt Maven / Gradle / Ivy

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

package com.pulumi.googlenative.apigateway.v1.kotlin.inputs

import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.googlenative.apigateway.v1.inputs.ApigatewayAuditConfigArgs.builder
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.applySuspend
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.List
import kotlin.jvm.JvmName

/**
 * Specifies the audit configuration for a service. The configuration determines which permission types are logged, and what identities, if any, are exempted from logging. An AuditConfig must have one or more AuditLogConfigs. If there are AuditConfigs for both `allServices` and a specific service, the union of the two AuditConfigs is used for that service: the log_types specified in each AuditConfig are enabled, and the exempted_members in each AuditLogConfig are exempted. Example Policy with multiple AuditConfigs: { "audit_configs": [ { "service": "allServices", "audit_log_configs": [ { "log_type": "DATA_READ", "exempted_members": [ "user:jose@example.com" ] }, { "log_type": "DATA_WRITE" }, { "log_type": "ADMIN_READ" } ] }, { "service": "sampleservice.googleapis.com", "audit_log_configs": [ { "log_type": "DATA_READ" }, { "log_type": "DATA_WRITE", "exempted_members": [ "user:aliya@example.com" ] } ] } ] } For sampleservice, this policy enables DATA_READ, DATA_WRITE and ADMIN_READ logging. It also exempts `[email protected]` from DATA_READ logging, and `[email protected]` from DATA_WRITE logging.
 * @property auditLogConfigs The configuration for logging of each type of permission.
 * @property service Specifies a service that will be enabled for audit logging. For example, `storage.googleapis.com`, `cloudsql.googleapis.com`. `allServices` is a special value that covers all services.
 */
public data class ApigatewayAuditConfigArgs(
    public val auditLogConfigs: Output>? = null,
    public val service: Output? = null,
) : ConvertibleToJava {
    override fun toJava(): com.pulumi.googlenative.apigateway.v1.inputs.ApigatewayAuditConfigArgs =
        com.pulumi.googlenative.apigateway.v1.inputs.ApigatewayAuditConfigArgs.builder()
            .auditLogConfigs(
                auditLogConfigs?.applyValue({ args0 ->
                    args0.map({ args0 ->
                        args0.let({ args0 ->
                            args0.toJava()
                        })
                    })
                }),
            )
            .service(service?.applyValue({ args0 -> args0 })).build()
}

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

    private var service: Output? = null

    /**
     * @param value The configuration for logging of each type of permission.
     */
    @JvmName("iemdermsbcnohysk")
    public suspend fun auditLogConfigs(`value`: Output>) {
        this.auditLogConfigs = value
    }

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

    /**
     * @param values The configuration for logging of each type of permission.
     */
    @JvmName("tilfmlcvxabcjwcj")
    public suspend fun auditLogConfigs(values: List>) {
        this.auditLogConfigs = Output.all(values)
    }

    /**
     * @param value Specifies a service that will be enabled for audit logging. For example, `storage.googleapis.com`, `cloudsql.googleapis.com`. `allServices` is a special value that covers all services.
     */
    @JvmName("faufsgvwambmywpx")
    public suspend fun service(`value`: Output) {
        this.service = value
    }

    /**
     * @param value The configuration for logging of each type of permission.
     */
    @JvmName("adeoxfkjspjgngvr")
    public suspend fun auditLogConfigs(`value`: List?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.auditLogConfigs = mapped
    }

    /**
     * @param argument The configuration for logging of each type of permission.
     */
    @JvmName("kwcbplbuojhsmovb")
    public suspend fun auditLogConfigs(argument: List Unit>) {
        val toBeMapped = argument.toList().map {
            ApigatewayAuditLogConfigArgsBuilder().applySuspend {
                it()
            }.build()
        }
        val mapped = of(toBeMapped)
        this.auditLogConfigs = mapped
    }

    /**
     * @param argument The configuration for logging of each type of permission.
     */
    @JvmName("yngtilqdgxgajdxl")
    public suspend fun auditLogConfigs(vararg argument: suspend ApigatewayAuditLogConfigArgsBuilder.() -> Unit) {
        val toBeMapped = argument.toList().map {
            ApigatewayAuditLogConfigArgsBuilder().applySuspend {
                it()
            }.build()
        }
        val mapped = of(toBeMapped)
        this.auditLogConfigs = mapped
    }

    /**
     * @param argument The configuration for logging of each type of permission.
     */
    @JvmName("jjgmubwtkjqkytwh")
    public suspend fun auditLogConfigs(argument: suspend ApigatewayAuditLogConfigArgsBuilder.() -> Unit) {
        val toBeMapped = listOf(
            ApigatewayAuditLogConfigArgsBuilder().applySuspend {
                argument()
            }.build(),
        )
        val mapped = of(toBeMapped)
        this.auditLogConfigs = mapped
    }

    /**
     * @param values The configuration for logging of each type of permission.
     */
    @JvmName("fogcnelyirmyktex")
    public suspend fun auditLogConfigs(vararg values: ApigatewayAuditLogConfigArgs) {
        val toBeMapped = values.toList()
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.auditLogConfigs = mapped
    }

    /**
     * @param value Specifies a service that will be enabled for audit logging. For example, `storage.googleapis.com`, `cloudsql.googleapis.com`. `allServices` is a special value that covers all services.
     */
    @JvmName("yyfxyebnhcjyamjm")
    public suspend fun service(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.service = mapped
    }

    internal fun build(): ApigatewayAuditConfigArgs = ApigatewayAuditConfigArgs(
        auditLogConfigs = auditLogConfigs,
        service = service,
    )
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy