@pwrdrvr/microapps-cdk 0.2.8 → 0.2.11

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.
Files changed (40) hide show
  1. package/.gitattributes +18 -18
  2. package/.jsii +1264 -165
  3. package/API.md +511 -8
  4. package/README.md +29 -0
  5. package/changelog.md +2 -0
  6. package/lib/MicroApps.d.ts +126 -105
  7. package/lib/MicroApps.d.ts.map +1 -0
  8. package/lib/MicroApps.js +32 -30
  9. package/lib/MicroAppsAPIGwy.d.ts +28 -61
  10. package/lib/MicroAppsAPIGwy.d.ts.map +1 -0
  11. package/lib/MicroAppsAPIGwy.js +17 -25
  12. package/lib/MicroAppsCF.d.ts +85 -104
  13. package/lib/MicroAppsCF.d.ts.map +1 -0
  14. package/lib/MicroAppsCF.js +58 -41
  15. package/lib/MicroAppsEdgeToOrigin.d.ts +108 -0
  16. package/lib/MicroAppsEdgeToOrigin.d.ts.map +1 -0
  17. package/lib/MicroAppsEdgeToOrigin.js +139 -0
  18. package/lib/MicroAppsS3.d.ts +19 -69
  19. package/lib/MicroAppsS3.d.ts.map +1 -0
  20. package/lib/MicroAppsS3.js +5 -32
  21. package/lib/MicroAppsSvcs.d.ts +58 -86
  22. package/lib/MicroAppsSvcs.d.ts.map +1 -0
  23. package/lib/MicroAppsSvcs.js +36 -95
  24. package/lib/MicroAppsTable.d.ts +60 -0
  25. package/lib/MicroAppsTable.d.ts.map +1 -0
  26. package/lib/MicroAppsTable.js +42 -0
  27. package/lib/index.d.ts +3 -0
  28. package/lib/index.d.ts.map +1 -0
  29. package/lib/index.js +3 -1
  30. package/lib/microapps-deployer/index.js +174 -113
  31. package/lib/microapps-deployer/index.js.map +3 -3
  32. package/lib/microapps-router/index.js +54 -69
  33. package/lib/microapps-router/index.js.map +3 -3
  34. package/lib/microapps-router/templates/appFrame.html +0 -0
  35. package/lib/utils/ReverseDomain.d.ts +1 -0
  36. package/lib/utils/ReverseDomain.d.ts.map +1 -0
  37. package/package.json +29 -24
  38. package/releasetag.txt +1 -0
  39. package/version.txt +1 -0
  40. package/patches/@aws-cdk+aws-apigatewayv2-alpha+2.8.0-alpha.0.patch +0 -39
