
com.pulumi.gcp.iam.kotlin.PrincipalAccessBoundaryPolicy.kt Maven / Gradle / Ivy
@file:Suppress("NAME_SHADOWING", "DEPRECATION")
package com.pulumi.gcp.iam.kotlin
import com.pulumi.core.Output
import com.pulumi.gcp.iam.kotlin.outputs.PrincipalAccessBoundaryPolicyDetails
import com.pulumi.gcp.iam.kotlin.outputs.PrincipalAccessBoundaryPolicyDetails.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
import kotlin.collections.Map
/**
* Builder for [PrincipalAccessBoundaryPolicy].
*/
@PulumiTagMarker
public class PrincipalAccessBoundaryPolicyResourceBuilder internal constructor() {
public var name: String? = null
public var args: PrincipalAccessBoundaryPolicyArgs = PrincipalAccessBoundaryPolicyArgs()
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 PrincipalAccessBoundaryPolicyArgsBuilder.() -> Unit) {
val builder = PrincipalAccessBoundaryPolicyArgsBuilder()
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(): PrincipalAccessBoundaryPolicy {
val builtJavaResource =
com.pulumi.gcp.iam.PrincipalAccessBoundaryPolicy(
this.name,
this.args.toJava(),
this.opts.toJava(),
)
return PrincipalAccessBoundaryPolicy(builtJavaResource)
}
}
/**
* An IAM Principal Access Boundary Policy resource
* To get more information about PrincipalAccessBoundaryPolicy, see:
* * [API documentation](https://cloud.google.com/iam/docs/reference/rest/v3/organizations.locations.principalAccessBoundaryPolicies)
* * How-to Guides
* * [Create and apply Principal Access Boundaries](https://cloud.google.com/iam/docs/principal-access-boundary-policies-create)
* ## Example Usage
* ### Iam Principal Access Boundary Policy
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as gcp from "@pulumi/gcp";
* const my_pab_policy = new gcp.iam.PrincipalAccessBoundaryPolicy("my-pab-policy", {
* organization: "123456789",
* location: "global",
* displayName: "test pab policy",
* principalAccessBoundaryPolicyId: "test-pab-policy",
* });
* ```
* ```python
* import pulumi
* import pulumi_gcp as gcp
* my_pab_policy = gcp.iam.PrincipalAccessBoundaryPolicy("my-pab-policy",
* organization="123456789",
* location="global",
* display_name="test pab policy",
* principal_access_boundary_policy_id="test-pab-policy")
* ```
* ```csharp
* using System.Collections.Generic;
* using System.Linq;
* using Pulumi;
* using Gcp = Pulumi.Gcp;
* return await Deployment.RunAsync(() =>
* {
* var my_pab_policy = new Gcp.Iam.PrincipalAccessBoundaryPolicy("my-pab-policy", new()
* {
* Organization = "123456789",
* Location = "global",
* DisplayName = "test pab policy",
* PrincipalAccessBoundaryPolicyId = "test-pab-policy",
* });
* });
* ```
* ```go
* package main
* import (
* "github.com/pulumi/pulumi-gcp/sdk/v8/go/gcp/iam"
* "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
* )
* func main() {
* pulumi.Run(func(ctx *pulumi.Context) error {
* _, err := iam.NewPrincipalAccessBoundaryPolicy(ctx, "my-pab-policy", &iam.PrincipalAccessBoundaryPolicyArgs{
* Organization: pulumi.String("123456789"),
* Location: pulumi.String("global"),
* DisplayName: pulumi.String("test pab policy"),
* PrincipalAccessBoundaryPolicyId: pulumi.String("test-pab-policy"),
* })
* if err != nil {
* return err
* }
* return nil
* })
* }
* ```
* ```java
* package generated_program;
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.gcp.iam.PrincipalAccessBoundaryPolicy;
* import com.pulumi.gcp.iam.PrincipalAccessBoundaryPolicyArgs;
* import java.util.List;
* import java.util.ArrayList;
* import java.util.Map;
* import java.io.File;
* import java.nio.file.Files;
* import java.nio.file.Paths;
* public class App {
* public static void main(String[] args) {
* Pulumi.run(App::stack);
* }
* public static void stack(Context ctx) {
* var my_pab_policy = new PrincipalAccessBoundaryPolicy("my-pab-policy", PrincipalAccessBoundaryPolicyArgs.builder()
* .organization("123456789")
* .location("global")
* .displayName("test pab policy")
* .principalAccessBoundaryPolicyId("test-pab-policy")
* .build());
* }
* }
* ```
* ```yaml
* resources:
* my-pab-policy:
* type: gcp:iam:PrincipalAccessBoundaryPolicy
* properties:
* organization: '123456789'
* location: global
* displayName: test pab policy
* principalAccessBoundaryPolicyId: test-pab-policy
* ```
*
* ## Import
* PrincipalAccessBoundaryPolicy can be imported using any of these accepted formats:
* * `organizations/{{organization}}/locations/{{location}}/principalAccessBoundaryPolicies/{{principal_access_boundary_policy_id}}`
* * `{{organization}}/{{location}}/{{principal_access_boundary_policy_id}}`
* When using the `pulumi import` command, PrincipalAccessBoundaryPolicy can be imported using one of the formats above. For example:
* ```sh
* $ pulumi import gcp:iam/principalAccessBoundaryPolicy:PrincipalAccessBoundaryPolicy default organizations/{{organization}}/locations/{{location}}/principalAccessBoundaryPolicies/{{principal_access_boundary_policy_id}}
* ```
* ```sh
* $ pulumi import gcp:iam/principalAccessBoundaryPolicy:PrincipalAccessBoundaryPolicy default {{organization}}/{{location}}/{{principal_access_boundary_policy_id}}
* ```
*/
public class PrincipalAccessBoundaryPolicy internal constructor(
override val javaResource: com.pulumi.gcp.iam.PrincipalAccessBoundaryPolicy,
) : KotlinCustomResource(javaResource, PrincipalAccessBoundaryPolicyMapper) {
/**
* User defined annotations. See https://google.aip.dev/148#annotations
* for more details such as format and size limitations
* **Note**: This field is non-authoritative, and will only manage the annotations present in your configuration.
* Please refer to the field `effective_annotations` for all of the annotations present on the resource.
*/
public val annotations: Output
© 2015 - 2025 Weber Informatics LLC | Privacy Policy