@pwrdrvr/microapps-cdk 0.0.28 → 0.0.29
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 +1884 -185
- package/API.md +890 -60
- package/README.md +2 -8
- package/lib/MicroApps.d.ts +77 -44
- package/lib/MicroApps.js +62 -33
- package/lib/MicroAppsAPIGwy.d.ts +123 -0
- package/lib/MicroAppsAPIGwy.js +178 -0
- package/lib/MicroAppsCF.d.ts +179 -17
- package/lib/MicroAppsCF.js +127 -45
- package/lib/MicroAppsS3.d.ts +114 -17
- package/lib/MicroAppsS3.js +55 -31
- package/lib/MicroAppsSvcs.d.ts +123 -25
- package/lib/MicroAppsSvcs.js +113 -152
- package/lib/index.d.ts +4 -0
- package/lib/index.js +5 -1
- package/lib/microapps-deployer/index.js +116 -88
- package/lib/microapps-deployer/index.js.map +3 -3
- package/lib/microapps-router/index.js +60 -51
- package/lib/microapps-router/index.js.map +3 -3
- package/lib/utils/ReverseDomain.d.ts +4 -0
- package/lib/utils/ReverseDomain.js +15 -0
- package/package.json +45 -45
package/lib/MicroAppsCF.js
CHANGED
|
@@ -1,100 +1,182 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var _a;
|
|
2
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
4
|
exports.MicroAppsCF = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
const path_1 = require("path");
|
|
4
7
|
const cf = require("@aws-cdk/aws-cloudfront");
|
|
5
8
|
const cforigins = require("@aws-cdk/aws-cloudfront-origins");
|
|
6
9
|
const r53 = require("@aws-cdk/aws-route53");
|
|
7
10
|
const r53targets = require("@aws-cdk/aws-route53-targets");
|
|
8
11
|
const cdk = require("@aws-cdk/core");
|
|
12
|
+
const ReverseDomain_1 = require("./utils/ReverseDomain");
|
|
13
|
+
/**
|
|
14
|
+
* @stability stable
|
|
15
|
+
*/
|
|
9
16
|
class MicroAppsCF extends cdk.Construct {
|
|
17
|
+
/**
|
|
18
|
+
* MicroApps - Create just CloudFront resources.
|
|
19
|
+
*
|
|
20
|
+
* @stability stable
|
|
21
|
+
*/
|
|
10
22
|
constructor(scope, id, props) {
|
|
11
23
|
super(scope, id);
|
|
12
24
|
if (props === undefined) {
|
|
13
25
|
throw new Error('props must be set');
|
|
14
26
|
}
|
|
15
|
-
|
|
27
|
+
if ((props.r53Zone === undefined && props.domainNameEdge !== undefined) ||
|
|
28
|
+
(props.r53Zone !== undefined && props.domainNameEdge === undefined)) {
|
|
29
|
+
throw new Error('If either of r53Zone or domainNameEdge are set then the other must be set');
|
|
30
|
+
}
|
|
31
|
+
const { domainNameEdge, domainNameOrigin, httpApi, removalPolicy, certEdge, assetNameRoot, assetNameSuffix, r53Zone, bucketLogs, bucketAppsOrigin, rootPathPrefix, } = props;
|
|
32
|
+
const apigwyOriginRequestPolicy = MicroAppsCF.createAPIOriginPolicy(this, {
|
|
33
|
+
assetNameRoot,
|
|
34
|
+
assetNameSuffix,
|
|
35
|
+
domainNameEdge,
|
|
36
|
+
});
|
|
37
|
+
//
|
|
38
|
+
// Determine URL of the origin FQDN
|
|
39
|
+
//
|
|
40
|
+
let httpOriginFQDN = 'invalid.pwrdrvr.com';
|
|
41
|
+
if (domainNameOrigin !== undefined) {
|
|
42
|
+
httpOriginFQDN = domainNameOrigin;
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
httpOriginFQDN = `${httpApi.apiId}.execute-api.${cdk.Aws.REGION}.amazonaws.com`;
|
|
46
|
+
}
|
|
16
47
|
//
|
|
17
48
|
// CloudFront Distro
|
|
18
49
|
//
|
|
19
|
-
const apiGwyOrigin = new cforigins.HttpOrigin(
|
|
50
|
+
const apiGwyOrigin = new cforigins.HttpOrigin(httpOriginFQDN, {
|
|
20
51
|
protocolPolicy: cf.OriginProtocolPolicy.HTTPS_ONLY,
|
|
21
52
|
originSslProtocols: [cf.OriginSslPolicy.TLS_V1_2],
|
|
22
53
|
});
|
|
23
|
-
this._cloudFrontDistro = new cf.Distribution(this, '
|
|
24
|
-
comment: `${assetNameRoot}${assetNameSuffix}
|
|
25
|
-
domainNames: [domainNameEdge],
|
|
54
|
+
this._cloudFrontDistro = new cf.Distribution(this, 'cft', {
|
|
55
|
+
comment: assetNameRoot ? `${assetNameRoot}${assetNameSuffix}` : domainNameEdge,
|
|
56
|
+
domainNames: domainNameEdge !== undefined ? [domainNameEdge] : undefined,
|
|
26
57
|
certificate: certEdge,
|
|
27
58
|
httpVersion: cf.HttpVersion.HTTP2,
|
|
28
59
|
defaultBehavior: {
|
|
29
60
|
allowedMethods: cf.AllowedMethods.ALLOW_ALL,
|
|
30
61
|
cachePolicy: cf.CachePolicy.CACHING_DISABLED,
|
|
31
62
|
compress: true,
|
|
32
|
-
originRequestPolicy:
|
|
63
|
+
originRequestPolicy: apigwyOriginRequestPolicy,
|
|
33
64
|
origin: apiGwyOrigin,
|
|
34
65
|
viewerProtocolPolicy: cf.ViewerProtocolPolicy.REDIRECT_TO_HTTPS,
|
|
35
66
|
},
|
|
36
67
|
enableIpv6: true,
|
|
37
68
|
priceClass: cf.PriceClass.PRICE_CLASS_100,
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
69
|
+
logBucket: bucketLogs,
|
|
70
|
+
logFilePrefix: props.domainNameEdge
|
|
71
|
+
? `${ReverseDomain_1.reverseDomain(props.domainNameEdge)}/cloudfront-raw/`
|
|
72
|
+
: undefined,
|
|
73
|
+
});
|
|
74
|
+
if (removalPolicy !== undefined) {
|
|
75
|
+
this._cloudFrontDistro.applyRemovalPolicy(removalPolicy);
|
|
76
|
+
}
|
|
77
|
+
// Add routes to the CloudFront Distribution
|
|
78
|
+
MicroAppsCF.addRoutes(scope, {
|
|
79
|
+
apiGwyOrigin,
|
|
80
|
+
bucketAppsOrigin,
|
|
81
|
+
distro: this._cloudFrontDistro,
|
|
82
|
+
apigwyOriginRequestPolicy: apigwyOriginRequestPolicy,
|
|
83
|
+
rootPathPrefix,
|
|
41
84
|
});
|
|
42
|
-
|
|
43
|
-
|
|
85
|
+
//
|
|
86
|
+
// Create the edge name for the CloudFront distro
|
|
87
|
+
//
|
|
88
|
+
if (r53Zone !== undefined) {
|
|
89
|
+
const rrAppsEdge = new r53.RecordSet(this, 'edge-arecord', {
|
|
90
|
+
recordName: domainNameEdge,
|
|
91
|
+
recordType: r53.RecordType.A,
|
|
92
|
+
target: r53.RecordTarget.fromAlias(new r53targets.CloudFrontTarget(this._cloudFrontDistro)),
|
|
93
|
+
zone: r53Zone,
|
|
94
|
+
});
|
|
95
|
+
if (removalPolicy !== undefined) {
|
|
96
|
+
rrAppsEdge.applyRemovalPolicy(removalPolicy);
|
|
97
|
+
}
|
|
44
98
|
}
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Create or get the origin request policy.
|
|
102
|
+
*
|
|
103
|
+
* If a custom domain name is NOT used for the origin then a policy
|
|
104
|
+
* will be created.
|
|
105
|
+
*
|
|
106
|
+
* If a custom domain name IS used for the origin then the ALL_VIEWER
|
|
107
|
+
* policy will be returned. This policy passes the Host header to the
|
|
108
|
+
* origin, which is fine when using a custom domain name on the origin.
|
|
109
|
+
*
|
|
110
|
+
* @stability stable
|
|
111
|
+
*/
|
|
112
|
+
static createAPIOriginPolicy(scope, props) {
|
|
113
|
+
const { assetNameRoot, assetNameSuffix, domainNameEdge } = props;
|
|
114
|
+
let apigwyOriginRequestPolicy = cf.OriginRequestPolicy.ALL_VIEWER;
|
|
115
|
+
if (domainNameEdge === undefined) {
|
|
116
|
+
// When not using a custom domain name we must limit down the origin policy to
|
|
117
|
+
// prevent it from passing the Host header (distribution_id.cloudfront.net) to
|
|
118
|
+
// apigwy which will then reject it with a 403 because it does not match the
|
|
119
|
+
// execute-api name that apigwy is expecting.
|
|
120
|
+
//
|
|
121
|
+
// 2021-12-28 - There is a bug in the name generation that causes the same asset
|
|
122
|
+
// in different stacks to have the same generated name. We have to make the id
|
|
123
|
+
// in all cases to ensure the generated name is unique.
|
|
124
|
+
apigwyOriginRequestPolicy = new cf.OriginRequestPolicy(scope, `apigwy-origin-policy-${cdk.Stack.of(scope).stackName}`, {
|
|
125
|
+
comment: assetNameRoot ? `${assetNameRoot}-apigwy${assetNameSuffix}` : undefined,
|
|
126
|
+
originRequestPolicyName: assetNameRoot
|
|
127
|
+
? `${assetNameRoot}-apigwy${assetNameSuffix}`
|
|
128
|
+
: undefined,
|
|
129
|
+
cookieBehavior: cf.OriginRequestCookieBehavior.all(),
|
|
130
|
+
queryStringBehavior: cf.OriginRequestQueryStringBehavior.all(),
|
|
131
|
+
headerBehavior: cf.OriginRequestHeaderBehavior.allowList('user-agent', 'referer'),
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
return apigwyOriginRequestPolicy;
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* Add API Gateway and S3 routes to an existing CloudFront Distribution.
|
|
138
|
+
*
|
|
139
|
+
* @stability stable
|
|
140
|
+
*/
|
|
141
|
+
static addRoutes(_scope, props) {
|
|
142
|
+
const { apiGwyOrigin, bucketAppsOrigin, distro, apigwyOriginRequestPolicy, rootPathPrefix = '', } = props;
|
|
45
143
|
//
|
|
46
144
|
// Add Behaviors
|
|
47
145
|
//
|
|
48
|
-
const
|
|
49
|
-
allowedMethods: cf.AllowedMethods.ALLOW_ALL,
|
|
50
|
-
cachePolicy: cf.CachePolicy.CACHING_DISABLED,
|
|
51
|
-
compress: true,
|
|
52
|
-
originRequestPolicy: cf.OriginRequestPolicy.ALL_VIEWER,
|
|
53
|
-
viewerProtocolPolicy: cf.ViewerProtocolPolicy.REDIRECT_TO_HTTPS,
|
|
54
|
-
};
|
|
55
|
-
const s3Behavior = {
|
|
146
|
+
const s3BehaviorOptions = {
|
|
56
147
|
allowedMethods: cf.AllowedMethods.ALLOW_GET_HEAD_OPTIONS,
|
|
57
148
|
cachePolicy: cf.CachePolicy.CACHING_OPTIMIZED,
|
|
58
149
|
compress: true,
|
|
59
150
|
originRequestPolicy: cf.OriginRequestPolicy.CORS_S3_ORIGIN,
|
|
60
151
|
viewerProtocolPolicy: cf.ViewerProtocolPolicy.REDIRECT_TO_HTTPS,
|
|
61
152
|
};
|
|
62
|
-
const
|
|
63
|
-
allowedMethods: cf.AllowedMethods.
|
|
64
|
-
|
|
153
|
+
const apiGwyBehaviorOptions = {
|
|
154
|
+
allowedMethods: cf.AllowedMethods.ALLOW_ALL,
|
|
155
|
+
// TODO: Caching needs to be set by the app response
|
|
156
|
+
cachePolicy: cf.CachePolicy.CACHING_DISABLED,
|
|
65
157
|
compress: true,
|
|
158
|
+
originRequestPolicy: apigwyOriginRequestPolicy,
|
|
66
159
|
viewerProtocolPolicy: cf.ViewerProtocolPolicy.REDIRECT_TO_HTTPS,
|
|
67
160
|
};
|
|
68
161
|
//
|
|
69
|
-
//
|
|
70
|
-
// Pull to the API first, then pull to S3 if it contains /static/
|
|
71
|
-
// Pull anything under /appName/x.y.z/ folder with '.' in file name to S3
|
|
72
|
-
// Let everything else fall through to the API Gateway
|
|
162
|
+
// All static assets are assumed to have a dot in them
|
|
73
163
|
//
|
|
74
|
-
|
|
75
|
-
this._cloudFrontDistro.addBehavior('/*/*/static/*', s3Exports.bucketAppsOrigin, s3Behavior);
|
|
76
|
-
this._cloudFrontDistro.addBehavior('/*/*/*.*', s3Exports.bucketAppsOrigin, s3Behavior);
|
|
77
|
-
this._cloudFrontDistro.addBehavior('/*/*/', apiGwyOrigin, apiGwyVersionRootBehavior);
|
|
164
|
+
distro.addBehavior(path_1.posix.join(rootPathPrefix, '/*/*/*.*'), bucketAppsOrigin, s3BehaviorOptions);
|
|
78
165
|
//
|
|
79
|
-
//
|
|
166
|
+
// Everything that isn't a static asset is going to API Gateway
|
|
167
|
+
// There is no trailing slash because Serverless Next.js wants
|
|
168
|
+
// go load pages at /release/0.0.3 (with no trailing slash).
|
|
80
169
|
//
|
|
81
|
-
|
|
82
|
-
zoneName: r53ZoneName,
|
|
83
|
-
hostedZoneId: r53ZoneID,
|
|
84
|
-
});
|
|
85
|
-
const rrAppsEdge = new r53.RecordSet(this, 'microapps-edge-arecord', {
|
|
86
|
-
recordName: domainNameEdge,
|
|
87
|
-
recordType: r53.RecordType.A,
|
|
88
|
-
target: r53.RecordTarget.fromAlias(new r53targets.CloudFrontTarget(this._cloudFrontDistro)),
|
|
89
|
-
zone,
|
|
90
|
-
});
|
|
91
|
-
if (autoDeleteEverything) {
|
|
92
|
-
rrAppsEdge.applyRemovalPolicy(cdk.RemovalPolicy.DESTROY);
|
|
93
|
-
}
|
|
170
|
+
distro.addBehavior(path_1.posix.join(rootPathPrefix, '/*'), apiGwyOrigin, apiGwyBehaviorOptions);
|
|
94
171
|
}
|
|
172
|
+
/**
|
|
173
|
+
* @stability stable
|
|
174
|
+
*/
|
|
95
175
|
get cloudFrontDistro() {
|
|
96
176
|
return this._cloudFrontDistro;
|
|
97
177
|
}
|
|
98
178
|
}
|
|
99
179
|
exports.MicroAppsCF = MicroAppsCF;
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MicroAppsCF.js","sourceRoot":"","sources":["../src/MicroAppsCF.ts"],"names":[],"mappings":"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","sourcesContent":["import * as acm from '@aws-cdk/aws-certificatemanager';\nimport * as cf from '@aws-cdk/aws-cloudfront';\nimport * as cforigins from '@aws-cdk/aws-cloudfront-origins';\nimport * as r53 from '@aws-cdk/aws-route53';\nimport * as r53targets from '@aws-cdk/aws-route53-targets';\nimport * as cdk from '@aws-cdk/core';\nimport { IMicroAppsS3Exports } from './MicroAppsS3';\n\nexport interface IMicroAppsCFExports {\n  readonly cloudFrontDistro: cf.Distribution;\n}\n\ninterface MicroAppsCFProps extends cdk.ResourceProps {\n  readonly autoDeleteEverything: boolean;\n  readonly s3Exports: IMicroAppsS3Exports;\n  readonly reverseDomainName: string;\n  readonly domainName: string;\n  readonly domainNameEdge: string;\n  readonly domainNameOrigin: string;\n\n  readonly assetNameRoot: string;\n  readonly assetNameSuffix: string;\n\n  readonly certEdge: acm.ICertificate;\n\n  readonly r53ZoneName: string;\n  readonly r53ZoneID: string;\n}\n\nexport class MicroAppsCF extends cdk.Construct implements IMicroAppsCFExports {\n  private _cloudFrontDistro: cf.Distribution;\n  public get cloudFrontDistro(): cf.Distribution {\n    return this._cloudFrontDistro;\n  }\n\n  constructor(scope: cdk.Construct, id: string, props?: MicroAppsCFProps) {\n    super(scope, id);\n\n    if (props === undefined) {\n      throw new Error('props must be set');\n    }\n\n    const {\n      s3Exports,\n      domainNameEdge,\n      domainNameOrigin,\n      reverseDomainName,\n      autoDeleteEverything,\n      certEdge,\n      assetNameRoot,\n      assetNameSuffix,\n      r53ZoneName,\n      r53ZoneID,\n    } = props;\n\n    //\n    // CloudFront Distro\n    //\n    const apiGwyOrigin = new cforigins.HttpOrigin(domainNameOrigin, {\n      protocolPolicy: cf.OriginProtocolPolicy.HTTPS_ONLY,\n      originSslProtocols: [cf.OriginSslPolicy.TLS_V1_2],\n    });\n    this._cloudFrontDistro = new cf.Distribution(this, 'microapps-cloudfront', {\n      comment: `${assetNameRoot}${assetNameSuffix}`,\n      domainNames: [domainNameEdge],\n      certificate: certEdge,\n      httpVersion: cf.HttpVersion.HTTP2,\n      defaultBehavior: {\n        allowedMethods: cf.AllowedMethods.ALLOW_ALL,\n        cachePolicy: cf.CachePolicy.CACHING_DISABLED,\n        compress: true,\n        originRequestPolicy: cf.OriginRequestPolicy.ALL_VIEWER,\n        origin: apiGwyOrigin,\n        viewerProtocolPolicy: cf.ViewerProtocolPolicy.REDIRECT_TO_HTTPS,\n      },\n      enableIpv6: true,\n      priceClass: cf.PriceClass.PRICE_CLASS_100,\n      enableLogging: true,\n      logBucket: props.s3Exports.bucketLogs,\n      logFilePrefix: `${reverseDomainName}/cloudfront-raw/`,\n    });\n    if (autoDeleteEverything) {\n      this._cloudFrontDistro.applyRemovalPolicy(cdk.RemovalPolicy.DESTROY);\n    }\n\n    //\n    // Add Behaviors\n    //\n    const apiGwyBehavior: cf.AddBehaviorOptions = {\n      allowedMethods: cf.AllowedMethods.ALLOW_ALL,\n      cachePolicy: cf.CachePolicy.CACHING_DISABLED,\n      compress: true,\n      originRequestPolicy: cf.OriginRequestPolicy.ALL_VIEWER,\n      viewerProtocolPolicy: cf.ViewerProtocolPolicy.REDIRECT_TO_HTTPS,\n    };\n    const s3Behavior: cf.AddBehaviorOptions = {\n      allowedMethods: cf.AllowedMethods.ALLOW_GET_HEAD_OPTIONS,\n      cachePolicy: cf.CachePolicy.CACHING_OPTIMIZED,\n      compress: true,\n      originRequestPolicy: cf.OriginRequestPolicy.CORS_S3_ORIGIN,\n      viewerProtocolPolicy: cf.ViewerProtocolPolicy.REDIRECT_TO_HTTPS,\n    };\n    const apiGwyVersionRootBehavior: cf.AddBehaviorOptions = {\n      allowedMethods: cf.AllowedMethods.ALLOW_GET_HEAD_OPTIONS,\n      cachePolicy: cf.CachePolicy.CACHING_OPTIMIZED,\n      compress: true,\n      viewerProtocolPolicy: cf.ViewerProtocolPolicy.REDIRECT_TO_HTTPS,\n    };\n\n    //\n    // Setup Routes\n    // Pull to the API first, then pull to S3 if it contains /static/\n    // Pull anything under /appName/x.y.z/ folder with '.' in file name to S3\n    // Let everything else fall through to the API Gateway\n    //\n    this._cloudFrontDistro.addBehavior('/*/*/api/*', apiGwyOrigin, apiGwyBehavior);\n    this._cloudFrontDistro.addBehavior('/*/*/static/*', s3Exports.bucketAppsOrigin, s3Behavior);\n    this._cloudFrontDistro.addBehavior('/*/*/*.*', s3Exports.bucketAppsOrigin, s3Behavior);\n    this._cloudFrontDistro.addBehavior('/*/*/', apiGwyOrigin, apiGwyVersionRootBehavior);\n\n    //\n    // Create the edge name for the CloudFront distro\n    //\n\n    const zone = r53.HostedZone.fromHostedZoneAttributes(this, 'microapps-zone', {\n      zoneName: r53ZoneName,\n      hostedZoneId: r53ZoneID,\n    });\n\n    const rrAppsEdge = new r53.RecordSet(this, 'microapps-edge-arecord', {\n      recordName: domainNameEdge,\n      recordType: r53.RecordType.A,\n      target: r53.RecordTarget.fromAlias(new r53targets.CloudFrontTarget(this._cloudFrontDistro)),\n      zone,\n    });\n    if (autoDeleteEverything) {\n      rrAppsEdge.applyRemovalPolicy(cdk.RemovalPolicy.DESTROY);\n    }\n  }\n}\n"]}
|
|
180
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
181
|
+
MicroAppsCF[_a] = { fqn: "@pwrdrvr/microapps-cdk.MicroAppsCF", version: "0.0.29" };
|
|
182
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MicroAppsCF.js","sourceRoot":"","sources":["../src/MicroAppsCF.ts"],"names":[],"mappings":"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","sourcesContent":["import { posix as posixPath } from 'path';\nimport * as apigwy from '@aws-cdk/aws-apigatewayv2';\nimport * as acm from '@aws-cdk/aws-certificatemanager';\nimport * as cf from '@aws-cdk/aws-cloudfront';\nimport * as cforigins from '@aws-cdk/aws-cloudfront-origins';\nimport * as r53 from '@aws-cdk/aws-route53';\nimport * as r53targets from '@aws-cdk/aws-route53-targets';\nimport * as s3 from '@aws-cdk/aws-s3';\nimport * as cdk from '@aws-cdk/core';\nimport { reverseDomain } from './utils/ReverseDomain';\n\nexport interface IMicroAppsCF {\n  readonly cloudFrontDistro: cf.Distribution;\n}\n\nexport interface MicroAppsCFProps {\n                                                                                                                                                                                                 \n  readonly removalPolicy?: cdk.RemovalPolicy;\n\n                                                           \n  readonly bucketAppsOrigin: cforigins.S3Origin;\n\n                                              \n  readonly bucketLogs?: s3.IBucket;\n\n                                                                                                                    \n  readonly domainNameEdge?: string;\n\n                                                                                                                                              \n  readonly domainNameOrigin?: string;\n\n                                                 \n  readonly httpApi: apigwy.HttpApi;\n\n                                                                                                                   \n  readonly assetNameRoot?: string;\n\n                                                                                            \n  readonly assetNameSuffix?: string;\n\n                                                                  \n  readonly certEdge?: acm.ICertificate;\n\n                                                                                 \n  readonly r53Zone?: r53.IHostedZone;\n\n                                                                                               \n  readonly rootPathPrefix?: string;\n}\n\nexport interface CreateAPIOriginPolicyOptions {\n  readonly assetNameRoot?: string;\n  readonly assetNameSuffix?: string;\n\n                                                                                                                                                                                   \n  readonly domainNameEdge?: string;\n}\n\nexport interface AddRoutesOptions {\n  readonly apiGwyOrigin: cf.IOrigin;\n  readonly bucketAppsOrigin: cforigins.S3Origin;\n  readonly distro: cf.Distribution;\n  readonly apigwyOriginRequestPolicy: cf.IOriginRequestPolicy;\n  readonly rootPathPrefix?: string;\n}\n\nexport class MicroAppsCF extends cdk.Construct implements IMicroAppsCF {\n                                                                                                                                                                                                                                                                                                                                                                                                                                  \n  public static createAPIOriginPolicy(\n    scope: cdk.Construct,\n    props: CreateAPIOriginPolicyOptions,\n  ): cf.IOriginRequestPolicy {\n    const { assetNameRoot, assetNameSuffix, domainNameEdge } = props;\n\n    let apigwyOriginRequestPolicy: cf.IOriginRequestPolicy = cf.OriginRequestPolicy.ALL_VIEWER;\n    if (domainNameEdge === undefined) {\n      // When not using a custom domain name we must limit down the origin policy to\n      // prevent it from passing the Host header (distribution_id.cloudfront.net) to\n      // apigwy which will then reject it with a 403 because it does not match the\n      // execute-api name that apigwy is expecting.\n      //\n      // 2021-12-28 - There is a bug in the name generation that causes the same asset\n      // in different stacks to have the same generated name.  We have to make the id\n      // in all cases to ensure the generated name is unique.\n      apigwyOriginRequestPolicy = new cf.OriginRequestPolicy(\n        scope,\n        `apigwy-origin-policy-${cdk.Stack.of(scope).stackName}`,\n        {\n          comment: assetNameRoot ? `${assetNameRoot}-apigwy${assetNameSuffix}` : undefined,\n\n          originRequestPolicyName: assetNameRoot\n            ? `${assetNameRoot}-apigwy${assetNameSuffix}`\n            : undefined,\n          cookieBehavior: cf.OriginRequestCookieBehavior.all(),\n          queryStringBehavior: cf.OriginRequestQueryStringBehavior.all(),\n          headerBehavior: cf.OriginRequestHeaderBehavior.allowList('user-agent', 'referer'),\n        },\n      );\n    }\n\n    return apigwyOriginRequestPolicy;\n  }\n\n                                                                                                                          \n  public static addRoutes(_scope: cdk.Construct, props: AddRoutesOptions) {\n    const {\n      apiGwyOrigin,\n      bucketAppsOrigin,\n      distro,\n      apigwyOriginRequestPolicy,\n      rootPathPrefix = '',\n    } = props;\n\n    //\n    // Add Behaviors\n    //\n    const s3BehaviorOptions: cf.AddBehaviorOptions = {\n      allowedMethods: cf.AllowedMethods.ALLOW_GET_HEAD_OPTIONS,\n      cachePolicy: cf.CachePolicy.CACHING_OPTIMIZED,\n      compress: true,\n      originRequestPolicy: cf.OriginRequestPolicy.CORS_S3_ORIGIN,\n      viewerProtocolPolicy: cf.ViewerProtocolPolicy.REDIRECT_TO_HTTPS,\n    };\n    const apiGwyBehaviorOptions: cf.AddBehaviorOptions = {\n      allowedMethods: cf.AllowedMethods.ALLOW_ALL,\n      // TODO: Caching needs to be set by the app response\n      cachePolicy: cf.CachePolicy.CACHING_DISABLED,\n      compress: true,\n      originRequestPolicy: apigwyOriginRequestPolicy,\n      viewerProtocolPolicy: cf.ViewerProtocolPolicy.REDIRECT_TO_HTTPS,\n    };\n\n    //\n    // All static assets are assumed to have a dot in them\n    //\n    distro.addBehavior(\n      posixPath.join(rootPathPrefix, '/*/*/*.*'),\n      bucketAppsOrigin,\n      s3BehaviorOptions,\n    );\n\n    //\n    // Everything that isn't a static asset is going to API Gateway\n    // There is no trailing slash because Serverless Next.js wants\n    // go load pages at /release/0.0.3 (with no trailing slash).\n    //\n    distro.addBehavior(posixPath.join(rootPathPrefix, '/*'), apiGwyOrigin, apiGwyBehaviorOptions);\n  }\n\n  private _cloudFrontDistro: cf.Distribution;\n  public get cloudFrontDistro(): cf.Distribution {\n    return this._cloudFrontDistro;\n  }\n\n                                                                                                                 \n  constructor(scope: cdk.Construct, id: string, props: MicroAppsCFProps) {\n    super(scope, id);\n\n    if (props === undefined) {\n      throw new Error('props must be set');\n    }\n\n    if (\n      (props.r53Zone === undefined && props.domainNameEdge !== undefined) ||\n      (props.r53Zone !== undefined && props.domainNameEdge === undefined)\n    ) {\n      throw new Error('If either of r53Zone or domainNameEdge are set then the other must be set');\n    }\n\n    const {\n      domainNameEdge,\n      domainNameOrigin,\n      httpApi,\n      removalPolicy,\n      certEdge,\n      assetNameRoot,\n      assetNameSuffix,\n      r53Zone,\n      bucketLogs,\n      bucketAppsOrigin,\n      rootPathPrefix,\n    } = props;\n\n    const apigwyOriginRequestPolicy = MicroAppsCF.createAPIOriginPolicy(this, {\n      assetNameRoot,\n      assetNameSuffix,\n      domainNameEdge,\n    });\n\n    //\n    // Determine URL of the origin FQDN\n    //\n    let httpOriginFQDN: string = 'invalid.pwrdrvr.com';\n    if (domainNameOrigin !== undefined) {\n      httpOriginFQDN = domainNameOrigin;\n    } else {\n      httpOriginFQDN = `${httpApi.apiId}.execute-api.${cdk.Aws.REGION}.amazonaws.com`;\n    }\n\n    //\n    // CloudFront Distro\n    //\n    const apiGwyOrigin = new cforigins.HttpOrigin(httpOriginFQDN, {\n      protocolPolicy: cf.OriginProtocolPolicy.HTTPS_ONLY,\n      originSslProtocols: [cf.OriginSslPolicy.TLS_V1_2],\n    });\n    this._cloudFrontDistro = new cf.Distribution(this, 'cft', {\n      comment: assetNameRoot ? `${assetNameRoot}${assetNameSuffix}` : domainNameEdge,\n      domainNames: domainNameEdge !== undefined ? [domainNameEdge] : undefined,\n      certificate: certEdge,\n      httpVersion: cf.HttpVersion.HTTP2,\n      defaultBehavior: {\n        allowedMethods: cf.AllowedMethods.ALLOW_ALL,\n        cachePolicy: cf.CachePolicy.CACHING_DISABLED,\n        compress: true,\n        originRequestPolicy: apigwyOriginRequestPolicy,\n        origin: apiGwyOrigin,\n        viewerProtocolPolicy: cf.ViewerProtocolPolicy.REDIRECT_TO_HTTPS,\n      },\n      enableIpv6: true,\n      priceClass: cf.PriceClass.PRICE_CLASS_100,\n      logBucket: bucketLogs,\n      logFilePrefix: props.domainNameEdge\n        ? `${reverseDomain(props.domainNameEdge)}/cloudfront-raw/`\n        : undefined,\n    });\n    if (removalPolicy !== undefined) {\n      this._cloudFrontDistro.applyRemovalPolicy(removalPolicy);\n    }\n\n    // Add routes to the CloudFront Distribution\n    MicroAppsCF.addRoutes(scope, {\n      apiGwyOrigin,\n      bucketAppsOrigin,\n      distro: this._cloudFrontDistro,\n      apigwyOriginRequestPolicy: apigwyOriginRequestPolicy,\n      rootPathPrefix,\n    });\n\n    //\n    // Create the edge name for the CloudFront distro\n    //\n\n    if (r53Zone !== undefined) {\n      const rrAppsEdge = new r53.RecordSet(this, 'edge-arecord', {\n        recordName: domainNameEdge,\n        recordType: r53.RecordType.A,\n        target: r53.RecordTarget.fromAlias(new r53targets.CloudFrontTarget(this._cloudFrontDistro)),\n        zone: r53Zone,\n      });\n      if (removalPolicy !== undefined) {\n        rrAppsEdge.applyRemovalPolicy(removalPolicy);\n      }\n    }\n  }\n}\n"]}
|
package/lib/MicroAppsS3.d.ts
CHANGED
|
@@ -2,42 +2,139 @@ import * as cf from '@aws-cdk/aws-cloudfront';
|
|
|
2
2
|
import * as cforigins from '@aws-cdk/aws-cloudfront-origins';
|
|
3
3
|
import * as s3 from '@aws-cdk/aws-s3';
|
|
4
4
|
import * as cdk from '@aws-cdk/core';
|
|
5
|
-
|
|
5
|
+
/**
|
|
6
|
+
* @stability stable
|
|
7
|
+
*/
|
|
8
|
+
export interface IMicroAppsS3 {
|
|
9
|
+
/**
|
|
10
|
+
* S3 bucket for deployed applications.
|
|
11
|
+
*
|
|
12
|
+
* @stability stable
|
|
13
|
+
*/
|
|
6
14
|
readonly bucketApps: s3.IBucket;
|
|
7
|
-
|
|
15
|
+
/**
|
|
16
|
+
* CloudFront Origin Access Identity for the deployed applications bucket.
|
|
17
|
+
*
|
|
18
|
+
* @stability stable
|
|
19
|
+
*/
|
|
8
20
|
readonly bucketAppsOAI: cf.OriginAccessIdentity;
|
|
21
|
+
/**
|
|
22
|
+
* CloudFront Origin for the deployed applications bucket.
|
|
23
|
+
*
|
|
24
|
+
* @stability stable
|
|
25
|
+
*/
|
|
9
26
|
readonly bucketAppsOrigin: cforigins.S3Origin;
|
|
27
|
+
/**
|
|
28
|
+
* S3 bucket for staged applications (prior to deploy).
|
|
29
|
+
*
|
|
30
|
+
* @stability stable
|
|
31
|
+
*/
|
|
10
32
|
readonly bucketAppsStaging: s3.IBucket;
|
|
11
|
-
|
|
33
|
+
/**
|
|
34
|
+
* S3 bucket for CloudFront logs.
|
|
35
|
+
*
|
|
36
|
+
* @stability stable
|
|
37
|
+
*/
|
|
12
38
|
readonly bucketLogs: s3.IBucket;
|
|
13
39
|
}
|
|
14
|
-
|
|
40
|
+
/**
|
|
41
|
+
* @stability stable
|
|
42
|
+
*/
|
|
43
|
+
export interface MicroAppsS3Props {
|
|
15
44
|
/**
|
|
16
|
-
*
|
|
17
|
-
* Requires that autoDeleteEverything be set to true.
|
|
45
|
+
* RemovalPolicy override for child resources.
|
|
18
46
|
*
|
|
19
|
-
*
|
|
47
|
+
* Note: if set to DESTROY the S3 buckes will have `autoDeleteObjects` set to `true`
|
|
48
|
+
*
|
|
49
|
+
* @default - per resource default
|
|
50
|
+
* @stability stable
|
|
20
51
|
*/
|
|
21
|
-
readonly
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
52
|
+
readonly removalPolicy?: cdk.RemovalPolicy;
|
|
53
|
+
/**
|
|
54
|
+
* S3 deployed apps bucket name.
|
|
55
|
+
*
|
|
56
|
+
* @default auto-assigned
|
|
57
|
+
* @stability stable
|
|
58
|
+
*/
|
|
59
|
+
readonly bucketAppsName?: string;
|
|
60
|
+
/**
|
|
61
|
+
* S3 staging apps bucket name.
|
|
62
|
+
*
|
|
63
|
+
* @default auto-assigned
|
|
64
|
+
* @stability stable
|
|
65
|
+
*/
|
|
66
|
+
readonly bucketAppsStagingName?: string;
|
|
67
|
+
/**
|
|
68
|
+
* S3 logs bucket name.
|
|
69
|
+
*
|
|
70
|
+
* @default auto-assigned
|
|
71
|
+
* @stability stable
|
|
72
|
+
*/
|
|
73
|
+
readonly bucketLogsName?: string;
|
|
74
|
+
/**
|
|
75
|
+
* Optional asset name root.
|
|
76
|
+
*
|
|
77
|
+
* @default - resource names auto assigned
|
|
78
|
+
* @stability stable
|
|
79
|
+
* @example
|
|
80
|
+
*
|
|
81
|
+
* microapps
|
|
82
|
+
*/
|
|
83
|
+
readonly assetNameRoot?: string;
|
|
84
|
+
/**
|
|
85
|
+
* Optional asset name suffix.
|
|
86
|
+
*
|
|
87
|
+
* @default none
|
|
88
|
+
* @stability stable
|
|
89
|
+
* @example
|
|
90
|
+
*
|
|
91
|
+
* -dev-pr-12
|
|
92
|
+
*/
|
|
93
|
+
readonly assetNameSuffix?: string;
|
|
25
94
|
}
|
|
26
|
-
|
|
95
|
+
/**
|
|
96
|
+
* @stability stable
|
|
97
|
+
*/
|
|
98
|
+
export declare class MicroAppsS3 extends cdk.Construct implements IMicroAppsS3 {
|
|
27
99
|
private _bucketApps;
|
|
100
|
+
/**
|
|
101
|
+
* S3 bucket for deployed applications.
|
|
102
|
+
*
|
|
103
|
+
* @stability stable
|
|
104
|
+
*/
|
|
28
105
|
get bucketApps(): s3.IBucket;
|
|
29
|
-
private _bucketAppsName;
|
|
30
|
-
get bucketAppsName(): string;
|
|
31
106
|
private _bucketAppsOAI;
|
|
107
|
+
/**
|
|
108
|
+
* CloudFront Origin Access Identity for the deployed applications bucket.
|
|
109
|
+
*
|
|
110
|
+
* @stability stable
|
|
111
|
+
*/
|
|
32
112
|
get bucketAppsOAI(): cf.OriginAccessIdentity;
|
|
33
113
|
private _bucketAppsOrigin;
|
|
114
|
+
/**
|
|
115
|
+
* CloudFront Origin for the deployed applications bucket.
|
|
116
|
+
*
|
|
117
|
+
* @stability stable
|
|
118
|
+
*/
|
|
34
119
|
get bucketAppsOrigin(): cforigins.S3Origin;
|
|
35
120
|
private _bucketAppsStaging;
|
|
121
|
+
/**
|
|
122
|
+
* S3 bucket for staged applications (prior to deploy).
|
|
123
|
+
*
|
|
124
|
+
* @stability stable
|
|
125
|
+
*/
|
|
36
126
|
get bucketAppsStaging(): s3.IBucket;
|
|
37
|
-
private _bucketAppsStagingName;
|
|
38
|
-
get bucketAppsStagingName(): string;
|
|
39
127
|
private _bucketLogs;
|
|
128
|
+
/**
|
|
129
|
+
* S3 bucket for CloudFront logs.
|
|
130
|
+
*
|
|
131
|
+
* @stability stable
|
|
132
|
+
*/
|
|
40
133
|
get bucketLogs(): s3.IBucket;
|
|
134
|
+
/**
|
|
135
|
+
* MicroApps - Create just S3 resources.
|
|
136
|
+
*
|
|
137
|
+
* @stability stable
|
|
138
|
+
*/
|
|
41
139
|
constructor(scope: cdk.Construct, id: string, props?: MicroAppsS3Props);
|
|
42
140
|
}
|
|
43
|
-
export {};
|
package/lib/MicroAppsS3.js
CHANGED
|
@@ -1,80 +1,104 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var _a;
|
|
2
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
4
|
exports.MicroAppsS3 = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
4
6
|
const cf = require("@aws-cdk/aws-cloudfront");
|
|
5
7
|
const cforigins = require("@aws-cdk/aws-cloudfront-origins");
|
|
6
8
|
const s3 = require("@aws-cdk/aws-s3");
|
|
7
9
|
const cdk = require("@aws-cdk/core");
|
|
10
|
+
/**
|
|
11
|
+
* @stability stable
|
|
12
|
+
*/
|
|
8
13
|
class MicroAppsS3 extends cdk.Construct {
|
|
14
|
+
/**
|
|
15
|
+
* MicroApps - Create just S3 resources.
|
|
16
|
+
*
|
|
17
|
+
* @stability stable
|
|
18
|
+
*/
|
|
9
19
|
constructor(scope, id, props) {
|
|
10
20
|
super(scope, id);
|
|
11
21
|
if (props === undefined) {
|
|
12
22
|
throw new Error('props must be set');
|
|
13
23
|
}
|
|
14
|
-
const {
|
|
15
|
-
// Use Auto-Delete S3Bucket
|
|
16
|
-
|
|
17
|
-
this._bucketAppsStagingName = `${reverseDomainName}-${assetNameRoot}-staging${assetNameSuffix}`;
|
|
18
|
-
const s3RemovalPolicy = autoDeleteEverything
|
|
19
|
-
? cdk.RemovalPolicy.DESTROY
|
|
20
|
-
: cdk.RemovalPolicy.RETAIN;
|
|
21
|
-
const s3AutoDeleteItems = autoDeleteEverything;
|
|
24
|
+
const { removalPolicy, assetNameRoot, assetNameSuffix } = props;
|
|
25
|
+
// Use Auto-Delete S3Bucket if removal policy is DESTROY
|
|
26
|
+
const s3AutoDeleteItems = removalPolicy === cdk.RemovalPolicy.DESTROY;
|
|
22
27
|
//
|
|
23
28
|
// S3 Bucket for Logging - Usable by many stacks
|
|
24
29
|
//
|
|
25
|
-
this._bucketLogs = new s3.Bucket(this, '
|
|
26
|
-
bucketName:
|
|
30
|
+
this._bucketLogs = new s3.Bucket(this, 'logs', {
|
|
31
|
+
bucketName: props.bucketLogsName,
|
|
27
32
|
autoDeleteObjects: s3AutoDeleteItems,
|
|
28
|
-
removalPolicy
|
|
33
|
+
removalPolicy,
|
|
29
34
|
});
|
|
30
35
|
//
|
|
31
36
|
// S3 Buckets for Apps
|
|
32
37
|
//
|
|
33
|
-
this._bucketApps = new s3.Bucket(this, '
|
|
34
|
-
bucketName:
|
|
38
|
+
this._bucketApps = new s3.Bucket(this, 'apps', {
|
|
39
|
+
bucketName: props.bucketAppsName,
|
|
35
40
|
autoDeleteObjects: s3AutoDeleteItems,
|
|
36
|
-
removalPolicy
|
|
41
|
+
removalPolicy,
|
|
37
42
|
});
|
|
38
|
-
this._bucketAppsStaging = new s3.Bucket(this, '
|
|
39
|
-
bucketName:
|
|
43
|
+
this._bucketAppsStaging = new s3.Bucket(this, 'staging', {
|
|
44
|
+
bucketName: props.bucketAppsStagingName,
|
|
40
45
|
autoDeleteObjects: s3AutoDeleteItems,
|
|
41
|
-
removalPolicy
|
|
46
|
+
removalPolicy,
|
|
42
47
|
});
|
|
43
48
|
// Create S3 Origin Identity
|
|
44
|
-
this._bucketAppsOAI = new cf.OriginAccessIdentity(this, '
|
|
45
|
-
comment: `${assetNameRoot}${assetNameSuffix}
|
|
49
|
+
this._bucketAppsOAI = new cf.OriginAccessIdentity(this, 'oai', {
|
|
50
|
+
comment: assetNameRoot !== undefined ? `${assetNameRoot}${assetNameSuffix}` : undefined,
|
|
46
51
|
});
|
|
47
|
-
if (
|
|
48
|
-
this._bucketAppsOAI.applyRemovalPolicy(
|
|
52
|
+
if (removalPolicy !== undefined) {
|
|
53
|
+
this._bucketAppsOAI.applyRemovalPolicy(removalPolicy);
|
|
49
54
|
}
|
|
50
|
-
//
|
|
51
|
-
// Add Origins
|
|
52
|
-
//
|
|
55
|
+
// Add Origin for CloudFront
|
|
53
56
|
this._bucketAppsOrigin = new cforigins.S3Origin(this._bucketApps, {
|
|
54
57
|
originAccessIdentity: this.bucketAppsOAI,
|
|
55
58
|
});
|
|
56
59
|
}
|
|
60
|
+
/**
|
|
61
|
+
* S3 bucket for deployed applications.
|
|
62
|
+
*
|
|
63
|
+
* @stability stable
|
|
64
|
+
*/
|
|
57
65
|
get bucketApps() {
|
|
58
66
|
return this._bucketApps;
|
|
59
67
|
}
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
68
|
+
/**
|
|
69
|
+
* CloudFront Origin Access Identity for the deployed applications bucket.
|
|
70
|
+
*
|
|
71
|
+
* @stability stable
|
|
72
|
+
*/
|
|
63
73
|
get bucketAppsOAI() {
|
|
64
74
|
return this._bucketAppsOAI;
|
|
65
75
|
}
|
|
76
|
+
/**
|
|
77
|
+
* CloudFront Origin for the deployed applications bucket.
|
|
78
|
+
*
|
|
79
|
+
* @stability stable
|
|
80
|
+
*/
|
|
66
81
|
get bucketAppsOrigin() {
|
|
67
82
|
return this._bucketAppsOrigin;
|
|
68
83
|
}
|
|
84
|
+
/**
|
|
85
|
+
* S3 bucket for staged applications (prior to deploy).
|
|
86
|
+
*
|
|
87
|
+
* @stability stable
|
|
88
|
+
*/
|
|
69
89
|
get bucketAppsStaging() {
|
|
70
90
|
return this._bucketAppsStaging;
|
|
71
91
|
}
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
92
|
+
/**
|
|
93
|
+
* S3 bucket for CloudFront logs.
|
|
94
|
+
*
|
|
95
|
+
* @stability stable
|
|
96
|
+
*/
|
|
75
97
|
get bucketLogs() {
|
|
76
98
|
return this._bucketLogs;
|
|
77
99
|
}
|
|
78
100
|
}
|
|
79
101
|
exports.MicroAppsS3 = MicroAppsS3;
|
|
80
|
-
|
|
102
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
103
|
+
MicroAppsS3[_a] = { fqn: "@pwrdrvr/microapps-cdk.MicroAppsS3", version: "0.0.29" };
|
|
104
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTWljcm9BcHBzUzMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvTWljcm9BcHBzUzMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSw4Q0FBOEM7QUFDOUMsNkRBQTZEO0FBQzdELHNDQUFzQztBQUN0QyxxQ0FBcUM7Ozs7QUF1Q3JDLE1BQWEsV0FBWSxTQUFRLEdBQUcsQ0FBQyxTQUFTOzs7Ozs7SUEyQjVDLFlBQVksS0FBb0IsRUFBRSxFQUFVLEVBQUUsS0FBd0I7UUFDcEUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixJQUFJLEtBQUssS0FBSyxTQUFTLEVBQUU7WUFDdkIsTUFBTSxJQUFJLEtBQUssQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO1NBQ3RDO1FBRUQsTUFBTSxFQUFFLGFBQWEsRUFBRSxhQUFhLEVBQUUsZUFBZSxFQUFFLEdBQUcsS0FBSyxDQUFDO1FBRWhFLHdEQUF3RDtRQUN4RCxNQUFNLGlCQUFpQixHQUFHLGFBQWEsS0FBSyxHQUFHLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQztRQUV0RSxFQUFFO1FBQ0YsZ0RBQWdEO1FBQ2hELEVBQUU7UUFDRixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksRUFBRSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsTUFBTSxFQUFFO1lBQzdDLFVBQVUsRUFBRSxLQUFLLENBQUMsY0FBYztZQUNoQyxpQkFBaUIsRUFBRSxpQkFBaUI7WUFDcEMsYUFBYTtTQUNkLENBQUMsQ0FBQztRQUVILEVBQUU7UUFDRixzQkFBc0I7UUFDdEIsRUFBRTtRQUNGLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxFQUFFLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRSxNQUFNLEVBQUU7WUFDN0MsVUFBVSxFQUFFLEtBQUssQ0FBQyxjQUFjO1lBQ2hDLGlCQUFpQixFQUFFLGlCQUFpQjtZQUNwQyxhQUFhO1NBQ2QsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLGtCQUFrQixHQUFHLElBQUksRUFBRSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFO1lBQ3ZELFVBQVUsRUFBRSxLQUFLLENBQUMscUJBQXFCO1lBQ3ZDLGlCQUFpQixFQUFFLGlCQUFpQjtZQUNwQyxhQUFhO1NBQ2QsQ0FBQyxDQUFDO1FBRUgsNEJBQTRCO1FBQzVCLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxFQUFFLENBQUMsb0JBQW9CLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRTtZQUM3RCxPQUFPLEVBQUUsYUFBYSxLQUFLLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRyxhQUFhLEdBQUcsZUFBZSxFQUFFLENBQUMsQ0FBQyxDQUFDLFNBQVM7U0FDeEYsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxhQUFhLEtBQUssU0FBUyxFQUFFO1lBQy9CLElBQUksQ0FBQyxjQUFjLENBQUMsa0JBQWtCLENBQUMsYUFBYSxDQUFDLENBQUM7U0FDdkQ7UUFFRCw0QkFBNEI7UUFDNUIsSUFBSSxDQUFDLGlCQUFpQixHQUFHLElBQUksU0FBUyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ2hFLG9CQUFvQixFQUFFLElBQUksQ0FBQyxhQUFhO1NBQ3pDLENBQUMsQ0FBQztJQUNMLENBQUM7Ozs7OztJQXhFRCxJQUFXLFVBQVU7UUFDbkIsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDO0lBQzFCLENBQUM7Ozs7OztJQUdELElBQVcsYUFBYTtRQUN0QixPQUFPLElBQUksQ0FBQyxjQUFjLENBQUM7SUFDN0IsQ0FBQzs7Ozs7O0lBR0QsSUFBVyxnQkFBZ0I7UUFDekIsT0FBTyxJQUFJLENBQUMsaUJBQWlCLENBQUM7SUFDaEMsQ0FBQzs7Ozs7O0lBR0QsSUFBVyxpQkFBaUI7UUFDMUIsT0FBTyxJQUFJLENBQUMsa0JBQWtCLENBQUM7SUFDakMsQ0FBQzs7Ozs7O0lBR0QsSUFBVyxVQUFVO1FBQ25CLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUMxQixDQUFDOztBQXhCSCxrQ0EyRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBjZiBmcm9tICdAYXdzLWNkay9hd3MtY2xvdWRmcm9udCc7XG5pbXBvcnQgKiBhcyBjZm9yaWdpbnMgZnJvbSAnQGF3cy1jZGsvYXdzLWNsb3VkZnJvbnQtb3JpZ2lucyc7XG5pbXBvcnQgKiBhcyBzMyBmcm9tICdAYXdzLWNkay9hd3MtczMnO1xuaW1wb3J0ICogYXMgY2RrIGZyb20gJ0Bhd3MtY2RrL2NvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElNaWNyb0FwcHNTMyB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IGJ1Y2tldEFwcHM6IHMzLklCdWNrZXQ7XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICByZWFkb25seSBidWNrZXRBcHBzT0FJOiBjZi5PcmlnaW5BY2Nlc3NJZGVudGl0eTtcblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbiAgcmVhZG9ubHkgYnVja2V0QXBwc09yaWdpbjogY2ZvcmlnaW5zLlMzT3JpZ2luO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICByZWFkb25seSBidWNrZXRBcHBzU3RhZ2luZzogczMuSUJ1Y2tldDtcblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICByZWFkb25seSBidWNrZXRMb2dzOiBzMy5JQnVja2V0O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1pY3JvQXBwc1MzUHJvcHMge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICByZWFkb25seSByZW1vdmFsUG9saWN5PzogY2RrLlJlbW92YWxQb2xpY3k7XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICByZWFkb25seSBidWNrZXRBcHBzTmFtZT86IHN0cmluZztcblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbiAgcmVhZG9ubHkgYnVja2V0QXBwc1N0YWdpbmdOYW1lPzogc3RyaW5nO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbiAgcmVhZG9ubHkgYnVja2V0TG9nc05hbWU/OiBzdHJpbmc7XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbiAgcmVhZG9ubHkgYXNzZXROYW1lUm9vdD86IHN0cmluZztcblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbiAgcmVhZG9ubHkgYXNzZXROYW1lU3VmZml4Pzogc3RyaW5nO1xufVxuXG5leHBvcnQgY2xhc3MgTWljcm9BcHBzUzMgZXh0ZW5kcyBjZGsuQ29uc3RydWN0IGltcGxlbWVudHMgSU1pY3JvQXBwc1MzIHtcbiAgcHJpdmF0ZSBfYnVja2V0QXBwczogczMuSUJ1Y2tldDtcbiAgcHVibGljIGdldCBidWNrZXRBcHBzKCk6IHMzLklCdWNrZXQge1xuICAgIHJldHVybiB0aGlzLl9idWNrZXRBcHBzO1xuICB9XG5cbiAgcHJpdmF0ZSBfYnVja2V0QXBwc09BSTogY2YuT3JpZ2luQWNjZXNzSWRlbnRpdHk7XG4gIHB1YmxpYyBnZXQgYnVja2V0QXBwc09BSSgpOiBjZi5PcmlnaW5BY2Nlc3NJZGVudGl0eSB7XG4gICAgcmV0dXJuIHRoaXMuX2J1Y2tldEFwcHNPQUk7XG4gIH1cblxuICBwcml2YXRlIF9idWNrZXRBcHBzT3JpZ2luOiBjZm9yaWdpbnMuUzNPcmlnaW47XG4gIHB1YmxpYyBnZXQgYnVja2V0QXBwc09yaWdpbigpOiBjZm9yaWdpbnMuUzNPcmlnaW4ge1xuICAgIHJldHVybiB0aGlzLl9idWNrZXRBcHBzT3JpZ2luO1xuICB9XG5cbiAgcHJpdmF0ZSBfYnVja2V0QXBwc1N0YWdpbmc6IHMzLklCdWNrZXQ7XG4gIHB1YmxpYyBnZXQgYnVja2V0QXBwc1N0YWdpbmcoKTogczMuSUJ1Y2tldCB7XG4gICAgcmV0dXJuIHRoaXMuX2J1Y2tldEFwcHNTdGFnaW5nO1xuICB9XG5cbiAgcHJpdmF0ZSBfYnVja2V0TG9nczogczMuSUJ1Y2tldDtcbiAgcHVibGljIGdldCBidWNrZXRMb2dzKCk6IHMzLklCdWNrZXQge1xuICAgIHJldHVybiB0aGlzLl9idWNrZXRMb2dzO1xuICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuICBjb25zdHJ1Y3RvcihzY29wZTogY2RrLkNvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM/OiBNaWNyb0FwcHNTM1Byb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIGlmIChwcm9wcyA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ3Byb3BzIG11c3QgYmUgc2V0Jyk7XG4gICAgfVxuXG4gICAgY29uc3QgeyByZW1vdmFsUG9saWN5LCBhc3NldE5hbWVSb290LCBhc3NldE5hbWVTdWZmaXggfSA9IHByb3BzO1xuXG4gICAgLy8gVXNlIEF1dG8tRGVsZXRlIFMzQnVja2V0IGlmIHJlbW92YWwgcG9saWN5IGlzIERFU1RST1lcbiAgICBjb25zdCBzM0F1dG9EZWxldGVJdGVtcyA9IHJlbW92YWxQb2xpY3kgPT09IGNkay5SZW1vdmFsUG9saWN5LkRFU1RST1k7XG5cbiAgICAvL1xuICAgIC8vIFMzIEJ1Y2tldCBmb3IgTG9nZ2luZyAtIFVzYWJsZSBieSBtYW55IHN0YWNrc1xuICAgIC8vXG4gICAgdGhpcy5fYnVja2V0TG9ncyA9IG5ldyBzMy5CdWNrZXQodGhpcywgJ2xvZ3MnLCB7XG4gICAgICBidWNrZXROYW1lOiBwcm9wcy5idWNrZXRMb2dzTmFtZSxcbiAgICAgIGF1dG9EZWxldGVPYmplY3RzOiBzM0F1dG9EZWxldGVJdGVtcyxcbiAgICAgIHJlbW92YWxQb2xpY3ksXG4gICAgfSk7XG5cbiAgICAvL1xuICAgIC8vIFMzIEJ1Y2tldHMgZm9yIEFwcHNcbiAgICAvL1xuICAgIHRoaXMuX2J1Y2tldEFwcHMgPSBuZXcgczMuQnVja2V0KHRoaXMsICdhcHBzJywge1xuICAgICAgYnVja2V0TmFtZTogcHJvcHMuYnVja2V0QXBwc05hbWUsXG4gICAgICBhdXRvRGVsZXRlT2JqZWN0czogczNBdXRvRGVsZXRlSXRlbXMsXG4gICAgICByZW1vdmFsUG9saWN5LFxuICAgIH0pO1xuICAgIHRoaXMuX2J1Y2tldEFwcHNTdGFnaW5nID0gbmV3IHMzLkJ1Y2tldCh0aGlzLCAnc3RhZ2luZycsIHtcbiAgICAgIGJ1Y2tldE5hbWU6IHByb3BzLmJ1Y2tldEFwcHNTdGFnaW5nTmFtZSxcbiAgICAgIGF1dG9EZWxldGVPYmplY3RzOiBzM0F1dG9EZWxldGVJdGVtcyxcbiAgICAgIHJlbW92YWxQb2xpY3ksXG4gICAgfSk7XG5cbiAgICAvLyBDcmVhdGUgUzMgT3JpZ2luIElkZW50aXR5XG4gICAgdGhpcy5fYnVja2V0QXBwc09BSSA9IG5ldyBjZi5PcmlnaW5BY2Nlc3NJZGVudGl0eSh0aGlzLCAnb2FpJywge1xuICAgICAgY29tbWVudDogYXNzZXROYW1lUm9vdCAhPT0gdW5kZWZpbmVkID8gYCR7YXNzZXROYW1lUm9vdH0ke2Fzc2V0TmFtZVN1ZmZpeH1gIDogdW5kZWZpbmVkLFxuICAgIH0pO1xuICAgIGlmIChyZW1vdmFsUG9saWN5ICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIHRoaXMuX2J1Y2tldEFwcHNPQUkuYXBwbHlSZW1vdmFsUG9saWN5KHJlbW92YWxQb2xpY3kpO1xuICAgIH1cblxuICAgIC8vIEFkZCBPcmlnaW4gZm9yIENsb3VkRnJvbnRcbiAgICB0aGlzLl9idWNrZXRBcHBzT3JpZ2luID0gbmV3IGNmb3JpZ2lucy5TM09yaWdpbih0aGlzLl9idWNrZXRBcHBzLCB7XG4gICAgICBvcmlnaW5BY2Nlc3NJZGVudGl0eTogdGhpcy5idWNrZXRBcHBzT0FJLFxuICAgIH0pO1xuICB9XG59XG4iXX0=
|