package/README.md CHANGED
@@ -30,6 +30,9 @@ For development / testing purposes only, each version of an applicaton can be ac
30
30
  - [next.config.js](#nextconfigjs)
31
31
  - [deploy.json](#deployjson)
32
32
  - [serverless.yaml](#serverlessyaml)
33
+ - [Troubleshooting](#troubleshooting)
34
+ - [CloudFront Requests to API Gateway are Rejected with 403 Forbidden](#cloudfront-requests-to-api-gateway-are-rejected-with-403-forbidden)
35
+ - [SignatureV4 Headers](#signaturev4-headers)
33
36
 
34
37
  # Video Preview of the Deploying CDK Construct
35
38
 
@@ -297,3 +300,29 @@ nextApp:
297
300
  deploy: false
298
301
  uploadStaticAssetsFromBuild: false
299
302
  ```
303
+
304
+ # Troubleshooting
305
+
306
+ ## CloudFront Requests to API Gateway are Rejected with 403 Forbidden
307
+
308
+ Requests to the API Gateway origin can be rejected with a 403 Forbidden error if the signed request headers are not sent to the origin by CloudFront.
309
+
310
+ The error in the API Gateway CloudWatch logs will show up as:
311
+
312
+ ```log
313
+ "authorizerError": "The request for the IAM Authorizer doesn't match the format that API Gateway expects."
314
+ ```
315
+
316
+ This can be simulated by simply running `curl [api-gateway-url]`, with no headers.
317
+
318
+ To confirm that API Gateway is allowing signed requests when the IAM Authorizer is configured, establish credentials as a user that is allowed to execute the API Gateay, install `awscurl` with `pip3 install awscurl`, then then use `awscurl --service execute-api --region [api-gateway-region] [api-gateway-url]`.
319
+
320
+ Signature headers will not be sent from CloudFront to API Gateway unless the `OriginRequestPolicy` is set to specifically include those headers on requests to the origin, or the `headersBehavior` is set to `cfront.OriginRequestHeaderBehavior.all()`.
321
+
322
+ Similarly, if `presign` is used, the `OriginRequestPolicy` must be set to `cfront.OriginRequestQueryStringBehavior.all()` or to specifically forward the query string parameters used by the presigned URL.
323
+
324
+ ### SignatureV4 Headers
325
+ - `authorization`
326
+ - `x-amz-date`
327
+ - `x-amz-security-token`
328
+ - `x-amz-content-sha256`
package/changelog.md ADDED
@@ -0,0 +1,2 @@
1
+
2
+ ### [0.2.11](https://github.com/pwrdrvr/microapps-core/compare/v0.2.10...v0.2.11) (2022-05-23)
@@ -1,83 +1,91 @@
1
1
  import { RemovalPolicy } from 'aws-cdk-lib';
2
2
  import * as acm from 'aws-cdk-lib/aws-certificatemanager';
3
+ import * as dynamodb from 'aws-cdk-lib/aws-dynamodb';
3
4
  import * as r53 from 'aws-cdk-lib/aws-route53';
4
5
  import { Construct } from 'constructs';
5
6
  import { IMicroAppsAPIGwy } from './MicroAppsAPIGwy';
6
7
  import { IMicroAppsCF } from './MicroAppsCF';
8
+ import { IMicroAppsEdgeToOrigin } from './MicroAppsEdgeToOrigin';
7
9
  import { IMicroAppsS3 } from './MicroAppsS3';
8
10
  import { IMicroAppsSvcs } from './MicroAppsSvcs';
9
11
  /**
10
- * (experimental) Properties to initialize an instance of `MicroApps`.
12
+ * A CDK Construct for creating a MicroApps runtime environment used
13
+ * to host Next.js, React, or any other sort of web application with
14
+ * multiple versions available for comparison, quick rollbacks, quick
15
+ * releases, and a complete lack of user disturbance on deploys.
11
16
  *
12
- * @experimental
17
+ * @remarks
18
+ *
19
+ * {@link MicroApps} provides a turn-key construct that creates all
20
+ * dependencies with limited exposure of underlying AWS Resource options.
21
+ * This construct is the easiest to use when exploring MicroApps for the
22
+ * first time.
23
+ *
24
+ * {@link MicroAppsAPIGwy}, {@link MicroAppsCF}, {@link MicroAppsS3},
25
+ * and {@link MicroAppsSvcs}, and their helper static methods, can be used
26
+ * to create AWS Resources more directly, to provide your own AWS Resources
27
+ * (e.g. an existing CloudFront Distribution), and to have more flexibility
28
+ * than the {@link MicroApps} construct offers.
29
+ *
30
+ * @packageDocumentation
31
+ */
32
+ /**
33
+ * Properties to initialize an instance of `MicroApps`.
13
34
  */
14
35
  export interface MicroAppsProps {
15
36
  /**
16
- * (experimental) RemovalPolicy override for child resources.
37
+ * RemovalPolicy override for child resources
17
38
  *
18
39
  * Note: if set to DESTROY the S3 buckes will have `autoDeleteObjects` set to `true`
19
40
  *
20
41
  * @default - per resource default
21
- * @experimental
22
42
  */
23
43
  readonly removalPolicy?: RemovalPolicy;
24
44
  /**
25
- * (experimental) Passed to NODE_ENV of Router and Deployer Lambda functions.
45
+ * Passed to NODE_ENV of Router and Deployer Lambda functions.
26
46
  *
27
47
  * @default dev
28
- * @experimental
29
48
  */
30
49
  readonly appEnv: string;
31
50
  /**
32
- * (experimental) Optional asset name root.
51
+ * Optional asset name root
33
52
  *
53
+ * @example microapps
34
54
  * @default - resource names auto assigned
35
- * @experimental
36
- * @example
37
- *
38
- * microapps
39
55
  */
40
56
  readonly assetNameRoot?: string;
41
57
  /**
42
- * (experimental) Optional asset name suffix.
58
+ * Optional asset name suffix
43
59
  *
60
+ * @example -dev-pr-12
44
61
  * @default none
45
- * @experimental
46
- * @example
47
- *
48
- * -dev-pr-12
49
62
  */
50
63
  readonly assetNameSuffix?: string;
51
64
  /**
52
- * (experimental) Route53 zone in which to create optional `domainNameEdge` record.
53
- *
54
- * @experimental
65
+ * Route53 zone in which to create optional `domainNameEdge` record
55
66
  */
56
67
  readonly r53Zone?: r53.IHostedZone;
57
68
  /**
58
- * (experimental) Certificate in US-East-1 for the CloudFront distribution.
59
- *
60
- * @experimental
69
+ * Certificate in US-East-1 for the CloudFront distribution.
61
70
  */
62
71
  readonly certEdge?: acm.ICertificate;
63
72
  /**
64
- * (experimental) Certificate in deployed region for the API Gateway.
65
- *
66
- * @experimental
73
+ * Certificate in deployed region for the API Gateway.
67
74
  */
68
75
  readonly certOrigin?: acm.ICertificate;
69
76
  /**
70
- * (experimental) Use a strict S3 Bucket Policy that prevents applications from reading/writing/modifying/deleting files in the S3 Bucket outside of the path that is specific to their app/version.
77
+ * Use a strict S3 Bucket Policy that prevents applications
78
+ * from reading/writing/modifying/deleting files in the S3 Bucket
79
+ * outside of the path that is specific to their app/version.
71
80
  *
72
81
  * This setting should be used when applications are less than
73
82
  * fully trusted.
74
83
  *
75
84
  * @default false
76
- * @experimental
77
85
  */
78
86
  readonly s3StrictBucketPolicy?: boolean;
79
87
  /**
80
- * (experimental) Applies when using s3StrictBucketPolicy = true.
88
+ * Applies when using s3StrictBucketPolicy = true
81
89
  *
82
90
  * IAM Role or IAM User names to exclude from the DENY rules on the S3 Bucket Policy.
83
91
  *
@@ -86,15 +94,13 @@ export interface MicroAppsProps {
86
94
  * Typically any admin roles / users that need to view or manage the S3 Bucket
87
95
  * would be added to this list.
88
96
  *
89
- * @see s3PolicyBypassAROAs
90
- * @experimental
91
- * @example
97
+ * @example ['arn:aws:iam::1234567890123:role/AdminAccess', 'arn:aws:iam::1234567890123:user/MyAdminUser']
92
98
  *
93
- * ['arn:aws:iam::1234567890123:role/AdminAccess', 'arn:aws:iam::1234567890123:user/MyAdminUser']
99
+ * @see s3PolicyBypassAROAs
94
100
  */
95
101
  readonly s3PolicyBypassPrincipalARNs?: string[];
96
102
  /**
97
- * (experimental) Applies when using s3StrictBucketPolicy = true.
103
+ * Applies when using s3StrictBucketPolicy = true
98
104
  *
99
105
  * AROAs of the IAM Role to exclude from the DENY rules on the S3 Bucket Policy.
100
106
  * This allows sessions that assume the IAM Role to be excluded from the
@@ -113,61 +119,51 @@ export interface MicroAppsProps {
113
119
  * wildcard matches and does not do wildcard matches implicitly either.
114
120
  *
115
121
  * The AROA must be used because there are only 3 Principal variables available:
116
- * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_variables.html#principaltable
117
- * aws:username, aws:userid, aws:PrincipalTag
122
+ * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_variables.html#principaltable
123
+ * aws:username, aws:userid, aws:PrincipalTag
118
124
  *
119
125
  * For an assumed role, aws:username is blank, aws:userid is:
120
- * [unique id AKA AROA for Role]:[session name]
126
+ * [unique id AKA AROA for Role]:[session name]
121
127
  *
122
128
  * Table of unique ID prefixes such as AROA:
123
- * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_identifiers.html#identifiers-prefixes
129
+ * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_identifiers.html#identifiers-prefixes
124
130
  *
125
131
  * The name of the role is simply not available for an assumed role and, if it was,
126
132
  * a complicated comparison would be requierd to prevent exclusion
127
133
  * of applying the Deny Rule to roles from other accounts.
128
134
  *
129
135
  * To get the AROA with the AWS CLI:
130
- * aws iam get-role --role-name ROLE-NAME
131
- * aws iam get-user -–user-name USER-NAME
136
+ * aws iam get-role --role-name ROLE-NAME
137
+ * aws iam get-user -–user-name USER-NAME
132
138
  *
133
- * @see s3StrictBucketPolicy
134
- * @experimental
135
- * @example
139
+ * @example [ 'AROA1234567890123' ]
136
140
  *
137
- * [ 'AROA1234567890123' ]
141
+ * @see s3StrictBucketPolicy
138
142
  */
139
143
  readonly s3PolicyBypassAROAs?: string[];
140
144
  /**
141
- * (experimental) Optional custom domain name for the CloudFront distribution.
145
+ * Optional custom domain name for the CloudFront distribution.
142
146
  *
147
+ * @example apps.pwrdrvr.com
143
148
  * @default auto-assigned
144
- * @experimental
145
- * @example
146
- *
147
- * apps.pwrdrvr.com
148
149
  */
149
150
  readonly domainNameEdge?: string;
150
151
  /**
151
- * (experimental) Optional custom domain name for the API Gateway HTTPv2 API.
152
+ * Optional custom domain name for the API Gateway HTTPv2 API.
152
153
  *
154
+ * @example apps-origin.pwrdrvr.com
153
155
  * @default auto-assigned
154
- * @experimental
155
- * @example
156
- *
157
- * apps-origin.pwrdrvr.com
158
156
  */
159
157
  readonly domainNameOrigin?: string;
160
158
  /**
161
- * (experimental) Path prefix on the root of the CloudFront distribution.
162
- *
163
- * @experimental
164
- * @example
159
+ * Path prefix on the root of the CloudFront distribution
165
160
  *
166
- * dev/
161
+ * @example dev/
167
162
  */
168
163
  readonly rootPathPrefix?: string;
169
164
  /**
170
- * (experimental) Create an extra Behavior (Route) for /api/ that allows API routes to have a period in them.
165
+ * Create an extra Behavior (Route) for /api/ that allows
166
+ * API routes to have a period in them.
171
167
  *
172
168
  * When false API routes with a period in the path will get routed to S3.
173
169
  *
@@ -175,45 +171,85 @@ export interface MicroAppsProps {
175
171
  * even if they have a period in the path.
176
172
  *
177
173
  * @default true
178
- * @experimental
179
174
  */
180
175
  readonly createAPIPathRoute?: boolean;
181
- }
182
- /**
183
- * (experimental) Represents a MicroApps.
184
- *
185
- * @experimental
186
- */
187
- export interface IMicroApps {
188
176
  /**
189
- * (experimental) {@inheritdoc IMicroAppsCF}.
177
+ * Adds an X-Forwarded-Host-Header when calling API Gateway
190
178
  *
191
- * @experimental
179
+ * Can only be trusted if `signingMode` is enabled, which restricts
180
+ * access to API Gateway to only IAM signed requests.
181
+ *
182
+ * Note: if true, creates OriginRequest Lambda @ Edge function for API Gateway Origin
183
+ * @default true
192
184
  */
193
- readonly cf: IMicroAppsCF;
185
+ readonly addXForwardedHostHeader?: boolean;
194
186
  /**
195
- * (experimental) {@inheritdoc IMicroAppsS3}.
187
+ * Replaces Host header (which will be the Edge domain name) with the Origin domain name
188
+ * when enabled. This is necessary when API Gateway has not been configured
189
+ * with a custom domain name that matches the exact domain name used by the CloudFront
190
+ * Distribution AND when the OriginRequestPolicy.HeadersBehavior is set
191
+ * to pass all headers to the origin.
196
192
  *
197
- * @experimental
193
+ * Note: if true, creates OriginRequest Lambda @ Edge function for API Gateway Origin
194
+ * @default true
198
195
  */
199
- readonly s3: IMicroAppsS3;
196
+ readonly replaceHostHeader?: boolean;
200
197
  /**
201
- * (experimental) {@inheritdoc IMicroAppsSvcs}.
198
+ * Requires IAM auth on the API Gateway origin if not set to 'none'.
199
+ *
200
+ * 'sign' - Uses request headers for auth.
201
+ * 'presign' - Uses query string for auth.
202
+ *
203
+ * If enabled,
202
204
  *
203
- * @experimental
205
+ * Note: if 'sign' or 'presign', creates OriginRequest Lambda @ Edge function for API Gateway Origin
206
+ * @default 'sign'
204
207
  */
205
- readonly svcs: IMicroAppsSvcs;
208
+ readonly signingMode?: 'sign' | 'presign' | 'none';
206
209
  /**
207
- * (experimental) {@inheritdoc IMicroAppsAPIGwy}.
210
+ * Origin region that API Gateway will be deployed to, used
211
+ * for the config.yml on the Edge function to sign requests for
212
+ * the correct region
208
213
  *
209
- * @experimental
214
+ * @default undefined
210
215
  */
216
+ readonly originRegion?: string;
217
+ /**
218
+ * Existing table for apps/versions/rules
219
+ *
220
+ * @warning - It is *strongly* suggested that production stacks create
221
+ * their own DynamoDB Table and pass it into this construct, for protection
222
+ * against data loss due to logical ID changes, the ability to configure
223
+ * Provisioned capacity with Auto Scaling, the ability to add additional indices, etc.
224
+ *
225
+ * Requirements:
226
+ * - Hash Key: `PK`
227
+ * - Sort Key: `SK`
228
+ *
229
+ * @default created by construct
230
+ */
231
+ readonly table?: dynamodb.ITable;
232
+ }
233
+ /**
234
+ * Represents a MicroApps
235
+ */
236
+ export interface IMicroApps {
237
+ /** {@inheritdoc IMicroAppsCF} */
238
+ readonly cf: IMicroAppsCF;
239
+ /** {@inheritdoc IMicroAppsEdgeToOrigin} */
240
+ readonly edgeToOrigin?: IMicroAppsEdgeToOrigin;
241
+ /** {@inheritdoc IMicroAppsS3} */
242
+ readonly s3: IMicroAppsS3;
243
+ /** {@inheritdoc IMicroAppsSvcs} */
244
+ readonly svcs: IMicroAppsSvcs;
245
+ /** {@inheritdoc IMicroAppsAPIGwy} */
211
246
  readonly apigwy: IMicroAppsAPIGwy;
212
247
  }
213
248
  /**
214
- * (experimental) Create a new MicroApps "turnkey" construct for simple deployments and for initial evaulation of the MicroApps framework.
249
+ * Create a new MicroApps "turnkey" construct for simple
250
+ * deployments and for initial evaulation of the MicroApps framework.
215
251
  *
216
- * Use this construct to create a working entire stack.
252
+ * Use this construct to create a PoC working entire stack.
217
253
  *
218
254
  * Do not use this construct when adding MicroApps to an existing
219
255
  * CloudFront, API Gateway, S3 Bucket, etc. or where access
@@ -221,40 +257,25 @@ export interface IMicroApps {
221
257
  * add additional Behaviors to the CloudFront distribution, set authorizors
222
258
  * on API Gateway, etc.).
223
259
  *
224
- * @see {@link https://github.com/pwrdrvr/microapps-core/blob/main/packages/cdk/lib/MicroApps.ts | example usage in a CDK Stack }
225
- * @experimental
260
+ * @warning This construct is not intended for production use.
261
+ * In a production stack the DynamoDB Table, API Gateway, S3 Buckets,
262
+ * etc. should be created in a "durable" stack where the IDs will not
263
+ * change and where changes to the MicroApps construct will not
264
+ * cause failures to deploy or data to be deleted.
265
+ *
266
+ * @see {@link https://github.com/pwrdrvr/microapps-core/blob/main/packages/cdk/lib/MicroApps.ts | example usage in a CDK Stack }
226
267
  */
227
268
  export declare class MicroApps extends Construct implements IMicroApps {
228
269
  private _cf;
229
- /**
230
- * (experimental) {@inheritdoc IMicroAppsCF}.
231
- *
232
- * @experimental
233
- */
234
270
  get cf(): IMicroAppsCF;
271
+ private _edgeToOrigin?;
272
+ get edgeToOrigin(): IMicroAppsEdgeToOrigin | undefined;
235
273
  private _s3;
236
- /**
237
- * (experimental) {@inheritdoc IMicroAppsS3}.
238
- *
239
- * @experimental
240
- */
241
274
  get s3(): IMicroAppsS3;
242
275
  private _apigwy;
243
- /**
244
- * (experimental) {@inheritdoc IMicroAppsAPIGwy}.
245
- *
246
- * @experimental
247
- */
248
276
  get apigwy(): IMicroAppsAPIGwy;
249
277
  private _svcs;
250
- /**
251
- * (experimental) {@inheritdoc IMicroAppsSvcs}.
252
- *
253
- * @experimental
254
- */
255
278
  get svcs(): IMicroAppsSvcs;
256
- /**
257
- * @experimental
258
- */
259
279
  constructor(scope: Construct, id: string, props?: MicroAppsProps);
260
280
  }
281
+ //# sourceMappingURL=MicroApps.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MicroApps.d.ts","sourceRoot":"","sources":["../src/MicroApps.ts"],"names":[],"mappings":"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"}
package/lib/MicroApps.js CHANGED
@@ -6,13 +6,15 @@ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const constructs_1 = require("constructs");
7
7
  const MicroAppsAPIGwy_1 = require("./MicroAppsAPIGwy");
8
8
  const MicroAppsCF_1 = require("./MicroAppsCF");
9
+ const MicroAppsEdgeToOrigin_1 = require("./MicroAppsEdgeToOrigin");
9
10
  const MicroAppsS3_1 = require("./MicroAppsS3");
10
11
  const MicroAppsSvcs_1 = require("./MicroAppsSvcs");
11
12
  const ReverseDomain_1 = require("./utils/ReverseDomain");
12
13
  /**
13
- * (experimental) Create a new MicroApps "turnkey" construct for simple deployments and for initial evaulation of the MicroApps framework.
14
+ * Create a new MicroApps "turnkey" construct for simple
15
+ * deployments and for initial evaulation of the MicroApps framework.
14
16
  *
15
- * Use this construct to create a working entire stack.
17
+ * Use this construct to create a PoC working entire stack.
16
18
  *
17
19
  * Do not use this construct when adding MicroApps to an existing
18
20
  * CloudFront, API Gateway, S3 Bucket, etc. or where access
@@ -20,19 +22,21 @@ const ReverseDomain_1 = require("./utils/ReverseDomain");
20
22
  * add additional Behaviors to the CloudFront distribution, set authorizors
21
23
  * on API Gateway, etc.).
22
24
  *
23
- * @see {@link https://github.com/pwrdrvr/microapps-core/blob/main/packages/cdk/lib/MicroApps.ts | example usage in a CDK Stack }
24
- * @experimental
25
+ * @warning This construct is not intended for production use.
26
+ * In a production stack the DynamoDB Table, API Gateway, S3 Buckets,
27
+ * etc. should be created in a "durable" stack where the IDs will not
28
+ * change and where changes to the MicroApps construct will not
29
+ * cause failures to deploy or data to be deleted.
30
+ *
31
+ * @see {@link https://github.com/pwrdrvr/microapps-core/blob/main/packages/cdk/lib/MicroApps.ts | example usage in a CDK Stack }
25
32
  */
26
33
  class MicroApps extends constructs_1.Construct {
27
- /**
28
- * @experimental
29
- */
30
34
  constructor(scope, id, props) {
31
35
  super(scope, id);
32
36
  if (props === undefined) {
33
37
  throw new Error('props must be set');
34
38
  }
35
- const { domainNameEdge, domainNameOrigin, assetNameRoot, assetNameSuffix, r53Zone, certEdge, appEnv = 'dev', certOrigin, removalPolicy, s3PolicyBypassAROAs, s3PolicyBypassPrincipalARNs, s3StrictBucketPolicy, rootPathPrefix, createAPIPathRoute = true, } = props;
39
+ const { domainNameEdge, domainNameOrigin, assetNameRoot, assetNameSuffix, r53Zone, certEdge, appEnv = 'dev', certOrigin, removalPolicy, s3PolicyBypassAROAs, s3PolicyBypassPrincipalARNs, s3StrictBucketPolicy, rootPathPrefix, createAPIPathRoute = true, addXForwardedHostHeader = true, replaceHostHeader = true, signingMode = 'sign', originRegion, table, } = props;
36
40
  this._s3 = new MicroAppsS3_1.MicroAppsS3(this, 's3', {
37
41
  removalPolicy,
38
42
  bucketLogsName: domainNameEdge ? `${ReverseDomain_1.reverseDomain(domainNameEdge)}-logs` : undefined,
@@ -52,7 +56,19 @@ class MicroApps extends constructs_1.Construct {
52
56
  r53Zone,
53
57
  certOrigin,
54
58
  rootPathPrefix,
59
+ requireIAMAuthorization: signingMode !== 'none',
55
60
  });
61
+ if (signingMode !== 'none' || replaceHostHeader || addXForwardedHostHeader) {
62
+ this._edgeToOrigin = new MicroAppsEdgeToOrigin_1.MicroAppsEdgeToOrigin(this, 'edgeToOrigin', {
63
+ assetNameRoot,
64
+ assetNameSuffix,
65
+ removalPolicy,
66
+ addXForwardedHostHeader,
67
+ replaceHostHeader,
68
+ originRegion,
69
+ signingMode,
70
+ });
71
+ }
56
72
  this._cf = new MicroAppsCF_1.MicroAppsCF(this, 'cft', {
57
73
  removalPolicy,
58
74
  assetNameRoot,
@@ -66,6 +82,7 @@ class MicroApps extends constructs_1.Construct {
66
82
  bucketLogs: this._s3.bucketLogs,
67
83
  rootPathPrefix,
68
84
  createAPIPathRoute,
85
+ edgeToOriginLambdas: this._edgeToOrigin ? this._edgeToOrigin.edgeToOriginLambdas : undefined,
69
86
  });
70
87
  this._svcs = new MicroAppsSvcs_1.MicroAppsSvcs(this, 'svcs', {
71
88
  httpApi: this.apigwy.httpApi,
@@ -80,42 +97,27 @@ class MicroApps extends constructs_1.Construct {
80
97
  s3PolicyBypassPrincipalARNs,
81
98
  s3StrictBucketPolicy,
82
99
  rootPathPrefix,
100
+ requireIAMAuthorization: signingMode !== 'none',
101
+ table,
83
102
  });
84
103
  }
85
- /**
86
- * (experimental) {@inheritdoc IMicroAppsCF}.
87
- *
88
- * @experimental
89
- */
90
104
  get cf() {
91
105
  return this._cf;
92
106
  }
93
- /**
94
- * (experimental) {@inheritdoc IMicroAppsS3}.
95
- *
96
- * @experimental
97
- */
107
+ get edgeToOrigin() {
108
+ return this._edgeToOrigin;
109
+ }
98
110
  get s3() {
99
111
  return this._s3;
100
112
  }
101
- /**
102
- * (experimental) {@inheritdoc IMicroAppsAPIGwy}.
103
- *
104
- * @experimental
105
- */
106
113
  get apigwy() {
107
114
  return this._apigwy;
108
115
  }
109
- /**
110
- * (experimental) {@inheritdoc IMicroAppsSvcs}.
111
- *
112
- * @experimental
113
- */
114
116
  get svcs() {
115
117
  return this._svcs;
116
118
  }
117
119
  }
118
120
  exports.MicroApps = MicroApps;
119
121
  _a = JSII_RTTI_SYMBOL_1;
120
- MicroApps[_a] = { fqn: "@pwrdrvr/microapps-cdk.MicroApps", version: "0.2.8" };
121
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MicroApps.js","sourceRoot":"","sources":["../src/MicroApps.ts"],"names":[],"mappings":";;;;;AAGA,2CAAuC;AACvC,uDAAsE;AACtE,+CAA0D;AAC1D,+CAA0D;AAC1D,mDAAgE;AAChE,yDAAsD;;;;;;;;;;;;;;;AAiEtD,MAAa,SAAU,SAAQ,sBAAS;;;;IAqBtC,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAsB;QAC9D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;SACtC;QAED,MAAM,EACJ,cAAc,EACd,gBAAgB,EAChB,aAAa,EACb,eAAe,EACf,OAAO,EACP,QAAQ,EACR,MAAM,GAAG,KAAK,EACd,UAAU,EACV,aAAa,EACb,mBAAmB,EACnB,2BAA2B,EAC3B,oBAAoB,EACpB,cAAc,EACd,kBAAkB,GAAG,IAAI,GAC1B,GAAG,KAAK,CAAC;QAEV,IAAI,CAAC,GAAG,GAAG,IAAI,yBAAW,CAAC,IAAI,EAAE,IAAI,EAAE;YACrC,aAAa;YACb,cAAc,EAAE,cAAc,CAAC,CAAC,CAAC,GAAG,6BAAa,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS;YACpF,cAAc,EAAE,cAAc,CAAC,CAAC,CAAC,GAAG,6BAAa,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS;YAC/E,qBAAqB,EAAE,cAAc;gBACnC,CAAC,CAAC,GAAG,6BAAa,CAAC,cAAc,CAAC,UAAU;gBAC5C,CAAC,CAAC,SAAS;YACb,aAAa;YACb,eAAe;SAChB,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,GAAG,IAAI,iCAAe,CAAC,IAAI,EAAE,KAAK,EAAE;YAC9C,aAAa;YACb,aAAa;YACb,eAAe;YACf,cAAc;YACd,gBAAgB;YAChB,OAAO;YACP,UAAU;YACV,cAAc;SACf,CAAC,CAAC;QACH,IAAI,CAAC,GAAG,GAAG,IAAI,yBAAW,CAAC,IAAI,EAAE,KAAK,EAAE;YACtC,aAAa;YACb,aAAa;YACb,eAAe;YACf,cAAc;YACd,gBAAgB;YAChB,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO;YAC7B,OAAO;YACP,QAAQ;YACR,gBAAgB,EAAE,IAAI,CAAC,GAAG,CAAC,gBAAgB;YAC3C,UAAU,EAAE,IAAI,CAAC,GAAG,CAAC,UAAU;YAC/B,cAAc;YACd,kBAAkB;SACnB,CAAC,CAAC;QACH,IAAI,CAAC,KAAK,GAAG,IAAI,6BAAa,CAAC,IAAI,EAAE,MAAM,EAAE;YAC3C,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,OAAO;YAC5B,aAAa;YACb,UAAU,EAAE,IAAI,CAAC,GAAG,CAAC,UAAU;YAC/B,aAAa,EAAE,IAAI,CAAC,GAAG,CAAC,aAAa;YACrC,iBAAiB,EAAE,IAAI,CAAC,GAAG,CAAC,iBAAiB;YAC7C,aAAa;YACb,eAAe;YACf,MAAM;YACN,mBAAmB;YACnB,2BAA2B;YAC3B,oBAAoB;YACpB,cAAc;SACf,CAAC,CAAC;IACL,CAAC;;;;;;IA3FD,IAAW,EAAE;QACX,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;;;;;;IAGD,IAAW,EAAE;QACX,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;;;;;;IAGD,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;;;;;;IAGD,IAAW,IAAI;QACb,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;;AAnBH,8BA8FC","sourcesContent":["import { RemovalPolicy } from 'aws-cdk-lib';\nimport * as acm from 'aws-cdk-lib/aws-certificatemanager';\nimport * as r53 from 'aws-cdk-lib/aws-route53';\nimport { Construct } from 'constructs';\nimport { IMicroAppsAPIGwy, MicroAppsAPIGwy } from './MicroAppsAPIGwy';\nimport { IMicroAppsCF, MicroAppsCF } from './MicroAppsCF';\nimport { IMicroAppsS3, MicroAppsS3 } from './MicroAppsS3';\nimport { IMicroAppsSvcs, MicroAppsSvcs } from './MicroAppsSvcs';\nimport { reverseDomain } from './utils/ReverseDomain';\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        \n\n                                                               \nexport interface MicroAppsProps {\n                                                                                                                                                                                                 \n  readonly removalPolicy?: RemovalPolicy;\n\n                                                                                                   \n  readonly appEnv: string;\n\n                                                                                                                   \n  readonly assetNameRoot?: string;\n\n                                                                                            \n  readonly assetNameSuffix?: string;\n\n                                                                                 \n  readonly r53Zone?: r53.IHostedZone;\n\n                                                                          \n  readonly certEdge?: acm.ICertificate;\n\n                                                                    \n  readonly certOrigin?: acm.ICertificate;\n\n                                                                                                                                                                                                                                                                                                                                \n  readonly s3StrictBucketPolicy?: boolean;\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       \n  readonly s3PolicyBypassPrincipalARNs?: string[];\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     \n  readonly s3PolicyBypassAROAs?: string[];\n\n                                                                                                                                             \n  readonly domainNameEdge?: string;\n\n                                                                                                                                                   \n  readonly domainNameOrigin?: string;\n\n                                                                                               \n  readonly rootPathPrefix?: string;\n\n                                                                                                                                                                                                                                                                                                                                                                    \n  readonly createAPIPathRoute?: boolean;\n}\n\n                                 \nexport interface IMicroApps {\n                                   \n  readonly cf: IMicroAppsCF;\n\n                                   \n  readonly s3: IMicroAppsS3;\n\n                                     \n  readonly svcs: IMicroAppsSvcs;\n\n                                       \n  readonly apigwy: IMicroAppsAPIGwy;\n}\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          \nexport class MicroApps extends Construct implements IMicroApps {\n  private _cf: MicroAppsCF;\n  public get cf(): IMicroAppsCF {\n    return this._cf;\n  }\n\n  private _s3: MicroAppsS3;\n  public get s3(): IMicroAppsS3 {\n    return this._s3;\n  }\n\n  private _apigwy: MicroAppsAPIGwy;\n  public get apigwy(): IMicroAppsAPIGwy {\n    return this._apigwy;\n  }\n\n  private _svcs: MicroAppsSvcs;\n  public get svcs(): IMicroAppsSvcs {\n    return this._svcs;\n  }\n\n  constructor(scope: Construct, id: string, props?: MicroAppsProps) {\n    super(scope, id);\n\n    if (props === undefined) {\n      throw new Error('props must be set');\n    }\n\n    const {\n      domainNameEdge,\n      domainNameOrigin,\n      assetNameRoot,\n      assetNameSuffix,\n      r53Zone,\n      certEdge,\n      appEnv = 'dev',\n      certOrigin,\n      removalPolicy,\n      s3PolicyBypassAROAs,\n      s3PolicyBypassPrincipalARNs,\n      s3StrictBucketPolicy,\n      rootPathPrefix,\n      createAPIPathRoute = true,\n    } = props;\n\n    this._s3 = new MicroAppsS3(this, 's3', {\n      removalPolicy,\n      bucketLogsName: domainNameEdge ? `${reverseDomain(domainNameEdge)}-logs` : undefined,\n      bucketAppsName: domainNameEdge ? `${reverseDomain(domainNameEdge)}` : undefined,\n      bucketAppsStagingName: domainNameEdge\n        ? `${reverseDomain(domainNameEdge)}-staging`\n        : undefined,\n      assetNameRoot,\n      assetNameSuffix,\n    });\n    this._apigwy = new MicroAppsAPIGwy(this, 'api', {\n      removalPolicy,\n      assetNameRoot,\n      assetNameSuffix,\n      domainNameEdge,\n      domainNameOrigin,\n      r53Zone,\n      certOrigin,\n      rootPathPrefix,\n    });\n    this._cf = new MicroAppsCF(this, 'cft', {\n      removalPolicy,\n      assetNameRoot,\n      assetNameSuffix,\n      domainNameEdge,\n      domainNameOrigin,\n      httpApi: this._apigwy.httpApi,\n      r53Zone,\n      certEdge,\n      bucketAppsOrigin: this._s3.bucketAppsOrigin,\n      bucketLogs: this._s3.bucketLogs,\n      rootPathPrefix,\n      createAPIPathRoute,\n    });\n    this._svcs = new MicroAppsSvcs(this, 'svcs', {\n      httpApi: this.apigwy.httpApi,\n      removalPolicy,\n      bucketApps: this._s3.bucketApps,\n      bucketAppsOAI: this._s3.bucketAppsOAI,\n      bucketAppsStaging: this._s3.bucketAppsStaging,\n      assetNameRoot,\n      assetNameSuffix,\n      appEnv,\n      s3PolicyBypassAROAs,\n      s3PolicyBypassPrincipalARNs,\n      s3StrictBucketPolicy,\n      rootPathPrefix,\n    });\n  }\n}\n"]}
122
+ MicroApps[_a] = { fqn: "@pwrdrvr/microapps-cdk.MicroApps", version: "0.2.11" };
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MicroApps.js","sourceRoot":"","sources":["../src/MicroApps.ts"],"names":[],"mappings":";;;;;AAIA,2CAAuC;AACvC,uDAAsE;AACtE,+CAA0D;AAC1D,mEAAwF;AACxF,+CAA0D;AAC1D,mDAAgE;AAChE,yDAAsD;AAwQtD;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAa,SAAU,SAAQ,sBAAS;IA0BtC,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAsB;QAC9D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;SACtC;QAED,MAAM,EACJ,cAAc,EACd,gBAAgB,EAChB,aAAa,EACb,eAAe,EACf,OAAO,EACP,QAAQ,EACR,MAAM,GAAG,KAAK,EACd,UAAU,EACV,aAAa,EACb,mBAAmB,EACnB,2BAA2B,EAC3B,oBAAoB,EACpB,cAAc,EACd,kBAAkB,GAAG,IAAI,EACzB,uBAAuB,GAAG,IAAI,EAC9B,iBAAiB,GAAG,IAAI,EACxB,WAAW,GAAG,MAAM,EACpB,YAAY,EACZ,KAAK,GACN,GAAG,KAAK,CAAC;QAEV,IAAI,CAAC,GAAG,GAAG,IAAI,yBAAW,CAAC,IAAI,EAAE,IAAI,EAAE;YACrC,aAAa;YACb,cAAc,EAAE,cAAc,CAAC,CAAC,CAAC,GAAG,6BAAa,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS;YACpF,cAAc,EAAE,cAAc,CAAC,CAAC,CAAC,GAAG,6BAAa,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS;YAC/E,qBAAqB,EAAE,cAAc;gBACnC,CAAC,CAAC,GAAG,6BAAa,CAAC,cAAc,CAAC,UAAU;gBAC5C,CAAC,CAAC,SAAS;YACb,aAAa;YACb,eAAe;SAChB,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,GAAG,IAAI,iCAAe,CAAC,IAAI,EAAE,KAAK,EAAE;YAC9C,aAAa;YACb,aAAa;YACb,eAAe;YACf,cAAc;YACd,gBAAgB;YAChB,OAAO;YACP,UAAU;YACV,cAAc;YACd,uBAAuB,EAAE,WAAW,KAAK,MAAM;SAChD,CAAC,CAAC;QACH,IAAI,WAAW,KAAK,MAAM,IAAI,iBAAiB,IAAI,uBAAuB,EAAE;YAC1E,IAAI,CAAC,aAAa,GAAG,IAAI,6CAAqB,CAAC,IAAI,EAAE,cAAc,EAAE;gBACnE,aAAa;gBACb,eAAe;gBACf,aAAa;gBACb,uBAAuB;gBACvB,iBAAiB;gBACjB,YAAY;gBACZ,WAAW;aACZ,CAAC,CAAC;SACJ;QACD,IAAI,CAAC,GAAG,GAAG,IAAI,yBAAW,CAAC,IAAI,EAAE,KAAK,EAAE;YACtC,aAAa;YACb,aAAa;YACb,eAAe;YACf,cAAc;YACd,gBAAgB;YAChB,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO;YAC7B,OAAO;YACP,QAAQ;YACR,gBAAgB,EAAE,IAAI,CAAC,GAAG,CAAC,gBAAgB;YAC3C,UAAU,EAAE,IAAI,CAAC,GAAG,CAAC,UAAU;YAC/B,cAAc;YACd,kBAAkB;YAClB,mBAAmB,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,CAAC,CAAC,SAAS;SAC7F,CAAC,CAAC;QACH,IAAI,CAAC,KAAK,GAAG,IAAI,6BAAa,CAAC,IAAI,EAAE,MAAM,EAAE;YAC3C,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,OAAO;YAC5B,aAAa;YACb,UAAU,EAAE,IAAI,CAAC,GAAG,CAAC,UAAU;YAC/B,aAAa,EAAE,IAAI,CAAC,GAAG,CAAC,aAAa;YACrC,iBAAiB,EAAE,IAAI,CAAC,GAAG,CAAC,iBAAiB;YAC7C,aAAa;YACb,eAAe;YACf,MAAM;YACN,mBAAmB;YACnB,2BAA2B;YAC3B,oBAAoB;YACpB,cAAc;YACd,uBAAuB,EAAE,WAAW,KAAK,MAAM;YAC/C,KAAK;SACN,CAAC,CAAC;IACL,CAAC;IApHD,IAAW,EAAE;QACX,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;IAGD,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAGD,IAAW,EAAE;QACX,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;IAGD,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAGD,IAAW,IAAI;QACb,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;;AAxBH,8BAuHC","sourcesContent":["import { RemovalPolicy } from 'aws-cdk-lib';\nimport * as acm from 'aws-cdk-lib/aws-certificatemanager';\nimport * as dynamodb from 'aws-cdk-lib/aws-dynamodb';\nimport * as r53 from 'aws-cdk-lib/aws-route53';\nimport { Construct } from 'constructs';\nimport { IMicroAppsAPIGwy, MicroAppsAPIGwy } from './MicroAppsAPIGwy';\nimport { IMicroAppsCF, MicroAppsCF } from './MicroAppsCF';\nimport { IMicroAppsEdgeToOrigin, MicroAppsEdgeToOrigin } from './MicroAppsEdgeToOrigin';\nimport { IMicroAppsS3, MicroAppsS3 } from './MicroAppsS3';\nimport { IMicroAppsSvcs, MicroAppsSvcs } from './MicroAppsSvcs';\nimport { reverseDomain } from './utils/ReverseDomain';\n\n/**\n * A CDK Construct for creating a MicroApps runtime environment used\n * to host Next.js, React, or any other sort of web application with\n * multiple versions available for comparison, quick rollbacks, quick\n * releases, and a complete lack of user disturbance on deploys.\n *\n * @remarks\n *\n * {@link MicroApps} provides a turn-key construct that creates all\n * dependencies with limited exposure of underlying AWS Resource options.\n * This construct is the easiest to use when exploring MicroApps for the\n * first time.\n *\n * {@link MicroAppsAPIGwy}, {@link MicroAppsCF}, {@link MicroAppsS3},\n * and {@link MicroAppsSvcs}, and their helper static methods, can be used\n * to create AWS Resources more directly, to provide your own AWS Resources\n * (e.g. an existing CloudFront Distribution), and to have more flexibility\n * than the {@link MicroApps} construct offers.\n *\n * @packageDocumentation\n */\n\n/**\n * Properties to initialize an instance of `MicroApps`.\n */\nexport interface MicroAppsProps {\n  /**\n   * RemovalPolicy override for child resources\n   *\n   * Note: if set to DESTROY the S3 buckes will have `autoDeleteObjects` set to `true`\n   *\n   * @default - per resource default\n   */\n  readonly removalPolicy?: RemovalPolicy;\n\n  /**\n   * Passed to NODE_ENV of Router and Deployer Lambda functions.\n   *\n   * @default dev\n   */\n  readonly appEnv: string;\n\n  /**\n   * Optional asset name root\n   *\n   * @example microapps\n   * @default - resource names auto assigned\n   */\n  readonly assetNameRoot?: string;\n\n  /**\n   * Optional asset name suffix\n   *\n   * @example -dev-pr-12\n   * @default none\n   */\n  readonly assetNameSuffix?: string;\n\n  /**\n   * Route53 zone in which to create optional `domainNameEdge` record\n   */\n  readonly r53Zone?: r53.IHostedZone;\n\n  /**\n   * Certificate in US-East-1 for the CloudFront distribution.\n   */\n  readonly certEdge?: acm.ICertificate;\n\n  /**\n   * Certificate in deployed region for the API Gateway.\n   */\n  readonly certOrigin?: acm.ICertificate;\n\n  /**\n   * Use a strict S3 Bucket Policy that prevents applications\n   * from reading/writing/modifying/deleting files in the S3 Bucket\n   * outside of the path that is specific to their app/version.\n   *\n   * This setting should be used when applications are less than\n   * fully trusted.\n   *\n   * @default false\n   */\n  readonly s3StrictBucketPolicy?: boolean;\n\n  /**\n   * Applies when using s3StrictBucketPolicy = true\n   *\n   * IAM Role or IAM User names to exclude from the DENY rules on the S3 Bucket Policy.\n   *\n   * Roles that are Assumed must instead have their AROA added to `s3PolicyBypassAROAs`.\n   *\n   * Typically any admin roles / users that need to view or manage the S3 Bucket\n   * would be added to this list.\n   *\n   * @example ['arn:aws:iam::1234567890123:role/AdminAccess', 'arn:aws:iam::1234567890123:user/MyAdminUser']\n   *\n   * @see s3PolicyBypassAROAs\n   */\n  readonly s3PolicyBypassPrincipalARNs?: string[];\n\n  /**\n   * Applies when using s3StrictBucketPolicy = true\n   *\n   * AROAs of the IAM Role to exclude from the DENY rules on the S3 Bucket Policy.\n   * This allows sessions that assume the IAM Role to be excluded from the\n   * DENY rules on the S3 Bucket Policy.\n   *\n   * Typically any admin roles / users that need to view or manage the S3 Bucket\n   * would be added to this list.\n   *\n   * Roles / users that are used directly, not assumed, can be added to `s3PolicyBypassRoleNames` instead.\n   *\n   * Note: This AROA must be specified to prevent this policy from locking\n   * out non-root sessions that have assumed the admin role.\n   *\n   * The notPrincipals will only match the role name exactly and will not match\n   * any session that has assumed the role since notPrincipals does not allow\n   * wildcard matches and does not do wildcard matches implicitly either.\n   *\n   * The AROA must be used because there are only 3 Principal variables available:\n   *  https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_variables.html#principaltable\n   *  aws:username, aws:userid, aws:PrincipalTag\n   *\n   * For an assumed role, aws:username is blank, aws:userid is:\n   *  [unique id AKA AROA for Role]:[session name]\n   *\n   * Table of unique ID prefixes such as AROA:\n   *  https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_identifiers.html#identifiers-prefixes\n   *\n   * The name of the role is simply not available for an assumed role and, if it was,\n   * a complicated comparison would be requierd to prevent exclusion\n   * of applying the Deny Rule to roles from other accounts.\n   *\n   * To get the AROA with the AWS CLI:\n   *   aws iam get-role --role-name ROLE-NAME\n   *   aws iam get-user -–user-name USER-NAME\n   *\n   * @example [ 'AROA1234567890123' ]\n   *\n   * @see s3StrictBucketPolicy\n   */\n  readonly s3PolicyBypassAROAs?: string[];\n\n  /**\n   * Optional custom domain name for the CloudFront distribution.\n   *\n   * @example apps.pwrdrvr.com\n   * @default auto-assigned\n   */\n  readonly domainNameEdge?: string;\n\n  /**\n   * Optional custom domain name for the API Gateway HTTPv2 API.\n   *\n   * @example apps-origin.pwrdrvr.com\n   * @default auto-assigned\n   */\n  readonly domainNameOrigin?: string;\n\n  /**\n   * Path prefix on the root of the CloudFront distribution\n   *\n   * @example dev/\n   */\n  readonly rootPathPrefix?: string;\n\n  /**\n   * Create an extra Behavior (Route) for /api/ that allows\n   * API routes to have a period in them.\n   *\n   * When false API routes with a period in the path will get routed to S3.\n   *\n   * When true API routes that contain /api/ in the path will get routed to API Gateway\n   * even if they have a period in the path.\n   *\n   * @default true\n   */\n  readonly createAPIPathRoute?: boolean;\n\n  /**\n   * Adds an X-Forwarded-Host-Header when calling API Gateway\n   *\n   * Can only be trusted if `signingMode` is enabled, which restricts\n   * access to API Gateway to only IAM signed requests.\n   *\n   * Note: if true, creates OriginRequest Lambda @ Edge function for API Gateway Origin\n   * @default true\n   */\n  readonly addXForwardedHostHeader?: boolean;\n\n  /**\n   * Replaces Host header (which will be the Edge domain name) with the Origin domain name\n   * when enabled.  This is necessary when API Gateway has not been configured\n   * with a custom domain name that matches the exact domain name used by the CloudFront\n   * Distribution AND when the OriginRequestPolicy.HeadersBehavior is set\n   * to pass all headers to the origin.\n   *\n   * Note: if true, creates OriginRequest Lambda @ Edge function for API Gateway Origin\n   * @default true\n   */\n  readonly replaceHostHeader?: boolean;\n\n  /**\n   * Requires IAM auth on the API Gateway origin if not set to 'none'.\n   *\n   * 'sign' - Uses request headers for auth.\n   * 'presign' - Uses query string for auth.\n   *\n   * If enabled,\n   *\n   * Note: if 'sign' or 'presign', creates OriginRequest Lambda @ Edge function for API Gateway Origin\n   * @default 'sign'\n   */\n  readonly signingMode?: 'sign' | 'presign' | 'none';\n\n  /**\n   * Origin region that API Gateway will be deployed to, used\n   * for the config.yml on the Edge function to sign requests for\n   * the correct region\n   *\n   * @default undefined\n   */\n  readonly originRegion?: string;\n\n  /**\n   * Existing table for apps/versions/rules\n   *\n   * @warning - It is *strongly* suggested that production stacks create\n   * their own DynamoDB Table and pass it into this construct, for protection\n   * against data loss due to logical ID changes, the ability to configure\n   * Provisioned capacity with Auto Scaling, the ability to add additional indices, etc.\n   *\n   * Requirements:\n   * - Hash Key: `PK`\n   * - Sort Key: `SK`\n   *\n   * @default created by construct\n   */\n  readonly table?: dynamodb.ITable;\n}\n\n/**\n * Represents a MicroApps\n */\nexport interface IMicroApps {\n  /** {@inheritdoc IMicroAppsCF} */\n  readonly cf: IMicroAppsCF;\n\n  /** {@inheritdoc IMicroAppsEdgeToOrigin} */\n  readonly edgeToOrigin?: IMicroAppsEdgeToOrigin;\n\n  /** {@inheritdoc IMicroAppsS3} */\n  readonly s3: IMicroAppsS3;\n\n  /** {@inheritdoc IMicroAppsSvcs} */\n  readonly svcs: IMicroAppsSvcs;\n\n  /** {@inheritdoc IMicroAppsAPIGwy} */\n  readonly apigwy: IMicroAppsAPIGwy;\n}\n\n/**\n * Create a new MicroApps \"turnkey\" construct for simple\n * deployments and for initial evaulation of the MicroApps framework.\n *\n * Use this construct to create a PoC working entire stack.\n *\n * Do not use this construct when adding MicroApps to an existing\n * CloudFront, API Gateway, S3 Bucket, etc. or where access\n * to all features of the AWS Resources are needed (e.g. to\n * add additional Behaviors to the CloudFront distribution, set authorizors\n * on API Gateway, etc.).\n *\n * @warning This construct is not intended for production use.\n * In a production stack the DynamoDB Table, API Gateway, S3 Buckets,\n * etc. should be created in a \"durable\" stack where the IDs will not\n * change and where changes to the MicroApps construct will not\n * cause failures to deploy or data to be deleted.\n *\n *  @see {@link https://github.com/pwrdrvr/microapps-core/blob/main/packages/cdk/lib/MicroApps.ts | example usage in a CDK Stack }\n */\nexport class MicroApps extends Construct implements IMicroApps {\n  private _cf: MicroAppsCF;\n  public get cf(): IMicroAppsCF {\n    return this._cf;\n  }\n\n  private _edgeToOrigin?: MicroAppsEdgeToOrigin;\n  public get edgeToOrigin(): IMicroAppsEdgeToOrigin | undefined {\n    return this._edgeToOrigin;\n  }\n\n  private _s3: MicroAppsS3;\n  public get s3(): IMicroAppsS3 {\n    return this._s3;\n  }\n\n  private _apigwy: MicroAppsAPIGwy;\n  public get apigwy(): IMicroAppsAPIGwy {\n    return this._apigwy;\n  }\n\n  private _svcs: MicroAppsSvcs;\n  public get svcs(): IMicroAppsSvcs {\n    return this._svcs;\n  }\n\n  constructor(scope: Construct, id: string, props?: MicroAppsProps) {\n    super(scope, id);\n\n    if (props === undefined) {\n      throw new Error('props must be set');\n    }\n\n    const {\n      domainNameEdge,\n      domainNameOrigin,\n      assetNameRoot,\n      assetNameSuffix,\n      r53Zone,\n      certEdge,\n      appEnv = 'dev',\n      certOrigin,\n      removalPolicy,\n      s3PolicyBypassAROAs,\n      s3PolicyBypassPrincipalARNs,\n      s3StrictBucketPolicy,\n      rootPathPrefix,\n      createAPIPathRoute = true,\n      addXForwardedHostHeader = true,\n      replaceHostHeader = true,\n      signingMode = 'sign',\n      originRegion,\n      table,\n    } = props;\n\n    this._s3 = new MicroAppsS3(this, 's3', {\n      removalPolicy,\n      bucketLogsName: domainNameEdge ? `${reverseDomain(domainNameEdge)}-logs` : undefined,\n      bucketAppsName: domainNameEdge ? `${reverseDomain(domainNameEdge)}` : undefined,\n      bucketAppsStagingName: domainNameEdge\n        ? `${reverseDomain(domainNameEdge)}-staging`\n        : undefined,\n      assetNameRoot,\n      assetNameSuffix,\n    });\n    this._apigwy = new MicroAppsAPIGwy(this, 'api', {\n      removalPolicy,\n      assetNameRoot,\n      assetNameSuffix,\n      domainNameEdge,\n      domainNameOrigin,\n      r53Zone,\n      certOrigin,\n      rootPathPrefix,\n      requireIAMAuthorization: signingMode !== 'none',\n    });\n    if (signingMode !== 'none' || replaceHostHeader || addXForwardedHostHeader) {\n      this._edgeToOrigin = new MicroAppsEdgeToOrigin(this, 'edgeToOrigin', {\n        assetNameRoot,\n        assetNameSuffix,\n        removalPolicy,\n        addXForwardedHostHeader,\n        replaceHostHeader,\n        originRegion,\n        signingMode,\n      });\n    }\n    this._cf = new MicroAppsCF(this, 'cft', {\n      removalPolicy,\n      assetNameRoot,\n      assetNameSuffix,\n      domainNameEdge,\n      domainNameOrigin,\n      httpApi: this._apigwy.httpApi,\n      r53Zone,\n      certEdge,\n      bucketAppsOrigin: this._s3.bucketAppsOrigin,\n      bucketLogs: this._s3.bucketLogs,\n      rootPathPrefix,\n      createAPIPathRoute,\n      edgeToOriginLambdas: this._edgeToOrigin ? this._edgeToOrigin.edgeToOriginLambdas : undefined,\n    });\n    this._svcs = new MicroAppsSvcs(this, 'svcs', {\n      httpApi: this.apigwy.httpApi,\n      removalPolicy,\n      bucketApps: this._s3.bucketApps,\n      bucketAppsOAI: this._s3.bucketAppsOAI,\n      bucketAppsStaging: this._s3.bucketAppsStaging,\n      assetNameRoot,\n      assetNameSuffix,\n      appEnv,\n      s3PolicyBypassAROAs,\n      s3PolicyBypassPrincipalARNs,\n      s3StrictBucketPolicy,\n      rootPathPrefix,\n      requireIAMAuthorization: signingMode !== 'none',\n      table,\n    });\n  }\n}\n"]}