@pwrdrvr/microapps-cdk 0.2.5 → 0.2.9
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 +119 -119
- package/README.md +282 -135
- package/lib/MicroApps.d.ts +51 -51
- package/lib/MicroApps.js +12 -12
- package/lib/MicroAppsAPIGwy.d.ts +31 -31
- package/lib/MicroAppsAPIGwy.js +12 -11
- package/lib/MicroAppsCF.d.ts +59 -59
- package/lib/MicroAppsCF.js +9 -9
- package/lib/MicroAppsS3.d.ts +39 -39
- package/lib/MicroAppsS3.js +14 -14
- package/lib/MicroAppsSvcs.d.ts +43 -43
- package/lib/MicroAppsSvcs.js +10 -10
- package/package.json +2 -2
package/lib/MicroAppsS3.d.ts
CHANGED
|
@@ -4,93 +4,93 @@ import * as cforigins from 'aws-cdk-lib/aws-cloudfront-origins';
|
|
|
4
4
|
import * as s3 from 'aws-cdk-lib/aws-s3';
|
|
5
5
|
import { Construct } from 'constructs';
|
|
6
6
|
/**
|
|
7
|
-
* Represents a MicroApps S3.
|
|
7
|
+
* (experimental) Represents a MicroApps S3.
|
|
8
8
|
*
|
|
9
|
-
* @
|
|
9
|
+
* @experimental
|
|
10
10
|
*/
|
|
11
11
|
export interface IMicroAppsS3 {
|
|
12
12
|
/**
|
|
13
|
-
* S3 bucket for deployed applications.
|
|
13
|
+
* (experimental) S3 bucket for deployed applications.
|
|
14
14
|
*
|
|
15
|
-
* @
|
|
15
|
+
* @experimental
|
|
16
16
|
*/
|
|
17
17
|
readonly bucketApps: s3.IBucket;
|
|
18
18
|
/**
|
|
19
|
-
* CloudFront Origin Access Identity for the deployed applications bucket.
|
|
19
|
+
* (experimental) CloudFront Origin Access Identity for the deployed applications bucket.
|
|
20
20
|
*
|
|
21
|
-
* @
|
|
21
|
+
* @experimental
|
|
22
22
|
*/
|
|
23
23
|
readonly bucketAppsOAI: cf.OriginAccessIdentity;
|
|
24
24
|
/**
|
|
25
|
-
* CloudFront Origin for the deployed applications bucket.
|
|
25
|
+
* (experimental) CloudFront Origin for the deployed applications bucket.
|
|
26
26
|
*
|
|
27
|
-
* @
|
|
27
|
+
* @experimental
|
|
28
28
|
*/
|
|
29
29
|
readonly bucketAppsOrigin: cforigins.S3Origin;
|
|
30
30
|
/**
|
|
31
|
-
* S3 bucket for staged applications (prior to deploy).
|
|
31
|
+
* (experimental) S3 bucket for staged applications (prior to deploy).
|
|
32
32
|
*
|
|
33
|
-
* @
|
|
33
|
+
* @experimental
|
|
34
34
|
*/
|
|
35
35
|
readonly bucketAppsStaging: s3.IBucket;
|
|
36
36
|
/**
|
|
37
|
-
* S3 bucket for CloudFront logs.
|
|
37
|
+
* (experimental) S3 bucket for CloudFront logs.
|
|
38
38
|
*
|
|
39
|
-
* @
|
|
39
|
+
* @experimental
|
|
40
40
|
*/
|
|
41
41
|
readonly bucketLogs: s3.IBucket;
|
|
42
42
|
}
|
|
43
43
|
/**
|
|
44
|
-
* Properties to initialize an instance of `MicroAppsS3`.
|
|
44
|
+
* (experimental) Properties to initialize an instance of `MicroAppsS3`.
|
|
45
45
|
*
|
|
46
|
-
* @
|
|
46
|
+
* @experimental
|
|
47
47
|
*/
|
|
48
48
|
export interface MicroAppsS3Props {
|
|
49
49
|
/**
|
|
50
|
-
* RemovalPolicy override for child resources.
|
|
50
|
+
* (experimental) RemovalPolicy override for child resources.
|
|
51
51
|
*
|
|
52
52
|
* Note: if set to DESTROY the S3 buckets will have `autoDeleteObjects` set to `true`
|
|
53
53
|
*
|
|
54
54
|
* @default - per resource default
|
|
55
|
-
* @
|
|
55
|
+
* @experimental
|
|
56
56
|
*/
|
|
57
57
|
readonly removalPolicy?: RemovalPolicy;
|
|
58
58
|
/**
|
|
59
|
-
* S3 deployed apps bucket name.
|
|
59
|
+
* (experimental) S3 deployed apps bucket name.
|
|
60
60
|
*
|
|
61
61
|
* @default auto-assigned
|
|
62
|
-
* @
|
|
62
|
+
* @experimental
|
|
63
63
|
*/
|
|
64
64
|
readonly bucketAppsName?: string;
|
|
65
65
|
/**
|
|
66
|
-
* S3 staging apps bucket name.
|
|
66
|
+
* (experimental) S3 staging apps bucket name.
|
|
67
67
|
*
|
|
68
68
|
* @default auto-assigned
|
|
69
|
-
* @
|
|
69
|
+
* @experimental
|
|
70
70
|
*/
|
|
71
71
|
readonly bucketAppsStagingName?: string;
|
|
72
72
|
/**
|
|
73
|
-
* S3 logs bucket name.
|
|
73
|
+
* (experimental) S3 logs bucket name.
|
|
74
74
|
*
|
|
75
75
|
* @default auto-assigned
|
|
76
|
-
* @
|
|
76
|
+
* @experimental
|
|
77
77
|
*/
|
|
78
78
|
readonly bucketLogsName?: string;
|
|
79
79
|
/**
|
|
80
|
-
* Optional asset name root.
|
|
80
|
+
* (experimental) Optional asset name root.
|
|
81
81
|
*
|
|
82
82
|
* @default - resource names auto assigned
|
|
83
|
-
* @
|
|
83
|
+
* @experimental
|
|
84
84
|
* @example
|
|
85
85
|
*
|
|
86
86
|
* microapps
|
|
87
87
|
*/
|
|
88
88
|
readonly assetNameRoot?: string;
|
|
89
89
|
/**
|
|
90
|
-
* Optional asset name suffix.
|
|
90
|
+
* (experimental) Optional asset name suffix.
|
|
91
91
|
*
|
|
92
92
|
* @default none
|
|
93
|
-
* @
|
|
93
|
+
* @experimental
|
|
94
94
|
* @example
|
|
95
95
|
*
|
|
96
96
|
* -dev-pr-12
|
|
@@ -98,48 +98,48 @@ export interface MicroAppsS3Props {
|
|
|
98
98
|
readonly assetNameSuffix?: string;
|
|
99
99
|
}
|
|
100
100
|
/**
|
|
101
|
-
* Create a new MicroApps S3 Bucket.
|
|
101
|
+
* (experimental) Create a new MicroApps S3 Bucket.
|
|
102
102
|
*
|
|
103
|
-
* @
|
|
103
|
+
* @experimental
|
|
104
104
|
*/
|
|
105
105
|
export declare class MicroAppsS3 extends Construct implements IMicroAppsS3 {
|
|
106
106
|
private _bucketApps;
|
|
107
107
|
/**
|
|
108
|
-
* S3 bucket for deployed applications.
|
|
108
|
+
* (experimental) S3 bucket for deployed applications.
|
|
109
109
|
*
|
|
110
|
-
* @
|
|
110
|
+
* @experimental
|
|
111
111
|
*/
|
|
112
112
|
get bucketApps(): s3.IBucket;
|
|
113
113
|
private _bucketAppsOAI;
|
|
114
114
|
/**
|
|
115
|
-
* CloudFront Origin Access Identity for the deployed applications bucket.
|
|
115
|
+
* (experimental) CloudFront Origin Access Identity for the deployed applications bucket.
|
|
116
116
|
*
|
|
117
|
-
* @
|
|
117
|
+
* @experimental
|
|
118
118
|
*/
|
|
119
119
|
get bucketAppsOAI(): cf.OriginAccessIdentity;
|
|
120
120
|
private _bucketAppsOrigin;
|
|
121
121
|
/**
|
|
122
|
-
* CloudFront Origin for the deployed applications bucket.
|
|
122
|
+
* (experimental) CloudFront Origin for the deployed applications bucket.
|
|
123
123
|
*
|
|
124
|
-
* @
|
|
124
|
+
* @experimental
|
|
125
125
|
*/
|
|
126
126
|
get bucketAppsOrigin(): cforigins.S3Origin;
|
|
127
127
|
private _bucketAppsStaging;
|
|
128
128
|
/**
|
|
129
|
-
* S3 bucket for staged applications (prior to deploy).
|
|
129
|
+
* (experimental) S3 bucket for staged applications (prior to deploy).
|
|
130
130
|
*
|
|
131
|
-
* @
|
|
131
|
+
* @experimental
|
|
132
132
|
*/
|
|
133
133
|
get bucketAppsStaging(): s3.IBucket;
|
|
134
134
|
private _bucketLogs;
|
|
135
135
|
/**
|
|
136
|
-
* S3 bucket for CloudFront logs.
|
|
136
|
+
* (experimental) S3 bucket for CloudFront logs.
|
|
137
137
|
*
|
|
138
|
-
* @
|
|
138
|
+
* @experimental
|
|
139
139
|
*/
|
|
140
140
|
get bucketLogs(): s3.IBucket;
|
|
141
141
|
/**
|
|
142
|
-
* @
|
|
142
|
+
* @experimental
|
|
143
143
|
*/
|
|
144
144
|
constructor(scope: Construct, id: string, props?: MicroAppsS3Props);
|
|
145
145
|
}
|
package/lib/MicroAppsS3.js
CHANGED
|
@@ -9,13 +9,13 @@ const cforigins = require("aws-cdk-lib/aws-cloudfront-origins");
|
|
|
9
9
|
const s3 = require("aws-cdk-lib/aws-s3");
|
|
10
10
|
const constructs_1 = require("constructs");
|
|
11
11
|
/**
|
|
12
|
-
* Create a new MicroApps S3 Bucket.
|
|
12
|
+
* (experimental) Create a new MicroApps S3 Bucket.
|
|
13
13
|
*
|
|
14
|
-
* @
|
|
14
|
+
* @experimental
|
|
15
15
|
*/
|
|
16
16
|
class MicroAppsS3 extends constructs_1.Construct {
|
|
17
17
|
/**
|
|
18
|
-
* @
|
|
18
|
+
* @experimental
|
|
19
19
|
*/
|
|
20
20
|
constructor(scope, id, props) {
|
|
21
21
|
super(scope, id);
|
|
@@ -59,41 +59,41 @@ class MicroAppsS3 extends constructs_1.Construct {
|
|
|
59
59
|
});
|
|
60
60
|
}
|
|
61
61
|
/**
|
|
62
|
-
* S3 bucket for deployed applications.
|
|
62
|
+
* (experimental) S3 bucket for deployed applications.
|
|
63
63
|
*
|
|
64
|
-
* @
|
|
64
|
+
* @experimental
|
|
65
65
|
*/
|
|
66
66
|
get bucketApps() {
|
|
67
67
|
return this._bucketApps;
|
|
68
68
|
}
|
|
69
69
|
/**
|
|
70
|
-
* CloudFront Origin Access Identity for the deployed applications bucket.
|
|
70
|
+
* (experimental) CloudFront Origin Access Identity for the deployed applications bucket.
|
|
71
71
|
*
|
|
72
|
-
* @
|
|
72
|
+
* @experimental
|
|
73
73
|
*/
|
|
74
74
|
get bucketAppsOAI() {
|
|
75
75
|
return this._bucketAppsOAI;
|
|
76
76
|
}
|
|
77
77
|
/**
|
|
78
|
-
* CloudFront Origin for the deployed applications bucket.
|
|
78
|
+
* (experimental) CloudFront Origin for the deployed applications bucket.
|
|
79
79
|
*
|
|
80
|
-
* @
|
|
80
|
+
* @experimental
|
|
81
81
|
*/
|
|
82
82
|
get bucketAppsOrigin() {
|
|
83
83
|
return this._bucketAppsOrigin;
|
|
84
84
|
}
|
|
85
85
|
/**
|
|
86
|
-
* S3 bucket for staged applications (prior to deploy).
|
|
86
|
+
* (experimental) S3 bucket for staged applications (prior to deploy).
|
|
87
87
|
*
|
|
88
|
-
* @
|
|
88
|
+
* @experimental
|
|
89
89
|
*/
|
|
90
90
|
get bucketAppsStaging() {
|
|
91
91
|
return this._bucketAppsStaging;
|
|
92
92
|
}
|
|
93
93
|
/**
|
|
94
|
-
* S3 bucket for CloudFront logs.
|
|
94
|
+
* (experimental) S3 bucket for CloudFront logs.
|
|
95
95
|
*
|
|
96
|
-
* @
|
|
96
|
+
* @experimental
|
|
97
97
|
*/
|
|
98
98
|
get bucketLogs() {
|
|
99
99
|
return this._bucketLogs;
|
|
@@ -101,5 +101,5 @@ class MicroAppsS3 extends constructs_1.Construct {
|
|
|
101
101
|
}
|
|
102
102
|
exports.MicroAppsS3 = MicroAppsS3;
|
|
103
103
|
_a = JSII_RTTI_SYMBOL_1;
|
|
104
|
-
MicroAppsS3[_a] = { fqn: "@pwrdrvr/microapps-cdk.MicroAppsS3", version: "0.2.
|
|
104
|
+
MicroAppsS3[_a] = { fqn: "@pwrdrvr/microapps-cdk.MicroAppsS3", version: "0.2.9" };
|
|
105
105
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTWljcm9BcHBzUzMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvTWljcm9BcHBzUzMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSw2Q0FBNEM7QUFDNUMsaURBQWlEO0FBQ2pELGdFQUFnRTtBQUNoRSx5Q0FBeUM7QUFDekMsMkNBQXVDOzs7Ozs7QUEwQ3ZDLE1BQWEsV0FBWSxTQUFRLHNCQUFTOzs7O0lBMEJ4QyxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQXdCO1FBQ2hFLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsSUFBSSxLQUFLLEtBQUssU0FBUyxFQUFFO1lBQ3ZCLE1BQU0sSUFBSSxLQUFLLENBQUMsbUJBQW1CLENBQUMsQ0FBQztTQUN0QztRQUVELE1BQU0sRUFBRSxhQUFhLEVBQUUsYUFBYSxFQUFFLGVBQWUsRUFBRSxHQUFHLEtBQUssQ0FBQztRQUVoRSx3REFBd0Q7UUFDeEQsTUFBTSxpQkFBaUIsR0FBRyxhQUFhLEtBQUssMkJBQWEsQ0FBQyxPQUFPLENBQUM7UUFFbEUsRUFBRTtRQUNGLGdEQUFnRDtRQUNoRCxFQUFFO1FBQ0YsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLEVBQUUsQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLE1BQU0sRUFBRTtZQUM3QyxVQUFVLEVBQUUsS0FBSyxDQUFDLGNBQWM7WUFDaEMsaUJBQWlCLEVBQUUsaUJBQWlCO1lBQ3BDLGFBQWE7U0FDZCxDQUFDLENBQUM7UUFFSCxFQUFFO1FBQ0Ysc0JBQXNCO1FBQ3RCLEVBQUU7UUFDRixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksRUFBRSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsTUFBTSxFQUFFO1lBQzdDLFVBQVUsRUFBRSxLQUFLLENBQUMsY0FBYztZQUNoQyxpQkFBaUIsRUFBRSxpQkFBaUI7WUFDcEMsYUFBYTtTQUNkLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxrQkFBa0IsR0FBRyxJQUFJLEVBQUUsQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRTtZQUN2RCxVQUFVLEVBQUUsS0FBSyxDQUFDLHFCQUFxQjtZQUN2QyxpQkFBaUIsRUFBRSxpQkFBaUI7WUFDcEMsYUFBYTtTQUNkLENBQUMsQ0FBQztRQUVILDRCQUE0QjtRQUM1QixJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksRUFBRSxDQUFDLG9CQUFvQixDQUFDLElBQUksRUFBRSxLQUFLLEVBQUU7WUFDN0QsT0FBTyxFQUFFLGFBQWEsS0FBSyxTQUFTLENBQUMsQ0FBQyxDQUFDLEdBQUcsYUFBYSxHQUFHLGVBQWUsRUFBRSxDQUFDLENBQUMsQ0FBQyxTQUFTO1NBQ3hGLENBQUMsQ0FBQztRQUNILElBQUksYUFBYSxLQUFLLFNBQVMsRUFBRTtZQUMvQixJQUFJLENBQUMsY0FBYyxDQUFDLGtCQUFrQixDQUFDLGFBQWEsQ0FBQyxDQUFDO1NBQ3ZEO1FBRUQsNEJBQTRCO1FBQzVCLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxJQUFJLFNBQVMsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNoRSxvQkFBb0IsRUFBRSxJQUFJLENBQUMsYUFBYTtTQUN6QyxDQUFDLENBQUM7SUFDTCxDQUFDOzs7Ozs7SUF2RUQsSUFBVyxVQUFVO1FBQ25CLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUMxQixDQUFDOzs7Ozs7SUFHRCxJQUFXLGFBQWE7UUFDdEIsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDO0lBQzdCLENBQUM7Ozs7OztJQUdELElBQVcsZ0JBQWdCO1FBQ3pCLE9BQU8sSUFBSSxDQUFDLGlCQUFpQixDQUFDO0lBQ2hDLENBQUM7Ozs7OztJQUdELElBQVcsaUJBQWlCO1FBQzFCLE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDO0lBQ2pDLENBQUM7Ozs7OztJQUdELElBQVcsVUFBVTtRQUNuQixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDMUIsQ0FBQzs7QUF4Qkgsa0NBMEVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmVtb3ZhbFBvbGljeSB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGNmIGZyb20gJ2F3cy1jZGstbGliL2F3cy1jbG91ZGZyb250JztcbmltcG9ydCAqIGFzIGNmb3JpZ2lucyBmcm9tICdhd3MtY2RrLWxpYi9hd3MtY2xvdWRmcm9udC1vcmlnaW5zJztcbmltcG9ydCAqIGFzIHMzIGZyb20gJ2F3cy1jZGstbGliL2F3cy1zMyc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG5leHBvcnQgaW50ZXJmYWNlIElNaWNyb0FwcHNTMyB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IGJ1Y2tldEFwcHM6IHMzLklCdWNrZXQ7XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICByZWFkb25seSBidWNrZXRBcHBzT0FJOiBjZi5PcmlnaW5BY2Nlc3NJZGVudGl0eTtcblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbiAgcmVhZG9ubHkgYnVja2V0QXBwc09yaWdpbjogY2ZvcmlnaW5zLlMzT3JpZ2luO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICByZWFkb25seSBidWNrZXRBcHBzU3RhZ2luZzogczMuSUJ1Y2tldDtcblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICByZWFkb25seSBidWNrZXRMb2dzOiBzMy5JQnVja2V0O1xufVxuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuZXhwb3J0IGludGVyZmFjZSBNaWNyb0FwcHNTM1Byb3BzIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IHJlbW92YWxQb2xpY3k/OiBSZW1vdmFsUG9saWN5O1xuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbiAgcmVhZG9ubHkgYnVja2V0QXBwc05hbWU/OiBzdHJpbmc7XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IGJ1Y2tldEFwcHNTdGFnaW5nTmFtZT86IHN0cmluZztcblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IGJ1Y2tldExvZ3NOYW1lPzogc3RyaW5nO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IGFzc2V0TmFtZVJvb3Q/OiBzdHJpbmc7XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IGFzc2V0TmFtZVN1ZmZpeD86IHN0cmluZztcbn1cblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbmV4cG9ydCBjbGFzcyBNaWNyb0FwcHNTMyBleHRlbmRzIENvbnN0cnVjdCBpbXBsZW1lbnRzIElNaWNyb0FwcHNTMyB7XG4gIHByaXZhdGUgX2J1Y2tldEFwcHM6IHMzLklCdWNrZXQ7XG4gIHB1YmxpYyBnZXQgYnVja2V0QXBwcygpOiBzMy5JQnVja2V0IHtcbiAgICByZXR1cm4gdGhpcy5fYnVja2V0QXBwcztcbiAgfVxuXG4gIHByaXZhdGUgX2J1Y2tldEFwcHNPQUk6IGNmLk9yaWdpbkFjY2Vzc0lkZW50aXR5O1xuICBwdWJsaWMgZ2V0IGJ1Y2tldEFwcHNPQUkoKTogY2YuT3JpZ2luQWNjZXNzSWRlbnRpdHkge1xuICAgIHJldHVybiB0aGlzLl9idWNrZXRBcHBzT0FJO1xuICB9XG5cbiAgcHJpdmF0ZSBfYnVja2V0QXBwc09yaWdpbjogY2ZvcmlnaW5zLlMzT3JpZ2luO1xuICBwdWJsaWMgZ2V0IGJ1Y2tldEFwcHNPcmlnaW4oKTogY2ZvcmlnaW5zLlMzT3JpZ2luIHtcbiAgICByZXR1cm4gdGhpcy5fYnVja2V0QXBwc09yaWdpbjtcbiAgfVxuXG4gIHByaXZhdGUgX2J1Y2tldEFwcHNTdGFnaW5nOiBzMy5JQnVja2V0O1xuICBwdWJsaWMgZ2V0IGJ1Y2tldEFwcHNTdGFnaW5nKCk6IHMzLklCdWNrZXQge1xuICAgIHJldHVybiB0aGlzLl9idWNrZXRBcHBzU3RhZ2luZztcbiAgfVxuXG4gIHByaXZhdGUgX2J1Y2tldExvZ3M6IHMzLklCdWNrZXQ7XG4gIHB1YmxpYyBnZXQgYnVja2V0TG9ncygpOiBzMy5JQnVja2V0IHtcbiAgICByZXR1cm4gdGhpcy5fYnVja2V0TG9ncztcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzPzogTWljcm9BcHBzUzNQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICBpZiAocHJvcHMgPT09IHVuZGVmaW5lZCkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdwcm9wcyBtdXN0IGJlIHNldCcpO1xuICAgIH1cblxuICAgIGNvbnN0IHsgcmVtb3ZhbFBvbGljeSwgYXNzZXROYW1lUm9vdCwgYXNzZXROYW1lU3VmZml4IH0gPSBwcm9wcztcblxuICAgIC8vIFVzZSBBdXRvLURlbGV0ZSBTM0J1Y2tldCBpZiByZW1vdmFsIHBvbGljeSBpcyBERVNUUk9ZXG4gICAgY29uc3QgczNBdXRvRGVsZXRlSXRlbXMgPSByZW1vdmFsUG9saWN5ID09PSBSZW1vdmFsUG9saWN5LkRFU1RST1k7XG5cbiAgICAvL1xuICAgIC8vIFMzIEJ1Y2tldCBmb3IgTG9nZ2luZyAtIFVzYWJsZSBieSBtYW55IHN0YWNrc1xuICAgIC8vXG4gICAgdGhpcy5fYnVja2V0TG9ncyA9IG5ldyBzMy5CdWNrZXQodGhpcywgJ2xvZ3MnLCB7XG4gICAgICBidWNrZXROYW1lOiBwcm9wcy5idWNrZXRMb2dzTmFtZSxcbiAgICAgIGF1dG9EZWxldGVPYmplY3RzOiBzM0F1dG9EZWxldGVJdGVtcyxcbiAgICAgIHJlbW92YWxQb2xpY3ksXG4gICAgfSk7XG5cbiAgICAvL1xuICAgIC8vIFMzIEJ1Y2tldHMgZm9yIEFwcHNcbiAgICAvL1xuICAgIHRoaXMuX2J1Y2tldEFwcHMgPSBuZXcgczMuQnVja2V0KHRoaXMsICdhcHBzJywge1xuICAgICAgYnVja2V0TmFtZTogcHJvcHMuYnVja2V0QXBwc05hbWUsXG4gICAgICBhdXRvRGVsZXRlT2JqZWN0czogczNBdXRvRGVsZXRlSXRlbXMsXG4gICAgICByZW1vdmFsUG9saWN5LFxuICAgIH0pO1xuICAgIHRoaXMuX2J1Y2tldEFwcHNTdGFnaW5nID0gbmV3IHMzLkJ1Y2tldCh0aGlzLCAnc3RhZ2luZycsIHtcbiAgICAgIGJ1Y2tldE5hbWU6IHByb3BzLmJ1Y2tldEFwcHNTdGFnaW5nTmFtZSxcbiAgICAgIGF1dG9EZWxldGVPYmplY3RzOiBzM0F1dG9EZWxldGVJdGVtcyxcbiAgICAgIHJlbW92YWxQb2xpY3ksXG4gICAgfSk7XG5cbiAgICAvLyBDcmVhdGUgUzMgT3JpZ2luIElkZW50aXR5XG4gICAgdGhpcy5fYnVja2V0QXBwc09BSSA9IG5ldyBjZi5PcmlnaW5BY2Nlc3NJZGVudGl0eSh0aGlzLCAnb2FpJywge1xuICAgICAgY29tbWVudDogYXNzZXROYW1lUm9vdCAhPT0gdW5kZWZpbmVkID8gYCR7YXNzZXROYW1lUm9vdH0ke2Fzc2V0TmFtZVN1ZmZpeH1gIDogdW5kZWZpbmVkLFxuICAgIH0pO1xuICAgIGlmIChyZW1vdmFsUG9saWN5ICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIHRoaXMuX2J1Y2tldEFwcHNPQUkuYXBwbHlSZW1vdmFsUG9saWN5KHJlbW92YWxQb2xpY3kpO1xuICAgIH1cblxuICAgIC8vIEFkZCBPcmlnaW4gZm9yIENsb3VkRnJvbnRcbiAgICB0aGlzLl9idWNrZXRBcHBzT3JpZ2luID0gbmV3IGNmb3JpZ2lucy5TM09yaWdpbih0aGlzLl9idWNrZXRBcHBzLCB7XG4gICAgICBvcmlnaW5BY2Nlc3NJZGVudGl0eTogdGhpcy5idWNrZXRBcHBzT0FJLFxuICAgIH0pO1xuICB9XG59XG4iXX0=
|
package/lib/MicroAppsSvcs.d.ts
CHANGED
|
@@ -6,82 +6,82 @@ import * as lambda from 'aws-cdk-lib/aws-lambda';
|
|
|
6
6
|
import * as s3 from 'aws-cdk-lib/aws-s3';
|
|
7
7
|
import { Construct } from 'constructs';
|
|
8
8
|
/**
|
|
9
|
-
* Properties to initialize an instance of `MicroAppsSvcs`.
|
|
9
|
+
* (experimental) Properties to initialize an instance of `MicroAppsSvcs`.
|
|
10
10
|
*
|
|
11
|
-
* @
|
|
11
|
+
* @experimental
|
|
12
12
|
*/
|
|
13
13
|
export interface MicroAppsSvcsProps {
|
|
14
14
|
/**
|
|
15
|
-
* RemovalPolicy override for child resources.
|
|
15
|
+
* (experimental) RemovalPolicy override for child resources.
|
|
16
16
|
*
|
|
17
17
|
* Note: if set to DESTROY the S3 buckes will have `autoDeleteObjects` set to `true`
|
|
18
18
|
*
|
|
19
19
|
* @default - per resource default
|
|
20
|
-
* @
|
|
20
|
+
* @experimental
|
|
21
21
|
*/
|
|
22
22
|
readonly removalPolicy?: RemovalPolicy;
|
|
23
23
|
/**
|
|
24
|
-
* S3 bucket for deployed applications.
|
|
24
|
+
* (experimental) S3 bucket for deployed applications.
|
|
25
25
|
*
|
|
26
|
-
* @
|
|
26
|
+
* @experimental
|
|
27
27
|
*/
|
|
28
28
|
readonly bucketApps: s3.IBucket;
|
|
29
29
|
/**
|
|
30
|
-
* CloudFront Origin Access Identity for the deployed applications bucket.
|
|
30
|
+
* (experimental) CloudFront Origin Access Identity for the deployed applications bucket.
|
|
31
31
|
*
|
|
32
|
-
* @
|
|
32
|
+
* @experimental
|
|
33
33
|
*/
|
|
34
34
|
readonly bucketAppsOAI: cf.OriginAccessIdentity;
|
|
35
35
|
/**
|
|
36
|
-
* S3 bucket for staged applications (prior to deploy).
|
|
36
|
+
* (experimental) S3 bucket for staged applications (prior to deploy).
|
|
37
37
|
*
|
|
38
|
-
* @
|
|
38
|
+
* @experimental
|
|
39
39
|
*/
|
|
40
40
|
readonly bucketAppsStaging: s3.IBucket;
|
|
41
41
|
/**
|
|
42
|
-
* API Gateway v2 HTTP for Router and app.
|
|
42
|
+
* (experimental) API Gateway v2 HTTP for Router and app.
|
|
43
43
|
*
|
|
44
|
-
* @
|
|
44
|
+
* @experimental
|
|
45
45
|
*/
|
|
46
46
|
readonly httpApi: apigwy.HttpApi;
|
|
47
47
|
/**
|
|
48
|
-
* Application environment, passed as `NODE_ENV` to the Router and Deployer Lambda functions.
|
|
48
|
+
* (experimental) Application environment, passed as `NODE_ENV` to the Router and Deployer Lambda functions.
|
|
49
49
|
*
|
|
50
|
-
* @
|
|
50
|
+
* @experimental
|
|
51
51
|
*/
|
|
52
52
|
readonly appEnv: string;
|
|
53
53
|
/**
|
|
54
|
-
* Optional asset name root.
|
|
54
|
+
* (experimental) Optional asset name root.
|
|
55
55
|
*
|
|
56
56
|
* @default - resource names auto assigned
|
|
57
|
-
* @
|
|
57
|
+
* @experimental
|
|
58
58
|
* @example
|
|
59
59
|
*
|
|
60
60
|
* microapps
|
|
61
61
|
*/
|
|
62
62
|
readonly assetNameRoot?: string;
|
|
63
63
|
/**
|
|
64
|
-
* Optional asset name suffix.
|
|
64
|
+
* (experimental) Optional asset name suffix.
|
|
65
65
|
*
|
|
66
66
|
* @default none
|
|
67
|
-
* @
|
|
67
|
+
* @experimental
|
|
68
68
|
* @example
|
|
69
69
|
*
|
|
70
70
|
* -dev-pr-12
|
|
71
71
|
*/
|
|
72
72
|
readonly assetNameSuffix?: string;
|
|
73
73
|
/**
|
|
74
|
-
* 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.
|
|
74
|
+
* (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.
|
|
75
75
|
*
|
|
76
76
|
* This setting should be used when applications are less than
|
|
77
77
|
* fully trusted.
|
|
78
78
|
*
|
|
79
79
|
* @default false
|
|
80
|
-
* @
|
|
80
|
+
* @experimental
|
|
81
81
|
*/
|
|
82
82
|
readonly s3StrictBucketPolicy?: boolean;
|
|
83
83
|
/**
|
|
84
|
-
* Applies when using s3StrictBucketPolicy = true.
|
|
84
|
+
* (experimental) Applies when using s3StrictBucketPolicy = true.
|
|
85
85
|
*
|
|
86
86
|
* IAM Role or IAM User names to exclude from the DENY rules on the S3 Bucket Policy.
|
|
87
87
|
*
|
|
@@ -91,14 +91,14 @@ export interface MicroAppsSvcsProps {
|
|
|
91
91
|
* would be added to this list.
|
|
92
92
|
*
|
|
93
93
|
* @see s3PolicyBypassAROAs
|
|
94
|
-
* @
|
|
94
|
+
* @experimental
|
|
95
95
|
* @example
|
|
96
96
|
*
|
|
97
97
|
* ['arn:aws:iam::1234567890123:role/AdminAccess', 'arn:aws:iam::1234567890123:user/MyAdminUser']
|
|
98
98
|
*/
|
|
99
99
|
readonly s3PolicyBypassPrincipalARNs?: string[];
|
|
100
100
|
/**
|
|
101
|
-
* Applies when using s3StrictBucketPolicy = true.
|
|
101
|
+
* (experimental) Applies when using s3StrictBucketPolicy = true.
|
|
102
102
|
*
|
|
103
103
|
* AROAs of the IAM Role to exclude from the DENY rules on the S3 Bucket Policy.
|
|
104
104
|
* This allows sessions that assume the IAM Role to be excluded from the
|
|
@@ -135,17 +135,17 @@ export interface MicroAppsSvcsProps {
|
|
|
135
135
|
* aws iam get-user -–user-name USER-NAME
|
|
136
136
|
*
|
|
137
137
|
* @see s3StrictBucketPolicy
|
|
138
|
-
* @
|
|
138
|
+
* @experimental
|
|
139
139
|
* @example
|
|
140
140
|
*
|
|
141
141
|
* [ 'AROA1234567890123' ]
|
|
142
142
|
*/
|
|
143
143
|
readonly s3PolicyBypassAROAs?: string[];
|
|
144
144
|
/**
|
|
145
|
-
* Path prefix on the root of the deployment.
|
|
145
|
+
* (experimental) Path prefix on the root of the deployment.
|
|
146
146
|
*
|
|
147
147
|
* @default none
|
|
148
|
-
* @
|
|
148
|
+
* @experimental
|
|
149
149
|
* @example
|
|
150
150
|
*
|
|
151
151
|
* dev/
|
|
@@ -153,59 +153,59 @@ export interface MicroAppsSvcsProps {
|
|
|
153
153
|
readonly rootPathPrefix?: string;
|
|
154
154
|
}
|
|
155
155
|
/**
|
|
156
|
-
* Represents a MicroApps Services.
|
|
156
|
+
* (experimental) Represents a MicroApps Services.
|
|
157
157
|
*
|
|
158
|
-
* @
|
|
158
|
+
* @experimental
|
|
159
159
|
*/
|
|
160
160
|
export interface IMicroAppsSvcs {
|
|
161
161
|
/**
|
|
162
|
-
* DynamoDB table used by Router, Deployer, and Release console app.
|
|
162
|
+
* (experimental) DynamoDB table used by Router, Deployer, and Release console app.
|
|
163
163
|
*
|
|
164
|
-
* @
|
|
164
|
+
* @experimental
|
|
165
165
|
*/
|
|
166
166
|
readonly table: dynamodb.ITable;
|
|
167
167
|
/**
|
|
168
|
-
* Lambda function for the Deployer.
|
|
168
|
+
* (experimental) Lambda function for the Deployer.
|
|
169
169
|
*
|
|
170
|
-
* @
|
|
170
|
+
* @experimental
|
|
171
171
|
*/
|
|
172
172
|
readonly deployerFunc: lambda.IFunction;
|
|
173
173
|
/**
|
|
174
|
-
* Lambda function for the Router.
|
|
174
|
+
* (experimental) Lambda function for the Router.
|
|
175
175
|
*
|
|
176
|
-
* @
|
|
176
|
+
* @experimental
|
|
177
177
|
*/
|
|
178
178
|
readonly routerFunc: lambda.IFunction;
|
|
179
179
|
}
|
|
180
180
|
/**
|
|
181
|
-
* Create a new MicroApps Services construct, including the Deployer and Router Lambda Functions, and the DynamoDB Table used by both.
|
|
181
|
+
* (experimental) Create a new MicroApps Services construct, including the Deployer and Router Lambda Functions, and the DynamoDB Table used by both.
|
|
182
182
|
*
|
|
183
|
-
* @
|
|
183
|
+
* @experimental
|
|
184
184
|
*/
|
|
185
185
|
export declare class MicroAppsSvcs extends Construct implements IMicroAppsSvcs {
|
|
186
186
|
private _table;
|
|
187
187
|
/**
|
|
188
|
-
* DynamoDB table used by Router, Deployer, and Release console app.
|
|
188
|
+
* (experimental) DynamoDB table used by Router, Deployer, and Release console app.
|
|
189
189
|
*
|
|
190
|
-
* @
|
|
190
|
+
* @experimental
|
|
191
191
|
*/
|
|
192
192
|
get table(): dynamodb.ITable;
|
|
193
193
|
private _deployerFunc;
|
|
194
194
|
/**
|
|
195
|
-
* Lambda function for the Deployer.
|
|
195
|
+
* (experimental) Lambda function for the Deployer.
|
|
196
196
|
*
|
|
197
|
-
* @
|
|
197
|
+
* @experimental
|
|
198
198
|
*/
|
|
199
199
|
get deployerFunc(): lambda.IFunction;
|
|
200
200
|
private _routerFunc;
|
|
201
201
|
/**
|
|
202
|
-
* Lambda function for the Router.
|
|
202
|
+
* (experimental) Lambda function for the Router.
|
|
203
203
|
*
|
|
204
|
-
* @
|
|
204
|
+
* @experimental
|
|
205
205
|
*/
|
|
206
206
|
get routerFunc(): lambda.IFunction;
|
|
207
207
|
/**
|
|
208
|
-
* @
|
|
208
|
+
* @experimental
|
|
209
209
|
*/
|
|
210
210
|
constructor(scope: Construct, id: string, props?: MicroAppsSvcsProps);
|
|
211
211
|
}
|
package/lib/MicroAppsSvcs.js
CHANGED
|
@@ -48,13 +48,13 @@ class HttpRouteIntegration extends apigwy.HttpRouteIntegration {
|
|
|
48
48
|
}
|
|
49
49
|
}
|
|
50
50
|
/**
|
|
51
|
-
* Create a new MicroApps Services construct, including the Deployer and Router Lambda Functions, and the DynamoDB Table used by both.
|
|
51
|
+
* (experimental) Create a new MicroApps Services construct, including the Deployer and Router Lambda Functions, and the DynamoDB Table used by both.
|
|
52
52
|
*
|
|
53
|
-
* @
|
|
53
|
+
* @experimental
|
|
54
54
|
*/
|
|
55
55
|
class MicroAppsSvcs extends constructs_1.Construct {
|
|
56
56
|
/**
|
|
57
|
-
* @
|
|
57
|
+
* @experimental
|
|
58
58
|
*/
|
|
59
59
|
constructor(scope, id, props) {
|
|
60
60
|
var _b;
|
|
@@ -448,25 +448,25 @@ class MicroAppsSvcs extends constructs_1.Construct {
|
|
|
448
448
|
});
|
|
449
449
|
}
|
|
450
450
|
/**
|
|
451
|
-
* DynamoDB table used by Router, Deployer, and Release console app.
|
|
451
|
+
* (experimental) DynamoDB table used by Router, Deployer, and Release console app.
|
|
452
452
|
*
|
|
453
|
-
* @
|
|
453
|
+
* @experimental
|
|
454
454
|
*/
|
|
455
455
|
get table() {
|
|
456
456
|
return this._table;
|
|
457
457
|
}
|
|
458
458
|
/**
|
|
459
|
-
* Lambda function for the Deployer.
|
|
459
|
+
* (experimental) Lambda function for the Deployer.
|
|
460
460
|
*
|
|
461
|
-
* @
|
|
461
|
+
* @experimental
|
|
462
462
|
*/
|
|
463
463
|
get deployerFunc() {
|
|
464
464
|
return this._deployerFunc;
|
|
465
465
|
}
|
|
466
466
|
/**
|
|
467
|
-
* Lambda function for the Router.
|
|
467
|
+
* (experimental) Lambda function for the Router.
|
|
468
468
|
*
|
|
469
|
-
* @
|
|
469
|
+
* @experimental
|
|
470
470
|
*/
|
|
471
471
|
get routerFunc() {
|
|
472
472
|
return this._routerFunc;
|
|
@@ -474,5 +474,5 @@ class MicroAppsSvcs extends constructs_1.Construct {
|
|
|
474
474
|
}
|
|
475
475
|
exports.MicroAppsSvcs = MicroAppsSvcs;
|
|
476
476
|
_a = JSII_RTTI_SYMBOL_1;
|
|
477
|
-
MicroAppsSvcs[_a] = { fqn: "@pwrdrvr/microapps-cdk.MicroAppsSvcs", version: "0.2.
|
|
477
|
+
MicroAppsSvcs[_a] = { fqn: "@pwrdrvr/microapps-cdk.MicroAppsSvcs", version: "0.2.9" };
|
|
478
478
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MicroAppsSvcs.js","sourceRoot":"","sources":["../src/MicroAppsSvcs.ts"],"names":[],"mappings":"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","sourcesContent":["import { existsSync } from 'fs';\nimport * as path from 'path';\nimport * as apigwy from '@aws-cdk/aws-apigatewayv2-alpha';\nimport { Aws, Duration, RemovalPolicy, Stack } from 'aws-cdk-lib';\nimport * as cf from 'aws-cdk-lib/aws-cloudfront';\nimport * as dynamodb from 'aws-cdk-lib/aws-dynamodb';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as lambdaNodejs from 'aws-cdk-lib/aws-lambda-nodejs';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport { Construct } from 'constructs';\n\n/**\n * Class missing from `@aws-cdk/aws-apigatewayv2-alpha`.\n */\nclass HttpRouteIntegration extends apigwy.HttpRouteIntegration {\n  private httpIntegrationProps?: apigwy.HttpIntegrationProps;\n\n  constructor(\n    id: string,\n    opts: { integration?: apigwy.HttpIntegration; integrationProps?: apigwy.HttpIntegrationProps },\n  ) {\n    super(id);\n    this.httpIntegrationProps = opts.integrationProps;\n    this.integration = opts.integration;\n  }\n\n  /**\n   * (experimental) Bind this integration to the route.\n   *\n   * @experimental\n   */\n  public bind(_options: apigwy.HttpRouteIntegrationBindOptions): apigwy.HttpRouteIntegrationConfig {\n    if (this.httpIntegrationProps === undefined) {\n      throw new TypeError('bind called without IntegrationProps defined');\n    }\n\n    return {\n      type: this.httpIntegrationProps.integrationType,\n      payloadFormatVersion:\n        this.httpIntegrationProps.payloadFormatVersion ?? apigwy.PayloadFormatVersion.VERSION_2_0,\n      connectionType: this.httpIntegrationProps.connectionType,\n      connectionId: this.httpIntegrationProps.connectionId,\n      credentials: this.httpIntegrationProps.credentials,\n      method: this.httpIntegrationProps.method,\n      parameterMapping: this.httpIntegrationProps.parameterMapping,\n      secureServerName: this.httpIntegrationProps.secureServerName,\n      subtype: this.httpIntegrationProps.integrationSubtype,\n      uri: this.httpIntegrationProps.integrationUri,\n    };\n  }\n}\n\n                                                                   \nexport interface MicroAppsSvcsProps {\n                                                                                                                                                                                                 \n  readonly removalPolicy?: RemovalPolicy;\n\n                                                    \n  readonly bucketApps: s3.IBucket;\n\n                                                                                       \n  readonly bucketAppsOAI: cf.OriginAccessIdentity;\n\n                                                                    \n  readonly bucketAppsStaging: s3.IBucket;\n\n                                                       \n  readonly httpApi: apigwy.HttpApi;\n\n                                                                                                               \n  readonly appEnv: string;\n\n                                                                                                                   \n  readonly assetNameRoot?: string;\n\n                                                                                            \n  readonly assetNameSuffix?: string;\n\n                                                                                                                                                                                                                                                                                                                                \n  readonly s3StrictBucketPolicy?: boolean;\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       \n  readonly s3PolicyBypassPrincipalARNs?: string[];\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     \n  readonly s3PolicyBypassAROAs?: string[];\n\n                                                                                                     \n  readonly rootPathPrefix?: string;\n}\n\n                                          \nexport interface IMicroAppsSvcs {\n                                                                                 \n  readonly table: dynamodb.ITable;\n\n                                                 \n  readonly deployerFunc: lambda.IFunction;\n\n                                               \n  readonly routerFunc: lambda.IFunction;\n}\n\n                                                                                                                                                 \nexport class MicroAppsSvcs extends Construct implements IMicroAppsSvcs {\n  private _table: dynamodb.Table;\n  public get table(): dynamodb.ITable {\n    return this._table;\n  }\n\n  private _deployerFunc: lambda.Function;\n  public get deployerFunc(): lambda.IFunction {\n    return this._deployerFunc;\n  }\n\n  private _routerFunc: lambda.Function;\n  public get routerFunc(): lambda.IFunction {\n    return this._routerFunc;\n  }\n\n  constructor(scope: Construct, id: string, props?: MicroAppsSvcsProps) {\n    super(scope, id);\n\n    if (props === undefined) {\n      throw new Error('props cannot be undefined');\n    }\n\n    const {\n      bucketApps,\n      bucketAppsOAI,\n      bucketAppsStaging,\n      s3PolicyBypassAROAs = [],\n      s3PolicyBypassPrincipalARNs = [],\n      s3StrictBucketPolicy = false,\n      appEnv,\n      httpApi,\n      removalPolicy,\n      assetNameRoot,\n      assetNameSuffix,\n      rootPathPrefix = '',\n    } = props;\n\n    if (s3StrictBucketPolicy === true) {\n      if (s3PolicyBypassAROAs.length === 0 && s3PolicyBypassPrincipalARNs.length === 0) {\n        throw new Error(\n          's3StrictBucketPolicy cannot be true without specifying at least one s3PolicyBypassAROAs or s3PolicyBypassPrincipalARNs',\n        );\n      }\n    }\n\n    //\n    // DynamoDB Table\n    //\n    this._table = new dynamodb.Table(this, 'table', {\n      tableName: assetNameRoot ? `${assetNameRoot}${assetNameSuffix}` : undefined,\n      billingMode: dynamodb.BillingMode.PAY_PER_REQUEST,\n      partitionKey: {\n        name: 'PK',\n        type: dynamodb.AttributeType.STRING,\n      },\n      sortKey: {\n        name: 'SK',\n        type: dynamodb.AttributeType.STRING,\n      },\n      removalPolicy,\n    });\n\n    //\n    // Router Lambda Function\n    //\n\n    // Create Router Lambda Function\n    const routerFuncProps: Omit<lambda.FunctionProps, 'handler' | 'code'> = {\n      functionName: assetNameRoot ? `${assetNameRoot}-router${assetNameSuffix}` : undefined,\n      memorySize: 1769,\n      logRetention: logs.RetentionDays.ONE_MONTH,\n      runtime: lambda.Runtime.NODEJS_14_X,\n      timeout: Duration.seconds(15),\n      environment: {\n        NODE_ENV: appEnv,\n        DATABASE_TABLE_NAME: this._table.tableName,\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n        ROOT_PATH_PREFIX: rootPathPrefix,\n      },\n    };\n    if (\n      process.env.NODE_ENV === 'test' &&\n      existsSync(path.join(__dirname, '..', '..', 'microapps-router', 'dist', 'index.js'))\n    ) {\n      // This is for local dev\n      this._routerFunc = new lambda.Function(this, 'router-func', {\n        code: lambda.Code.fromAsset(path.join(__dirname, '..', '..', 'microapps-router', 'dist')),\n        handler: 'index.handler',\n        ...routerFuncProps,\n      });\n    } else if (existsSync(path.join(__dirname, 'microapps-router', 'index.js'))) {\n      // This is for built apps packaged with the CDK construct\n      this._routerFunc = new lambda.Function(this, 'router-func', {\n        code: lambda.Code.fromAsset(path.join(__dirname, 'microapps-router')),\n        handler: 'index.handler',\n        ...routerFuncProps,\n      });\n    } else {\n      // Create Router Lambda Layer\n      const routerDataFiles = new lambda.LayerVersion(this, 'router-templates', {\n        code: lambda.Code.fromAsset(\n          path.join(__dirname, '..', '..', 'microapps-router', 'templates'),\n        ),\n        removalPolicy,\n      });\n\n      this._routerFunc = new lambdaNodejs.NodejsFunction(this, 'router-func', {\n        entry: path.join(__dirname, '..', '..', 'microapps-router', 'src', 'index.ts'),\n        handler: 'handler',\n        bundling: {\n          minify: true,\n          sourceMap: true,\n        },\n        layers: [routerDataFiles],\n        ...routerFuncProps,\n      });\n    }\n    if (removalPolicy !== undefined) {\n      this._routerFunc.applyRemovalPolicy(removalPolicy);\n    }\n    const policyReadTarget = new iam.PolicyStatement({\n      effect: iam.Effect.ALLOW,\n      actions: ['s3:GetObject'],\n      resources: [`${bucketApps.bucketArn}/*`],\n    });\n    for (const router of [this._routerFunc]) {\n      router.addToRolePolicy(policyReadTarget);\n      // Give the Router access to DynamoDB table\n      this._table.grantReadData(router);\n      this._table.grant(router, 'dynamodb:DescribeTable');\n    }\n\n    //\n    // Deployer Lambda Function\n    //\n\n    // Create Deployer Lambda Function\n    const iamRoleUploadName = assetNameRoot\n      ? `${assetNameRoot}-deployer-upload${assetNameSuffix}`\n      : undefined;\n    const deployerFuncName = assetNameRoot\n      ? `${assetNameRoot}-deployer${assetNameSuffix}`\n      : undefined;\n    const deployerFuncProps: Omit<lambda.FunctionProps, 'handler' | 'code'> = {\n      functionName: deployerFuncName,\n      memorySize: 1769,\n      logRetention: logs.RetentionDays.ONE_MONTH,\n      runtime: lambda.Runtime.NODEJS_14_X,\n      timeout: Duration.seconds(15),\n      environment: {\n        NODE_ENV: appEnv,\n        APIGWY_ID: httpApi.httpApiId,\n        DATABASE_TABLE_NAME: this._table.tableName,\n        FILESTORE_STAGING_BUCKET: bucketAppsStaging.bucketName,\n        FILESTORE_DEST_BUCKET: bucketApps.bucketName,\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n        ROOT_PATH_PREFIX: rootPathPrefix,\n      },\n    };\n    if (\n      process.env.NODE_ENV === 'test' &&\n      existsSync(path.join(__dirname, '..', '..', 'microapps-deployer', 'dist', 'index.js'))\n    ) {\n      // This is for local dev\n      this._deployerFunc = new lambda.Function(this, 'deployer-func', {\n        code: lambda.Code.fromAsset(path.join(__dirname, '..', '..', 'microapps-deployer', 'dist')),\n        handler: 'index.handler',\n        ...deployerFuncProps,\n      });\n    } else if (existsSync(path.join(__dirname, 'microapps-deployer', 'index.js'))) {\n      // This is for built apps packaged with the CDK construct\n      this._deployerFunc = new lambda.Function(this, 'deployer-func', {\n        code: lambda.Code.fromAsset(path.join(__dirname, 'microapps-deployer')),\n        handler: 'index.handler',\n        ...deployerFuncProps,\n      });\n    } else {\n      this._deployerFunc = new lambdaNodejs.NodejsFunction(this, 'deployer-func', {\n        entry: path.join(__dirname, '..', '..', 'microapps-deployer', 'src', 'index.ts'),\n        handler: 'handler',\n        bundling: {\n          minify: true,\n          sourceMap: true,\n        },\n        ...deployerFuncProps,\n      });\n    }\n    if (removalPolicy !== undefined) {\n      this._deployerFunc.applyRemovalPolicy(removalPolicy);\n    }\n    // Give the Deployer access to DynamoDB table\n    this._table.grantReadWriteData(this._deployerFunc);\n    this._table.grant(this._deployerFunc, 'dynamodb:DescribeTable');\n\n    //\n    // Deloyer upload temp role\n    // Deployer assumes this role with a limited policy to generate\n    // an STS temp token to return to microapps-publish for the upload.\n    //\n    const iamRoleUpload = new iam.Role(this, 'deployer-upload-role', {\n      roleName: iamRoleUploadName,\n      inlinePolicies: {\n        uploadPolicy: new iam.PolicyDocument({\n          statements: [\n            new iam.PolicyStatement({\n              actions: ['s3:ListBucket'],\n              resources: [bucketAppsStaging.bucketArn],\n            }),\n            new iam.PolicyStatement({\n              actions: ['s3:PutObject', 's3:GetObject', 's3:AbortMultipartUpload'],\n              resources: [`${bucketAppsStaging.bucketArn}/*`],\n            }),\n          ],\n        }),\n      },\n      assumedBy: this._deployerFunc.grantPrincipal,\n    });\n    this._deployerFunc.addEnvironment('UPLOAD_ROLE_NAME', iamRoleUpload.roleName);\n\n    //\n    // Update S3 permissions\n    //\n    // Create PrincipalARN List\n    const s3PolicyBypassArnPrincipals: iam.ArnPrincipal[] = [];\n    for (const arnPrincipal of s3PolicyBypassPrincipalARNs) {\n      s3PolicyBypassArnPrincipals.push(new iam.ArnPrincipal(arnPrincipal));\n    }\n    // Create AROA List that matches assumed sessions\n    const s3PolicyBypassAROAMatches: string[] = [];\n    for (const aroa of s3PolicyBypassAROAs) {\n      s3PolicyBypassAROAMatches.push(`${aroa}:*`);\n    }\n    // Deny apps from reading:\n    // - If they are missing the microapp-name tag\n    // - Anything outside of the folder that matches their microapp-name tag\n    const policyDenyPrefixOutsideTag = new iam.PolicyStatement({\n      sid: 'deny-prefix-outside-microapp-name-tag',\n      effect: iam.Effect.DENY,\n      actions: ['s3:*'],\n      notPrincipals: [\n        new iam.CanonicalUserPrincipal(\n          bucketAppsOAI.cloudFrontOriginAccessIdentityS3CanonicalUserId,\n        ),\n        new iam.AccountRootPrincipal(),\n        ...s3PolicyBypassArnPrincipals,\n        this._deployerFunc.grantPrincipal,\n      ],\n      notResources: [\n        `${bucketApps.bucketArn}/\\${aws:PrincipalTag/microapp-name}/*`,\n        bucketApps.bucketArn,\n      ],\n      conditions: {\n        Null: { 'aws:PrincipalTag/microapp-name': 'false' },\n        // StringNotLike: {'aws:'}\n      },\n    });\n    if (removalPolicy !== undefined) {\n      policyDenyPrefixOutsideTag.addCondition(\n        // Allows the DeletableBucket Lambda to delete items in the buckets\n        'StringNotLike',\n        { 'aws:PrincipalTag/application': `${Stack.of(this).stackName}-core*` },\n      );\n    }\n    const policyDenyMissingTag = new iam.PolicyStatement({\n      sid: 'deny-missing-microapp-name-tag',\n      effect: iam.Effect.DENY,\n      actions: ['s3:*'],\n      notPrincipals: [\n        new iam.CanonicalUserPrincipal(\n          bucketAppsOAI.cloudFrontOriginAccessIdentityS3CanonicalUserId,\n        ),\n        new iam.AccountRootPrincipal(),\n        // Exclude the Deployer Function directly\n        this._deployerFunc.grantPrincipal,\n        // 2021-12-04 - Not 100% sure that this is actually needed...\n        // Let's test this and remove if actually not necessary\n        new iam.ArnPrincipal(\n          `arn:aws:sts::${Aws.ACCOUNT_ID}:assumed-role/${this._deployerFunc.role?.roleName}/${this._deployerFunc.functionName}`,\n        ),\n        ...s3PolicyBypassArnPrincipals,\n      ],\n      resources: [`${bucketApps.bucketArn}/*`, bucketApps.bucketArn],\n      conditions: {\n        Null: { 'aws:PrincipalTag/microapp-name': 'true' },\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        // 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 them implicitly either.\n        // The AROA must be used because there are only 3 Principal variables:\n        //  https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_variables.html#principaltable\n        //  aws:username, aws:userid, aws:PrincipalTag\n        // For an assumed role, aws:username is blank, aws:userid is:\n        //  [unique id AKA AROA for Role]:[session name]\n        // Table of unique ID prefixes such as AROA:\n        //  https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_identifiers.html#identifiers-prefixes\n        // The name of the role is simply not available and if it was\n        // we'd need to write a complicated comparison to make sure\n        // that we didn't exclude the Deny tag from roles in 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        StringNotLike: { 'aws:userid': [Aws.ACCOUNT_ID, ...s3PolicyBypassAROAMatches] },\n      },\n    });\n    if (removalPolicy !== undefined) {\n      policyDenyMissingTag.addCondition(\n        // Allows the DeletableBucket Lambda to delete items in the buckets\n        'StringNotLike',\n        { 'aws:PrincipalTag/application': `${Stack.of(this).stackName}-core*` },\n      );\n    }\n    const policyCloudFrontAccess = new iam.PolicyStatement({\n      sid: 'cloudfront-oai-access',\n      effect: iam.Effect.ALLOW,\n      actions: ['s3:GetObject', 's3:ListBucket'],\n      principals: [\n        new iam.CanonicalUserPrincipal(\n          bucketAppsOAI.cloudFrontOriginAccessIdentityS3CanonicalUserId,\n        ),\n      ],\n      resources: [`${bucketApps.bucketArn}/*`, bucketApps.bucketArn],\n    });\n\n    if (bucketApps.policy === undefined) {\n      const document = new s3.BucketPolicy(this, 's3-policy', {\n        bucket: bucketApps,\n      }).document;\n      document.addStatements(policyCloudFrontAccess);\n\n      if (s3StrictBucketPolicy) {\n        document.addStatements(policyDenyPrefixOutsideTag);\n        document.addStatements(policyDenyMissingTag);\n      }\n    } else {\n      bucketApps.policy.document.addStatements(policyCloudFrontAccess);\n\n      if (s3StrictBucketPolicy) {\n        bucketApps.policy.document.addStatements(policyDenyPrefixOutsideTag);\n        bucketApps.policy.document.addStatements(policyDenyMissingTag);\n      }\n    }\n\n    // Allow the Lambda to read from the staging bucket\n    const policyReadListStaging = new iam.PolicyStatement({\n      effect: iam.Effect.ALLOW,\n      // FIXME: Allow Deployer to delete from Staging bucket\n      actions: ['s3:DeleteObject', 's3:GetObject', 's3:ListBucket'],\n      resources: [`${bucketAppsStaging.bucketArn}/*`, bucketAppsStaging.bucketArn],\n    });\n    this._deployerFunc.addToRolePolicy(policyReadListStaging);\n\n    // Allow the Lambda to write to the target bucket and delete\n    const policyReadWriteListTarget = new iam.PolicyStatement({\n      effect: iam.Effect.ALLOW,\n      actions: ['s3:DeleteObject', 's3:GetObject', 's3:PutObject', 's3:ListBucket'],\n      resources: [`${bucketApps.bucketArn}/*`, bucketApps.bucketArn],\n    });\n    this._deployerFunc.addToRolePolicy(policyReadWriteListTarget);\n\n    // Allow the deployer to get a temporary STS token\n    const policyGetSTSToken = new iam.PolicyStatement({\n      effect: iam.Effect.ALLOW,\n      actions: ['sts:GetFederationToken'],\n      resources: ['*'],\n    });\n    this._deployerFunc.addToRolePolicy(policyGetSTSToken);\n\n    // Allow the deployer to assume the upload role\n    const policyAssumeUpload = new iam.PolicyStatement({\n      effect: iam.Effect.ALLOW,\n      actions: ['sts:AssumeRole'],\n      resources: [iamRoleUpload.roleArn],\n    });\n    this._deployerFunc.addToRolePolicy(policyAssumeUpload);\n\n    //\n    // Give Deployer permissions to create routes and integrations\n    // on the API Gateway API.\n    //\n\n    // Grant the ability to List all APIs (we have to find it)\n    const policyAPIList = new iam.PolicyStatement({\n      effect: iam.Effect.ALLOW,\n      actions: ['apigateway:GET'],\n      resources: [`arn:aws:apigateway:${Aws.REGION}::/apis`],\n    });\n    this._deployerFunc.addToRolePolicy(policyAPIList);\n    // Grant full control over the API we created\n    const policyAPIManage = new iam.PolicyStatement({\n      effect: iam.Effect.ALLOW,\n      actions: ['apigateway:*'],\n      resources: [\n        `arn:aws:apigateway:${Aws.REGION}:${Aws.ACCOUNT_ID}:${httpApi.httpApiId}/*`,\n        `arn:aws:apigateway:${Aws.REGION}::/apis/${httpApi.httpApiId}/integrations/*`,\n        `arn:aws:apigateway:${Aws.REGION}::/apis/${httpApi.httpApiId}/integrations`,\n        `arn:aws:apigateway:${Aws.REGION}::/apis/${httpApi.httpApiId}/routes`,\n        `arn:aws:apigateway:${Aws.REGION}::/apis/${httpApi.httpApiId}/routes/*`,\n      ],\n    });\n    this._deployerFunc.addToRolePolicy(policyAPIManage);\n    // Grant full control over lambdas that indicate they are microapps\n    const policyAPIManageLambdas = new iam.PolicyStatement({\n      effect: iam.Effect.ALLOW,\n      actions: ['lambda:*'],\n      resources: [\n        `arn:aws:lambda:${Aws.REGION}:${Aws.ACCOUNT_ID}:function:*`,\n        `arn:aws:lambda:${Aws.REGION}:${Aws.ACCOUNT_ID}:function:*:*`,\n      ],\n      conditions: {\n        StringEqualsIfExists: { 'aws:ResourceTag/microapp-managed': 'true' },\n      },\n    });\n    this._deployerFunc.addToRolePolicy(policyAPIManageLambdas);\n\n    // Create an integration for the Router\n    // All traffic without another route goes to the Router\n    const intRouter = new apigwy.HttpIntegration(this, 'router-integration', {\n      integrationType: apigwy.HttpIntegrationType.AWS_PROXY,\n      httpApi,\n      integrationUri: this._routerFunc.functionArn,\n      payloadFormatVersion: apigwy.PayloadFormatVersion.VERSION_2_0,\n    });\n    // new apigwycfn.CfnIntegration(this, 'router-integration', {\n    //   apiId: httpApi.httpApiId,\n    //   integrationType: 'AWS_PROXY',\n    //   integrationUri: routerFunc.functionArn,\n    // });\n    // new apigwycfn.CfnRoute(this, 'route-default', {\n    //   apiId: httpApi.httpApiId,\n    //   routeKey: apigwy.HttpRouteKey.DEFAULT.key,\n    //   target: `integrations/${intRouter.integrationId}`,\n    // });\n\n    // This creates an integration and a router\n    const route = new apigwy.HttpRoute(this, 'route-default', {\n      httpApi,\n      routeKey: apigwy.HttpRouteKey.DEFAULT,\n      // @ts-expect-error null is needed to prevent this.bind call\n      authorizer: apigwy.Auth,\n      integration: new HttpRouteIntegration('router-integration', {\n        integration: intRouter,\n      }),\n    });\n\n    let routeArn = route.produceRouteArn(apigwy.HttpMethod.ANY);\n    // Remove the trailing `/` on the ARN, which is not correct\n    routeArn = routeArn.slice(0, routeArn.length - 1);\n\n    // Grant API Gateway permission to invoke the Lambda\n    new lambda.CfnPermission(this, 'router-invoke', {\n      action: 'lambda:InvokeFunction',\n      functionName: this._routerFunc.functionName,\n      principal: 'apigateway.amazonaws.com',\n      sourceArn: routeArn,\n    });\n  }\n}\n"]}
|