truemark-cdk-lib 1.6.4 → 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.
- package/aws-ecs/lib/standard-application-fargate-service.d.ts +7 -0
- package/aws-ecs/lib/standard-application-fargate-service.js +2 -2
- package/aws-s3/lib/cloud-front-bucket.d.ts +84 -1
- package/aws-s3/lib/cloud-front-bucket.js +105 -7
- package/aws-s3/lib/website-bucket.d.ts +79 -1
- package/aws-s3/lib/website-bucket.js +100 -11
- package/package.json +2 -2
|
@@ -96,6 +96,12 @@ export interface StandardApplicationFargateServiceProps extends StandardFargateS
|
|
|
96
96
|
* Additional domain names to associate with this service.
|
|
97
97
|
*/
|
|
98
98
|
readonly domainNames?: string[];
|
|
99
|
+
/**
|
|
100
|
+
* Set this to true to skip the creation of route53 records. By default records will be created in domainName and domainZone is provided.
|
|
101
|
+
*
|
|
102
|
+
* @default - false
|
|
103
|
+
*/
|
|
104
|
+
readonly skipCreateRoute53Records?: boolean;
|
|
99
105
|
/**
|
|
100
106
|
* Path pattern to match on the load balancer.
|
|
101
107
|
*
|
|
@@ -121,6 +127,7 @@ export interface StandardApplicationFargateServiceProps extends StandardFargateS
|
|
|
121
127
|
readonly targetGroupPriority?: number;
|
|
122
128
|
/**
|
|
123
129
|
* Zone of the domain name. If set, a route53 record is created for the service.
|
|
130
|
+
*
|
|
124
131
|
*/
|
|
125
132
|
readonly domainZone?: IHostedZone;
|
|
126
133
|
}
|
|
@@ -86,7 +86,7 @@ class StandardApplicationFargateService extends standard_fargate_service_1.Stand
|
|
|
86
86
|
conditions: targetGroupConditions,
|
|
87
87
|
priority: (_r = props.targetGroupPriority) !== null && _r !== void 0 ? _r : 1
|
|
88
88
|
});
|
|
89
|
-
if (props.domainName !== undefined && props.domainZone !== undefined) {
|
|
89
|
+
if (props.domainName !== undefined && props.domainZone !== undefined && !props.skipCreateRoute53Records) {
|
|
90
90
|
this.domainName = aws_route53_2.DomainName.fromFqdn(props.domainName, props.domainZone);
|
|
91
91
|
this.route53Record = this.domainName.createARecord(this, aws_route53_1.RecordTarget.fromAlias(new aws_route53_targets_1.LoadBalancerTarget(loadBalancer)));
|
|
92
92
|
}
|
|
@@ -95,4 +95,4 @@ class StandardApplicationFargateService extends standard_fargate_service_1.Stand
|
|
|
95
95
|
}
|
|
96
96
|
}
|
|
97
97
|
exports.StandardApplicationFargateService = StandardApplicationFargateService;
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"standard-application-fargate-service.js","sourceRoot":"","sources":["standard-application-fargate-service.ts"],"names":[],"mappings":"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","sourcesContent":["import {StandardFargateService, StandardFargateServiceProps} from \"./standard-fargate-service\";\nimport {Construct} from \"constructs\";\nimport {Duration} from \"aws-cdk-lib\";\nimport {\n  ApplicationListener,\n  ApplicationLoadBalancer,\n  ApplicationProtocol,\n  ApplicationTargetGroup, IApplicationListener, IApplicationLoadBalancer, ListenerCondition,\n  TargetGroupLoadBalancingAlgorithmType\n} from \"aws-cdk-lib/aws-elasticloadbalancingv2\";\nimport {ARecord, IHostedZone, RecordTarget} from \"aws-cdk-lib/aws-route53\";\nimport {DomainName} from \"../../aws-route53\";\nimport {LoadBalancerTarget} from \"aws-cdk-lib/aws-route53-targets\";\n\n/**\n * Properties for StandardApplicationFargateService\n */\nexport interface StandardApplicationFargateServiceProps extends StandardFargateServiceProps {\n\n  /**\n   * The name of an application-based stickiness cookie.\n   *\n   * @default - lb_affinity\n   */\n  readonly stickinessCookieName?: string;\n\n  /**\n   * The stickiness cookie expiration period. Set to 0 to disable.\n   *\n   * @default - Duration.days(1)\n   */\n  readonly stickinessCookieDuration?: Duration;\n\n  /**\n   * The time period during which the load balancer sends a newly registered target a\n   * linearly increasing share of the traffic to the target group. Set this to 0\n   * to disable.\n   *\n   * @default - Duration.seconds(30)\n   */\n  readonly slowStart?: Duration;\n\n  /**\n   * The protocol used by the application in the container.\n   *\n   * @default - ApplicationProtocol.HTTP\n   */\n  readonly applicationProtocol?: ApplicationProtocol;\n\n  /**\n   * The amount of time for Elastic Load Balancing to wait before deregistering a target.\n   *\n   * @default - Duration.seconds(10)\n   */\n  readonly deregistrationDelay?: Duration;\n\n  /**\n   * The approximate number of seconds between health checks for an individual target.\n   *\n   * @default - Duration.seconds(10)\n   */\n  readonly healthCheckInterval?: Duration\n\n  /**\n   * The ping path destination where Elastic Load Balancing sends health check requests.\n   *\n   * @default - /health\n   */\n  readonly healthCheckPath?: string;\n\n  /**\n   * The amount of time, in seconds, during which no response from a target means a failed health check\n   *\n   * @default - Duration.seconds(3)\n   */\n  readonly healthCheckTimeout?: Duration;\n\n  /**\n   * The number of consecutive health checks successes required before considering an unhealthy target healthy.\n   *\n   * @default - 2\n   */\n  readonly healthyThresholdCount?: number;\n\n  /**\n   * The number of consecutive health check failures required before considering a target unhealthy.\n   *\n   * @default - 2\n   */\n  readonly unhealthyThresholdCount?: number;\n\n  /**\n   * HTTP code to use when checking for a successful response from a target\n   *\n   * @default - 200-299\n   */\n  readonly healthyHttpCodes?: string;\n\n  /**\n   * The load balancing algorithm to select targets for routing requests.\n   * To set this to LEAST_OUTSTANDING_REQUESTS, stickiness must be disabled.\n   *\n   * @default - ROUND_ROBIN\n   */\n  readonly loadBalancingAlgorithmType?: TargetGroupLoadBalancingAlgorithmType;\n\n  /**\n   * The number of ALB requests to target for scaling.\n   * Disabled by default.\n   */\n  readonly scaleRequestPerTarget?: number;\n\n  /**\n   * Domain name associated with this service.\n   */\n  readonly domainName?: string;\n\n  /**\n   * Additional domain names to associate with this service.\n   */\n  readonly domainNames?: string[];\n\n  /**\n   * Path pattern to match on the load balancer.\n   *\n   * @default - [\"/*\"]\n   */\n  readonly pathPattern?: string[];\n\n  /**\n   * Load balancer to attach this service to. If passed an ARN or name a lookup will be\n   * performed to locate the load balancer.\n   */\n  readonly loadBalancer: IApplicationLoadBalancer | string;\n\n  /**\n   * The listener protocol to attach this service to.\n   *\n   * @default - ApplicationProtocol.HTTPS\n   */\n  readonly listenerProtocol?: ApplicationProtocol;\n\n  /**\n   * The priority to give the target group on the ALB.\n   *\n   * @default - 1\n   */\n  readonly targetGroupPriority?: number;\n\n  /**\n   * Zone of the domain name. If set, a route53 record is created for the service.\n   */\n  readonly domainZone?: IHostedZone;\n}\n\n/**\n * Creates an ECS Fargate service and maps it to an Application Load Balancer (ALB).\n */\nexport class StandardApplicationFargateService extends StandardFargateService {\n\n  readonly loadBalancer: IApplicationLoadBalancer;\n  readonly listener: IApplicationListener;\n  readonly domainName?: DomainName;\n  readonly route53Record?: ARecord;\n\n  constructor(scope: Construct, id: string, props: StandardApplicationFargateServiceProps) {\n    super(scope, id, props);\n\n    let stickinessCookieDuration: Duration | undefined = props.stickinessCookieDuration ?? Duration.days(1);\n    if (stickinessCookieDuration.toSeconds() === 0) {\n      stickinessCookieDuration = undefined;\n    }\n\n    let stickinessCookieName: string | undefined;\n    if (stickinessCookieDuration !== undefined) {\n      stickinessCookieName = props.stickinessCookieName ?? \"lb_affinity\"\n    }\n\n    let slowStart: Duration | undefined = props.slowStart ?? Duration.seconds(30);\n    if (slowStart.toSeconds() === 0) {\n      slowStart = undefined;\n    }\n\n    const targetGroup = new ApplicationTargetGroup(this, \"TargetGroup\", {\n      targets: [this.service],\n      vpc: props.cluster.vpc,\n      port: this.port,\n      protocol: props.applicationProtocol ?? ApplicationProtocol.HTTP,\n      deregistrationDelay: props.deregistrationDelay ?? Duration.seconds(10),\n      slowStart,\n      healthCheck: {\n        enabled: true,\n        interval: props.healthCheckInterval ?? Duration.seconds(10),\n        path: props.healthCheckPath ?? \"/health\",\n        timeout: props.healthCheckTimeout ?? Duration.seconds(3),\n        healthyThresholdCount: props.healthyThresholdCount ?? 2,\n        unhealthyThresholdCount: props.unhealthyThresholdCount ?? 2,\n        healthyHttpCodes: props.healthyHttpCodes ?? \"200-299\"\n      },\n      stickinessCookieName,\n      stickinessCookieDuration,\n      loadBalancingAlgorithmType: props.loadBalancingAlgorithmType ?? TargetGroupLoadBalancingAlgorithmType.ROUND_ROBIN\n    });\n\n    if (props.scaleRequestPerTarget !== undefined) {\n      this.scaling.scaleOnRequestCount(\"RequestCountScaling\", {\n        scaleInCooldown: this.scaleInCooldown,\n        scaleOutCooldown: this.scaleOutCooldown,\n        targetGroup,\n        requestsPerTarget: props.scaleRequestPerTarget,\n      });\n    }\n\n    const targetGroupConditions: ListenerCondition[] = [];\n    targetGroupConditions.push(ListenerCondition.pathPatterns(props.pathPattern ?? [\"/*\"]));\n    if (props.domainName !== undefined) {\n      targetGroupConditions.push(ListenerCondition.hostHeaders([props.domainName, ...props.domainNames ?? []]));\n    }\n\n    let loadBalancer: IApplicationLoadBalancer;\n    if (typeof props.loadBalancer === \"string\") {\n      if (props.loadBalancer.startsWith(\"arn:\")) {\n        loadBalancer = ApplicationLoadBalancer.fromLookup(this, \"LoadBalancer\", {\n          loadBalancerArn: props.loadBalancer\n        });\n      } else {\n        loadBalancer = ApplicationLoadBalancer.fromLookup(this, \"LoadBalancer\", {\n          loadBalancerTags: {\n            Name: props.loadBalancer\n          }\n        });\n      }\n    } else {\n      loadBalancer = props.loadBalancer;\n    }\n\n    const listener = ApplicationListener.fromLookup(this, \"Listener\", {\n      loadBalancerArn: loadBalancer.loadBalancerArn,\n      listenerProtocol: props.listenerProtocol ?? ApplicationProtocol.HTTPS\n    });\n\n    listener.addTargetGroups(`${id}TargetGroups`, {\n      targetGroups: [targetGroup],\n      conditions: targetGroupConditions,\n      priority: props.targetGroupPriority ?? 1\n    });\n\n    if (props.domainName !== undefined && props.domainZone !== undefined) {\n      this.domainName = DomainName.fromFqdn(props.domainName, props.domainZone);\n      this.route53Record = this.domainName.createARecord(this,\n        RecordTarget.fromAlias(new LoadBalancerTarget(loadBalancer)));\n    }\n\n    this.loadBalancer = loadBalancer;\n    this.listener = listener;\n  }\n}\n"]}
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"standard-application-fargate-service.js","sourceRoot":"","sources":["standard-application-fargate-service.ts"],"names":[],"mappings":"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","sourcesContent":["import {StandardFargateService, StandardFargateServiceProps} from \"./standard-fargate-service\";\nimport {Construct} from \"constructs\";\nimport {Duration} from \"aws-cdk-lib\";\nimport {\n  ApplicationListener,\n  ApplicationLoadBalancer,\n  ApplicationProtocol,\n  ApplicationTargetGroup, IApplicationListener, IApplicationLoadBalancer, ListenerCondition,\n  TargetGroupLoadBalancingAlgorithmType\n} from \"aws-cdk-lib/aws-elasticloadbalancingv2\";\nimport {ARecord, IHostedZone, RecordTarget} from \"aws-cdk-lib/aws-route53\";\nimport {DomainName} from \"../../aws-route53\";\nimport {LoadBalancerTarget} from \"aws-cdk-lib/aws-route53-targets\";\n\n/**\n * Properties for StandardApplicationFargateService\n */\nexport interface StandardApplicationFargateServiceProps extends StandardFargateServiceProps {\n\n  /**\n   * The name of an application-based stickiness cookie.\n   *\n   * @default - lb_affinity\n   */\n  readonly stickinessCookieName?: string;\n\n  /**\n   * The stickiness cookie expiration period. Set to 0 to disable.\n   *\n   * @default - Duration.days(1)\n   */\n  readonly stickinessCookieDuration?: Duration;\n\n  /**\n   * The time period during which the load balancer sends a newly registered target a\n   * linearly increasing share of the traffic to the target group. Set this to 0\n   * to disable.\n   *\n   * @default - Duration.seconds(30)\n   */\n  readonly slowStart?: Duration;\n\n  /**\n   * The protocol used by the application in the container.\n   *\n   * @default - ApplicationProtocol.HTTP\n   */\n  readonly applicationProtocol?: ApplicationProtocol;\n\n  /**\n   * The amount of time for Elastic Load Balancing to wait before deregistering a target.\n   *\n   * @default - Duration.seconds(10)\n   */\n  readonly deregistrationDelay?: Duration;\n\n  /**\n   * The approximate number of seconds between health checks for an individual target.\n   *\n   * @default - Duration.seconds(10)\n   */\n  readonly healthCheckInterval?: Duration\n\n  /**\n   * The ping path destination where Elastic Load Balancing sends health check requests.\n   *\n   * @default - /health\n   */\n  readonly healthCheckPath?: string;\n\n  /**\n   * The amount of time, in seconds, during which no response from a target means a failed health check\n   *\n   * @default - Duration.seconds(3)\n   */\n  readonly healthCheckTimeout?: Duration;\n\n  /**\n   * The number of consecutive health checks successes required before considering an unhealthy target healthy.\n   *\n   * @default - 2\n   */\n  readonly healthyThresholdCount?: number;\n\n  /**\n   * The number of consecutive health check failures required before considering a target unhealthy.\n   *\n   * @default - 2\n   */\n  readonly unhealthyThresholdCount?: number;\n\n  /**\n   * HTTP code to use when checking for a successful response from a target\n   *\n   * @default - 200-299\n   */\n  readonly healthyHttpCodes?: string;\n\n  /**\n   * The load balancing algorithm to select targets for routing requests.\n   * To set this to LEAST_OUTSTANDING_REQUESTS, stickiness must be disabled.\n   *\n   * @default - ROUND_ROBIN\n   */\n  readonly loadBalancingAlgorithmType?: TargetGroupLoadBalancingAlgorithmType;\n\n  /**\n   * The number of ALB requests to target for scaling.\n   * Disabled by default.\n   */\n  readonly scaleRequestPerTarget?: number;\n\n  /**\n   * Domain name associated with this service.\n   */\n  readonly domainName?: string;\n\n  /**\n   * Additional domain names to associate with this service.\n   */\n  readonly domainNames?: string[];\n\n  /**\n   * Set this to true to skip the creation of route53 records. By default records will be created in domainName and domainZone is provided.\n   *\n   * @default - false\n   */\n  readonly skipCreateRoute53Records?: boolean;\n\n  /**\n   * Path pattern to match on the load balancer.\n   *\n   * @default - [\"/*\"]\n   */\n  readonly pathPattern?: string[];\n\n  /**\n   * Load balancer to attach this service to. If passed an ARN or name a lookup will be\n   * performed to locate the load balancer.\n   */\n  readonly loadBalancer: IApplicationLoadBalancer | string;\n\n  /**\n   * The listener protocol to attach this service to.\n   *\n   * @default - ApplicationProtocol.HTTPS\n   */\n  readonly listenerProtocol?: ApplicationProtocol;\n\n  /**\n   * The priority to give the target group on the ALB.\n   *\n   * @default - 1\n   */\n  readonly targetGroupPriority?: number;\n\n  /**\n   * Zone of the domain name. If set, a route53 record is created for the service.\n   *\n   */\n  readonly domainZone?: IHostedZone;\n}\n\n/**\n * Creates an ECS Fargate service and maps it to an Application Load Balancer (ALB).\n */\nexport class StandardApplicationFargateService extends StandardFargateService {\n\n  readonly loadBalancer: IApplicationLoadBalancer;\n  readonly listener: IApplicationListener;\n  readonly domainName?: DomainName;\n  readonly route53Record?: ARecord;\n\n  constructor(scope: Construct, id: string, props: StandardApplicationFargateServiceProps) {\n    super(scope, id, props);\n\n    let stickinessCookieDuration: Duration | undefined = props.stickinessCookieDuration ?? Duration.days(1);\n    if (stickinessCookieDuration.toSeconds() === 0) {\n      stickinessCookieDuration = undefined;\n    }\n\n    let stickinessCookieName: string | undefined;\n    if (stickinessCookieDuration !== undefined) {\n      stickinessCookieName = props.stickinessCookieName ?? \"lb_affinity\"\n    }\n\n    let slowStart: Duration | undefined = props.slowStart ?? Duration.seconds(30);\n    if (slowStart.toSeconds() === 0) {\n      slowStart = undefined;\n    }\n\n    const targetGroup = new ApplicationTargetGroup(this, \"TargetGroup\", {\n      targets: [this.service],\n      vpc: props.cluster.vpc,\n      port: this.port,\n      protocol: props.applicationProtocol ?? ApplicationProtocol.HTTP,\n      deregistrationDelay: props.deregistrationDelay ?? Duration.seconds(10),\n      slowStart,\n      healthCheck: {\n        enabled: true,\n        interval: props.healthCheckInterval ?? Duration.seconds(10),\n        path: props.healthCheckPath ?? \"/health\",\n        timeout: props.healthCheckTimeout ?? Duration.seconds(3),\n        healthyThresholdCount: props.healthyThresholdCount ?? 2,\n        unhealthyThresholdCount: props.unhealthyThresholdCount ?? 2,\n        healthyHttpCodes: props.healthyHttpCodes ?? \"200-299\"\n      },\n      stickinessCookieName,\n      stickinessCookieDuration,\n      loadBalancingAlgorithmType: props.loadBalancingAlgorithmType ?? TargetGroupLoadBalancingAlgorithmType.ROUND_ROBIN\n    });\n\n    if (props.scaleRequestPerTarget !== undefined) {\n      this.scaling.scaleOnRequestCount(\"RequestCountScaling\", {\n        scaleInCooldown: this.scaleInCooldown,\n        scaleOutCooldown: this.scaleOutCooldown,\n        targetGroup,\n        requestsPerTarget: props.scaleRequestPerTarget,\n      });\n    }\n\n    const targetGroupConditions: ListenerCondition[] = [];\n    targetGroupConditions.push(ListenerCondition.pathPatterns(props.pathPattern ?? [\"/*\"]));\n    if (props.domainName !== undefined) {\n      targetGroupConditions.push(ListenerCondition.hostHeaders([props.domainName, ...props.domainNames ?? []]));\n    }\n\n    let loadBalancer: IApplicationLoadBalancer;\n    if (typeof props.loadBalancer === \"string\") {\n      if (props.loadBalancer.startsWith(\"arn:\")) {\n        loadBalancer = ApplicationLoadBalancer.fromLookup(this, \"LoadBalancer\", {\n          loadBalancerArn: props.loadBalancer\n        });\n      } else {\n        loadBalancer = ApplicationLoadBalancer.fromLookup(this, \"LoadBalancer\", {\n          loadBalancerTags: {\n            Name: props.loadBalancer\n          }\n        });\n      }\n    } else {\n      loadBalancer = props.loadBalancer;\n    }\n\n    const listener = ApplicationListener.fromLookup(this, \"Listener\", {\n      loadBalancerArn: loadBalancer.loadBalancerArn,\n      listenerProtocol: props.listenerProtocol ?? ApplicationProtocol.HTTPS\n    });\n\n    listener.addTargetGroups(`${id}TargetGroups`, {\n      targetGroups: [targetGroup],\n      conditions: targetGroupConditions,\n      priority: props.targetGroupPriority ?? 1\n    });\n\n    if (props.domainName !== undefined && props.domainZone !== undefined && !props.skipCreateRoute53Records) {\n      this.domainName = DomainName.fromFqdn(props.domainName, props.domainZone);\n      this.route53Record = this.domainName.createARecord(this,\n        RecordTarget.fromAlias(new LoadBalancerTarget(loadBalancer)));\n    }\n\n    this.loadBalancer = loadBalancer;\n    this.listener = listener;\n  }\n}\n"]}
|
|
@@ -4,6 +4,8 @@ import { OriginAccessIdentity } from "aws-cdk-lib/aws-cloudfront";
|
|
|
4
4
|
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
|
+
import { S3Origin } from "aws-cdk-lib/aws-cloudfront-origins";
|
|
8
|
+
import { Grant, IGrantable } from "aws-cdk-lib/aws-iam";
|
|
7
9
|
/**
|
|
8
10
|
* Properties for CloudFrontBucket.
|
|
9
11
|
*/
|
|
@@ -48,7 +50,7 @@ export declare class CloudFrontBucket extends ExtendedConstruct {
|
|
|
48
50
|
readonly originAccessIdentity: OriginAccessIdentity;
|
|
49
51
|
readonly originAccessIdentityId: string;
|
|
50
52
|
private nextDeployCount;
|
|
51
|
-
constructor(scope: Construct, id: string, props
|
|
53
|
+
constructor(scope: Construct, id: string, props?: CloudFrontBucketProps);
|
|
52
54
|
/**
|
|
53
55
|
* Helper method to deploy local assets to the created bucket. Ths function assumes
|
|
54
56
|
* CloudFront invalidation requests will be sent for mutable files to serve new content.
|
|
@@ -93,4 +95,85 @@ export declare class CloudFrontBucket extends ExtendedConstruct {
|
|
|
93
95
|
* @param prune true to prune old files; default is false
|
|
94
96
|
*/
|
|
95
97
|
deploySource(source: ISource, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment;
|
|
98
|
+
/**
|
|
99
|
+
* Helper method to return a CloudFront Origin for this bucket.
|
|
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;
|
|
96
179
|
}
|
|
@@ -7,24 +7,25 @@ const aws_s3_deployment_1 = require("aws-cdk-lib/aws-s3-deployment");
|
|
|
7
7
|
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
8
8
|
const aws_cdk_1 = require("../../aws-cdk");
|
|
9
9
|
const truemark_1 = require("../../truemark");
|
|
10
|
+
const aws_cloudfront_origins_1 = require("aws-cdk-lib/aws-cloudfront-origins");
|
|
10
11
|
/**
|
|
11
12
|
* Simple Construct for creating buckets that will be accessed directly by CloudFront as an Origin.
|
|
12
13
|
*/
|
|
13
14
|
class CloudFrontBucket extends aws_cdk_1.ExtendedConstruct {
|
|
14
15
|
constructor(scope, id, props) {
|
|
15
16
|
var _a, _b, _c, _d;
|
|
16
|
-
super(scope, id, { standardTags: aws_cdk_1.StandardTags.merge(props.standardTags, truemark_1.LibStandardTags) });
|
|
17
|
+
super(scope, id, { standardTags: aws_cdk_1.StandardTags.merge(props === null || props === void 0 ? void 0 : props.standardTags, truemark_1.LibStandardTags) });
|
|
17
18
|
this.deployCount = 0;
|
|
18
|
-
const removalPolicy = (_a = props.removalPolicy) !== null && _a !== void 0 ? _a : aws_cdk_lib_1.RemovalPolicy.RETAIN;
|
|
19
|
-
const autoDeleteObjects = ((_b = props.autoDeleteObjects) !== null && _b !== void 0 ? _b : false) && removalPolicy === aws_cdk_lib_1.RemovalPolicy.DESTROY;
|
|
19
|
+
const removalPolicy = (_a = props === null || props === void 0 ? void 0 : props.removalPolicy) !== null && _a !== void 0 ? _a : aws_cdk_lib_1.RemovalPolicy.RETAIN;
|
|
20
|
+
const autoDeleteObjects = ((_b = props === null || props === void 0 ? void 0 : props.autoDeleteObjects) !== null && _b !== void 0 ? _b : false) && removalPolicy === aws_cdk_lib_1.RemovalPolicy.DESTROY;
|
|
20
21
|
this.bucket = new aws_s3_1.Bucket(this, "Default", {
|
|
21
22
|
encryption: aws_s3_1.BucketEncryption.S3_MANAGED,
|
|
22
23
|
blockPublicAccess: aws_s3_1.BlockPublicAccess.BLOCK_ALL,
|
|
23
24
|
removalPolicy,
|
|
24
25
|
autoDeleteObjects,
|
|
25
|
-
versioned: (_c = props.versioned) !== null && _c !== void 0 ? _c : false,
|
|
26
|
-
transferAcceleration: (_d = props.transferAcceleration) !== null && _d !== void 0 ? _d : false,
|
|
27
|
-
bucketName: props.bucketName
|
|
26
|
+
versioned: (_c = props === null || props === void 0 ? void 0 : props.versioned) !== null && _c !== void 0 ? _c : false,
|
|
27
|
+
transferAcceleration: (_d = props === null || props === void 0 ? void 0 : props.transferAcceleration) !== null && _d !== void 0 ? _d : false,
|
|
28
|
+
bucketName: props === null || props === void 0 ? void 0 : props.bucketName
|
|
28
29
|
});
|
|
29
30
|
this.bucketName = this.bucket.bucketName;
|
|
30
31
|
this.bucketArn = this.bucket.bucketArn;
|
|
@@ -108,6 +109,103 @@ class CloudFrontBucket extends aws_cdk_1.ExtendedConstruct {
|
|
|
108
109
|
deploySource(source, maxAge, sMaxAge, prune) {
|
|
109
110
|
return this.deploySources([source], maxAge, sMaxAge, prune);
|
|
110
111
|
}
|
|
112
|
+
/**
|
|
113
|
+
* Helper method to return a CloudFront Origin for this bucket.
|
|
114
|
+
*/
|
|
115
|
+
toOrigin() {
|
|
116
|
+
return new aws_cloudfront_origins_1.S3Origin(this.bucket, {
|
|
117
|
+
originAccessIdentity: this.originAccessIdentity
|
|
118
|
+
});
|
|
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
|
+
}
|
|
111
209
|
}
|
|
112
210
|
exports.CloudFrontBucket = CloudFrontBucket;
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloud-front-bucket.js","sourceRoot":"","sources":["cloud-front-bucket.ts"],"names":[],"mappings":"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","sourcesContent":["import {Construct} from \"constructs\";\nimport {BlockPublicAccess, Bucket, BucketEncryption, IBucket} from \"aws-cdk-lib/aws-s3\";\nimport {OriginAccessIdentity} from \"aws-cdk-lib/aws-cloudfront\";\nimport {BucketDeployment, CacheControl, ISource, Source} from \"aws-cdk-lib/aws-s3-deployment\";\nimport {Duration, RemovalPolicy} from \"aws-cdk-lib\";\nimport {ExtendedConstruct, ExtendedConstructProps, StandardTags} from \"../../aws-cdk\";\nimport {LibStandardTags} from \"../../truemark\";\n\n/**\n * Properties for CloudFrontBucket.\n */\nexport interface CloudFrontBucketProps extends ExtendedConstructProps {\n\n  /**\n   * Policy to apply when the bucket is removed from this stack.\n   * @default RemovalPolicy.RETAIN\n   */\n  readonly removalPolicy?: RemovalPolicy;\n\n  /**\n   * Whether all objects should be automatically deleted when the bucket is removed from the stack or when the stack is deleted.\n   * Requires the removalPolicy to be set to RemovalPolicy.DESTROY. Default is false.\n   *\n   * @default false\n   */\n  readonly autoDeleteObjects?: boolean;\n\n  /**\n   * Whether this bucket should have versioning turned on or not. Default is false.\n   *\n   * @default false\n   */\n  readonly versioned?: boolean;\n\n  /**\n   * Whether this bucket should have transfer acceleration turned on or not. Default is false.\n   *\n   * @default false\n   */\n  readonly transferAcceleration?: boolean;\n\n  /**\n   * Optional bucket name. If not provided, a name will be generated.\n   */\n  readonly bucketName?: string;\n}\n\n/**\n * Simple Construct for creating buckets that will be accessed directly by CloudFront as an Origin.\n */\nexport class CloudFrontBucket extends ExtendedConstruct {\n\n  private deployCount: number = 0;\n\n  readonly bucket: Bucket;\n  readonly bucketName: string;\n  readonly bucketArn: string;\n  readonly originAccessIdentity: OriginAccessIdentity;\n  readonly originAccessIdentityId: string;\n\n  private nextDeployCount(): string {\n    let current = this.deployCount++;\n    return current === 0 ? '' : `${current}`;\n  }\n\n  constructor(scope: Construct, id: string, props: CloudFrontBucketProps) {\n    super(scope, id, {standardTags: StandardTags.merge(props.standardTags, LibStandardTags)});\n\n    const removalPolicy = props.removalPolicy ?? RemovalPolicy.RETAIN;\n    const autoDeleteObjects = (props.autoDeleteObjects ?? false) && removalPolicy === RemovalPolicy.DESTROY;\n\n    this.bucket = new Bucket(this, \"Default\", {\n      encryption: BucketEncryption.S3_MANAGED, // CloudFront cannot use KMS with S3\n      blockPublicAccess: BlockPublicAccess.BLOCK_ALL,\n      removalPolicy,\n      autoDeleteObjects,\n      versioned: props.versioned ?? false,\n      transferAcceleration: props.transferAcceleration ?? false,\n      bucketName: props.bucketName\n    });\n    this.bucketName = this.bucket.bucketName;\n    this.bucketArn = this.bucket.bucketArn;\n    this.originAccessIdentity = new OriginAccessIdentity(this, \"Access\", {\n      comment: `S3 bucket ${this.bucket.bucketName}`\n    });\n    this.originAccessIdentityId = this.originAccessIdentity.originAccessIdentityId;\n    this.bucket.grantRead(this.originAccessIdentity);\n  }\n\n  /**\n   * Helper method to deploy local assets to the created bucket. Ths function assumes\n   * CloudFront invalidation requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param paths the paths to the local assets\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deployPaths(paths: string[], maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return new BucketDeployment(this, `Deploy${this.nextDeployCount()}`, {\n      sources: paths.map(path => Source.asset(path)),\n      destinationBucket: this.bucket,\n      prune: prune ?? false,\n      cacheControl: [\n        CacheControl.setPublic(),\n        CacheControl.maxAge(maxAge ?? Duration.minutes(15)),\n        CacheControl.sMaxAge(sMaxAge ?? Duration.days(7))\n      ]\n    });\n  }\n\n  /**\n   * Helper method to deploy local assets to the created bucket. Ths function assumes\n   * CloudFront invalidation requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param path the path to the local assets\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deployPath(path: string, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return this.deployPaths([path], maxAge, sMaxAge, prune);\n  }\n\n  /**\n   * Helper method to assets to the created bucket. This function assumes CloudFront invalidation\n   * requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param sources the sources to deploy\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deploySources(sources: ISource[], maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return new BucketDeployment(this, `Deploy${this.nextDeployCount()}`, {\n      sources: sources,\n      destinationBucket: this.bucket,\n      prune: prune ?? false,\n      cacheControl: [\n        CacheControl.setPublic(),\n        CacheControl.maxAge(maxAge ?? Duration.minutes(15)),\n        CacheControl.sMaxAge(sMaxAge ?? Duration.days(7))\n      ]\n    });\n  }\n\n  /**\n   * Helper method to assets to the created bucket. This function assumes CloudFront invalidation\n   * requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param source the source to deploy\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deploySource(source: ISource, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return this.deploySources([source], maxAge, sMaxAge, prune);\n  }\n}\n"]}
|
|
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
|
*/
|
|
@@ -46,7 +47,7 @@ export declare class WebsiteBucket extends Construct {
|
|
|
46
47
|
readonly bucketWebsiteUrl: string;
|
|
47
48
|
readonly bucketWebsiteDomainName: string;
|
|
48
49
|
readonly record: ARecord | WeightedARecord | LatencyARecord;
|
|
49
|
-
constructor(scope: Construct, id: string, props
|
|
50
|
+
constructor(scope: Construct, id: string, props?: WebsiteBucketProps);
|
|
50
51
|
/**
|
|
51
52
|
* Helper method to deploy local assets to the created bucket. Ths function assumes
|
|
52
53
|
* CloudFront invalidation requests will be sent for mutable files to serve new content.
|
|
@@ -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
|
}
|
|
@@ -15,9 +15,9 @@ class WebsiteBucket extends constructs_1.Construct {
|
|
|
15
15
|
constructor(scope, id, props) {
|
|
16
16
|
var _a, _b, _c, _d, _e, _f, _g, _h;
|
|
17
17
|
super(scope, id);
|
|
18
|
-
const removalPolicy = (_a = props.removalPolicy) !== null && _a !== void 0 ? _a : aws_cdk_lib_1.RemovalPolicy.RETAIN;
|
|
19
|
-
const autoDeleteObjects = ((_b = props.autoDeleteObjects) !== null && _b !== void 0 ? _b : false) && removalPolicy === aws_cdk_lib_1.RemovalPolicy.DESTROY;
|
|
20
|
-
const domainName = props.domainName === undefined ? undefined : new aws_route53_1.DomainName({
|
|
18
|
+
const removalPolicy = (_a = props === null || props === void 0 ? void 0 : props.removalPolicy) !== null && _a !== void 0 ? _a : aws_cdk_lib_1.RemovalPolicy.RETAIN;
|
|
19
|
+
const autoDeleteObjects = ((_b = props === null || props === void 0 ? void 0 : props.autoDeleteObjects) !== null && _b !== void 0 ? _b : false) && removalPolicy === aws_cdk_lib_1.RemovalPolicy.DESTROY;
|
|
20
|
+
const domainName = (props === null || props === void 0 ? void 0 : props.domainName) === undefined ? undefined : new aws_route53_1.DomainName({
|
|
21
21
|
prefix: props.domainName.prefix,
|
|
22
22
|
zone: props.domainName.zone
|
|
23
23
|
});
|
|
@@ -25,10 +25,10 @@ class WebsiteBucket extends constructs_1.Construct {
|
|
|
25
25
|
bucketName: domainName === null || domainName === void 0 ? void 0 : domainName.toString(),
|
|
26
26
|
encryption: aws_s3_1.BucketEncryption.S3_MANAGED,
|
|
27
27
|
publicReadAccess: true,
|
|
28
|
-
websiteIndexDocument: (_c = props.websiteIndexDocument) !== null && _c !== void 0 ? _c : "index.html",
|
|
29
|
-
websiteErrorDocument: (_d = props.websiteErrorDocument) !== null && _d !== void 0 ? _d : "error.html",
|
|
30
|
-
websiteRedirect: props.websiteRedirect,
|
|
31
|
-
websiteRoutingRules: props.websiteRoutingRules,
|
|
28
|
+
websiteIndexDocument: (_c = props === null || props === void 0 ? void 0 : props.websiteIndexDocument) !== null && _c !== void 0 ? _c : "index.html",
|
|
29
|
+
websiteErrorDocument: (_d = props === null || props === void 0 ? void 0 : props.websiteErrorDocument) !== null && _d !== void 0 ? _d : "error.html",
|
|
30
|
+
websiteRedirect: props === null || props === void 0 ? void 0 : props.websiteRedirect,
|
|
31
|
+
websiteRoutingRules: props === null || props === void 0 ? void 0 : props.websiteRoutingRules,
|
|
32
32
|
removalPolicy,
|
|
33
33
|
autoDeleteObjects,
|
|
34
34
|
});
|
|
@@ -36,13 +36,13 @@ class WebsiteBucket extends constructs_1.Construct {
|
|
|
36
36
|
this.bucketArn = this.bucket.bucketArn;
|
|
37
37
|
this.bucketWebsiteUrl = this.bucket.bucketWebsiteUrl;
|
|
38
38
|
this.bucketWebsiteDomainName = this.bucket.bucketWebsiteDomainName;
|
|
39
|
-
if (domainName !== undefined && ((_f = (_e = props.domainName) === null || _e === void 0 ? void 0 : _e.create) !== null && _f !== void 0 ? _f : true)) {
|
|
39
|
+
if (domainName !== undefined && ((_f = (_e = props === null || props === void 0 ? void 0 : props.domainName) === null || _e === void 0 ? void 0 : _e.create) !== null && _f !== void 0 ? _f : true)) {
|
|
40
40
|
const target = aws_route53_2.RecordTarget.fromAlias(new aws_route53_targets_1.BucketWebsiteTarget(this.bucket));
|
|
41
41
|
// TODO Evaluate
|
|
42
|
-
if (((_g = props.domainName) === null || _g === void 0 ? void 0 : _g.latency) !== undefined) {
|
|
42
|
+
if (((_g = props === null || props === void 0 ? void 0 : props.domainName) === null || _g === void 0 ? void 0 : _g.latency) !== undefined) {
|
|
43
43
|
this.record = domainName.createLatencyARecord(this, target);
|
|
44
44
|
}
|
|
45
|
-
else if (((_h = props.domainName) === null || _h === void 0 ? void 0 : _h.weight) !== undefined) {
|
|
45
|
+
else if (((_h = props === null || props === void 0 ? void 0 : props.domainName) === null || _h === void 0 ? void 0 : _h.weight) !== undefined) {
|
|
46
46
|
this.record = domainName.createWeightedARecord(this, target, props.domainName.weight);
|
|
47
47
|
}
|
|
48
48
|
else {
|
|
@@ -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
|
}
|