truemark-cdk-lib 1.6.5 → 1.6.6

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.
@@ -5,6 +5,7 @@ import { BucketDeployment, ISource } from "aws-cdk-lib/aws-s3-deployment";
5
5
  import { Duration, RemovalPolicy } from "aws-cdk-lib";
6
6
  import { ExtendedConstruct, ExtendedConstructProps } from "../../aws-cdk";
7
7
  import { S3Origin } from "aws-cdk-lib/aws-cloudfront-origins";
8
+ import { Grant, IGrantable } from "aws-cdk-lib/aws-iam";
8
9
  /**
9
10
  * Properties for CloudFrontBucket.
10
11
  */
@@ -98,4 +99,81 @@ export declare class CloudFrontBucket extends ExtendedConstruct {
98
99
  * Helper method to return a CloudFront Origin for this bucket.
99
100
  */
100
101
  toOrigin(): S3Origin;
102
+ /**
103
+ * Grant read permissions for this bucket and it's contents to an IAM
104
+ * principal (Role/Group/User).
105
+ *
106
+ * If encryption is used, permission to use the key to decrypt the contents
107
+ * of the bucket will also be granted to the same principal.
108
+ *
109
+ * @param identity The principal
110
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
111
+ */
112
+ grantRead(identity: IGrantable, objectsKeyPattern?: any): Grant;
113
+ /**
114
+ * Grant write permissions to this bucket to an IAM principal.
115
+ *
116
+ * If encryption is used, permission to use the key to encrypt the contents
117
+ * of written files will also be granted to the same principal.
118
+ *
119
+ * Before CDK version 1.85.0, this method granted the `s3:PutObject*` permission that included `s3:PutObjectAcl`,
120
+ * which could be used to grant read/write object access to IAM principals in other accounts.
121
+ * If you want to get rid of that behavior, update your CDK version to 1.85.0 or later,
122
+ * and make sure the `@aws-cdk/aws-s3:grantWriteWithoutAcl` feature flag is set to `true`
123
+ * in the `context` key of your cdk.json file.
124
+ * If you've already updated, but still need the principal to have permissions to modify the ACLs,
125
+ * use the `grantPutAcl` method.
126
+ *
127
+ * @param identity The principal
128
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
129
+ * @param allowedActionPatterns Restrict the permissions to certain list of action patterns
130
+ */
131
+ grantWrite(identity: IGrantable, objectsKeyPattern?: any, allowedActionPatterns?: string[]): Grant;
132
+ /**
133
+ * Grants s3:PutObject* and s3:Abort* permissions for this bucket to an IAM principal.
134
+ *
135
+ * If encryption is used, permission to use the key to encrypt the contents
136
+ * of written files will also be granted to the same principal.
137
+ * @param identity The principal
138
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
139
+ */
140
+ grantPut(identity: IGrantable, objectsKeyPattern?: any): Grant;
141
+ /**
142
+ * Grant the given IAM identity permissions to modify the ACLs of objects in the given Bucket.
143
+ *
144
+ * If your application has the '@aws-cdk/aws-s3:grantWriteWithoutAcl' feature flag set,
145
+ * calling `grantWrite` or `grantReadWrite` no longer grants permissions to modify the ACLs of the objects;
146
+ * in this case, if you need to modify object ACLs, call this method explicitly.
147
+ *
148
+ * @param identity The principal
149
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
150
+ */
151
+ grantPutAcl(identity: IGrantable, objectsKeyPattern?: string): Grant;
152
+ /**
153
+ * Grants s3:DeleteObject* permission to an IAM principal for objects
154
+ * in this bucket.
155
+ *
156
+ * @param identity The principal
157
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
158
+ */
159
+ grantDelete(identity: IGrantable, objectsKeyPattern?: any): Grant;
160
+ /**
161
+ * Grants read/write permissions for this bucket and it's contents to an IAM
162
+ * principal (Role/Group/User).
163
+ *
164
+ * If an encryption key is used, permission to use the key for
165
+ * encrypt/decrypt will also be granted.
166
+ *
167
+ * Before CDK version 1.85.0, this method granted the `s3:PutObject*` permission that included `s3:PutObjectAcl`,
168
+ * which could be used to grant read/write object access to IAM principals in other accounts.
169
+ * If you want to get rid of that behavior, update your CDK version to 1.85.0 or later,
170
+ * and make sure the `@aws-cdk/aws-s3:grantWriteWithoutAcl` feature flag is set to `true`
171
+ * in the `context` key of your cdk.json file.
172
+ * If you've already updated, but still need the principal to have permissions to modify the ACLs,
173
+ * use the `grantPutAcl` method.
174
+ *
175
+ * @param identity The principal
176
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
177
+ */
178
+ grantReadWrite(identity: IGrantable, objectsKeyPattern?: any): Grant;
101
179
  }
@@ -117,6 +117,95 @@ class CloudFrontBucket extends aws_cdk_1.ExtendedConstruct {
117
117
  originAccessIdentity: this.originAccessIdentity
118
118
  });
119
119
  }
