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

com.pulumi.googlenative.securitycenter.v1.kotlin.OrganizationSourceIamMember.kt Maven / Gradle / Ivy

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

package com.pulumi.googlenative.securitycenter.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 [OrganizationSourceIamMember].
 */
@PulumiTagMarker
public class OrganizationSourceIamMemberResourceBuilder internal constructor() {
    public var name: String? = null

    public var args: OrganizationSourceIamMemberArgs = OrganizationSourceIamMemberArgs()

    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 OrganizationSourceIamMemberArgsBuilder.() -> Unit) {
        val builder = OrganizationSourceIamMemberArgsBuilder()
        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(): OrganizationSourceIamMember {
        val builtJavaResource =
            com.pulumi.googlenative.securitycenter.v1.OrganizationSourceIamMember(
                this.name,
                this.args.toJava(),
                this.opts.toJava(),
            )
        return OrganizationSourceIamMember(builtJavaResource)
    }
}

/**
 * Sets the access control policy on the specified Source.
 */
public class OrganizationSourceIamMember internal constructor(
    override val javaResource: com.pulumi.googlenative.securitycenter.v1.OrganizationSourceIamMember,
) : KotlinCustomResource(javaResource, OrganizationSourceIamMemberMapper) {
    /**
     * 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 })

    /**
     * Specifies the principals requesting access for a Google Cloud resource. `members` can have the following values: * `allUsers`: A special identifier that represents anyone who is on the internet; with or without a Google account. * `allAuthenticatedUsers`: A special identifier that represents anyone who is authenticated with a Google account or a service account. Does not include identities that come from external identity providers (IdPs) through identity federation. * `user:{emailid}`: An email address that represents a specific Google account. For example, `[email protected]` . * `serviceAccount:{emailid}`: An email address that represents a Google service account. For example, `[email protected]`. * `serviceAccount:{projectid}.svc.id.goog[{namespace}/{kubernetes-sa}]`: An identifier for a [Kubernetes service account](https://cloud.google.com/kubernetes-engine/docs/how-to/kubernetes-service-accounts). For example, `my-project.svc.id.goog[my-namespace/my-kubernetes-sa]`. * `group:{emailid}`: An email address that represents a Google group. For example, `[email protected]`. * `domain:{domain}`: The G Suite domain (primary) that represents all the users of that domain. For example, `google.com` or `example.com`. * `deleted:user:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a user that has been recently deleted. For example, `[email protected]?uid=123456789012345678901`. If the user is recovered, this value reverts to `user:{emailid}` and the recovered user retains the role in the binding. * `deleted:serviceAccount:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a service account that has been recently deleted. For example, `[email protected]?uid=123456789012345678901`. If the service account is undeleted, this value reverts to `serviceAccount:{emailid}` and the undeleted service account retains the role in the binding. * `deleted:group:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a Google group that has been recently deleted. For example, `[email protected]?uid=123456789012345678901`. If the group is recovered, this value reverts to `group:{emailid}` and the recovered group retains the role in the binding.
     */
    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 })

    /**
     * Role that is assigned to the list of `members`, or principals. For example, `roles/viewer`, `roles/editor`, or `roles/owner`.
     */
    public val role: Output
        get() = javaResource.role().applyValue({ args0 -> args0 })
}

public object OrganizationSourceIamMemberMapper : ResourceMapper {
    override fun supportsMappingOfType(javaResource: Resource): Boolean =
        com.pulumi.googlenative.securitycenter.v1.OrganizationSourceIamMember::class == javaResource::class

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

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

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




© 2015 - 2025 Weber Informatics LLC | Privacy Policy