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

com.pulumi.googlenative.binaryauthorization.v1.kotlin.PolicyIamMember.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.

The newest version!
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.googlenative.binaryauthorization.v1.kotlin

import com.pulumi.core.Output
import com.pulumi.googlenative.iam.v1.kotlin.outputs.Condition
import com.pulumi.googlenative.iam.v1.kotlin.outputs.Condition.Companion.toKotlin
import com.pulumi.kotlin.KotlinCustomResource
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.ResourceMapper
import com.pulumi.kotlin.options.CustomResourceOptions
import com.pulumi.kotlin.options.CustomResourceOptionsBuilder
import com.pulumi.resources.Resource
import kotlin.Boolean
import kotlin.String
import kotlin.Suppress
import kotlin.Unit

/**
 * Builder for [PolicyIamMember].
 */
@PulumiTagMarker
public class PolicyIamMemberResourceBuilder internal constructor() {
    public var name: String? = null

    public var args: PolicyIamMemberArgs = PolicyIamMemberArgs()

    public var opts: CustomResourceOptions = CustomResourceOptions()

    /**
     * @param name The _unique_ name of the resulting resource.
     */
    public fun name(`value`: String) {
        this.name = value
    }

    /**
     * @param block The arguments to use to populate this resource's properties.
     */
    public suspend fun args(block: suspend PolicyIamMemberArgsBuilder.() -> Unit) {
        val builder = PolicyIamMemberArgsBuilder()
        block(builder)
        this.args = builder.build()
    }

    /**
     * @param block A bag of options that control this resource's behavior.
     */
    public suspend fun opts(block: suspend CustomResourceOptionsBuilder.() -> Unit) {
        this.opts = com.pulumi.kotlin.options.CustomResourceOptions.opts(block)
    }

    internal fun build(): PolicyIamMember {
        val builtJavaResource =
            com.pulumi.googlenative.binaryauthorization.v1.PolicyIamMember(
                this.name,
                this.args.toJava(),
                this.opts.toJava(),
            )
        return PolicyIamMember(builtJavaResource)
    }
}

/**
 * Sets the access control policy on the specified resource. Replaces any existing policy. Can return `NOT_FOUND`, `INVALID_ARGUMENT`, and `PERMISSION_DENIED` errors.
 */
public class PolicyIamMember internal constructor(
    override val javaResource: com.pulumi.googlenative.binaryauthorization.v1.PolicyIamMember,
) : KotlinCustomResource(javaResource, PolicyIamMemberMapper) {
    /**
     * An IAM Condition for a given binding. See https://cloud.google.com/iam/docs/conditions-overview for additional details.
     */
    public val condition: Output?
        get() = javaResource.condition().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    toKotlin(args0)
                })
            }).orElse(null)
        })

    /**
     * The etag of the resource's IAM policy.
     */
    public val etag: Output
        get() = javaResource.etag().applyValue({ args0 -> args0 })

    /**
     * Identity that will be granted the privilege in role. The entry can have one of the following values:
     *  * user:{emailid}: An email address that represents a specific Google account. For example, [email protected] or [email protected].
     *  * serviceAccount:{emailid}: An email address that represents a service account. For example, [email protected].
     *  * group:{emailid}: An email address that represents a Google group. For example, [email protected].
     *  * domain:{domain}: A G Suite domain (primary, instead of alias) name that represents all the users of that domain. For example, google.com or example.com.
     */
    public val member: Output
        get() = javaResource.member().applyValue({ args0 -> args0 })

    /**
     * The name of the resource to manage IAM policies for.
     */
    public val name: Output
        get() = javaResource.name().applyValue({ args0 -> args0 })

    /**
     * The project in which the resource belongs. If it is not provided, a default will be supplied.
     */
    public val project: Output
        get() = javaResource.project().applyValue({ args0 -> args0 })

    /**
     * The role that should be applied.
     */
    public val role: Output
        get() = javaResource.role().applyValue({ args0 -> args0 })
}

public object PolicyIamMemberMapper : ResourceMapper {
    override fun supportsMappingOfType(javaResource: Resource): Boolean =
        com.pulumi.googlenative.binaryauthorization.v1.PolicyIamMember::class == javaResource::class

    override fun map(javaResource: Resource): PolicyIamMember = PolicyIamMember(
        javaResource as
            com.pulumi.googlenative.binaryauthorization.v1.PolicyIamMember,
    )
}

/**
 * @see [PolicyIamMember].
 * @param name The _unique_ name of the resulting resource.
 * @param block Builder for [PolicyIamMember].
 */
public suspend fun policyIamMember(
    name: String,
    block: suspend PolicyIamMemberResourceBuilder.() -> Unit,
): PolicyIamMember {
    val builder = PolicyIamMemberResourceBuilder()
    builder.name(name)
    block(builder)
    return builder.build()
}

/**
 * @see [PolicyIamMember].
 * @param name The _unique_ name of the resulting resource.
 */
public fun policyIamMember(name: String): PolicyIamMember {
    val builder = PolicyIamMemberResourceBuilder()
    builder.name(name)
    return builder.build()
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy