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.
@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.PulumiTagMarker
import com.pulumi.kubernetes.rbac.v1alpha1.inputs.PolicyRulePatchArgs.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 PolicyRulePatchArgs(
public val apiGroups: Output>? = null,
public val nonResourceURLs: Output>? = null,
public val resourceNames: Output>? = null,
public val resources: Output>? = null,
public val verbs: Output>? = null,
) : ConvertibleToJava {
override fun toJava(): com.pulumi.kubernetes.rbac.v1alpha1.inputs.PolicyRulePatchArgs =
com.pulumi.kubernetes.rbac.v1alpha1.inputs.PolicyRulePatchArgs.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 [PolicyRulePatchArgs].
*/
@PulumiTagMarker
public class PolicyRulePatchArgsBuilder 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("ubibjjlhhhxfpaum")
public suspend fun apiGroups(`value`: Output>) {
this.apiGroups = value
}
@JvmName("byvamubbabdplbqp")
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("rgwvpejjiyrnkllq")
public suspend fun apiGroups(values: List