120
+ /**
121
+ * Grant read permissions for this bucket and it's contents to an IAM
122
+ * principal (Role/Group/User).
123
+ *
124
+ * If encryption is used, permission to use the key to decrypt the contents
125
+ * of the bucket will also be granted to the same principal.
126
+ *
127
+ * @param identity The principal
128
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
129
+ */
130
+ grantRead(identity, objectsKeyPattern) {
131
+ return this.bucket.grantRead(identity, objectsKeyPattern);
132
+ }
133
+ /**
134
+ * Grant write permissions to this bucket to an IAM principal.
135
+ *
136
+ * If encryption is used, permission to use the key to encrypt the contents
137
+ * of written files will also be granted to the same principal.
138
+ *
139
+ * Before CDK version 1.85.0, this method granted the `s3:PutObject*` permission that included `s3:PutObjectAcl`,
140
+ * which could be used to grant read/write object access to IAM principals in other accounts.
141
+ * If you want to get rid of that behavior, update your CDK version to 1.85.0 or later,
142
+ * and make sure the `@aws-cdk/aws-s3:grantWriteWithoutAcl` feature flag is set to `true`
143
+ * in the `context` key of your cdk.json file.
144
+ * If you've already updated, but still need the principal to have permissions to modify the ACLs,
145
+ * use the `grantPutAcl` method.
146
+ *
147
+ * @param identity The principal
148
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
149
+ * @param allowedActionPatterns Restrict the permissions to certain list of action patterns
150
+ */
151
+ grantWrite(identity, objectsKeyPattern, allowedActionPatterns) {
152
+ return this.bucket.grantWrite(identity, objectsKeyPattern, allowedActionPatterns);
153
+ }
154
+ /**
155
+ * Grants s3:PutObject* and s3:Abort* permissions for this bucket to an IAM principal.
156
+ *
157
+ * If encryption is used, permission to use the key to encrypt the contents
158
+ * of written files will also be granted to the same principal.
159
+ * @param identity The principal
160
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
161
+ */
162
+ grantPut(identity, objectsKeyPattern) {
163
+ return this.bucket.grantPut(identity, objectsKeyPattern);
164
+ }
165
+ /**
166
+ * Grant the given IAM identity permissions to modify the ACLs of objects in the given Bucket.
167
+ *
168
+ * If your application has the '@aws-cdk/aws-s3:grantWriteWithoutAcl' feature flag set,
169
+ * calling `grantWrite` or `grantReadWrite` no longer grants permissions to modify the ACLs of the objects;
170
+ * in this case, if you need to modify object ACLs, call this method explicitly.
171
+ *
172
+ * @param identity The principal
173
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
174
+ */
175
+ grantPutAcl(identity, objectsKeyPattern) {
176
+ return this.bucket.grantPutAcl(identity, objectsKeyPattern);
177
+ }
178
+ /**
179
+ * Grants s3:DeleteObject* permission to an IAM principal for objects
180
+ * in this bucket.
181
+ *
182
+ * @param identity The principal
183
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
184
+ */
185
+ grantDelete(identity, objectsKeyPattern) {
186
+ return this.bucket.grantDelete(identity, objectsKeyPattern);
187
+ }
188
+ /**
189
+ * Grants read/write permissions for this bucket and it's contents to an IAM
190
+ * principal (Role/Group/User).
191
+ *
192
+ * If an encryption key is used, permission to use the key for
193
+ * encrypt/decrypt will also be granted.
194
+ *
195
+ * Before CDK version 1.85.0, this method granted the `s3:PutObject*` permission that included `s3:PutObjectAcl`,
196
+ * which could be used to grant read/write object access to IAM principals in other accounts.
197
+ * If you want to get rid of that behavior, update your CDK version to 1.85.0 or later,
198
+ * and make sure the `@aws-cdk/aws-s3:grantWriteWithoutAcl` feature flag is set to `true`
199
+ * in the `context` key of your cdk.json file.
200
+ * If you've already updated, but still need the principal to have permissions to modify the ACLs,
201
+ * use the `grantPutAcl` method.
202
+ *
203
+ * @param identity The principal
204
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
205
+ */
206
+ grantReadWrite(identity, objectsKeyPattern) {
207
+ return this.bucket.grantReadWrite(identity, objectsKeyPattern);
208
+ }
120
209
  }
121
210
  exports.CloudFrontBucket = CloudFrontBucket;
