1. Packages
  2. AWS Native

AWS Native is in preview. AWS Classic is fully supported.

AWS Native v0.121.0 published on Monday, Aug 26, 2024 by Pulumi

AWS Native

aws-native logo

AWS Native is in preview. AWS Classic is fully supported.

AWS Native v0.121.0 published on Monday, Aug 26, 2024 by Pulumi

    AWS Native is in public preview. AWS Native provides coverage of all resources in the AWS Cloud Control API, including same-day access to all new AWS resources. However, some AWS resources are not yet available in AWS Native.

    For new projects, we recommend using AWS Native and AWS Classic side-by-side so you can get the speed and correctness benefits of AWS Native where possible. For existing projects, AWS Classic remains fully supported; at this time, we recommend waiting to migrate existing projects to AWS Native.

    The AWS Native provider for Pulumi can provision many of the cloud resources available in AWS. It manages and provisions resources using the AWS Cloud Control API, which typically supports new AWS features on the day of launch. Resources available in the Pulumi AWS Native provider are based on the resources defined in the AWS CloudFormation Registry.

    Hundreds of AWS resources are available in AWS Native. As AWS Cloud Control API adds resources, we will update AWS Native to include them.

    AWS Native must be configured with credentials to deploy and update resources in AWS; see Installation & Configuration for instructions.

    Examples

    Check out the examples below to try out AWS Native:

    import * as awsnative from "@pulumi/aws-native";
    
    const bucket = new awsnative.s3.Bucket("source");
    
    const accessPoint = new awsnative.s3.AccessPoint("ap", {
       bucket: bucket.id,
    });
    
    const objectlambda = new awsnative.s3objectlambda.AccessPoint("objectlambda-ap", {
       objectLambdaConfiguration: {
           supportingAccessPoint: accessPoint.arn,
           transformationConfigurations: [{
               actions: ["GetObject"],
               contentTransformation: {
                   AwsLambda: {
                       FunctionArn: fn.arn,
                   },
               },
           }]
       }
    });
    
    import pulumi
    import pulumi_aws_native as aws_native
    
    my_bucket = aws_native.s3.Bucket("myBucket")
    
    ap = aws_native.s3.AccessPoint("ap", bucket=my_bucket.id)
    
    objectlambdaap = aws_native.s3objectlambda.AccessPoint("objectlambdaap", object_lambda_configuration=aws_native.s3objectlambda.AccessPointObjectLambdaConfigurationArgs(
        supporting_access_point=ap.arn,
        transformation_configurations=[aws_native.s3objectlambda.AccessPointTransformationConfigurationArgs(
            actions=["GetObject"],
            content_transformation={
                "AwsLambda": {
                    "FunctionArn": fn.arn,
                },
            },
        )],
    ))
    
    var bucket = new AwsNative.S3.Bucket("my-bucket");
    
    var accessPoint = new AwsNative.S3.AccessPoint("ap", new AwsNative.S3.AccessPointArgs
    {
        Bucket = bucket.Id
    });
    
    var objectLambda = new AwsNative.S3ObjectLambda.AccessPoint("objectlambda-ap", new AwsNative.S3ObjectLambda.AccessPointArgs
    {
        ObjectLambdaConfiguration = new AwsNative.S3ObjectLambda.Inputs.AccessPointObjectLambdaConfigurationArgs
        {
            SupportingAccessPoint = accessPoint.Arn,
            TransformationConfigurations =
            {
                new AwsNative.S3ObjectLambda.Inputs.AccessPointTransformationConfigurationArgs
                {
                    Actions = { "GetObject" },
                    ContentTransformation = fn.Arn.Apply(arn => new Dictionary<string, object>
                    {
                        ["AwsLambda"] = new Dictionary<string, object>
                        {
                            ["FunctionArn"] = arn
                        }
                    }
                }
            }
        }
    });
    
    func main() {
        pulumi.Run(func(ctx *pulumi.Context) error {
            myBucket, err := s3.NewBucket(ctx, "myBucket", nil)
            if err != nil {
                return err
            }
            ap, err := s3.NewAccessPoint(ctx, "ap", &s3.AccessPointArgs{
                Bucket: myBucket.ID(),
            })
            if err != nil {
                return err
            }
    
            _, err = s3objectlambda.NewAccessPoint(ctx, "objectlambdaap", &s3objectlambda.AccessPointArgs{
                ObjectLambdaConfiguration: &s3objectlambda.AccessPointObjectLambdaConfigurationArgs{
                    SupportingAccessPoint: ap.Arn,
                    TransformationConfigurations: s3objectlambda.AccessPointTransformationConfigurationArray{
                        &s3objectlambda.AccessPointTransformationConfigurationArgs{
                            Actions: pulumi.StringArray{
                                pulumi.String("GetObject"),
                            },
                            ContentTransformation: pulumi.Map{
                                "AwsLambda": pulumi.Map{
                                    "FunctionArn": fn.Arn,
                                },
                            },
                        },
                    },
                },
            })
            if err != nil {
                return err
            }
            return nil
        })
    }
    
    import java.util.Map;
    
    import com.pulumi.Context;
    import com.pulumi.Exports;
    import com.pulumi.Pulumi;
    import com.pulumi.core.Output;
    
    import com.pulumi.awsnative.s3.Bucket;
    import com.pulumi.awsnative.s3.AccessPoint;
    import com.pulumi.awsnative.s3.AccessPointArgs;
    import com.pulumi.awsnative.s3objectlambda.inputs.AccessPointObjectLambdaConfigurationArgs;
    import com.pulumi.awsnative.s3objectlambda.inputs.AccessPointTransformationConfigurationArgs;
    
    
    public class App {
        public static void main(String[] args) {
            Pulumi.run(App::stack);
        }
    
        private static void stack(Context ctx) {
    
            final var bucket = new Bucket("source");
    
            final var accessPoint = new AccessPoint("ap", AccessPointArgs.builder()
                .bucket(bucket.getId())
                .build());
    
            final Output<String> functionArn = /* your function arn */;
    
            final var contentTransform = functionArn.applyValue(arn ->
                Map.of("AwsLambda", Map.of("FunctionArn", arn))
            );
    
            final var objectLambdaConfig = AccessPointObjectLambdaConfigurationArgs
                .builder()
                .supportingAccessPoint(accessPoint.arn())
                .transformationConfigurations(
                    AccessPointTransformationConfigurationArgs
                        .builder()
                        .actions("GetObject")
                        .contentTransformation(contentTransform)
                        .build()
                )
                .build();
    
            final var objectLambdaArgs = com.pulumi.awsnative.s3objectlambda.AccessPointArgs
                .builder()
                .objectLambdaConfiguration(objectLambdaConfig)
                .build();
    
            final var objectLambda = new com.pulumi.awsnative.s3objectlambda.AccessPoint("objectlambda-ap", objectLambdaArgs);
            ctx.export("objectLambdaArn", objectLambda.arn());
        }
    }
    
    resources:
      myBucket:
        type: 'aws-native:s3:Bucket'
      ap:
        type: 'aws-native:s3:AccessPoint'
        properties:
          bucket: '${myBucket}'
      action:
        type: 'aws-native:s3objectlambda:AccessPoint'
        properties:
          objectLambdaConfiguration:
            supportingAccessPoint: '${ap.Arn}'
            transformationConfigurations:
              - actions:
                  - GetObject
                contentTransformation:
                  AwsLambda:
                    FunctionArn: '${fn.Arn}'
    

    Third Party Resources

    The SDK for the AWS Native Cloud Control provider only includes resources for which Amazon have published the corresponding CloudFormation specifications. AWS also supports CloudFormation extensions via the CloudFormation registry which can also be accessed via Cloud Control.

    If you want to manage resources using Pulumi’s AWS Native Cloud Control Provider which aren’t in the SDK, you can use the ExtensionResource resource within root of the SDK. The input properties and output properties are untyped allowing passing in any arbitrary values which will be passed to the Cloud Control API and tracked with Pulumi’s managed state model.

    Here’s a very simple demonstration of using the ExtensionResource to create an S3 bucket:

    import * as pulumi from "@pulumi/pulumi";
    import * as aws_native from "@pulumi/aws-native";
    
    const myBucket = new aws_native.ExtensionResource("myBucket", {
        type: "AWS::S3::Bucket",
        properties: {
            BucketName: "my-bucket",
        },
    });
    
    import pulumi
    import pulumi_aws_native as aws_native
    
    my_bucket = aws_native.ExtensionResource("myBucket",
        type="AWS::S3::Bucket",
        properties={
            "BucketName": "my-bucket",
        })
    
    package main
    
    import (
        awsnative "github.com/pulumi/pulumi-aws-native/sdk/go/aws"
        "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
    )
    
    func main() {
        pulumi.Run(func(ctx *pulumi.Context) error {
            _, err := awsnative.NewExtensionResource(ctx, "myBucket", &awsnative.ExtensionResourceArgs{
                Type: pulumi.String("AWS::S3::Bucket"),
                Properties: pulumi.Map{
                    "BucketName": pulumi.Any("my-bucket"),
                },
            })
            if err != nil {
                return err
            }
            return nil
        })
    }
    
    using System.Collections.Generic;
    using System.Linq;
    using Pulumi;
    using AwsNative = Pulumi.AwsNative;
    
    return await Deployment.RunAsync(() =>
    {
        var myBucket = new AwsNative.ExtensionResource("myBucket", new()
        {
            Type = "AWS::S3::Bucket",
            Properties = 
            {
                { "BucketName", "my-bucket" },
            },
        });
    
    });
    
    package generated_program;
    
    import com.pulumi.Context;
    import com.pulumi.Pulumi;
    import com.pulumi.core.Output;
    import com.pulumi.awsnative.ExtensionResource;
    import com.pulumi.awsnative.ExtensionResourceArgs;
    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 myBucket = new ExtensionResource("myBucket", ExtensionResourceArgs.builder()
                .type("AWS::S3::Bucket")
                .properties(Map.of("BucketName", "my-bucket"))
                .build());
    
        }
    }
    
    resources:
      myBucket:
        type: 'aws-native:index:ExtensionResource'
        properties:
          type: 'AWS::S3::Bucket'
          properties:
            BucketName: my-bucket
    
    aws-native logo

    AWS Native is in preview. AWS Classic is fully supported.

    AWS Native v0.121.0 published on Monday, Aug 26, 2024 by Pulumi