com.pulumi.aws.sns.kotlin.DataProtectionPolicy.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pulumi-aws-kotlin Show documentation
Show all versions of pulumi-aws-kotlin Show documentation
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.aws.sns.kotlin
import com.pulumi.core.Output
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 [DataProtectionPolicy].
*/
@PulumiTagMarker
public class DataProtectionPolicyResourceBuilder internal constructor() {
public var name: String? = null
public var args: DataProtectionPolicyArgs = DataProtectionPolicyArgs()
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 DataProtectionPolicyArgsBuilder.() -> Unit) {
val builder = DataProtectionPolicyArgsBuilder()
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(): DataProtectionPolicy {
val builtJavaResource = com.pulumi.aws.sns.DataProtectionPolicy(
this.name,
this.args.toJava(),
this.opts.toJava(),
)
return DataProtectionPolicy(builtJavaResource)
}
}
/**
* Provides an SNS data protection topic policy resource
* ## Example Usage
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as aws from "@pulumi/aws";
* const example = new aws.sns.Topic("example", {name: "example"});
* const exampleDataProtectionPolicy = new aws.sns.DataProtectionPolicy("example", {
* arn: example.arn,
* policy: JSON.stringify({
* Description: "Example data protection policy",
* Name: "__example_data_protection_policy",
* Statement: [{
* DataDirection: "Inbound",
* DataIdentifier: ["arn:aws:dataprotection::aws:data-identifier/EmailAddress"],
* Operation: {
* Deny: {},
* },
* Principal: ["*"],
* Sid: "__deny_statement_11ba9d96",
* }],
* Version: "2021-06-01",
* }),
* });
* ```
* ```python
* import pulumi
* import json
* import pulumi_aws as aws
* example = aws.sns.Topic("example", name="example")
* example_data_protection_policy = aws.sns.DataProtectionPolicy("example",
* arn=example.arn,
* policy=json.dumps({
* "Description": "Example data protection policy",
* "Name": "__example_data_protection_policy",
* "Statement": [{
* "DataDirection": "Inbound",
* "DataIdentifier": ["arn:aws:dataprotection::aws:data-identifier/EmailAddress"],
* "Operation": {
* "Deny": {},
* },
* "Principal": ["*"],
* "Sid": "__deny_statement_11ba9d96",
* }],
* "Version": "2021-06-01",
* }))
* ```
* ```csharp
* using System.Collections.Generic;
* using System.Linq;
* using System.Text.Json;
* using Pulumi;
* using Aws = Pulumi.Aws;
* return await Deployment.RunAsync(() =>
* {
* var example = new Aws.Sns.Topic("example", new()
* {
* Name = "example",
* });
* var exampleDataProtectionPolicy = new Aws.Sns.DataProtectionPolicy("example", new()
* {
* Arn = example.Arn,
* Policy = JsonSerializer.Serialize(new Dictionary
* {
* ["Description"] = "Example data protection policy",
* ["Name"] = "__example_data_protection_policy",
* ["Statement"] = new[]
* {
* new Dictionary
* {
* ["DataDirection"] = "Inbound",
* ["DataIdentifier"] = new[]
* {
* "arn:aws:dataprotection::aws:data-identifier/EmailAddress",
* },
* ["Operation"] = new Dictionary
* {
* ["Deny"] = new Dictionary
* {
* },
* },
* ["Principal"] = new[]
* {
* "*",
* },
* ["Sid"] = "__deny_statement_11ba9d96",
* },
* },
* ["Version"] = "2021-06-01",
* }),
* });
* });
* ```
* ```go
* package main
* import (
* "encoding/json"
* "github.com/pulumi/pulumi-aws/sdk/v6/go/aws/sns"
* "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
* )
* func main() {
* pulumi.Run(func(ctx *pulumi.Context) error {
* example, err := sns.NewTopic(ctx, "example", &sns.TopicArgs{
* Name: pulumi.String("example"),
* })
* if err != nil {
* return err
* }
* tmpJSON0, err := json.Marshal(map[string]interface{}{
* "Description": "Example data protection policy",
* "Name": "__example_data_protection_policy",
* "Statement": []map[string]interface{}{
* map[string]interface{}{
* "DataDirection": "Inbound",
* "DataIdentifier": []string{
* "arn:aws:dataprotection::aws:data-identifier/EmailAddress",
* },
* "Operation": map[string]interface{}{
* "Deny": map[string]interface{}{},
* },
* "Principal": []string{
* "*",
* },
* "Sid": "__deny_statement_11ba9d96",
* },
* },
* "Version": "2021-06-01",
* })
* if err != nil {
* return err
* }
* json0 := string(tmpJSON0)
* _, err = sns.NewDataProtectionPolicy(ctx, "example", &sns.DataProtectionPolicyArgs{
* Arn: example.Arn,
* Policy: pulumi.String(json0),
* })
* 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.aws.sns.Topic;
* import com.pulumi.aws.sns.TopicArgs;
* import com.pulumi.aws.sns.DataProtectionPolicy;
* import com.pulumi.aws.sns.DataProtectionPolicyArgs;
* import static com.pulumi.codegen.internal.Serialization.*;
* 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 example = new Topic("example", TopicArgs.builder()
* .name("example")
* .build());
* var exampleDataProtectionPolicy = new DataProtectionPolicy("exampleDataProtectionPolicy", DataProtectionPolicyArgs.builder()
* .arn(example.arn())
* .policy(serializeJson(
* jsonObject(
* jsonProperty("Description", "Example data protection policy"),
* jsonProperty("Name", "__example_data_protection_policy"),
* jsonProperty("Statement", jsonArray(jsonObject(
* jsonProperty("DataDirection", "Inbound"),
* jsonProperty("DataIdentifier", jsonArray("arn:aws:dataprotection::aws:data-identifier/EmailAddress")),
* jsonProperty("Operation", jsonObject(
* jsonProperty("Deny", jsonObject(
* ))
* )),
* jsonProperty("Principal", jsonArray("*")),
* jsonProperty("Sid", "__deny_statement_11ba9d96")
* ))),
* jsonProperty("Version", "2021-06-01")
* )))
* .build());
* }
* }
* ```
* ```yaml
* resources:
* example:
* type: aws:sns:Topic
* properties:
* name: example
* exampleDataProtectionPolicy:
* type: aws:sns:DataProtectionPolicy
* name: example
* properties:
* arn: ${example.arn}
* policy:
* fn::toJSON:
* Description: Example data protection policy
* Name: __example_data_protection_policy
* Statement:
* - DataDirection: Inbound
* DataIdentifier:
* - arn:aws:dataprotection::aws:data-identifier/EmailAddress
* Operation:
* Deny: {}
* Principal:
* - '*'
* Sid: __deny_statement_11ba9d96
* Version: 2021-06-01
* ```
*
* ## Import
* Using `pulumi import`, import SNS Data Protection Topic Policy using the topic ARN. For example:
* ```sh
* $ pulumi import aws:sns/dataProtectionPolicy:DataProtectionPolicy example arn:aws:sns:us-west-2:123456789012:example
* ```
*/
public class DataProtectionPolicy internal constructor(
override val javaResource: com.pulumi.aws.sns.DataProtectionPolicy,
) : KotlinCustomResource(javaResource, DataProtectionPolicyMapper) {
/**
* The ARN of the SNS topic
*/
public val arn: Output
get() = javaResource.arn().applyValue({ args0 -> args0 })
/**
* The fully-formed AWS policy as JSON. For more information about building AWS IAM policy documents with this provider, see the AWS IAM Policy Document Guide.
*/
public val policy: Output
get() = javaResource.policy().applyValue({ args0 -> args0 })
}
public object DataProtectionPolicyMapper : ResourceMapper {
override fun supportsMappingOfType(javaResource: Resource): Boolean =
com.pulumi.aws.sns.DataProtectionPolicy::class == javaResource::class
override fun map(javaResource: Resource): DataProtectionPolicy = DataProtectionPolicy(
javaResource
as com.pulumi.aws.sns.DataProtectionPolicy,
)
}
/**
* @see [DataProtectionPolicy].
* @param name The _unique_ name of the resulting resource.
* @param block Builder for [DataProtectionPolicy].
*/
public suspend fun dataProtectionPolicy(
name: String,
block: suspend DataProtectionPolicyResourceBuilder.() -> Unit,
): DataProtectionPolicy {
val builder = DataProtectionPolicyResourceBuilder()
builder.name(name)
block(builder)
return builder.build()
}
/**
* @see [DataProtectionPolicy].
* @param name The _unique_ name of the resulting resource.
*/
public fun dataProtectionPolicy(name: String): DataProtectionPolicy {
val builder = DataProtectionPolicyResourceBuilder()
builder.name(name)
return builder.build()
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy