@pwrdrvr/microapps-cdk 1.2.0-beta.5 → 1.2.0-beta.8
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/.jsii +5169 -280
- package/API.md +277 -25
- package/lib/MicroApps.js +1 -1
- package/lib/MicroAppsCF.d.ts +2 -2
- package/lib/MicroAppsCF.js +2 -2
- package/lib/MicroAppsChildDeployer.js +8 -3
- package/lib/MicroAppsEdgeToOrigin.js +16 -9
- package/lib/MicroAppsS3.d.ts +4 -5
- package/lib/MicroAppsS3.js +4 -4
- package/lib/MicroAppsSvcs.js +8 -3
- package/lib/MicroAppsTable.js +1 -1
- package/lib/microapps-deployer/index.js +95 -125
- package/lib/microapps-deployer/index.js.map +4 -4
- package/lib/microapps-edge-to-origin/index.js +96 -79
- package/lib/microapps-edge-to-origin/index.js.map +4 -4
- package/lib/microapps-router/index.js +88 -71
- package/lib/microapps-router/index.js.map +4 -4
- package/package.json +8 -8
package/API.md
CHANGED
|
@@ -57,6 +57,7 @@ new MicroApps(scope: Construct, id: string, props?: MicroAppsProps)
|
|
|
57
57
|
| **Name** | **Description** |
|
|
58
58
|
| --- | --- |
|
|
59
59
|
| <code><a href="#@pwrdrvr/microapps-cdk.MicroApps.toString">toString</a></code> | Returns a string representation of this construct. |
|
|
60
|
+
| <code><a href="#@pwrdrvr/microapps-cdk.MicroApps.with">with</a></code> | Applies one or more mixins to this construct. |
|
|
60
61
|
|
|
61
62
|
---
|
|
62
63
|
|
|
@@ -68,6 +69,27 @@ public toString(): string
|
|
|
68
69
|
|
|
69
70
|
Returns a string representation of this construct.
|
|
70
71
|
|
|
72
|
+
##### `with` <a name="with" id="@pwrdrvr/microapps-cdk.MicroApps.with"></a>
|
|
73
|
+
|
|
74
|
+
```typescript
|
|
75
|
+
public with(mixins: ...IMixin[]): IConstruct
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
Applies one or more mixins to this construct.
|
|
79
|
+
|
|
80
|
+
Mixins are applied in order. The list of constructs is captured at the
|
|
81
|
+
start of the call, so constructs added by a mixin will not be visited.
|
|
82
|
+
Use multiple `with()` calls if subsequent mixins should apply to added
|
|
83
|
+
constructs.
|
|
84
|
+
|
|
85
|
+
###### `mixins`<sup>Required</sup> <a name="mixins" id="@pwrdrvr/microapps-cdk.MicroApps.with.parameter.mixins"></a>
|
|
86
|
+
|
|
87
|
+
- *Type:* ...constructs.IMixin[]
|
|
88
|
+
|
|
89
|
+
The mixins to apply.
|
|
90
|
+
|
|
91
|
+
---
|
|
92
|
+
|
|
71
93
|
#### Static Functions <a name="Static Functions" id="Static Functions"></a>
|
|
72
94
|
|
|
73
95
|
| **Name** | **Description** |
|
|
@@ -76,7 +98,7 @@ Returns a string representation of this construct.
|
|
|
76
98
|
|
|
77
99
|
---
|
|
78
100
|
|
|
79
|
-
#####
|
|
101
|
+
##### `isConstruct` <a name="isConstruct" id="@pwrdrvr/microapps-cdk.MicroApps.isConstruct"></a>
|
|
80
102
|
|
|
81
103
|
```typescript
|
|
82
104
|
import { MicroApps } from '@pwrdrvr/microapps-cdk'
|
|
@@ -86,6 +108,20 @@ MicroApps.isConstruct(x: any)
|
|
|
86
108
|
|
|
87
109
|
Checks if `x` is a construct.
|
|
88
110
|
|
|
111
|
+
Use this method instead of `instanceof` to properly detect `Construct`
|
|
112
|
+
instances, even when the construct library is symlinked.
|
|
113
|
+
|
|
114
|
+
Explanation: in JavaScript, multiple copies of the `constructs` library on
|
|
115
|
+
disk are seen as independent, completely different libraries. As a
|
|
116
|
+
consequence, the class `Construct` in each copy of the `constructs` library
|
|
117
|
+
is seen as a different class, and an instance of one class will not test as
|
|
118
|
+
`instanceof` the other class. `npm install` will not create installations
|
|
119
|
+
like this, but users may manually symlink construct libraries together or
|
|
120
|
+
use a monorepo tool: in those cases, multiple copies of the `constructs`
|
|
121
|
+
library can be accidentally installed, and `instanceof` will behave
|
|
122
|
+
unpredictably. It is safest to avoid using `instanceof`, and using
|
|
123
|
+
this type-testing method instead.
|
|
124
|
+
|
|
89
125
|
###### `x`<sup>Required</sup> <a name="x" id="@pwrdrvr/microapps-cdk.MicroApps.isConstruct.parameter.x"></a>
|
|
90
126
|
|
|
91
127
|
- *Type:* any
|
|
@@ -212,6 +248,7 @@ new MicroAppsCF(scope: Construct, id: string, props: MicroAppsCFProps)
|
|
|
212
248
|
| **Name** | **Description** |
|
|
213
249
|
| --- | --- |
|
|
214
250
|
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsCF.toString">toString</a></code> | Returns a string representation of this construct. |
|
|
251
|
+
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsCF.with">with</a></code> | Applies one or more mixins to this construct. |
|
|
215
252
|
|
|
216
253
|
---
|
|
217
254
|
|
|
@@ -223,6 +260,27 @@ public toString(): string
|
|
|
223
260
|
|
|
224
261
|
Returns a string representation of this construct.
|
|
225
262
|
|
|
263
|
+
##### `with` <a name="with" id="@pwrdrvr/microapps-cdk.MicroAppsCF.with"></a>
|
|
264
|
+
|
|
265
|
+
```typescript
|
|
266
|
+
public with(mixins: ...IMixin[]): IConstruct
|
|
267
|
+
```
|
|
268
|
+
|
|
269
|
+
Applies one or more mixins to this construct.
|
|
270
|
+
|
|
271
|
+
Mixins are applied in order. The list of constructs is captured at the
|
|
272
|
+
start of the call, so constructs added by a mixin will not be visited.
|
|
273
|
+
Use multiple `with()` calls if subsequent mixins should apply to added
|
|
274
|
+
constructs.
|
|
275
|
+
|
|
276
|
+
###### `mixins`<sup>Required</sup> <a name="mixins" id="@pwrdrvr/microapps-cdk.MicroAppsCF.with.parameter.mixins"></a>
|
|
277
|
+
|
|
278
|
+
- *Type:* ...constructs.IMixin[]
|
|
279
|
+
|
|
280
|
+
The mixins to apply.
|
|
281
|
+
|
|
282
|
+
---
|
|
283
|
+
|
|
226
284
|
#### Static Functions <a name="Static Functions" id="Static Functions"></a>
|
|
227
285
|
|
|
228
286
|
| **Name** | **Description** |
|
|
@@ -233,7 +291,7 @@ Returns a string representation of this construct.
|
|
|
233
291
|
|
|
234
292
|
---
|
|
235
293
|
|
|
236
|
-
#####
|
|
294
|
+
##### `isConstruct` <a name="isConstruct" id="@pwrdrvr/microapps-cdk.MicroAppsCF.isConstruct"></a>
|
|
237
295
|
|
|
238
296
|
```typescript
|
|
239
297
|
import { MicroAppsCF } from '@pwrdrvr/microapps-cdk'
|
|
@@ -243,6 +301,20 @@ MicroAppsCF.isConstruct(x: any)
|
|
|
243
301
|
|
|
244
302
|
Checks if `x` is a construct.
|
|
245
303
|
|
|
304
|
+
Use this method instead of `instanceof` to properly detect `Construct`
|
|
305
|
+
instances, even when the construct library is symlinked.
|
|
306
|
+
|
|
307
|
+
Explanation: in JavaScript, multiple copies of the `constructs` library on
|
|
308
|
+
disk are seen as independent, completely different libraries. As a
|
|
309
|
+
consequence, the class `Construct` in each copy of the `constructs` library
|
|
310
|
+
is seen as a different class, and an instance of one class will not test as
|
|
311
|
+
`instanceof` the other class. `npm install` will not create installations
|
|
312
|
+
like this, but users may manually symlink construct libraries together or
|
|
313
|
+
use a monorepo tool: in those cases, multiple copies of the `constructs`
|
|
314
|
+
library can be accidentally installed, and `instanceof` will behave
|
|
315
|
+
unpredictably. It is safest to avoid using `instanceof`, and using
|
|
316
|
+
this type-testing method instead.
|
|
317
|
+
|
|
246
318
|
###### `x`<sup>Required</sup> <a name="x" id="@pwrdrvr/microapps-cdk.MicroAppsCF.isConstruct.parameter.x"></a>
|
|
247
319
|
|
|
248
320
|
- *Type:* any
|
|
@@ -381,6 +453,7 @@ new MicroAppsChildDeployer(scope: Construct, id: string, props?: MicroAppsChildD
|
|
|
381
453
|
| **Name** | **Description** |
|
|
382
454
|
| --- | --- |
|
|
383
455
|
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsChildDeployer.toString">toString</a></code> | Returns a string representation of this construct. |
|
|
456
|
+
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsChildDeployer.with">with</a></code> | Applies one or more mixins to this construct. |
|
|
384
457
|
|
|
385
458
|
---
|
|
386
459
|
|
|
@@ -392,6 +465,27 @@ public toString(): string
|
|
|
392
465
|
|
|
393
466
|
Returns a string representation of this construct.
|
|
394
467
|
|
|
468
|
+
##### `with` <a name="with" id="@pwrdrvr/microapps-cdk.MicroAppsChildDeployer.with"></a>
|
|
469
|
+
|
|
470
|
+
```typescript
|
|
471
|
+
public with(mixins: ...IMixin[]): IConstruct
|
|
472
|
+
```
|
|
473
|
+
|
|
474
|
+
Applies one or more mixins to this construct.
|
|
475
|
+
|
|
476
|
+
Mixins are applied in order. The list of constructs is captured at the
|
|
477
|
+
start of the call, so constructs added by a mixin will not be visited.
|
|
478
|
+
Use multiple `with()` calls if subsequent mixins should apply to added
|
|
479
|
+
constructs.
|
|
480
|
+
|
|
481
|
+
###### `mixins`<sup>Required</sup> <a name="mixins" id="@pwrdrvr/microapps-cdk.MicroAppsChildDeployer.with.parameter.mixins"></a>
|
|
482
|
+
|
|
483
|
+
- *Type:* ...constructs.IMixin[]
|
|
484
|
+
|
|
485
|
+
The mixins to apply.
|
|
486
|
+
|
|
487
|
+
---
|
|
488
|
+
|
|
395
489
|
#### Static Functions <a name="Static Functions" id="Static Functions"></a>
|
|
396
490
|
|
|
397
491
|
| **Name** | **Description** |
|
|
@@ -400,7 +494,7 @@ Returns a string representation of this construct.
|
|
|
400
494
|
|
|
401
495
|
---
|
|
402
496
|
|
|
403
|
-
#####
|
|
497
|
+
##### `isConstruct` <a name="isConstruct" id="@pwrdrvr/microapps-cdk.MicroAppsChildDeployer.isConstruct"></a>
|
|
404
498
|
|
|
405
499
|
```typescript
|
|
406
500
|
import { MicroAppsChildDeployer } from '@pwrdrvr/microapps-cdk'
|
|
@@ -410,6 +504,20 @@ MicroAppsChildDeployer.isConstruct(x: any)
|
|
|
410
504
|
|
|
411
505
|
Checks if `x` is a construct.
|
|
412
506
|
|
|
507
|
+
Use this method instead of `instanceof` to properly detect `Construct`
|
|
508
|
+
instances, even when the construct library is symlinked.
|
|
509
|
+
|
|
510
|
+
Explanation: in JavaScript, multiple copies of the `constructs` library on
|
|
511
|
+
disk are seen as independent, completely different libraries. As a
|
|
512
|
+
consequence, the class `Construct` in each copy of the `constructs` library
|
|
513
|
+
is seen as a different class, and an instance of one class will not test as
|
|
514
|
+
`instanceof` the other class. `npm install` will not create installations
|
|
515
|
+
like this, but users may manually symlink construct libraries together or
|
|
516
|
+
use a monorepo tool: in those cases, multiple copies of the `constructs`
|
|
517
|
+
library can be accidentally installed, and `instanceof` will behave
|
|
518
|
+
unpredictably. It is safest to avoid using `instanceof`, and using
|
|
519
|
+
this type-testing method instead.
|
|
520
|
+
|
|
413
521
|
###### `x`<sup>Required</sup> <a name="x" id="@pwrdrvr/microapps-cdk.MicroAppsChildDeployer.isConstruct.parameter.x"></a>
|
|
414
522
|
|
|
415
523
|
- *Type:* any
|
|
@@ -497,6 +605,7 @@ new MicroAppsEdgeToOrigin(scope: Construct, id: string, props: MicroAppsEdgeToOr
|
|
|
497
605
|
| **Name** | **Description** |
|
|
498
606
|
| --- | --- |
|
|
499
607
|
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsEdgeToOrigin.toString">toString</a></code> | Returns a string representation of this construct. |
|
|
608
|
+
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsEdgeToOrigin.with">with</a></code> | Applies one or more mixins to this construct. |
|
|
500
609
|
|
|
501
610
|
---
|
|
502
611
|
|
|
@@ -508,6 +617,27 @@ public toString(): string
|
|
|
508
617
|
|
|
509
618
|
Returns a string representation of this construct.
|
|
510
619
|
|
|
620
|
+
##### `with` <a name="with" id="@pwrdrvr/microapps-cdk.MicroAppsEdgeToOrigin.with"></a>
|
|
621
|
+
|
|
622
|
+
```typescript
|
|
623
|
+
public with(mixins: ...IMixin[]): IConstruct
|
|
624
|
+
```
|
|
625
|
+
|
|
626
|
+
Applies one or more mixins to this construct.
|
|
627
|
+
|
|
628
|
+
Mixins are applied in order. The list of constructs is captured at the
|
|
629
|
+
start of the call, so constructs added by a mixin will not be visited.
|
|
630
|
+
Use multiple `with()` calls if subsequent mixins should apply to added
|
|
631
|
+
constructs.
|
|
632
|
+
|
|
633
|
+
###### `mixins`<sup>Required</sup> <a name="mixins" id="@pwrdrvr/microapps-cdk.MicroAppsEdgeToOrigin.with.parameter.mixins"></a>
|
|
634
|
+
|
|
635
|
+
- *Type:* ...constructs.IMixin[]
|
|
636
|
+
|
|
637
|
+
The mixins to apply.
|
|
638
|
+
|
|
639
|
+
---
|
|
640
|
+
|
|
511
641
|
#### Static Functions <a name="Static Functions" id="Static Functions"></a>
|
|
512
642
|
|
|
513
643
|
| **Name** | **Description** |
|
|
@@ -517,7 +647,7 @@ Returns a string representation of this construct.
|
|
|
517
647
|
|
|
518
648
|
---
|
|
519
649
|
|
|
520
|
-
#####
|
|
650
|
+
##### `isConstruct` <a name="isConstruct" id="@pwrdrvr/microapps-cdk.MicroAppsEdgeToOrigin.isConstruct"></a>
|
|
521
651
|
|
|
522
652
|
```typescript
|
|
523
653
|
import { MicroAppsEdgeToOrigin } from '@pwrdrvr/microapps-cdk'
|
|
@@ -527,6 +657,20 @@ MicroAppsEdgeToOrigin.isConstruct(x: any)
|
|
|
527
657
|
|
|
528
658
|
Checks if `x` is a construct.
|
|
529
659
|
|
|
660
|
+
Use this method instead of `instanceof` to properly detect `Construct`
|
|
661
|
+
instances, even when the construct library is symlinked.
|
|
662
|
+
|
|
663
|
+
Explanation: in JavaScript, multiple copies of the `constructs` library on
|
|
664
|
+
disk are seen as independent, completely different libraries. As a
|
|
665
|
+
consequence, the class `Construct` in each copy of the `constructs` library
|
|
666
|
+
is seen as a different class, and an instance of one class will not test as
|
|
667
|
+
`instanceof` the other class. `npm install` will not create installations
|
|
668
|
+
like this, but users may manually symlink construct libraries together or
|
|
669
|
+
use a monorepo tool: in those cases, multiple copies of the `constructs`
|
|
670
|
+
library can be accidentally installed, and `instanceof` will behave
|
|
671
|
+
unpredictably. It is safest to avoid using `instanceof`, and using
|
|
672
|
+
this type-testing method instead.
|
|
673
|
+
|
|
530
674
|
###### `x`<sup>Required</sup> <a name="x" id="@pwrdrvr/microapps-cdk.MicroAppsEdgeToOrigin.isConstruct.parameter.x"></a>
|
|
531
675
|
|
|
532
676
|
- *Type:* any
|
|
@@ -661,6 +805,7 @@ new MicroAppsS3(scope: Construct, id: string, props?: MicroAppsS3Props)
|
|
|
661
805
|
| **Name** | **Description** |
|
|
662
806
|
| --- | --- |
|
|
663
807
|
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsS3.toString">toString</a></code> | Returns a string representation of this construct. |
|
|
808
|
+
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsS3.with">with</a></code> | Applies one or more mixins to this construct. |
|
|
664
809
|
|
|
665
810
|
---
|
|
666
811
|
|
|
@@ -672,6 +817,27 @@ public toString(): string
|
|
|
672
817
|
|
|
673
818
|
Returns a string representation of this construct.
|
|
674
819
|
|
|
820
|
+
##### `with` <a name="with" id="@pwrdrvr/microapps-cdk.MicroAppsS3.with"></a>
|
|
821
|
+
|
|
822
|
+
```typescript
|
|
823
|
+
public with(mixins: ...IMixin[]): IConstruct
|
|
824
|
+
```
|
|
825
|
+
|
|
826
|
+
Applies one or more mixins to this construct.
|
|
827
|
+
|
|
828
|
+
Mixins are applied in order. The list of constructs is captured at the
|
|
829
|
+
start of the call, so constructs added by a mixin will not be visited.
|
|
830
|
+
Use multiple `with()` calls if subsequent mixins should apply to added
|
|
831
|
+
constructs.
|
|
832
|
+
|
|
833
|
+
###### `mixins`<sup>Required</sup> <a name="mixins" id="@pwrdrvr/microapps-cdk.MicroAppsS3.with.parameter.mixins"></a>
|
|
834
|
+
|
|
835
|
+
- *Type:* ...constructs.IMixin[]
|
|
836
|
+
|
|
837
|
+
The mixins to apply.
|
|
838
|
+
|
|
839
|
+
---
|
|
840
|
+
|
|
675
841
|
#### Static Functions <a name="Static Functions" id="Static Functions"></a>
|
|
676
842
|
|
|
677
843
|
| **Name** | **Description** |
|
|
@@ -680,7 +846,7 @@ Returns a string representation of this construct.
|
|
|
680
846
|
|
|
681
847
|
---
|
|
682
848
|
|
|
683
|
-
#####
|
|
849
|
+
##### `isConstruct` <a name="isConstruct" id="@pwrdrvr/microapps-cdk.MicroAppsS3.isConstruct"></a>
|
|
684
850
|
|
|
685
851
|
```typescript
|
|
686
852
|
import { MicroAppsS3 } from '@pwrdrvr/microapps-cdk'
|
|
@@ -690,6 +856,20 @@ MicroAppsS3.isConstruct(x: any)
|
|
|
690
856
|
|
|
691
857
|
Checks if `x` is a construct.
|
|
692
858
|
|
|
859
|
+
Use this method instead of `instanceof` to properly detect `Construct`
|
|
860
|
+
instances, even when the construct library is symlinked.
|
|
861
|
+
|
|
862
|
+
Explanation: in JavaScript, multiple copies of the `constructs` library on
|
|
863
|
+
disk are seen as independent, completely different libraries. As a
|
|
864
|
+
consequence, the class `Construct` in each copy of the `constructs` library
|
|
865
|
+
is seen as a different class, and an instance of one class will not test as
|
|
866
|
+
`instanceof` the other class. `npm install` will not create installations
|
|
867
|
+
like this, but users may manually symlink construct libraries together or
|
|
868
|
+
use a monorepo tool: in those cases, multiple copies of the `constructs`
|
|
869
|
+
library can be accidentally installed, and `instanceof` will behave
|
|
870
|
+
unpredictably. It is safest to avoid using `instanceof`, and using
|
|
871
|
+
this type-testing method instead.
|
|
872
|
+
|
|
693
873
|
###### `x`<sup>Required</sup> <a name="x" id="@pwrdrvr/microapps-cdk.MicroAppsS3.isConstruct.parameter.x"></a>
|
|
694
874
|
|
|
695
875
|
- *Type:* any
|
|
@@ -705,8 +885,8 @@ Any object.
|
|
|
705
885
|
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsS3.property.node">node</a></code> | <code>constructs.Node</code> | The tree node. |
|
|
706
886
|
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsS3.property.bucketApps">bucketApps</a></code> | <code>aws-cdk-lib.aws_s3.IBucket</code> | S3 bucket for deployed applications. |
|
|
707
887
|
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsS3.property.bucketAppsOAI">bucketAppsOAI</a></code> | <code>aws-cdk-lib.aws_cloudfront.OriginAccessIdentity</code> | CloudFront Origin Access Identity for the deployed applications bucket. |
|
|
708
|
-
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsS3.property.bucketAppsOriginApp">bucketAppsOriginApp</a></code> | <code>aws-cdk-lib.
|
|
709
|
-
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsS3.property.bucketAppsOriginS3">bucketAppsOriginS3</a></code> | <code>aws-cdk-lib.
|
|
888
|
+
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsS3.property.bucketAppsOriginApp">bucketAppsOriginApp</a></code> | <code>aws-cdk-lib.aws_cloudfront.IOrigin</code> | CloudFront Origin for the deployed applications bucket Marked with `x-microapps-origin: app` so the OriginRequest function knows to send the request to the application origin first, if configured for a particular application. |
|
|
889
|
+
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsS3.property.bucketAppsOriginS3">bucketAppsOriginS3</a></code> | <code>aws-cdk-lib.aws_cloudfront.IOrigin</code> | CloudFront Origin for the deployed applications bucket Marked with `x-microapps-origin: s3` so the OriginRequest function knows to NOT send the request to the application origin and instead let it fall through to the S3 bucket. |
|
|
710
890
|
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsS3.property.bucketAppsStaging">bucketAppsStaging</a></code> | <code>aws-cdk-lib.aws_s3.IBucket</code> | S3 bucket for staged applications (prior to deploy). |
|
|
711
891
|
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsS3.property.bucketLogs">bucketLogs</a></code> | <code>aws-cdk-lib.aws_s3.IBucket</code> | S3 bucket for CloudFront logs. |
|
|
712
892
|
|
|
@@ -751,10 +931,10 @@ CloudFront Origin Access Identity for the deployed applications bucket.
|
|
|
751
931
|
##### `bucketAppsOriginApp`<sup>Required</sup> <a name="bucketAppsOriginApp" id="@pwrdrvr/microapps-cdk.MicroAppsS3.property.bucketAppsOriginApp"></a>
|
|
752
932
|
|
|
753
933
|
```typescript
|
|
754
|
-
public readonly bucketAppsOriginApp:
|
|
934
|
+
public readonly bucketAppsOriginApp: IOrigin;
|
|
755
935
|
```
|
|
756
936
|
|
|
757
|
-
- *Type:* aws-cdk-lib.
|
|
937
|
+
- *Type:* aws-cdk-lib.aws_cloudfront.IOrigin
|
|
758
938
|
|
|
759
939
|
CloudFront Origin for the deployed applications bucket Marked with `x-microapps-origin: app` so the OriginRequest function knows to send the request to the application origin first, if configured for a particular application.
|
|
760
940
|
|
|
@@ -763,10 +943,10 @@ CloudFront Origin for the deployed applications bucket Marked with `x-microapps-
|
|
|
763
943
|
##### `bucketAppsOriginS3`<sup>Required</sup> <a name="bucketAppsOriginS3" id="@pwrdrvr/microapps-cdk.MicroAppsS3.property.bucketAppsOriginS3"></a>
|
|
764
944
|
|
|
765
945
|
```typescript
|
|
766
|
-
public readonly bucketAppsOriginS3:
|
|
946
|
+
public readonly bucketAppsOriginS3: IOrigin;
|
|
767
947
|
```
|
|
768
948
|
|
|
769
|
-
- *Type:* aws-cdk-lib.
|
|
949
|
+
- *Type:* aws-cdk-lib.aws_cloudfront.IOrigin
|
|
770
950
|
|
|
771
951
|
CloudFront Origin for the deployed applications bucket Marked with `x-microapps-origin: s3` so the OriginRequest function knows to NOT send the request to the application origin and instead let it fall through to the S3 bucket.
|
|
772
952
|
|
|
@@ -842,6 +1022,7 @@ new MicroAppsSvcs(scope: Construct, id: string, props?: MicroAppsSvcsProps)
|
|
|
842
1022
|
| **Name** | **Description** |
|
|
843
1023
|
| --- | --- |
|
|
844
1024
|
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsSvcs.toString">toString</a></code> | Returns a string representation of this construct. |
|
|
1025
|
+
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsSvcs.with">with</a></code> | Applies one or more mixins to this construct. |
|
|
845
1026
|
|
|
846
1027
|
---
|
|
847
1028
|
|
|
@@ -853,6 +1034,27 @@ public toString(): string
|
|
|
853
1034
|
|
|
854
1035
|
Returns a string representation of this construct.
|
|
855
1036
|
|
|
1037
|
+
##### `with` <a name="with" id="@pwrdrvr/microapps-cdk.MicroAppsSvcs.with"></a>
|
|
1038
|
+
|
|
1039
|
+
```typescript
|
|
1040
|
+
public with(mixins: ...IMixin[]): IConstruct
|
|
1041
|
+
```
|
|
1042
|
+
|
|
1043
|
+
Applies one or more mixins to this construct.
|
|
1044
|
+
|
|
1045
|
+
Mixins are applied in order. The list of constructs is captured at the
|
|
1046
|
+
start of the call, so constructs added by a mixin will not be visited.
|
|
1047
|
+
Use multiple `with()` calls if subsequent mixins should apply to added
|
|
1048
|
+
constructs.
|
|
1049
|
+
|
|
1050
|
+
###### `mixins`<sup>Required</sup> <a name="mixins" id="@pwrdrvr/microapps-cdk.MicroAppsSvcs.with.parameter.mixins"></a>
|
|
1051
|
+
|
|
1052
|
+
- *Type:* ...constructs.IMixin[]
|
|
1053
|
+
|
|
1054
|
+
The mixins to apply.
|
|
1055
|
+
|
|
1056
|
+
---
|
|
1057
|
+
|
|
856
1058
|
#### Static Functions <a name="Static Functions" id="Static Functions"></a>
|
|
857
1059
|
|
|
858
1060
|
| **Name** | **Description** |
|
|
@@ -861,7 +1063,7 @@ Returns a string representation of this construct.
|
|
|
861
1063
|
|
|
862
1064
|
---
|
|
863
1065
|
|
|
864
|
-
#####
|
|
1066
|
+
##### `isConstruct` <a name="isConstruct" id="@pwrdrvr/microapps-cdk.MicroAppsSvcs.isConstruct"></a>
|
|
865
1067
|
|
|
866
1068
|
```typescript
|
|
867
1069
|
import { MicroAppsSvcs } from '@pwrdrvr/microapps-cdk'
|
|
@@ -871,6 +1073,20 @@ MicroAppsSvcs.isConstruct(x: any)
|
|
|
871
1073
|
|
|
872
1074
|
Checks if `x` is a construct.
|
|
873
1075
|
|
|
1076
|
+
Use this method instead of `instanceof` to properly detect `Construct`
|
|
1077
|
+
instances, even when the construct library is symlinked.
|
|
1078
|
+
|
|
1079
|
+
Explanation: in JavaScript, multiple copies of the `constructs` library on
|
|
1080
|
+
disk are seen as independent, completely different libraries. As a
|
|
1081
|
+
consequence, the class `Construct` in each copy of the `constructs` library
|
|
1082
|
+
is seen as a different class, and an instance of one class will not test as
|
|
1083
|
+
`instanceof` the other class. `npm install` will not create installations
|
|
1084
|
+
like this, but users may manually symlink construct libraries together or
|
|
1085
|
+
use a monorepo tool: in those cases, multiple copies of the `constructs`
|
|
1086
|
+
library can be accidentally installed, and `instanceof` will behave
|
|
1087
|
+
unpredictably. It is safest to avoid using `instanceof`, and using
|
|
1088
|
+
this type-testing method instead.
|
|
1089
|
+
|
|
874
1090
|
###### `x`<sup>Required</sup> <a name="x" id="@pwrdrvr/microapps-cdk.MicroAppsSvcs.isConstruct.parameter.x"></a>
|
|
875
1091
|
|
|
876
1092
|
- *Type:* any
|
|
@@ -984,6 +1200,7 @@ new MicroAppsTable(scope: Construct, id: string, props?: MicroAppsTableProps)
|
|
|
984
1200
|
| **Name** | **Description** |
|
|
985
1201
|
| --- | --- |
|
|
986
1202
|
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsTable.toString">toString</a></code> | Returns a string representation of this construct. |
|
|
1203
|
+
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsTable.with">with</a></code> | Applies one or more mixins to this construct. |
|
|
987
1204
|
|
|
988
1205
|
---
|
|
989
1206
|
|
|
@@ -995,6 +1212,27 @@ public toString(): string
|
|
|
995
1212
|
|
|
996
1213
|
Returns a string representation of this construct.
|
|
997
1214
|
|
|
1215
|
+
##### `with` <a name="with" id="@pwrdrvr/microapps-cdk.MicroAppsTable.with"></a>
|
|
1216
|
+
|
|
1217
|
+
```typescript
|
|
1218
|
+
public with(mixins: ...IMixin[]): IConstruct
|
|
1219
|
+
```
|
|
1220
|
+
|
|
1221
|
+
Applies one or more mixins to this construct.
|
|
1222
|
+
|
|
1223
|
+
Mixins are applied in order. The list of constructs is captured at the
|
|
1224
|
+
start of the call, so constructs added by a mixin will not be visited.
|
|
1225
|
+
Use multiple `with()` calls if subsequent mixins should apply to added
|
|
1226
|
+
constructs.
|
|
1227
|
+
|
|
1228
|
+
###### `mixins`<sup>Required</sup> <a name="mixins" id="@pwrdrvr/microapps-cdk.MicroAppsTable.with.parameter.mixins"></a>
|
|
1229
|
+
|
|
1230
|
+
- *Type:* ...constructs.IMixin[]
|
|
1231
|
+
|
|
1232
|
+
The mixins to apply.
|
|
1233
|
+
|
|
1234
|
+
---
|
|
1235
|
+
|
|
998
1236
|
#### Static Functions <a name="Static Functions" id="Static Functions"></a>
|
|
999
1237
|
|
|
1000
1238
|
| **Name** | **Description** |
|
|
@@ -1003,7 +1241,7 @@ Returns a string representation of this construct.
|
|
|
1003
1241
|
|
|
1004
1242
|
---
|
|
1005
1243
|
|
|
1006
|
-
#####
|
|
1244
|
+
##### `isConstruct` <a name="isConstruct" id="@pwrdrvr/microapps-cdk.MicroAppsTable.isConstruct"></a>
|
|
1007
1245
|
|
|
1008
1246
|
```typescript
|
|
1009
1247
|
import { MicroAppsTable } from '@pwrdrvr/microapps-cdk'
|
|
@@ -1013,6 +1251,20 @@ MicroAppsTable.isConstruct(x: any)
|
|
|
1013
1251
|
|
|
1014
1252
|
Checks if `x` is a construct.
|
|
1015
1253
|
|
|
1254
|
+
Use this method instead of `instanceof` to properly detect `Construct`
|
|
1255
|
+
instances, even when the construct library is symlinked.
|
|
1256
|
+
|
|
1257
|
+
Explanation: in JavaScript, multiple copies of the `constructs` library on
|
|
1258
|
+
disk are seen as independent, completely different libraries. As a
|
|
1259
|
+
consequence, the class `Construct` in each copy of the `constructs` library
|
|
1260
|
+
is seen as a different class, and an instance of one class will not test as
|
|
1261
|
+
`instanceof` the other class. `npm install` will not create installations
|
|
1262
|
+
like this, but users may manually symlink construct libraries together or
|
|
1263
|
+
use a monorepo tool: in those cases, multiple copies of the `constructs`
|
|
1264
|
+
library can be accidentally installed, and `instanceof` will behave
|
|
1265
|
+
unpredictably. It is safest to avoid using `instanceof`, and using
|
|
1266
|
+
this type-testing method instead.
|
|
1267
|
+
|
|
1016
1268
|
###### `x`<sup>Required</sup> <a name="x" id="@pwrdrvr/microapps-cdk.MicroAppsTable.isConstruct.parameter.x"></a>
|
|
1017
1269
|
|
|
1018
1270
|
- *Type:* any
|
|
@@ -1375,8 +1627,8 @@ const microAppsCFProps: MicroAppsCFProps = { ... }
|
|
|
1375
1627
|
|
|
1376
1628
|
| **Name** | **Type** | **Description** |
|
|
1377
1629
|
| --- | --- | --- |
|
|
1378
|
-
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsCFProps.property.bucketAppsOriginApp">bucketAppsOriginApp</a></code> | <code>aws-cdk-lib.
|
|
1379
|
-
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsCFProps.property.bucketAppsOriginS3">bucketAppsOriginS3</a></code> | <code>aws-cdk-lib.
|
|
1630
|
+
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsCFProps.property.bucketAppsOriginApp">bucketAppsOriginApp</a></code> | <code>aws-cdk-lib.aws_cloudfront.IOrigin</code> | S3 bucket origin for deployed applications Marked with `x-microapps-origin: app`. |
|
|
1631
|
+
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsCFProps.property.bucketAppsOriginS3">bucketAppsOriginS3</a></code> | <code>aws-cdk-lib.aws_cloudfront.IOrigin</code> | S3 bucket origin for deployed applications Marked with `x-microapps-origin: s3`. |
|
|
1380
1632
|
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsCFProps.property.assetNameRoot">assetNameRoot</a></code> | <code>string</code> | Optional asset name root. |
|
|
1381
1633
|
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsCFProps.property.assetNameSuffix">assetNameSuffix</a></code> | <code>string</code> | Optional asset name suffix. |
|
|
1382
1634
|
| <code><a href="#@pwrdrvr/microapps-cdk.MicroAppsCFProps.property.bucketLogs">bucketLogs</a></code> | <code>aws-cdk-lib.aws_s3.IBucket</code> | S3 bucket for CloudFront logs. |
|
|
@@ -1396,10 +1648,10 @@ const microAppsCFProps: MicroAppsCFProps = { ... }
|
|
|
1396
1648
|
##### `bucketAppsOriginApp`<sup>Required</sup> <a name="bucketAppsOriginApp" id="@pwrdrvr/microapps-cdk.MicroAppsCFProps.property.bucketAppsOriginApp"></a>
|
|
1397
1649
|
|
|
1398
1650
|
```typescript
|
|
1399
|
-
public readonly bucketAppsOriginApp:
|
|
1651
|
+
public readonly bucketAppsOriginApp: IOrigin;
|
|
1400
1652
|
```
|
|
1401
1653
|
|
|
1402
|
-
- *Type:* aws-cdk-lib.
|
|
1654
|
+
- *Type:* aws-cdk-lib.aws_cloudfront.IOrigin
|
|
1403
1655
|
|
|
1404
1656
|
S3 bucket origin for deployed applications Marked with `x-microapps-origin: app`.
|
|
1405
1657
|
|
|
@@ -1408,10 +1660,10 @@ S3 bucket origin for deployed applications Marked with `x-microapps-origin: app`
|
|
|
1408
1660
|
##### `bucketAppsOriginS3`<sup>Required</sup> <a name="bucketAppsOriginS3" id="@pwrdrvr/microapps-cdk.MicroAppsCFProps.property.bucketAppsOriginS3"></a>
|
|
1409
1661
|
|
|
1410
1662
|
```typescript
|
|
1411
|
-
public readonly bucketAppsOriginS3:
|
|
1663
|
+
public readonly bucketAppsOriginS3: IOrigin;
|
|
1412
1664
|
```
|
|
1413
1665
|
|
|
1414
|
-
- *Type:* aws-cdk-lib.
|
|
1666
|
+
- *Type:* aws-cdk-lib.aws_cloudfront.IOrigin
|
|
1415
1667
|
|
|
1416
1668
|
S3 bucket origin for deployed applications Marked with `x-microapps-origin: s3`.
|
|
1417
1669
|
|
|
@@ -3247,8 +3499,8 @@ Represents a MicroApps S3.
|
|
|
3247
3499
|
| --- | --- | --- |
|
|
3248
3500
|
| <code><a href="#@pwrdrvr/microapps-cdk.IMicroAppsS3.property.bucketApps">bucketApps</a></code> | <code>aws-cdk-lib.aws_s3.IBucket</code> | S3 bucket for deployed applications. |
|
|
3249
3501
|
| <code><a href="#@pwrdrvr/microapps-cdk.IMicroAppsS3.property.bucketAppsOAI">bucketAppsOAI</a></code> | <code>aws-cdk-lib.aws_cloudfront.OriginAccessIdentity</code> | CloudFront Origin Access Identity for the deployed applications bucket. |
|
|
3250
|
-
| <code><a href="#@pwrdrvr/microapps-cdk.IMicroAppsS3.property.bucketAppsOriginApp">bucketAppsOriginApp</a></code> | <code>aws-cdk-lib.
|
|
3251
|
-
| <code><a href="#@pwrdrvr/microapps-cdk.IMicroAppsS3.property.bucketAppsOriginS3">bucketAppsOriginS3</a></code> | <code>aws-cdk-lib.
|
|
3502
|
+
| <code><a href="#@pwrdrvr/microapps-cdk.IMicroAppsS3.property.bucketAppsOriginApp">bucketAppsOriginApp</a></code> | <code>aws-cdk-lib.aws_cloudfront.IOrigin</code> | CloudFront Origin for the deployed applications bucket Marked with `x-microapps-origin: app` so the OriginRequest function knows to send the request to the application origin first, if configured for a particular application. |
|
|
3503
|
+
| <code><a href="#@pwrdrvr/microapps-cdk.IMicroAppsS3.property.bucketAppsOriginS3">bucketAppsOriginS3</a></code> | <code>aws-cdk-lib.aws_cloudfront.IOrigin</code> | CloudFront Origin for the deployed applications bucket Marked with `x-microapps-origin: s3` so the OriginRequest function knows to NOT send the request to the application origin and instead let it fall through to the S3 bucket. |
|
|
3252
3504
|
| <code><a href="#@pwrdrvr/microapps-cdk.IMicroAppsS3.property.bucketAppsStaging">bucketAppsStaging</a></code> | <code>aws-cdk-lib.aws_s3.IBucket</code> | S3 bucket for staged applications (prior to deploy). |
|
|
3253
3505
|
| <code><a href="#@pwrdrvr/microapps-cdk.IMicroAppsS3.property.bucketLogs">bucketLogs</a></code> | <code>aws-cdk-lib.aws_s3.IBucket</code> | S3 bucket for CloudFront logs. |
|
|
3254
3506
|
|
|
@@ -3281,10 +3533,10 @@ CloudFront Origin Access Identity for the deployed applications bucket.
|
|
|
3281
3533
|
##### `bucketAppsOriginApp`<sup>Required</sup> <a name="bucketAppsOriginApp" id="@pwrdrvr/microapps-cdk.IMicroAppsS3.property.bucketAppsOriginApp"></a>
|
|
3282
3534
|
|
|
3283
3535
|
```typescript
|
|
3284
|
-
public readonly bucketAppsOriginApp:
|
|
3536
|
+
public readonly bucketAppsOriginApp: IOrigin;
|
|
3285
3537
|
```
|
|
3286
3538
|
|
|
3287
|
-
- *Type:* aws-cdk-lib.
|
|
3539
|
+
- *Type:* aws-cdk-lib.aws_cloudfront.IOrigin
|
|
3288
3540
|
|
|
3289
3541
|
CloudFront Origin for the deployed applications bucket Marked with `x-microapps-origin: app` so the OriginRequest function knows to send the request to the application origin first, if configured for a particular application.
|
|
3290
3542
|
|
|
@@ -3293,10 +3545,10 @@ CloudFront Origin for the deployed applications bucket Marked with `x-microapps-
|
|
|
3293
3545
|
##### `bucketAppsOriginS3`<sup>Required</sup> <a name="bucketAppsOriginS3" id="@pwrdrvr/microapps-cdk.IMicroAppsS3.property.bucketAppsOriginS3"></a>
|
|
3294
3546
|
|
|
3295
3547
|
```typescript
|
|
3296
|
-
public readonly bucketAppsOriginS3:
|
|
3548
|
+
public readonly bucketAppsOriginS3: IOrigin;
|
|
3297
3549
|
```
|
|
3298
3550
|
|
|
3299
|
-
- *Type:* aws-cdk-lib.
|
|
3551
|
+
- *Type:* aws-cdk-lib.aws_cloudfront.IOrigin
|
|
3300
3552
|
|
|
3301
3553
|
CloudFront Origin for the deployed applications bucket Marked with `x-microapps-origin: s3` so the OriginRequest function knows to NOT send the request to the application origin and instead let it fall through to the S3 bucket.
|
|
3302
3554
|
|
package/lib/MicroApps.js
CHANGED
|
@@ -118,5 +118,5 @@ class MicroApps extends constructs_1.Construct {
|
|
|
118
118
|
}
|
|
119
119
|
exports.MicroApps = MicroApps;
|
|
120
120
|
_a = JSII_RTTI_SYMBOL_1;
|
|
121
|
-
MicroApps[_a] = { fqn: "@pwrdrvr/microapps-cdk.MicroApps", version: "1.2.0-beta.
|
|
121
|
+
MicroApps[_a] = { fqn: "@pwrdrvr/microapps-cdk.MicroApps", version: "1.2.0-beta.8" };
|
|
122
122
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MicroApps.js","sourceRoot":"","sources":["../src/MicroApps.ts"],"names":[],"mappings":"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","sourcesContent":["import { RemovalPolicy } from 'aws-cdk-lib';\nimport * as acm from 'aws-cdk-lib/aws-certificatemanager';\nimport * as cf from 'aws-cdk-lib/aws-cloudfront';\nimport * as dynamodb from 'aws-cdk-lib/aws-dynamodb';\nimport * as r53 from 'aws-cdk-lib/aws-route53';\nimport { Construct } from 'constructs';\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 API Gateway for non-edge invocation\n   *\n   * @default false\n   */\n  readonly createAPIGateway?: boolean;\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   * Create an extra Behavior (Route) for /_next/data/\n   * This route is used by Next.js to load data from the API Gateway\n   * on `getServerSideProps` calls.  The requests can end in `.json`,\n   * which would cause them to be routed to S3 if this route is not created.\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 /_next/data/ 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 createNextDataPathRoute?: 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 or Lambda function 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   * Optional Origin Shield Region\n   *\n   * This should be the region where the DynamoDB is located so the\n   * EdgeToOrigin calls have the lowest latency (~1 ms).\n   *\n   * @default originRegion if specified, otherwise undefined\n   */\n  readonly originShieldRegion?: 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 | dynamodb.ITableV2;\n\n  /**\n   * Pre-set table name for apps/versions/rules\n   *\n   * This is required when using v2 routing\n   */\n  readonly tableNameForEdgeToOrigin?: string;\n\n  /**\n   * Additional edge lambda functions\n   */\n  readonly edgeLambdas?: cf.EdgeLambda[];\n\n  /**\n   * Account IDs allowed for cross-account Function URL invocations\n   *\n   * @default []\n   */\n  readonly allowedFunctionUrlAccounts?: string[];\n\n  /**\n   * List of allowed locale prefixes for pages\n   *\n   * @example: ['en', 'fr', 'es']\n   * @default none\n   */\n  readonly allowedLocalePrefixes?: string[];\n\n  /**\n   * Additional IAM Role ARNs that should be allowed to invoke apps in child accounts\n   */\n  readonly edgeToOriginRoleARNs?: string[];\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\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 _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      removalPolicy,\n      s3PolicyBypassAROAs,\n      s3PolicyBypassPrincipalARNs,\n      s3StrictBucketPolicy,\n      rootPathPrefix,\n      createAPIGateway = false,\n      createAPIPathRoute = true,\n      createNextDataPathRoute = true,\n      addXForwardedHostHeader = true,\n      replaceHostHeader = true,\n      signingMode = 'sign',\n      originRegion,\n      table,\n      tableNameForEdgeToOrigin,\n      originShieldRegion = originRegion,\n      allowedFunctionUrlAccounts = [],\n      edgeToOriginRoleARNs = [],\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      originShieldRegion,\n    });\n    this._svcs = new MicroAppsSvcs(this, 'svcs', {\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      edgeToOriginRoleARN: edgeToOriginRoleARNs,\n    });\n    const edgeLambdas: cf.EdgeLambda[] = [];\n\n    if (signingMode !== 'none' || replaceHostHeader || addXForwardedHostHeader) {\n      this._edgeToOrigin = new MicroAppsEdgeToOrigin(this, 'edgeToOrigin', {\n        assetNameRoot,\n        assetNameSuffix,\n        removalPolicy,\n        addXForwardedHostHeader,\n        setupApiGatewayPermissions: createAPIGateway,\n        replaceHostHeader,\n        originRegion,\n        signingMode,\n        rootPathPrefix,\n        tableRulesArn: tableNameForEdgeToOrigin || this._svcs.table.tableName,\n        allowedFunctionUrlAccounts,\n        allowedLocalePrefixes: props.allowedLocalePrefixes,\n      });\n\n      edgeLambdas.push(...this._edgeToOrigin.edgeToOriginLambdas);\n    }\n    // Add any extra lambdas\n    if (props.edgeLambdas?.length) {\n      edgeLambdas.push(...props.edgeLambdas);\n    }\n    this._cf = new MicroAppsCF(this, 'cft', {\n      removalPolicy,\n      assetNameRoot,\n      assetNameSuffix,\n      domainNameEdge,\n      domainNameOrigin,\n      r53Zone,\n      certEdge,\n      bucketAppsOriginS3: this._s3.bucketAppsOriginS3,\n      bucketAppsOriginApp: this._s3.bucketAppsOriginApp,\n      bucketLogs: this._s3.bucketLogs,\n      rootPathPrefix,\n      createAPIPathRoute,\n      createNextDataPathRoute,\n      originShieldRegion,\n      ...(edgeLambdas.length ? { edgeLambdas } : {}),\n    });\n  }\n}\n"]}
|
package/lib/MicroAppsCF.d.ts
CHANGED
|
@@ -30,12 +30,12 @@ export interface MicroAppsCFProps {
|
|
|
30
30
|
* S3 bucket origin for deployed applications
|
|
31
31
|
* Marked with `x-microapps-origin: s3`
|
|
32
32
|
*/
|
|
33
|
-
readonly bucketAppsOriginS3:
|
|
33
|
+
readonly bucketAppsOriginS3: cf.IOrigin;
|
|
34
34
|
/**
|
|
35
35
|
* S3 bucket origin for deployed applications
|
|
36
36
|
* Marked with `x-microapps-origin: app`
|
|
37
37
|
*/
|
|
38
|
-
readonly bucketAppsOriginApp:
|
|
38
|
+
readonly bucketAppsOriginApp: cf.IOrigin;
|
|
39
39
|
/**
|
|
40
40
|
* S3 bucket for CloudFront logs
|
|
41
41
|
*/
|