
com.pulumi.aws.efs.kotlin.FileSystemPolicy.kt Maven / Gradle / Ivy
@file:Suppress("NAME_SHADOWING", "DEPRECATION")
package com.pulumi.aws.efs.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 [FileSystemPolicy].
*/
@PulumiTagMarker
public class FileSystemPolicyResourceBuilder internal constructor() {
public var name: String? = null
public var args: FileSystemPolicyArgs = FileSystemPolicyArgs()
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 FileSystemPolicyArgsBuilder.() -> Unit) {
val builder = FileSystemPolicyArgsBuilder()
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(): FileSystemPolicy {
val builtJavaResource = com.pulumi.aws.efs.FileSystemPolicy(
this.name,
this.args.toJava(),
this.opts.toJava(),
)
return FileSystemPolicy(builtJavaResource)
}
}
/**
* Provides an Elastic File System (EFS) File System Policy resource.
* ## Example Usage
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as aws from "@pulumi/aws";
* const fs = new aws.efs.FileSystem("fs", {creationToken: "my-product"});
* const policy = aws.iam.getPolicyDocumentOutput({
* statements: [{
* sid: "ExampleStatement01",
* effect: "Allow",
* principals: [{
* type: "AWS",
* identifiers: ["*"],
* }],
* actions: [
* "elasticfilesystem:ClientMount",
* "elasticfilesystem:ClientWrite",
* ],
* resources: [fs.arn],
* conditions: [{
* test: "Bool",
* variable: "aws:SecureTransport",
* values: ["true"],
* }],
* }],
* });
* const policyFileSystemPolicy = new aws.efs.FileSystemPolicy("policy", {
* fileSystemId: fs.id,
* policy: policy.apply(policy => policy.json),
* });
* ```
* ```python
* import pulumi
* import pulumi_aws as aws
* fs = aws.efs.FileSystem("fs", creation_token="my-product")
* policy = aws.iam.get_policy_document_output(statements=[{
* "sid": "ExampleStatement01",
* "effect": "Allow",
* "principals": [{
* "type": "AWS",
* "identifiers": ["*"],
* }],
* "actions": [
* "elasticfilesystem:ClientMount",
* "elasticfilesystem:ClientWrite",
* ],
* "resources": [fs.arn],
* "conditions": [{
* "test": "Bool",
* "variable": "aws:SecureTransport",
* "values": ["true"],
* }],
* }])
* policy_file_system_policy = aws.efs.FileSystemPolicy("policy",
* file_system_id=fs.id,
* policy=policy.json)
* ```
* ```csharp
* using System.Collections.Generic;
* using System.Linq;
* using Pulumi;
* using Aws = Pulumi.Aws;
* return await Deployment.RunAsync(() =>
* {
* var fs = new Aws.Efs.FileSystem("fs", new()
* {
* CreationToken = "my-product",
* });
* var policy = Aws.Iam.GetPolicyDocument.Invoke(new()
* {
* Statements = new[]
* {
* new Aws.Iam.Inputs.GetPolicyDocumentStatementInputArgs
* {
* Sid = "ExampleStatement01",
* Effect = "Allow",
* Principals = new[]
* {
* new Aws.Iam.Inputs.GetPolicyDocumentStatementPrincipalInputArgs
* {
* Type = "AWS",
* Identifiers = new[]
* {
* "*",
* },
* },
* },
* Actions = new[]
* {
* "elasticfilesystem:ClientMount",
* "elasticfilesystem:ClientWrite",
* },
* Resources = new[]
* {
* fs.Arn,
* },
* Conditions = new[]
* {
* new Aws.Iam.Inputs.GetPolicyDocumentStatementConditionInputArgs
* {
* Test = "Bool",
* Variable = "aws:SecureTransport",
* Values = new[]
* {
* "true",
* },
* },
* },
* },
* },
* });
* var policyFileSystemPolicy = new Aws.Efs.FileSystemPolicy("policy", new()
* {
* FileSystemId = fs.Id,
* Policy = policy.Apply(getPolicyDocumentResult => getPolicyDocumentResult.Json),
* });
* });
* ```
* ```go
* package main
* import (
* "github.com/pulumi/pulumi-aws/sdk/v6/go/aws/efs"
* "github.com/pulumi/pulumi-aws/sdk/v6/go/aws/iam"
* "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
* )
* func main() {
* pulumi.Run(func(ctx *pulumi.Context) error {
* fs, err := efs.NewFileSystem(ctx, "fs", &efs.FileSystemArgs{
* CreationToken: pulumi.String("my-product"),
* })
* if err != nil {
* return err
* }
* policy := iam.GetPolicyDocumentOutput(ctx, iam.GetPolicyDocumentOutputArgs{
* Statements: iam.GetPolicyDocumentStatementArray{
* &iam.GetPolicyDocumentStatementArgs{
* Sid: pulumi.String("ExampleStatement01"),
* Effect: pulumi.String("Allow"),
* Principals: iam.GetPolicyDocumentStatementPrincipalArray{
* &iam.GetPolicyDocumentStatementPrincipalArgs{
* Type: pulumi.String("AWS"),
* Identifiers: pulumi.StringArray{
* pulumi.String("*"),
* },
* },
* },
* Actions: pulumi.StringArray{
* pulumi.String("elasticfilesystem:ClientMount"),
* pulumi.String("elasticfilesystem:ClientWrite"),
* },
* Resources: pulumi.StringArray{
* fs.Arn,
* },
* Conditions: iam.GetPolicyDocumentStatementConditionArray{
* &iam.GetPolicyDocumentStatementConditionArgs{
* Test: pulumi.String("Bool"),
* Variable: pulumi.String("aws:SecureTransport"),
* Values: pulumi.StringArray{
* pulumi.String("true"),
* },
* },
* },
* },
* },
* }, nil)
* _, err = efs.NewFileSystemPolicy(ctx, "policy", &efs.FileSystemPolicyArgs{
* FileSystemId: fs.ID(),
* Policy: pulumi.String(policy.ApplyT(func(policy iam.GetPolicyDocumentResult) (*string, error) {
* return &policy.Json, nil
* }).(pulumi.StringPtrOutput)),
* })
* 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.efs.FileSystem;
* import com.pulumi.aws.efs.FileSystemArgs;
* import com.pulumi.aws.iam.IamFunctions;
* import com.pulumi.aws.iam.inputs.GetPolicyDocumentArgs;
* import com.pulumi.aws.efs.FileSystemPolicy;
* import com.pulumi.aws.efs.FileSystemPolicyArgs;
* 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 fs = new FileSystem("fs", FileSystemArgs.builder()
* .creationToken("my-product")
* .build());
* final var policy = IamFunctions.getPolicyDocument(GetPolicyDocumentArgs.builder()
* .statements(GetPolicyDocumentStatementArgs.builder()
* .sid("ExampleStatement01")
* .effect("Allow")
* .principals(GetPolicyDocumentStatementPrincipalArgs.builder()
* .type("AWS")
* .identifiers("*")
* .build())
* .actions(
* "elasticfilesystem:ClientMount",
* "elasticfilesystem:ClientWrite")
* .resources(fs.arn())
* .conditions(GetPolicyDocumentStatementConditionArgs.builder()
* .test("Bool")
* .variable("aws:SecureTransport")
* .values("true")
* .build())
* .build())
* .build());
* var policyFileSystemPolicy = new FileSystemPolicy("policyFileSystemPolicy", FileSystemPolicyArgs.builder()
* .fileSystemId(fs.id())
* .policy(policy.applyValue(getPolicyDocumentResult -> getPolicyDocumentResult).applyValue(policy -> policy.applyValue(getPolicyDocumentResult -> getPolicyDocumentResult.json())))
* .build());
* }
* }
* ```
* ```yaml
* resources:
* fs:
* type: aws:efs:FileSystem
* properties:
* creationToken: my-product
* policyFileSystemPolicy:
* type: aws:efs:FileSystemPolicy
* name: policy
* properties:
* fileSystemId: ${fs.id}
* policy: ${policy.json}
* variables:
* policy:
* fn::invoke:
* Function: aws:iam:getPolicyDocument
* Arguments:
* statements:
* - sid: ExampleStatement01
* effect: Allow
* principals:
* - type: AWS
* identifiers:
* - '*'
* actions:
* - elasticfilesystem:ClientMount
* - elasticfilesystem:ClientWrite
* resources:
* - ${fs.arn}
* conditions:
* - test: Bool
* variable: aws:SecureTransport
* values:
* - 'true'
* ```
*
* ## Import
* Using `pulumi import`, import the EFS file system policies using the `id`. For example:
* ```sh
* $ pulumi import aws:efs/fileSystemPolicy:FileSystemPolicy foo fs-6fa144c6
* ```
*/
public class FileSystemPolicy internal constructor(
override val javaResource: com.pulumi.aws.efs.FileSystemPolicy,
) : KotlinCustomResource(javaResource, FileSystemPolicyMapper) {
/**
* A flag to indicate whether to bypass the `aws.efs.FileSystemPolicy` lockout safety check. The policy lockout safety check determines whether the policy in the request will prevent the principal making the request will be locked out from making future `PutFileSystemPolicy` requests on the file system. Set `bypass_policy_lockout_safety_check` to `true` only when you intend to prevent the principal that is making the request from making a subsequent `PutFileSystemPolicy` request on the file system. The default value is `false`.
*/
public val bypassPolicyLockoutSafetyCheck: Output?
get() = javaResource.bypassPolicyLockoutSafetyCheck().applyValue({ args0 ->
args0.map({ args0 ->
args0
}).orElse(null)
})
/**
* The ID of the EFS file system.
*/
public val fileSystemId: Output
get() = javaResource.fileSystemId().applyValue({ args0 -> args0 })
/**
* The JSON formatted file system policy for the EFS file system. see [Docs](https://docs.aws.amazon.com/efs/latest/ug/access-control-overview.html#access-control-manage-access-intro-resource-policies) for more info.
* The following arguments are optional:
*/
public val policy: Output
get() = javaResource.policy().applyValue({ args0 -> args0 })
}
public object FileSystemPolicyMapper : ResourceMapper {
override fun supportsMappingOfType(javaResource: Resource): Boolean =
com.pulumi.aws.efs.FileSystemPolicy::class == javaResource::class
override fun map(javaResource: Resource): FileSystemPolicy = FileSystemPolicy(
javaResource as
com.pulumi.aws.efs.FileSystemPolicy,
)
}
/**
* @see [FileSystemPolicy].
* @param name The _unique_ name of the resulting resource.
* @param block Builder for [FileSystemPolicy].
*/
public suspend fun fileSystemPolicy(
name: String,
block: suspend FileSystemPolicyResourceBuilder.() -> Unit,
): FileSystemPolicy {
val builder = FileSystemPolicyResourceBuilder()
builder.name(name)
block(builder)
return builder.build()
}
/**
* @see [FileSystemPolicy].
* @param name The _unique_ name of the resulting resource.
*/
public fun fileSystemPolicy(name: String): FileSystemPolicy {
val builder = FileSystemPolicyResourceBuilder()
builder.name(name)
return builder.build()
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy