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

com.pulumi.kubernetes.rbac.v1alpha1.kotlin.inputs.PolicyRuleArgs.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: 4.18.2.0
Show newest version
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.kubernetes.rbac.v1alpha1.kotlin.inputs

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.kubernetes.rbac.v1alpha1.inputs.PolicyRuleArgs.builder
import kotlin.String
import kotlin.Suppress
import kotlin.collections.List
import kotlin.jvm.JvmName

/**
 * PolicyRule holds information that describes a policy rule, but does not contain information about who the rule applies to or which namespace the rule applies to.
 * @property apiGroups APIGroups is the name of the APIGroup that contains the resources.  If multiple API groups are specified, any action requested against one of the enumerated resources in any API group will be allowed.
 * @property nonResourceURLs NonResourceURLs is a set of partial urls that a user should have access to.  *s are allowed, but only as the full, final step in the path This name is intentionally different than the internal type so that the DefaultConvert works nicely and because the ordering may be different. Since non-resource URLs are not namespaced, this field is only applicable for ClusterRoles referenced from a ClusterRoleBinding. Rules can either apply to API resources (such as "pods" or "secrets") or non-resource URL paths (such as "/api"),  but not both.
 * @property resourceNames ResourceNames is an optional white list of names that the rule applies to.  An empty set means that everything is allowed.
 * @property resources Resources is a list of resources this rule applies to.  ResourceAll represents all resources.
 * @property verbs Verbs is a list of Verbs that apply to ALL the ResourceKinds and AttributeRestrictions contained in this rule.  VerbAll represents all kinds.
 */
