Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.
@file:Suppress("NAME_SHADOWING", "DEPRECATION")
package com.pulumi.kubernetes.rbac.v1beta1.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.v1beta1.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 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. '*' represents all resources in the specified apiGroups. '*/foo' represents the subresource 'foo' for all resources in the specified apiGroups.
* @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.v1beta1.inputs.PolicyRuleArgs =
com.pulumi.kubernetes.rbac.v1beta1.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("gewlxrdyhcfflasi")
public suspend fun apiGroups(`value`: Output>) {
this.apiGroups = value
}
@JvmName("yqoblyuqpwwjneth")
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("xtfdluqavubkrgsg")
public suspend fun apiGroups(values: List