truemark-cdk-lib 1.5.3 → 1.5.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -41,34 +41,47 @@ export interface CloudFrontBucketProps extends ExtendedConstructProps {
41
41
  * Simple Construct for creating buckets that will be accessed directly by CloudFront as an Origin.
42
42
  */
43
43
  export declare class CloudFrontBucket extends ExtendedConstruct {
44
+ private deployCount;
44
45
  readonly bucket: Bucket;
45
46
  readonly bucketName: string;
46
47
  readonly bucketArn: string;
47
48
  readonly originAccessIdentity: OriginAccessIdentity;
48
49
  readonly originAccessIdentityId: string;
50
+ private nextDeployCount;
49
51
  constructor(scope: Construct, id: string, props: CloudFrontBucketProps);
50
52
  /**
51
53
  * Helper method to deploy local assets to the created bucket. Ths function assumes
52
54
  * CloudFront invalidation requests will be sent for mutable files to serve new content.
53
55
  * For more complicated deployments, use BucketDeployment directly.
54
56
  *
55
- * @param path the path to the local assets
57
+ * @param paths the paths to the local assets
56
58
  * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)
57
59
  * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)
58
60
  * @param prune true to prune old files; default is false
59
61
  */
60
- deployPath(path: string, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment;
62
+ deployPaths(paths: string[], maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment;
61
63
  /**
62
64
  * Helper method to deploy local assets to the created bucket. Ths function assumes
63
65
  * CloudFront invalidation requests will be sent for mutable files to serve new content.
64
66
  * For more complicated deployments, use BucketDeployment directly.
65
67
  *
66
- * @param paths the paths to the local assets
68
+ * @param path the path to the local assets
67
69
  * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)
68
70
  * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)
69
71
  * @param prune true to prune old files; default is false
70
72
  */
71
- deployPaths(paths: string[], maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment;
73
+ deployPath(path: string, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment;
74
+ /**
75
+ * Helper method to assets to the created bucket. This function assumes CloudFront invalidation
76
+ * requests will be sent for mutable files to serve new content.
77
+ * For more complicated deployments, use BucketDeployment directly.
78
+ *
79
+ * @param sources the sources to deploy
80
+ * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)
81
+ * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)
82
+ * @param prune true to prune old files; default is false
83
+ */
84
+ deploySources(sources: ISource[], maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment;
72
85
  /**
73
86
  * Helper method to assets to the created bucket. This function assumes CloudFront invalidation
74
87
  * requests will be sent for mutable files to serve new content.
@@ -14,6 +14,7 @@ class CloudFrontBucket extends aws_cdk_1.ExtendedConstruct {
14
14
  constructor(scope, id, props) {
15
15
  var _a, _b, _c, _d;
16
16
  super(scope, id, { standardTags: aws_cdk_1.StandardTags.merge(props.standardTags, truemark_1.LibStandardTags) });
17
+ this.deployCount = 0;
17
18
  const removalPolicy = (_a = props.removalPolicy) !== null && _a !== void 0 ? _a : aws_cdk_lib_1.RemovalPolicy.RETAIN;
18
19
  const autoDeleteObjects = ((_b = props.autoDeleteObjects) !== null && _b !== void 0 ? _b : false) && removalPolicy === aws_cdk_lib_1.RemovalPolicy.DESTROY;
19
20
  this.bucket = new aws_s3_1.Bucket(this, "Default", {
@@ -33,6 +34,32 @@ class CloudFrontBucket extends aws_cdk_1.ExtendedConstruct {
33
34
  this.originAccessIdentityId = this.originAccessIdentity.originAccessIdentityId;
34
35
  this.bucket.grantRead(this.originAccessIdentity);
35
36
  }
37
+ nextDeployCount() {
38
+ let current = this.deployCount++;
39
+ return current === 0 ? '' : `${current}`;
40
+ }
41
+ /**
42
+ * Helper method to deploy local assets to the created bucket. Ths function assumes
43
+ * CloudFront invalidation requests will be sent for mutable files to serve new content.
44
+ * For more complicated deployments, use BucketDeployment directly.
45
+ *
46
+ * @param paths the paths to the local assets
47
+ * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)
48
+ * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)
49
+ * @param prune true to prune old files; default is false
50
+ */
51
+ deployPaths(paths, maxAge, sMaxAge, prune) {
52
+ return new aws_s3_deployment_1.BucketDeployment(this, `Deploy${this.nextDeployCount()}`, {
53
+ sources: paths.map(path => aws_s3_deployment_1.Source.asset(path)),
54
+ destinationBucket: this.bucket,
55
+ prune: prune !== null && prune !== void 0 ? prune : false,
56
+ cacheControl: [
57
+ aws_s3_deployment_1.CacheControl.setPublic(),
58
+ aws_s3_deployment_1.CacheControl.maxAge(maxAge !== null && maxAge !== void 0 ? maxAge : aws_cdk_lib_1.Duration.minutes(15)),
59
+ aws_s3_deployment_1.CacheControl.sMaxAge(sMaxAge !== null && sMaxAge !== void 0 ? sMaxAge : aws_cdk_lib_1.Duration.days(7))
60
+ ]
61
+ });
62
+ }
36
63
  /**
37
64
  * Helper method to deploy local assets to the created bucket. Ths function assumes
38
65
  * CloudFront invalidation requests will be sent for mutable files to serve new content.
@@ -47,18 +74,18 @@ class CloudFrontBucket extends aws_cdk_1.ExtendedConstruct {
47
74
  return this.deployPaths([path], maxAge, sMaxAge, prune);
48
75
  }
49
76
  /**
50
- * Helper method to deploy local assets to the created bucket. Ths function assumes
51
- * CloudFront invalidation requests will be sent for mutable files to serve new content.
77
+ * Helper method to assets to the created bucket. This function assumes CloudFront invalidation
78
+ * requests will be sent for mutable files to serve new content.
52
79
  * For more complicated deployments, use BucketDeployment directly.
53
80
  *
54
- * @param paths the paths to the local assets
81
+ * @param sources the sources to deploy
55
82
  * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)
56
83
  * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)
57
84
  * @param prune true to prune old files; default is false
58
85
  */
59
- deployPaths(paths, maxAge, sMaxAge, prune) {
60
- return new aws_s3_deployment_1.BucketDeployment(this, "Deploy", {
61
- sources: paths.map(path => aws_s3_deployment_1.Source.asset(path)),
86
+ deploySources(sources, maxAge, sMaxAge, prune) {
87
+ return new aws_s3_deployment_1.BucketDeployment(this, `Deploy${this.nextDeployCount()}`, {
88
+ sources: sources,
62
89
  destinationBucket: this.bucket,
63
90
  prune: prune !== null && prune !== void 0 ? prune : false,
64
91
  cacheControl: [
@@ -79,17 +106,8 @@ class CloudFrontBucket extends aws_cdk_1.ExtendedConstruct {
79
106
  * @param prune true to prune old files; default is false
80
107
  */
81
108
  deploySource(source, maxAge, sMaxAge, prune) {
82
- return new aws_s3_deployment_1.BucketDeployment(this, "Deploy", {
83
- sources: [source],
84
- destinationBucket: this.bucket,
85
- prune: prune !== null && prune !== void 0 ? prune : false,
86
- cacheControl: [
87
- aws_s3_deployment_1.CacheControl.setPublic(),
88
- aws_s3_deployment_1.CacheControl.maxAge(maxAge !== null && maxAge !== void 0 ? maxAge : aws_cdk_lib_1.Duration.minutes(15)),
89
- aws_s3_deployment_1.CacheControl.sMaxAge(sMaxAge !== null && sMaxAge !== void 0 ? sMaxAge : aws_cdk_lib_1.Duration.days(7))
90
- ]
91
- });
109
+ return this.deploySources([source], maxAge, sMaxAge, prune);
92
110
  }
93
111
  }
94
112
  exports.CloudFrontBucket = CloudFrontBucket;
95
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloud-front-bucket.js","sourceRoot":"","sources":["cloud-front-bucket.ts"],"names":[],"mappings":"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","sourcesContent":["import {Construct} from \"constructs\";\nimport {BlockPublicAccess, Bucket, BucketEncryption, IBucket} from \"aws-cdk-lib/aws-s3\";\nimport {OriginAccessIdentity} from \"aws-cdk-lib/aws-cloudfront\";\nimport {BucketDeployment, CacheControl, ISource, Source} from \"aws-cdk-lib/aws-s3-deployment\";\nimport {Duration, RemovalPolicy} from \"aws-cdk-lib\";\nimport {ExtendedConstruct, ExtendedConstructProps, StandardTags} from \"../../aws-cdk\";\nimport {LibStandardTags} from \"../../truemark\";\n\n/**\n * Properties for CloudFrontBucket.\n */\nexport interface CloudFrontBucketProps extends ExtendedConstructProps {\n\n  /**\n   * Policy to apply when the bucket is removed from this stack.\n   * @default RemovalPolicy.RETAIN\n   */\n  readonly removalPolicy?: RemovalPolicy;\n\n  /**\n   * Whether all objects should be automatically deleted when the bucket is removed from the stack or when the stack is deleted.\n   * Requires the removalPolicy to be set to RemovalPolicy.DESTROY. Default is false.\n   *\n   * @default false\n   */\n  readonly autoDeleteObjects?: boolean;\n\n  /**\n   * Whether this bucket should have versioning turned on or not. Default is false.\n   *\n   * @default false\n   */\n  readonly versioned?: boolean;\n\n  /**\n   * Whether this bucket should have transfer acceleration turned on or not. Default is false.\n   *\n   * @default false\n   */\n  readonly transferAcceleration?: boolean;\n\n  /**\n   * Optional bucket name. If not provided, a name will be generated.\n   */\n  readonly bucketName?: string;\n}\n\n/**\n * Simple Construct for creating buckets that will be accessed directly by CloudFront as an Origin.\n */\nexport class CloudFrontBucket extends ExtendedConstruct {\n\n  readonly bucket: Bucket;\n  readonly bucketName: string;\n  readonly bucketArn: string;\n  readonly originAccessIdentity: OriginAccessIdentity;\n  readonly originAccessIdentityId: string;\n\n  constructor(scope: Construct, id: string, props: CloudFrontBucketProps) {\n    super(scope, id, {standardTags: StandardTags.merge(props.standardTags, LibStandardTags)});\n\n    const removalPolicy = props.removalPolicy ?? RemovalPolicy.RETAIN;\n    const autoDeleteObjects = (props.autoDeleteObjects ?? false) && removalPolicy === RemovalPolicy.DESTROY;\n\n    this.bucket = new Bucket(this, \"Default\", {\n      encryption: BucketEncryption.S3_MANAGED, // CloudFront cannot use KMS with S3\n      blockPublicAccess: BlockPublicAccess.BLOCK_ALL,\n      removalPolicy,\n      autoDeleteObjects,\n      versioned: props.versioned ?? false,\n      transferAcceleration: props.transferAcceleration ?? false,\n      bucketName: props.bucketName\n    });\n    this.bucketName = this.bucket.bucketName;\n    this.bucketArn = this.bucket.bucketArn;\n    this.originAccessIdentity = new OriginAccessIdentity(this, \"Access\", {\n      comment: `S3 bucket ${this.bucket.bucketName}`\n    });\n    this.originAccessIdentityId = this.originAccessIdentity.originAccessIdentityId;\n    this.bucket.grantRead(this.originAccessIdentity);\n  }\n\n  /**\n   * Helper method to deploy local assets to the created bucket. Ths function assumes\n   * CloudFront invalidation requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param path the path to the local assets\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deployPath(path: string, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return this.deployPaths([path], maxAge, sMaxAge, prune);\n  }\n\n  /**\n   * Helper method to deploy local assets to the created bucket. Ths function assumes\n   * CloudFront invalidation requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param paths the paths to the local assets\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deployPaths(paths: string[], maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return new BucketDeployment(this, \"Deploy\", {\n      sources: paths.map(path => Source.asset(path)),\n      destinationBucket: this.bucket,\n      prune: prune ?? false,\n      cacheControl: [\n        CacheControl.setPublic(),\n        CacheControl.maxAge(maxAge ?? Duration.minutes(15)),\n        CacheControl.sMaxAge(sMaxAge ?? Duration.days(7))\n      ]\n    });\n  }\n\n  /**\n   * Helper method to assets to the created bucket. This function assumes CloudFront invalidation\n   * requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param source the source to deploy\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deploySource(source: ISource, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return new BucketDeployment(this, \"Deploy\", {\n      sources: [source],\n      destinationBucket: this.bucket,\n      prune: prune ?? false,\n      cacheControl: [\n        CacheControl.setPublic(),\n        CacheControl.maxAge(maxAge ?? Duration.minutes(15)),\n        CacheControl.sMaxAge(sMaxAge ?? Duration.days(7))\n      ]\n    })\n  }\n}\n"]}
113
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloud-front-bucket.js","sourceRoot":"","sources":["cloud-front-bucket.ts"],"names":[],"mappings":"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","sourcesContent":["import {Construct} from \"constructs\";\nimport {BlockPublicAccess, Bucket, BucketEncryption, IBucket} from \"aws-cdk-lib/aws-s3\";\nimport {OriginAccessIdentity} from \"aws-cdk-lib/aws-cloudfront\";\nimport {BucketDeployment, CacheControl, ISource, Source} from \"aws-cdk-lib/aws-s3-deployment\";\nimport {Duration, RemovalPolicy} from \"aws-cdk-lib\";\nimport {ExtendedConstruct, ExtendedConstructProps, StandardTags} from \"../../aws-cdk\";\nimport {LibStandardTags} from \"../../truemark\";\n\n/**\n * Properties for CloudFrontBucket.\n */\nexport interface CloudFrontBucketProps extends ExtendedConstructProps {\n\n  /**\n   * Policy to apply when the bucket is removed from this stack.\n   * @default RemovalPolicy.RETAIN\n   */\n  readonly removalPolicy?: RemovalPolicy;\n\n  /**\n   * Whether all objects should be automatically deleted when the bucket is removed from the stack or when the stack is deleted.\n   * Requires the removalPolicy to be set to RemovalPolicy.DESTROY. Default is false.\n   *\n   * @default false\n   */\n  readonly autoDeleteObjects?: boolean;\n\n  /**\n   * Whether this bucket should have versioning turned on or not. Default is false.\n   *\n   * @default false\n   */\n  readonly versioned?: boolean;\n\n  /**\n   * Whether this bucket should have transfer acceleration turned on or not. Default is false.\n   *\n   * @default false\n   */\n  readonly transferAcceleration?: boolean;\n\n  /**\n   * Optional bucket name. If not provided, a name will be generated.\n   */\n  readonly bucketName?: string;\n}\n\n/**\n * Simple Construct for creating buckets that will be accessed directly by CloudFront as an Origin.\n */\nexport class CloudFrontBucket extends ExtendedConstruct {\n\n  private deployCount: number = 0;\n\n  readonly bucket: Bucket;\n  readonly bucketName: string;\n  readonly bucketArn: string;\n  readonly originAccessIdentity: OriginAccessIdentity;\n  readonly originAccessIdentityId: string;\n\n  private nextDeployCount(): string {\n    let current = this.deployCount++;\n    return current === 0 ? '' : `${current}`;\n  }\n\n  constructor(scope: Construct, id: string, props: CloudFrontBucketProps) {\n    super(scope, id, {standardTags: StandardTags.merge(props.standardTags, LibStandardTags)});\n\n    const removalPolicy = props.removalPolicy ?? RemovalPolicy.RETAIN;\n    const autoDeleteObjects = (props.autoDeleteObjects ?? false) && removalPolicy === RemovalPolicy.DESTROY;\n\n    this.bucket = new Bucket(this, \"Default\", {\n      encryption: BucketEncryption.S3_MANAGED, // CloudFront cannot use KMS with S3\n      blockPublicAccess: BlockPublicAccess.BLOCK_ALL,\n      removalPolicy,\n      autoDeleteObjects,\n      versioned: props.versioned ?? false,\n      transferAcceleration: props.transferAcceleration ?? false,\n      bucketName: props.bucketName\n    });\n    this.bucketName = this.bucket.bucketName;\n    this.bucketArn = this.bucket.bucketArn;\n    this.originAccessIdentity = new OriginAccessIdentity(this, \"Access\", {\n      comment: `S3 bucket ${this.bucket.bucketName}`\n    });\n    this.originAccessIdentityId = this.originAccessIdentity.originAccessIdentityId;\n    this.bucket.grantRead(this.originAccessIdentity);\n  }\n\n  /**\n   * Helper method to deploy local assets to the created bucket. Ths function assumes\n   * CloudFront invalidation requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param paths the paths to the local assets\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deployPaths(paths: string[], maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return new BucketDeployment(this, `Deploy${this.nextDeployCount()}`, {\n      sources: paths.map(path => Source.asset(path)),\n      destinationBucket: this.bucket,\n      prune: prune ?? false,\n      cacheControl: [\n        CacheControl.setPublic(),\n        CacheControl.maxAge(maxAge ?? Duration.minutes(15)),\n        CacheControl.sMaxAge(sMaxAge ?? Duration.days(7))\n      ]\n    });\n  }\n\n  /**\n   * Helper method to deploy local assets to the created bucket. Ths function assumes\n   * CloudFront invalidation requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param path the path to the local assets\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deployPath(path: string, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return this.deployPaths([path], maxAge, sMaxAge, prune);\n  }\n\n  /**\n   * Helper method to assets to the created bucket. This function assumes CloudFront invalidation\n   * requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param sources the sources to deploy\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deploySources(sources: ISource[], maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return new BucketDeployment(this, `Deploy${this.nextDeployCount()}`, {\n      sources: sources,\n      destinationBucket: this.bucket,\n      prune: prune ?? false,\n      cacheControl: [\n        CacheControl.setPublic(),\n        CacheControl.maxAge(maxAge ?? Duration.minutes(15)),\n        CacheControl.sMaxAge(sMaxAge ?? Duration.days(7))\n      ]\n    });\n  }\n\n  /**\n   * Helper method to assets to the created bucket. This function assumes CloudFront invalidation\n   * requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param source the source to deploy\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deploySource(source: ISource, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return this.deploySources([source], maxAge, sMaxAge, prune);\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "truemark-cdk-lib",
3
- "version": "1.5.3",
3
+ "version": "1.5.4",
4
4
  "main": "index.js",
5
5
  "types": "index.d.ts",
6
6
  "scripts": {
@@ -73,5 +73,5 @@
73
73
  "publishConfig": {
74
74
  "access": "public"
75
75
  },
76
- "gitHead": "e369e42f91e73fc5947c82de23436dfbfb956594"
76
+ "gitHead": "e13ac758d43022f153bd7d3dff1bea80845c8e1f"
77
77
  }