122
- //# 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} 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\";\nimport {S3Origin} from \"aws-cdk-lib/aws-cloudfront-origins\";\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  /**\n   * Helper method to return a CloudFront Origin for this bucket.\n   */\n  toOrigin(): S3Origin {\n    return new S3Origin(this.bucket, {\n      originAccessIdentity: this.originAccessIdentity\n    });\n  }\n}\n"]}
211
+ //# 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} 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\";\nimport {S3Origin} from \"aws-cdk-lib/aws-cloudfront-origins\";\nimport {Grant, IGrantable} from \"aws-cdk-lib/aws-iam\";\nimport * as iam from \"aws-cdk-lib/aws-iam\";\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  /**\n   * Helper method to return a CloudFront Origin for this bucket.\n   */\n  toOrigin(): S3Origin {\n    return new S3Origin(this.bucket, {\n      originAccessIdentity: this.originAccessIdentity\n    });\n  }\n\n  /**\n   * Grant read permissions for this bucket and it's contents to an IAM\n   * principal (Role/Group/User).\n   *\n   * If encryption is used, permission to use the key to decrypt the contents\n   * of the bucket will also be granted to the same principal.\n   *\n   * @param identity The principal\n   * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')\n   */\n  grantRead(identity: IGrantable, objectsKeyPattern?: any): Grant {\n    return this.bucket.grantRead(identity, objectsKeyPattern);\n  }\n\n  /**\n   * Grant write permissions to this bucket to an IAM principal.\n   *\n   * If encryption is used, permission to use the key to encrypt the contents\n   * of written files will also be granted to the same principal.\n   *\n   * Before CDK version 1.85.0, this method granted the `s3:PutObject*` permission that included `s3:PutObjectAcl`,\n   * which could be used to grant read/write object access to IAM principals in other accounts.\n   * If you want to get rid of that behavior, update your CDK version to 1.85.0 or later,\n   * and make sure the `@aws-cdk/aws-s3:grantWriteWithoutAcl` feature flag is set to `true`\n   * in the `context` key of your cdk.json file.\n   * If you've already updated, but still need the principal to have permissions to modify the ACLs,\n   * use the `grantPutAcl` method.\n   *\n   * @param identity The principal\n   * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')\n   * @param allowedActionPatterns Restrict the permissions to certain list of action patterns\n   */\n  grantWrite(identity: IGrantable, objectsKeyPattern?: any, allowedActionPatterns?: string[]): Grant {\n    return this.bucket.grantWrite(identity, objectsKeyPattern, allowedActionPatterns);\n  }\n\n  /**\n   * Grants s3:PutObject* and s3:Abort* permissions for this bucket to an IAM principal.\n   *\n   * If encryption is used, permission to use the key to encrypt the contents\n   * of written files will also be granted to the same principal.\n   * @param identity The principal\n   * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')\n   */\n  grantPut(identity: IGrantable, objectsKeyPattern?: any): Grant {\n    return this.bucket.grantPut(identity, objectsKeyPattern);\n  }\n\n  /**\n   * Grant the given IAM identity permissions to modify the ACLs of objects in the given Bucket.\n   *\n   * If your application has the '@aws-cdk/aws-s3:grantWriteWithoutAcl' feature flag set,\n   * calling `grantWrite` or `grantReadWrite` no longer grants permissions to modify the ACLs of the objects;\n   * in this case, if you need to modify object ACLs, call this method explicitly.\n   *\n   * @param identity The principal\n   * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')\n   */\n  grantPutAcl(identity: IGrantable, objectsKeyPattern?: string): Grant {\n    return this.bucket.grantPutAcl(identity, objectsKeyPattern);\n  }\n\n  /**\n   * Grants s3:DeleteObject* permission to an IAM principal for objects\n   * in this bucket.\n   *\n   * @param identity The principal\n   * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')\n   */\n  grantDelete(identity: IGrantable, objectsKeyPattern?: any): Grant {\n    return this.bucket.grantDelete(identity, objectsKeyPattern);\n  }\n\n  /**\n   * Grants read/write permissions for this bucket and it's contents to an IAM\n   * principal (Role/Group/User).\n   *\n   * If an encryption key is used, permission to use the key for\n   * encrypt/decrypt will also be granted.\n   *\n   * Before CDK version 1.85.0, this method granted the `s3:PutObject*` permission that included `s3:PutObjectAcl`,\n   * which could be used to grant read/write object access to IAM principals in other accounts.\n   * If you want to get rid of that behavior, update your CDK version to 1.85.0 or later,\n   * and make sure the `@aws-cdk/aws-s3:grantWriteWithoutAcl` feature flag is set to `true`\n   * in the `context` key of your cdk.json file.\n   * If you've already updated, but still need the principal to have permissions to modify the ACLs,\n   * use the `grantPutAcl` method.\n   *\n   * @param identity The principal\n   * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')\n   */\n  grantReadWrite(identity: IGrantable, objectsKeyPattern?: any): Grant {\n    return this.bucket.grantReadWrite(identity, objectsKeyPattern);\n  }\n\n}\n"]}
@@ -4,6 +4,7 @@ import { LatencyARecord, WeightedARecord } from "../../aws-route53";
4
4
  import { ARecord, IHostedZone } from "aws-cdk-lib/aws-route53";
5
5
  import { RemovalPolicy, Duration } from "aws-cdk-lib";
6
6
  import { BucketDeployment } from "aws-cdk-lib/aws-s3-deployment";
7
+ import { Grant, IGrantable } from "aws-cdk-lib/aws-iam";
7
8
  /**
8
9
  * Domain name properties for a bucket based website.
9
10
  */
