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":"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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\";\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.
|
|
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": "
|
|
75
|
+
"gitHead": "cfd8ebcfcea1904a6b70a7b5590c9991e5a8ad24"
|
|
76
76
|
}
|