UNPKG

@gammarers/aws-secure-bucket

Version:
121 lines 17.3 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.SecureBucket = exports.SecureBucketType = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const aws_cdk_lib_1 = require("aws-cdk-lib"); const iam = require("aws-cdk-lib/aws-iam"); const s3 = require("aws-cdk-lib/aws-s3"); /** * @TODO: Not yet supported * https://github.com/aws/jsii/issues/4468 * type omitKeys = 'publicReadAccess|enforceSSL|blockPublicAccess'; * export interface CodePipelineStateChangeDetectionEventRuleProps extends Omit<s3.BucketProps, 'publicReadAccess'> {} */ var SecureBucketType; (function (SecureBucketType) { /** * @deprecated This property is deprecated. Use the bucketType property instead. */ SecureBucketType["SINGLE_PIPELINE_ARTIFACT"] = "single-pipeline-artifact"; /** * If you are setting a custom Qualifier and using it as the artifact bucket for the CDK pipeline, is it selected as the single region deployment pipeline artifact bucket. */ SecureBucketType["SINGLE_REGION_DEPLOYMENT_PIPELINE_ARTIFACT_BUCKET"] = "single-region-deployment-pipeline-artifact-bucket"; /** * @deprecated This property is deprecated. Use the bucketType property instead. */ SecureBucketType["MULTI_PIPELINE_ARTIFACT"] = "multi-pipeline-artifact"; /** * If you are setting a custom Qualifier and using it as the artifact bucket for the CDK pipeline, is it selected as the multi region deployment pipeline artifact bucket. */ SecureBucketType["MULTI_REGION_DEPLOYMENT_PIPELINE_ARTIFACT_BUCKET"] = "multi-region-deployment-pipeline-artifact-bucket"; /** * If you are using it as the CloudFront origin bucket, is it selected as the cloudfront origin bucket. * @deprecated This property is deprecated. Use the bucketType property instead. */ SecureBucketType["CLOUD_FRONT_ORIGIN"] = "cloudfront-origin"; /** * If you are using it as the CloudFront origin bucket, is it selected as the cloudfront origin bucket. */ SecureBucketType["CLOUD_FRONT_ORIGIN_BUCKET"] = "cloudfront-origin-bucket"; /** * If you are not setting a custom Qualifier and using it as the default bucket, is it selected as the default bucket. * @deprecated This property is deprecated. Use the bucketType property instead. */ SecureBucketType["DEFAULT"] = "default"; /** * If you are not setting a custom Qualifier and using it as the default bucket, is it selected as the default bucket. */ SecureBucketType["DEFAULT_BUCKET"] = "default-bucket"; })(SecureBucketType || (exports.SecureBucketType = SecureBucketType = {})); class SecureBucket extends s3.Bucket { constructor(scope, id, props) { const bucketType = props?.bucketType || SecureBucketType.DEFAULT; super(scope, id, { ...props, removalPolicy: aws_cdk_lib_1.RemovalPolicy.RETAIN, // encryption: props?.encryption || s3.BucketEncryption.KMS_MANAGED, encryption: (() => { if (props?.isCloudFrontOriginBucket === true || (bucketType === SecureBucketType.CLOUD_FRONT_ORIGIN || bucketType === SecureBucketType.CLOUD_FRONT_ORIGIN_BUCKET)) { return s3.BucketEncryption.S3_MANAGED; } return props?.encryption || s3.BucketEncryption.KMS_MANAGED; })(), accessControl: (() => { if (!props?.accessControl) { return s3.BucketAccessControl.PRIVATE; } return props.accessControl; })(), eventBridgeEnabled: undefined, publicReadAccess: false, blockPublicAccess: s3.BlockPublicAccess.BLOCK_ALL, enforceSSL: true, versioned: props?.versioned !== undefined ? props.versioned : true, objectOwnership: (() => { if (props?.objectOwnership) { return props.objectOwnership; } return s3.ObjectOwnership.BUCKET_OWNER_ENFORCED; })(), }); // Get CfnBucket const cfnBucket = this.node.defaultChild; if (props?.eventBridgeEnabled === true) { cfnBucket.addPropertyOverride('NotificationConfiguration.EventBridgeConfiguration.EventBridgeEnabled', true); } // 👇 Get account & region const account = aws_cdk_lib_1.Stack.of(this).account; const region = aws_cdk_lib_1.Stack.of(this).region; if (props?.isPipelineArtifactBucket || bucketType === SecureBucketType.SINGLE_PIPELINE_ARTIFACT || bucketType === SecureBucketType.MULTI_PIPELINE_ARTIFACT || bucketType === SecureBucketType.SINGLE_REGION_DEPLOYMENT_PIPELINE_ARTIFACT_BUCKET || bucketType === SecureBucketType.MULTI_REGION_DEPLOYMENT_PIPELINE_ARTIFACT_BUCKET) { // 👇 Get qualifier // const qualifier = Stack.of(this).synthesizer.bootstrapQualifier || defaultQualifier; const qualifier = aws_cdk_lib_1.Stack.of(this).synthesizer.bootstrapQualifier; // add resource policy when custom qualifier if (qualifier && (qualifier != aws_cdk_lib_1.DefaultStackSynthesizer.DEFAULT_QUALIFIER)) { this.addToResourcePolicy(new iam.PolicyStatement({ actions: [ 's3:*', ], resources: [ `${this.bucketArn}`, `${this.bucketArn}/*`, ], principals: [ new iam.ArnPrincipal(`arn:aws:iam::${account}:role/cdk-${qualifier}-deploy-role-${account}-${region}`), ], })); } } } } exports.SecureBucket = SecureBucket; _a = JSII_RTTI_SYMBOL_1; SecureBucket[_a] = { fqn: "@gammarers/aws-secure-bucket.SecureBucket", version: "2.5.7" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { DefaultStackSynthesizer, RemovalPolicy, Stack } from 'aws-cdk-lib';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport { Construct } from 'constructs';\n\n/**\n * @TODO: Not yet supported\n * https://github.com/aws/jsii/issues/4468\n * type omitKeys = 'publicReadAccess|enforceSSL|blockPublicAccess';\n * export interface CodePipelineStateChangeDetectionEventRuleProps extends Omit<s3.BucketProps, 'publicReadAccess'> {}\n */\n\nexport enum SecureBucketType {\n  /**\n   * @deprecated This property is deprecated. Use the bucketType property instead.\n   */\n  SINGLE_PIPELINE_ARTIFACT = 'single-pipeline-artifact',\n  /**\n   * If you are setting a custom Qualifier and using it as the artifact bucket for the CDK pipeline, is it selected as the single region deployment pipeline artifact bucket.\n   */\n  SINGLE_REGION_DEPLOYMENT_PIPELINE_ARTIFACT_BUCKET = 'single-region-deployment-pipeline-artifact-bucket',\n  /**\n   * @deprecated This property is deprecated. Use the bucketType property instead.\n   */\n  MULTI_PIPELINE_ARTIFACT = 'multi-pipeline-artifact',\n  /**\n   * If you are setting a custom Qualifier and using it as the artifact bucket for the CDK pipeline, is it selected as the multi region deployment pipeline artifact bucket.\n   */\n  MULTI_REGION_DEPLOYMENT_PIPELINE_ARTIFACT_BUCKET = 'multi-region-deployment-pipeline-artifact-bucket',\n  /**\n   * If you are using it as the CloudFront origin bucket, is it selected as the cloudfront origin bucket.\n   * @deprecated This property is deprecated. Use the bucketType property instead.\n   */\n  CLOUD_FRONT_ORIGIN = 'cloudfront-origin',\n  /**\n   * If you are using it as the CloudFront origin bucket, is it selected as the cloudfront origin bucket.\n   */\n  CLOUD_FRONT_ORIGIN_BUCKET = 'cloudfront-origin-bucket',\n  /**\n   * If you are not setting a custom Qualifier and using it as the default bucket, is it selected as the default bucket.\n   * @deprecated This property is deprecated. Use the bucketType property instead.\n   */\n  DEFAULT = 'default',\n  /**\n   * If you are not setting a custom Qualifier and using it as the default bucket, is it selected as the default bucket.\n   */\n  DEFAULT_BUCKET = 'default-bucket',\n}\n\nexport interface SecureBucketProps extends s3.BucketProps {\n\n  /**\n   * If you are setting a custom Qualifier and using it as the artifact bucket for the CDK pipeline, set it to true.\n   * @deprecated This property is deprecated. Use the bucketType property instead.\n   * @default false\n   */\n  readonly isPipelineArtifactBucket?: boolean;\n\n  /**\n   * If your are using it as the CloudFront origin bucket, set it to true.\n   * @deprecated This property is deprecated. Use the bucketType property instead.\n   * @default false\n   */\n  readonly isCloudFrontOriginBucket?: boolean;\n\n  /**\n   * The type of the bucket.\n   * @default SecureBucketType.DEFAULT\n   */\n  readonly bucketType?: SecureBucketType;\n}\n\nexport class SecureBucket extends s3.Bucket {\n  constructor(scope: Construct, id: string, props?: SecureBucketProps) {\n    const bucketType = props?.bucketType || SecureBucketType.DEFAULT;\n    super(scope, id, {\n      ...props,\n      removalPolicy: RemovalPolicy.RETAIN,\n      // encryption: props?.encryption || s3.BucketEncryption.KMS_MANAGED,\n      encryption: (() => {\n        if (props?.isCloudFrontOriginBucket === true\n          || (bucketType === SecureBucketType.CLOUD_FRONT_ORIGIN || bucketType === SecureBucketType.CLOUD_FRONT_ORIGIN_BUCKET)) {\n          return s3.BucketEncryption.S3_MANAGED;\n        }\n        return props?.encryption || s3.BucketEncryption.KMS_MANAGED;\n      })(),\n      accessControl: (() => {\n        if (!props?.accessControl) {\n          return s3.BucketAccessControl.PRIVATE;\n        }\n        return props.accessControl;\n      })(),\n      eventBridgeEnabled: undefined,\n      publicReadAccess: false,\n      blockPublicAccess: s3.BlockPublicAccess.BLOCK_ALL,\n      enforceSSL: true,\n      versioned: props?.versioned !== undefined ? props.versioned : true,\n      objectOwnership: (() => {\n        if (props?.objectOwnership) {\n          return props.objectOwnership;\n        }\n        return s3.ObjectOwnership.BUCKET_OWNER_ENFORCED;\n      })(),\n    });\n\n    // Get CfnBucket\n    const cfnBucket = this.node.defaultChild as s3.CfnBucket;\n    if (props?.eventBridgeEnabled === true) {\n      cfnBucket.addPropertyOverride('NotificationConfiguration.EventBridgeConfiguration.EventBridgeEnabled', true);\n    }\n\n    // 👇 Get account & region\n    const account = Stack.of(this).account;\n    const region = Stack.of(this).region;\n\n    if (props?.isPipelineArtifactBucket\n      || bucketType === SecureBucketType.SINGLE_PIPELINE_ARTIFACT\n      || bucketType === SecureBucketType.MULTI_PIPELINE_ARTIFACT\n      || bucketType === SecureBucketType.SINGLE_REGION_DEPLOYMENT_PIPELINE_ARTIFACT_BUCKET\n      || bucketType === SecureBucketType.MULTI_REGION_DEPLOYMENT_PIPELINE_ARTIFACT_BUCKET) {\n\n      // 👇 Get qualifier\n      // const qualifier = Stack.of(this).synthesizer.bootstrapQualifier || defaultQualifier;\n      const qualifier = Stack.of(this).synthesizer.bootstrapQualifier;\n\n      // add resource policy when custom qualifier\n      if (qualifier && (qualifier != DefaultStackSynthesizer.DEFAULT_QUALIFIER)) {\n\n        this.addToResourcePolicy(new iam.PolicyStatement({\n          actions: [\n            's3:*',\n          ],\n          resources: [\n            `${this.bucketArn}`,\n            `${this.bucketArn}/*`,\n          ],\n          principals: [\n            new iam.ArnPrincipal(`arn:aws:iam::${account}:role/cdk-${qualifier}-deploy-role-${account}-${region}`),\n          ],\n        }));\n      }\n    }\n  }\n}"]}