@@ -58,4 +59,81 @@ export declare class WebsiteBucket extends Construct {
58
59
  * @param prune
59
60
  */
60
61
  deploy(path: string, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment;
62
+ /**
63
+ * Grant read permissions for this bucket and it's contents to an IAM
64
+ * principal (Role/Group/User).
65
+ *
66
+ * If encryption is used, permission to use the key to decrypt the contents
67
+ * of the bucket will also be granted to the same principal.
68
+ *
69
+ * @param identity The principal
70
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
71
+ */
72
+ grantRead(identity: IGrantable, objectsKeyPattern?: any): Grant;
73
+ /**
74
+ * Grant write permissions to this bucket to an IAM principal.
75
+ *
76
+ * If encryption is used, permission to use the key to encrypt the contents
77
+ * of written files will also be granted to the same principal.
78
+ *
79
+ * Before CDK version 1.85.0, this method granted the `s3:PutObject*` permission that included `s3:PutObjectAcl`,
80
+ * which could be used to grant read/write object access to IAM principals in other accounts.
81
+ * If you want to get rid of that behavior, update your CDK version to 1.85.0 or later,
82
+ * and make sure the `@aws-cdk/aws-s3:grantWriteWithoutAcl` feature flag is set to `true`
83
+ * in the `context` key of your cdk.json file.
84
+ * If you've already updated, but still need the principal to have permissions to modify the ACLs,
85
+ * use the `grantPutAcl` method.
86
+ *
87
+ * @param identity The principal
88
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
89
+ * @param allowedActionPatterns Restrict the permissions to certain list of action patterns
90
+ */
91
+ grantWrite(identity: IGrantable, objectsKeyPattern?: any, allowedActionPatterns?: string[]): Grant;
92
+ /**
93
+ * Grants s3:PutObject* and s3:Abort* permissions for this bucket to an IAM principal.
94
+ *
95
+ * If encryption is used, permission to use the key to encrypt the contents
96
+ * of written files will also be granted to the same principal.
97
+ * @param identity The principal
98
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
99
+ */
100
+ grantPut(identity: IGrantable, objectsKeyPattern?: any): Grant;
101
+ /**
102
+ * Grant the given IAM identity permissions to modify the ACLs of objects in the given Bucket.
103
+ *
104
+ * If your application has the '@aws-cdk/aws-s3:grantWriteWithoutAcl' feature flag set,
105
+ * calling `grantWrite` or `grantReadWrite` no longer grants permissions to modify the ACLs of the objects;
106
+ * in this case, if you need to modify object ACLs, call this method explicitly.
107
+ *
108
+ * @param identity The principal
109
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
110
+ */
111
+ grantPutAcl(identity: IGrantable, objectsKeyPattern?: string): Grant;
112
+ /**
113
+ * Grants s3:DeleteObject* permission to an IAM principal for objects
114
+ * in this bucket.
115
+ *
116
+ * @param identity The principal
117
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
118
+ */
119
+ grantDelete(identity: IGrantable, objectsKeyPattern?: any): Grant;
120
+ /**
121
+ * Grants read/write permissions for this bucket and it's contents to an IAM
122
+ * principal (Role/Group/User).
123
+ *
124
+ * If an encryption key is used, permission to use the key for
125
+ * encrypt/decrypt will also be granted.
126
+ *
127
+ * Before CDK version 1.85.0, this method granted the `s3:PutObject*` permission that included `s3:PutObjectAcl`,
128
+ * which could be used to grant read/write object access to IAM principals in other accounts.
129
+ * If you want to get rid of that behavior, update your CDK version to 1.85.0 or later,
130
+ * and make sure the `@aws-cdk/aws-s3:grantWriteWithoutAcl` feature flag is set to `true`
131
+ * in the `context` key of your cdk.json file.
132
+ * If you've already updated, but still need the principal to have permissions to modify the ACLs,
133
+ * use the `grantPutAcl` method.
134
+ *
135
+ * @param identity The principal
136
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
137
+ */
138
+ grantReadWrite(identity: IGrantable, objectsKeyPattern?: any): Grant;
61
139
  }
@@ -73,6 +73,95 @@ class WebsiteBucket extends constructs_1.Construct {
73
73
  ]
74
74
  });
75
75
  }
76
+ /**
77
+ * Grant read permissions for this bucket and it's contents to an IAM
78
+ * principal (Role/Group/User).
79
+ *
80
+ * If encryption is used, permission to use the key to decrypt the contents
81
+ * of the bucket will also be granted to the same principal.
82
+ *
83
+ * @param identity The principal
84
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
85
+ */
86
+ grantRead(identity, objectsKeyPattern) {
87
+ return this.bucket.grantRead(identity, objectsKeyPattern);
88
+ }
89
+ /**
90
+ * Grant write permissions to this bucket to an IAM principal.
91
+ *
92
+ * If encryption is used, permission to use the key to encrypt the contents
93
+ * of written files will also be granted to the same principal.
94
+ *
95
+ * Before CDK version 1.85.0, this method granted the `s3:PutObject*` permission that included `s3:PutObjectAcl`,
96
+ * which could be used to grant read/write object access to IAM principals in other accounts.
97
+ * If you want to get rid of that behavior, update your CDK version to 1.85.0 or later,
98
+ * and make sure the `@aws-cdk/aws-s3:grantWriteWithoutAcl` feature flag is set to `true`
99
+ * in the `context` key of your cdk.json file.
100
+ * If you've already updated, but still need the principal to have permissions to modify the ACLs,
101
+ * use the `grantPutAcl` method.
102
+ *
103
+ * @param identity The principal
104
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
105
+ * @param allowedActionPatterns Restrict the permissions to certain list of action patterns
106
+ */
107
+ grantWrite(identity, objectsKeyPattern, allowedActionPatterns) {
108
+ return this.bucket.grantWrite(identity, objectsKeyPattern, allowedActionPatterns);
109
+ }
110
+ /**
111
+ * Grants s3:PutObject* and s3:Abort* permissions for this bucket to an IAM principal.
112
+ *
113
+ * If encryption is used, permission to use the key to encrypt the contents
114
+ * of written files will also be granted to the same principal.
115
+ * @param identity The principal
116
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
117
+ */
118
+ grantPut(identity, objectsKeyPattern) {
119
+ return this.bucket.grantPut(identity, objectsKeyPattern);
120
+ }
121
+ /**
122
+ * Grant the given IAM identity permissions to modify the ACLs of objects in the given Bucket.
123
+ *
124
+ * If your application has the '@aws-cdk/aws-s3:grantWriteWithoutAcl' feature flag set,
125
+ * calling `grantWrite` or `grantReadWrite` no longer grants permissions to modify the ACLs of the objects;
126
+ * in this case, if you need to modify object ACLs, call this method explicitly.
127
+ *
128
+ * @param identity The principal
129
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
130
+ */
131
+ grantPutAcl(identity, objectsKeyPattern) {
132
+ return this.bucket.grantPutAcl(identity, objectsKeyPattern);
133
+ }
134
+ /**
135
+ * Grants s3:DeleteObject* permission to an IAM principal for objects
136
+ * in this bucket.
137
+ *
138
+ * @param identity The principal
139
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
140
+ */
141
+ grantDelete(identity, objectsKeyPattern) {
142
+ return this.bucket.grantDelete(identity, objectsKeyPattern);
143
+ }
144
+ /**
145
+ * Grants read/write permissions for this bucket and it's contents to an IAM
146
+ * principal (Role/Group/User).
147
+ *
148
+ * If an encryption key is used, permission to use the key for
149
+ * encrypt/decrypt will also be granted.
150
+ *
151
+ * Before CDK version 1.85.0, this method granted the `s3:PutObject*` permission that included `s3:PutObjectAcl`,
152
+ * which could be used to grant read/write object access to IAM principals in other accounts.
153
+ * If you want to get rid of that behavior, update your CDK version to 1.85.0 or later,
154
+ * and make sure the `@aws-cdk/aws-s3:grantWriteWithoutAcl` feature flag is set to `true`
155
+ * in the `context` key of your cdk.json file.
156
+ * If you've already updated, but still need the principal to have permissions to modify the ACLs,
157
+ * use the `grantPutAcl` method.
158
+ *
159
+ * @param identity The principal
160
+ * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')
161
+ */
162
+ grantReadWrite(identity, objectsKeyPattern) {
163
+ return this.bucket.grantReadWrite(identity, objectsKeyPattern);
164
+ }
76
165
  }
77
166
  exports.WebsiteBucket = WebsiteBucket;
78
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"website-bucket.js","sourceRoot":"","sources":["website-bucket.ts"],"names":[],"mappings":"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","sourcesContent":["import {Construct} from \"constructs\";\nimport {Bucket, BucketEncryption, RedirectTarget, RoutingRule} from \"aws-cdk-lib/aws-s3\";\nimport {DomainName, LatencyARecord, WeightedARecord} from \"../../aws-route53\";\nimport {ARecord, IHostedZone, RecordTarget} from \"aws-cdk-lib/aws-route53\";\nimport {BucketWebsiteTarget} from \"aws-cdk-lib/aws-route53-targets\";\nimport {RemovalPolicy, Duration} from \"aws-cdk-lib\";\nimport {BucketDeployment, CacheControl, Source} from \"aws-cdk-lib/aws-s3-deployment\";\n\n\n/**\n * Domain name properties for a bucket based website.\n */\nexport interface WebsiteDomainNameProps {\n\n  readonly prefix?: string;\n\n  readonly zone: string | IHostedZone;\n\n  readonly weight?: number;\n\n  readonly latency?: boolean;\n\n  readonly create?: boolean;\n\n}\n\n/**\n * Properties for WebsiteBucket.\n */\nexport interface WebsiteBucketProps {\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.\n   *\n   * @default false\n   */\n  readonly autoDeleteObjects?: boolean;\n\n  readonly domainName?: WebsiteDomainNameProps;\n\n  readonly websiteIndexDocument?: string;\n\n  readonly websiteErrorDocument?: string;\n\n  readonly websiteRedirect?: RedirectTarget;\n\n  readonly websiteRoutingRules?: RoutingRule[];\n}\n\n/**\n * Simple Construct for creating buckets that will be accessed directly as a website.\n */\nexport class WebsiteBucket extends Construct {\n\n  readonly bucket: Bucket;\n  readonly bucketName: string;\n  readonly bucketArn: string;\n  readonly bucketWebsiteUrl: string;\n  readonly bucketWebsiteDomainName: string;\n  readonly record: ARecord | WeightedARecord | LatencyARecord;\n\n  constructor(scope: Construct, id: string, props?: WebsiteBucketProps) {\n    super(scope, id);\n\n    const removalPolicy = props?.removalPolicy ?? RemovalPolicy.RETAIN;\n    const autoDeleteObjects = (props?.autoDeleteObjects ?? false) && removalPolicy === RemovalPolicy.DESTROY;\n\n    const domainName = props?.domainName === undefined ? undefined : new DomainName({\n      prefix: props.domainName.prefix,\n      zone: props.domainName.zone\n    });\n\n    this.bucket = new Bucket(this, \"Default\", {\n      bucketName: domainName?.toString(),\n      encryption: BucketEncryption.S3_MANAGED,\n      publicReadAccess: true,\n      websiteIndexDocument: props?.websiteIndexDocument ?? \"index.html\",\n      websiteErrorDocument: props?.websiteErrorDocument ?? \"error.html\",\n      websiteRedirect: props?.websiteRedirect,\n      websiteRoutingRules: props?.websiteRoutingRules,\n      removalPolicy,\n      autoDeleteObjects,\n    });\n    this.bucketName = this.bucket.bucketName;\n    this.bucketArn = this.bucket.bucketArn;\n    this.bucketWebsiteUrl = this.bucket.bucketWebsiteUrl;\n    this.bucketWebsiteDomainName = this.bucket.bucketWebsiteDomainName;\n\n    if (domainName !== undefined && (props?.domainName?.create ?? true)) {\n      const target = RecordTarget.fromAlias(new BucketWebsiteTarget(this.bucket));\n      // TODO Evaluate\n      if (props?.domainName?.latency !== undefined) {\n        this.record = domainName.createLatencyARecord(this, target);\n      } else if (props?.domainName?.weight !== undefined) {\n        this.record = domainName.createWeightedARecord(this, target, props.domainName.weight);\n      } else {\n        this.record = domainName.createARecord(this, target);\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\n   */\n  deploy(path: string, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return new BucketDeployment(this, \"Deploy\", {\n      sources: [Source.asset(path)],\n      destinationBucket: this.bucket,\n      prune: prune ?? false,\n      memoryLimit: 512,\n      cacheControl: [\n        CacheControl.setPublic(),\n        CacheControl.maxAge(maxAge ?? Duration.minutes(15)),\n        CacheControl.sMaxAge(sMaxAge ?? Duration.days(7))\n      ]\n    });\n  }\n}\n"]}
167
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"website-bucket.js","sourceRoot":"","sources":["website-bucket.ts"],"names":[],"mappings":";;;AAAA,2CAAqC;AACrC,+CAAyF;AACzF,mDAA8E;AAC9E,yDAA2E;AAC3E,yEAAoE;AACpE,6CAAoD;AACpD,qEAAqF;AAmDrF;;GAEG;AACH,MAAa,aAAc,SAAQ,sBAAS;IAS1C,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA0B;;QAClE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,aAAa,SAAG,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,aAAa,mCAAI,2BAAa,CAAC,MAAM,CAAC;QACnE,MAAM,iBAAiB,GAAG,OAAC,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,iBAAiB,mCAAI,KAAK,CAAC,IAAI,aAAa,KAAK,2BAAa,CAAC,OAAO,CAAC;QAEzG,MAAM,UAAU,GAAG,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,UAAU,MAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,wBAAU,CAAC;YAC9E,MAAM,EAAE,KAAK,CAAC,UAAU,CAAC,MAAM;YAC/B,IAAI,EAAE,KAAK,CAAC,UAAU,CAAC,IAAI;SAC5B,CAAC,CAAC;QAEH,IAAI,CAAC,MAAM,GAAG,IAAI,eAAM,CAAC,IAAI,EAAE,SAAS,EAAE;YACxC,UAAU,EAAE,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,QAAQ,EAAE;YAClC,UAAU,EAAE,yBAAgB,CAAC,UAAU;YACvC,gBAAgB,EAAE,IAAI;YACtB,oBAAoB,QAAE,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,oBAAoB,mCAAI,YAAY;YACjE,oBAAoB,QAAE,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,oBAAoB,mCAAI,YAAY;YACjE,eAAe,EAAE,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,eAAe;YACvC,mBAAmB,EAAE,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,mBAAmB;YAC/C,aAAa;YACb,iBAAiB;SAClB,CAAC,CAAC;QACH,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC;QACzC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;QACvC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC;QACrD,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,MAAM,CAAC,uBAAuB,CAAC;QAEnE,IAAI,UAAU,KAAK,SAAS,IAAI,aAAC,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,UAAU,0CAAE,MAAM,mCAAI,IAAI,CAAC,EAAE;YACnE,MAAM,MAAM,GAAG,0BAAY,CAAC,SAAS,CAAC,IAAI,yCAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;YAC5E,gBAAgB;YAChB,IAAI,OAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,UAAU,0CAAE,OAAO,MAAK,SAAS,EAAE;gBAC5C,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC,oBAAoB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;aAC7D;iBAAM,IAAI,OAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,UAAU,0CAAE,MAAM,MAAK,SAAS,EAAE;gBAClD,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC,qBAAqB,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;aACvF;iBAAM;gBACL,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC,aAAa,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;aACtD;SACF;IACH,CAAC;IAED;;;;;;;;;OASG;IACH,MAAM,CAAC,IAAY,EAAE,MAAiB,EAAE,OAAkB,EAAE,KAAe;QACzE,OAAO,IAAI,oCAAgB,CAAC,IAAI,EAAE,QAAQ,EAAE;YAC1C,OAAO,EAAE,CAAC,0BAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAC7B,iBAAiB,EAAE,IAAI,CAAC,MAAM;YAC9B,KAAK,EAAE,KAAK,aAAL,KAAK,cAAL,KAAK,GAAI,KAAK;YACrB,WAAW,EAAE,GAAG;YAChB,YAAY,EAAE;gBACZ,gCAAY,CAAC,SAAS,EAAE;gBACxB,gCAAY,CAAC,MAAM,CAAC,MAAM,aAAN,MAAM,cAAN,MAAM,GAAI,sBAAQ,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;gBACnD,gCAAY,CAAC,OAAO,CAAC,OAAO,aAAP,OAAO,cAAP,OAAO,GAAI,sBAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aAClD;SACF,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;;;OASG;IACH,SAAS,CAAC,QAAoB,EAAE,iBAAuB;QACrD,OAAO,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAC;IAC5D,CAAC;IAED;;;;;;;;;;;;;;;;;OAiBG;IACH,UAAU,CAAC,QAAoB,EAAE,iBAAuB,EAAE,qBAAgC;QACxF,OAAO,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,QAAQ,EAAE,iBAAiB,EAAE,qBAAqB,CAAC,CAAC;IACpF,CAAC;IAED;;;;;;;OAOG;IACH,QAAQ,CAAC,QAAoB,EAAE,iBAAuB;QACpD,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAC;IAC3D,CAAC;IAED;;;;;;;;;OASG;IACH,WAAW,CAAC,QAAoB,EAAE,iBAA0B;QAC1D,OAAO,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAC;IAC9D,CAAC;IAED;;;;;;OAMG;IACH,WAAW,CAAC,QAAoB,EAAE,iBAAuB;QACvD,OAAO,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAC;IAC9D,CAAC;IAED;;;;;;;;;;;;;;;;;OAiBG;IACH,cAAc,CAAC,QAAoB,EAAE,iBAAuB;QAC1D,OAAO,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAC;IACjE,CAAC;CACF;AAvKD,sCAuKC","sourcesContent":["import {Construct} from \"constructs\";\nimport {Bucket, BucketEncryption, RedirectTarget, RoutingRule} from \"aws-cdk-lib/aws-s3\";\nimport {DomainName, LatencyARecord, WeightedARecord} from \"../../aws-route53\";\nimport {ARecord, IHostedZone, RecordTarget} from \"aws-cdk-lib/aws-route53\";\nimport {BucketWebsiteTarget} from \"aws-cdk-lib/aws-route53-targets\";\nimport {RemovalPolicy, Duration} from \"aws-cdk-lib\";\nimport {BucketDeployment, CacheControl, Source} from \"aws-cdk-lib/aws-s3-deployment\";\nimport {Grant, IGrantable} from \"aws-cdk-lib/aws-iam\";\n\n\n/**\n * Domain name properties for a bucket based website.\n */\nexport interface WebsiteDomainNameProps {\n\n  readonly prefix?: string;\n\n  readonly zone: string | IHostedZone;\n\n  readonly weight?: number;\n\n  readonly latency?: boolean;\n\n  readonly create?: boolean;\n\n}\n\n/**\n * Properties for WebsiteBucket.\n */\nexport interface WebsiteBucketProps {\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.\n   *\n   * @default false\n   */\n  readonly autoDeleteObjects?: boolean;\n\n  readonly domainName?: WebsiteDomainNameProps;\n\n  readonly websiteIndexDocument?: string;\n\n  readonly websiteErrorDocument?: string;\n\n  readonly websiteRedirect?: RedirectTarget;\n\n  readonly websiteRoutingRules?: RoutingRule[];\n}\n\n/**\n * Simple Construct for creating buckets that will be accessed directly as a website.\n */\nexport class WebsiteBucket extends Construct {\n\n  readonly bucket: Bucket;\n  readonly bucketName: string;\n  readonly bucketArn: string;\n  readonly bucketWebsiteUrl: string;\n  readonly bucketWebsiteDomainName: string;\n  readonly record: ARecord | WeightedARecord | LatencyARecord;\n\n  constructor(scope: Construct, id: string, props?: WebsiteBucketProps) {\n    super(scope, id);\n\n    const removalPolicy = props?.removalPolicy ?? RemovalPolicy.RETAIN;\n    const autoDeleteObjects = (props?.autoDeleteObjects ?? false) && removalPolicy === RemovalPolicy.DESTROY;\n\n    const domainName = props?.domainName === undefined ? undefined : new DomainName({\n      prefix: props.domainName.prefix,\n      zone: props.domainName.zone\n    });\n\n    this.bucket = new Bucket(this, \"Default\", {\n      bucketName: domainName?.toString(),\n      encryption: BucketEncryption.S3_MANAGED,\n      publicReadAccess: true,\n      websiteIndexDocument: props?.websiteIndexDocument ?? \"index.html\",\n      websiteErrorDocument: props?.websiteErrorDocument ?? \"error.html\",\n      websiteRedirect: props?.websiteRedirect,\n      websiteRoutingRules: props?.websiteRoutingRules,\n      removalPolicy,\n      autoDeleteObjects,\n    });\n    this.bucketName = this.bucket.bucketName;\n    this.bucketArn = this.bucket.bucketArn;\n    this.bucketWebsiteUrl = this.bucket.bucketWebsiteUrl;\n    this.bucketWebsiteDomainName = this.bucket.bucketWebsiteDomainName;\n\n    if (domainName !== undefined && (props?.domainName?.create ?? true)) {\n      const target = RecordTarget.fromAlias(new BucketWebsiteTarget(this.bucket));\n      // TODO Evaluate\n      if (props?.domainName?.latency !== undefined) {\n        this.record = domainName.createLatencyARecord(this, target);\n      } else if (props?.domainName?.weight !== undefined) {\n        this.record = domainName.createWeightedARecord(this, target, props.domainName.weight);\n      } else {\n        this.record = domainName.createARecord(this, target);\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\n   */\n  deploy(path: string, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return new BucketDeployment(this, \"Deploy\", {\n      sources: [Source.asset(path)],\n      destinationBucket: this.bucket,\n      prune: prune ?? false,\n      memoryLimit: 512,\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   * Grant read permissions for this bucket and it's contents to an IAM\n   * principal (Role/Group/User).\n   *\n   * If encryption is used, permission to use the key to decrypt the contents\n   * of the bucket will also be granted to the same principal.\n   *\n   * @param identity The principal\n   * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')\n   */\n  grantRead(identity: IGrantable, objectsKeyPattern?: any): Grant {\n    return this.bucket.grantRead(identity, objectsKeyPattern);\n  }\n\n  /**\n   * Grant write permissions to this bucket to an IAM principal.\n   *\n   * If encryption is used, permission to use the key to encrypt the contents\n   * of written files will also be granted to the same principal.\n   *\n   * Before CDK version 1.85.0, this method granted the `s3:PutObject*` permission that included `s3:PutObjectAcl`,\n   * which could be used to grant read/write object access to IAM principals in other accounts.\n   * If you want to get rid of that behavior, update your CDK version to 1.85.0 or later,\n   * and make sure the `@aws-cdk/aws-s3:grantWriteWithoutAcl` feature flag is set to `true`\n   * in the `context` key of your cdk.json file.\n   * If you've already updated, but still need the principal to have permissions to modify the ACLs,\n   * use the `grantPutAcl` method.\n   *\n   * @param identity The principal\n   * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')\n   * @param allowedActionPatterns Restrict the permissions to certain list of action patterns\n   */\n  grantWrite(identity: IGrantable, objectsKeyPattern?: any, allowedActionPatterns?: string[]): Grant {\n    return this.bucket.grantWrite(identity, objectsKeyPattern, allowedActionPatterns);\n  }\n\n  /**\n   * Grants s3:PutObject* and s3:Abort* permissions for this bucket to an IAM principal.\n   *\n   * If encryption is used, permission to use the key to encrypt the contents\n   * of written files will also be granted to the same principal.\n   * @param identity The principal\n   * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')\n   */\n  grantPut(identity: IGrantable, objectsKeyPattern?: any): Grant {\n    return this.bucket.grantPut(identity, objectsKeyPattern);\n  }\n\n  /**\n   * Grant the given IAM identity permissions to modify the ACLs of objects in the given Bucket.\n   *\n   * If your application has the '@aws-cdk/aws-s3:grantWriteWithoutAcl' feature flag set,\n   * calling `grantWrite` or `grantReadWrite` no longer grants permissions to modify the ACLs of the objects;\n   * in this case, if you need to modify object ACLs, call this method explicitly.\n   *\n   * @param identity The principal\n   * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')\n   */\n  grantPutAcl(identity: IGrantable, objectsKeyPattern?: string): Grant {\n    return this.bucket.grantPutAcl(identity, objectsKeyPattern);\n  }\n\n  /**\n   * Grants s3:DeleteObject* permission to an IAM principal for objects\n   * in this bucket.\n   *\n   * @param identity The principal\n   * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')\n   */\n  grantDelete(identity: IGrantable, objectsKeyPattern?: any): Grant {\n    return this.bucket.grantDelete(identity, objectsKeyPattern);\n  }\n\n  /**\n   * Grants read/write permissions for this bucket and it's contents to an IAM\n   * principal (Role/Group/User).\n   *\n   * If an encryption key is used, permission to use the key for\n   * encrypt/decrypt will also be granted.\n   *\n   * Before CDK version 1.85.0, this method granted the `s3:PutObject*` permission that included `s3:PutObjectAcl`,\n   * which could be used to grant read/write object access to IAM principals in other accounts.\n   * If you want to get rid of that behavior, update your CDK version to 1.85.0 or later,\n   * and make sure the `@aws-cdk/aws-s3:grantWriteWithoutAcl` feature flag is set to `true`\n   * in the `context` key of your cdk.json file.\n   * If you've already updated, but still need the principal to have permissions to modify the ACLs,\n   * use the `grantPutAcl` method.\n   *\n   * @param identity The principal\n   * @param objectsKeyPattern Restrict the permission to a certain key pattern (default '*')\n   */\n  grantReadWrite(identity: IGrantable, objectsKeyPattern?: any): Grant {\n    return this.bucket.grantReadWrite(identity, objectsKeyPattern);\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "truemark-cdk-lib",
3
- "version": "1.6.5",
3
+ "version": "1.6.6",
4
4
  "main": "index.js",
5
5
  "types": "index.d.ts",
6
6
  "scripts": {
@@ -72,5 +72,5 @@
72
72
  "publishConfig": {
73
73
  "access": "public"
74
74
  },
75
- "gitHead": "8b125ab93367f1da7193bddfb93096d10b583a86"
75
+ "gitHead": "cfd8ebcfcea1904a6b70a7b5590c9991e5a8ad24"
76
76
  }