public data class PolicyRuleArgs(
    public val apiGroups: Output>? = null,
    public val nonResourceURLs: Output>? = null,
    public val resourceNames: Output>? = null,
    public val resources: Output>? = null,
    public val verbs: Output>,
) : ConvertibleToJava {
    override fun toJava(): com.pulumi.kubernetes.rbac.v1alpha1.inputs.PolicyRuleArgs =
        com.pulumi.kubernetes.rbac.v1alpha1.inputs.PolicyRuleArgs.builder()
            .apiGroups(apiGroups?.applyValue({ args0 -> args0.map({ args0 -> args0 }) }))
            .nonResourceURLs(nonResourceURLs?.applyValue({ args0 -> args0.map({ args0 -> args0 }) }))
            .resourceNames(resourceNames?.applyValue({ args0 -> args0.map({ args0 -> args0 }) }))
            .resources(resources?.applyValue({ args0 -> args0.map({ args0 -> args0 }) }))
            .verbs(verbs.applyValue({ args0 -> args0.map({ args0 -> args0 }) })).build()
}

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

    private var nonResourceURLs: Output>? = null

    private var resourceNames: Output>? = null

    private var resources: Output>? = null

    private var verbs: Output>? = null

    /**
     * @param value APIGroups is the name of the APIGroup that contains the resources.  If multiple API groups are specified, any action requested against one of the enumerated resources in any API group will be allowed.
     */
    @JvmName("nilfkadxvhyiottr")
    public suspend fun apiGroups(`value`: Output>) {
        this.apiGroups = value
    }

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

    /**
     * @param values APIGroups is the name of the APIGroup that contains the resources.  If multiple API groups are specified, any action requested against one of the enumerated resources in any API group will be allowed.
     */
    @JvmName("yyatppwflispgcxh")
    public suspend fun apiGroups(values: List>) {
        this.apiGroups = Output.all(values)
    }

    /**
     * @param value NonResourceURLs is a set of partial urls that a user should have access to.  *s are allowed, but only as the full, final step in the path This name is intentionally different than the internal type so that the DefaultConvert works nicely and because the ordering may be different. Since non-resource URLs are not namespaced, this field is only applicable for ClusterRoles referenced from a ClusterRoleBinding. Rules can either apply to API resources (such as "pods" or "secrets") or non-resource URL paths (such as "/api"),  but not both.
     */
    @JvmName("xwjgcdchwpkpxlyk")
    public suspend fun nonResourceURLs(`value`: Output>) {
        this.nonResourceURLs = value
    }

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

    /**
     * @param values NonResourceURLs is a set of partial urls that a user should have access to.  *s are allowed, but only as the full, final step in the path This name is intentionally different than the internal type so that the DefaultConvert works nicely and because the ordering may be different. Since non-resource URLs are not namespaced, this field is only applicable for ClusterRoles referenced from a ClusterRoleBinding. Rules can either apply to API resources (such as "pods" or "secrets") or non-resource URL paths (such as "/api"),  but not both.
     */
    @JvmName("iepkvvbyikdwbnvx")
    public suspend fun nonResourceURLs(values: List>) {
        this.nonResourceURLs = Output.all(values)
    }

    /**
     * @param value ResourceNames is an optional white list of names that the rule applies to.  An empty set means that everything is allowed.
     */
    @JvmName("mbcbmkmvjxsowayv")
    public suspend fun resourceNames(`value`: Output>) {
        this.resourceNames = value
    }

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

    /**
     * @param values ResourceNames is an optional white list of names that the rule applies to.  An empty set means that everything is allowed.
     */
    @JvmName("jdhphvthqbhforck")
    public suspend fun resourceNames(values: List>) {
        this.resourceNames = Output.all(values)
    }

    /**
     * @param value Resources is a list of resources this rule applies to.  ResourceAll represents all resources.
     */
    @JvmName("tskjhhqtehddrmkp")
    public suspend fun resources(`value`: Output>) {
        this.resources = value
    }

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

    /**
     * @param values Resources is a list of resources this rule applies to.  ResourceAll represents all resources.
     */
    @JvmName("hikolhiyrpxydeak")
    public suspend fun resources(values: List>) {
        this.resources = Output.all(values)
    }

    /**
     * @param value Verbs is a list of Verbs that apply to ALL the ResourceKinds and AttributeRestrictions contained in this rule.  VerbAll represents all kinds.
     */
    @JvmName("tuovtnishvimkcqv")
    public suspend fun verbs(`value`: Output>) {
        this.verbs = value
    }

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

    /**
     * @param values Verbs is a list of Verbs that apply to ALL the ResourceKinds and AttributeRestrictions contained in this rule.  VerbAll represents all kinds.
     */
    @JvmName("akebvioptumccdqa")
    public suspend fun verbs(values: List>) {
        this.verbs = Output.all(values)
    }

    /**
     * @param value APIGroups is the name of the APIGroup that contains the resources.  If multiple API groups are specified, any action requested against one of the enumerated resources in any API group will be allowed.
     */
    @JvmName("fjetbccytuwomiom")
    public suspend fun apiGroups(`value`: List?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.apiGroups = mapped
    }

    /**
     * @param values APIGroups is the name of the APIGroup that contains the resources.  If multiple API groups are specified, any action requested against one of the enumerated resources in any API group will be allowed.
     */
    @JvmName("pfqsjkjlgtmlrgxs")
    public suspend fun apiGroups(vararg values: String) {
        val toBeMapped = values.toList()
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.apiGroups = mapped
    }

    /**
     * @param value NonResourceURLs is a set of partial urls that a user should have access to.  *s are allowed, but only as the full, final step in the path This name is intentionally different than the internal type so that the DefaultConvert works nicely and because the ordering may be different. Since non-resource URLs are not namespaced, this field is only applicable for ClusterRoles referenced from a ClusterRoleBinding. Rules can either apply to API resources (such as "pods" or "secrets") or non-resource URL paths (such as "/api"),  but not both.
     */
    @JvmName("yhvyflsjpvkeoxaw")
    public suspend fun nonResourceURLs(`value`: List?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.nonResourceURLs = mapped
    }

    /**
     * @param values NonResourceURLs is a set of partial urls that a user should have access to.  *s are allowed, but only as the full, final step in the path This name is intentionally different than the internal type so that the DefaultConvert works nicely and because the ordering may be different. Since non-resource URLs are not namespaced, this field is only applicable for ClusterRoles referenced from a ClusterRoleBinding. Rules can either apply to API resources (such as "pods" or "secrets") or non-resource URL paths (such as "/api"),  but not both.
     */
    @JvmName("vibjfwwjpbhetfji")
    public suspend fun nonResourceURLs(vararg values: String) {
        val toBeMapped = values.toList()
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.nonResourceURLs = mapped
    }

    /**
     * @param value ResourceNames is an optional white list of names that the rule applies to.  An empty set means that everything is allowed.
     */
    @JvmName("xoricmunlopbcsvm")
    public suspend fun resourceNames(`value`: List?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.resourceNames = mapped
    }

    /**
     * @param values ResourceNames is an optional white list of names that the rule applies to.  An empty set means that everything is allowed.
     */
    @JvmName("nudxspbfshahbuvx")
    public suspend fun resourceNames(vararg values: String) {
        val toBeMapped = values.toList()
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.resourceNames = mapped
    }

    /**
     * @param value Resources is a list of resources this rule applies to.  ResourceAll represents all resources.
     */
    @JvmName("dyjnwdcwmvvvvjsp")
    public suspend fun resources(`value`: List?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.resources = mapped
    }

    /**
     * @param values Resources is a list of resources this rule applies to.  ResourceAll represents all resources.
     */
    @JvmName("tjbevvrnyejicupn")
    public suspend fun resources(vararg values: String) {
        val toBeMapped = values.toList()
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.resources = mapped
    }

    /**
     * @param value Verbs is a list of Verbs that apply to ALL the ResourceKinds and AttributeRestrictions contained in this rule.  VerbAll represents all kinds.
     */
    @JvmName("jnerjvylsljownjk")
    public suspend fun verbs(`value`: List) {
        val toBeMapped = value
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.verbs = mapped
    }

    /**
     * @param values Verbs is a list of Verbs that apply to ALL the ResourceKinds and AttributeRestrictions contained in this rule.  VerbAll represents all kinds.
     */
    @JvmName("uapmktmwvavgixku")
    public suspend fun verbs(vararg values: String) {
        val toBeMapped = values.toList()
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.verbs = mapped
    }

    internal fun build(): PolicyRuleArgs = PolicyRuleArgs(
        apiGroups = apiGroups,
        nonResourceURLs = nonResourceURLs,
        resourceNames = resourceNames,
        resources = resources,
        verbs = verbs ?: throw PulumiNullFieldException("verbs"),
    )
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy