@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
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.MicroAppsAPIGwy = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
const apigwy = require("@aws-cdk/aws-apigatewayv2");
|
|
7
|
+
const iam = require("@aws-cdk/aws-iam");
|
|
8
|
+
const logs = require("@aws-cdk/aws-logs");
|
|
9
|
+
const r53 = require("@aws-cdk/aws-route53");
|
|
10
|
+
const r53targets = require("@aws-cdk/aws-route53-targets");
|
|
11
|
+
const cdk = require("@aws-cdk/core");
|
|
12
|
+
/**
|
|
13
|
+
* @stability stable
|
|
14
|
+
*/
|
|
15
|
+
class MicroAppsAPIGwy extends cdk.Construct {
|
|
16
|
+
/**
|
|
17
|
+
* MicroApps - Create just API Gateway.
|
|
18
|
+
*
|
|
19
|
+
* @stability stable
|
|
20
|
+
*/
|
|
21
|
+
constructor(scope, id, props) {
|
|
22
|
+
super(scope, id);
|
|
23
|
+
if (props === undefined) {
|
|
24
|
+
throw new Error('props cannot be undefined');
|
|
25
|
+
}
|
|
26
|
+
if ((props.r53Zone === undefined && props.domainNameEdge !== undefined) ||
|
|
27
|
+
(props.r53Zone !== undefined && props.domainNameEdge === undefined)) {
|
|
28
|
+
throw new Error('If either of r53Zone or domainNameEdge are set then the other must be set');
|
|
29
|
+
}
|
|
30
|
+
if ((props.domainNameOrigin === undefined && props.certOrigin !== undefined) ||
|
|
31
|
+
(props.domainNameOrigin !== undefined && props.certOrigin === undefined)) {
|
|
32
|
+
throw new Error('If either of domainNameOrigin or certOrigin are set then the other must be set');
|
|
33
|
+
}
|
|
34
|
+
if ((props.domainNameEdge === undefined && props.certOrigin !== undefined) ||
|
|
35
|
+
(props.domainNameEdge !== undefined && props.certOrigin === undefined)) {
|
|
36
|
+
throw new Error('If either of domainNameOrigin or certOrigin are set then the other must be set');
|
|
37
|
+
}
|
|
38
|
+
const { r53Zone, domainNameEdge, domainNameOrigin, certOrigin, removalPolicy, assetNameRoot, assetNameSuffix, rootPathPrefix, } = props;
|
|
39
|
+
// API Gateway uses the `id` string as the gateway name without
|
|
40
|
+
// any randomization... we have to make sure the name is unique-ish
|
|
41
|
+
const apigatewayName = assetNameRoot
|
|
42
|
+
? `${assetNameRoot}${assetNameSuffix}`
|
|
43
|
+
: `${cdk.Stack.of(this).stackName}-microapps`;
|
|
44
|
+
//
|
|
45
|
+
// APIGateway domain names for CloudFront and origin
|
|
46
|
+
//
|
|
47
|
+
this._httpApi = new apigwy.HttpApi(this, 'gwy', {
|
|
48
|
+
apiName: apigatewayName,
|
|
49
|
+
createDefaultStage: false,
|
|
50
|
+
});
|
|
51
|
+
if (removalPolicy !== undefined) {
|
|
52
|
+
this._httpApi.applyRemovalPolicy(removalPolicy);
|
|
53
|
+
}
|
|
54
|
+
// Create the stage
|
|
55
|
+
const stage = new apigwy.HttpStage(this, 'stage', {
|
|
56
|
+
httpApi: this._httpApi,
|
|
57
|
+
autoDeploy: true,
|
|
58
|
+
// If rootPathPrefix is not defined this will be the $default stage
|
|
59
|
+
stageName: rootPathPrefix,
|
|
60
|
+
});
|
|
61
|
+
if (domainNameEdge !== undefined && certOrigin !== undefined) {
|
|
62
|
+
// Create Custom Domains for API Gateway
|
|
63
|
+
const dnAppsEdge = new apigwy.DomainName(this, 'microapps-apps-edge-dn', {
|
|
64
|
+
domainName: domainNameEdge,
|
|
65
|
+
certificate: certOrigin,
|
|
66
|
+
});
|
|
67
|
+
if (removalPolicy !== undefined) {
|
|
68
|
+
dnAppsEdge.applyRemovalPolicy(removalPolicy);
|
|
69
|
+
}
|
|
70
|
+
// Create the edge domain name mapping for the API
|
|
71
|
+
const apiMapping = new apigwy.ApiMapping(this, 'mapping', {
|
|
72
|
+
api: this._httpApi,
|
|
73
|
+
domainName: dnAppsEdge,
|
|
74
|
+
stage,
|
|
75
|
+
});
|
|
76
|
+
// 2022-01-16 - CDK is still generating CloudFormation with no dependency
|
|
77
|
+
// between the R53 RecordSet and the Mapping
|
|
78
|
+
apiMapping.node.addDependency(dnAppsEdge);
|
|
79
|
+
}
|
|
80
|
+
if (domainNameOrigin !== undefined && certOrigin !== undefined) {
|
|
81
|
+
this._dnAppsOrigin = new apigwy.DomainName(this, 'origin-dn', {
|
|
82
|
+
domainName: domainNameOrigin,
|
|
83
|
+
certificate: certOrigin,
|
|
84
|
+
});
|
|
85
|
+
if (removalPolicy !== undefined) {
|
|
86
|
+
this._dnAppsOrigin.applyRemovalPolicy(removalPolicy);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
// Enable access logs on API Gateway
|
|
90
|
+
const apiAccessLogs = new logs.LogGroup(this, 'logs', {
|
|
91
|
+
logGroupName: apigatewayName
|
|
92
|
+
? `/aws/apigwy/${apigatewayName}`
|
|
93
|
+
: `/aws/apigwy/${this.httpApi.httpApiName}`,
|
|
94
|
+
retention: logs.RetentionDays.TWO_WEEKS,
|
|
95
|
+
});
|
|
96
|
+
if (removalPolicy !== undefined) {
|
|
97
|
+
apiAccessLogs.applyRemovalPolicy(removalPolicy);
|
|
98
|
+
}
|
|
99
|
+
// const stage = this._httpApi.defaultStage?.node.defaultChild as apigwy.CfnStage;
|
|
100
|
+
stage.accessLogSettings = {
|
|
101
|
+
destinationArn: apiAccessLogs.logGroupArn,
|
|
102
|
+
format: JSON.stringify({
|
|
103
|
+
requestId: '$context.requestId',
|
|
104
|
+
userAgent: '$context.identity.userAgent',
|
|
105
|
+
sourceIp: '$context.identity.sourceIp',
|
|
106
|
+
requestTime: '$context.requestTime',
|
|
107
|
+
requestTimeEpoch: '$context.requestTimeEpoch',
|
|
108
|
+
httpMethod: '$context.httpMethod',
|
|
109
|
+
path: '$context.path',
|
|
110
|
+
status: '$context.status',
|
|
111
|
+
protocol: '$context.protocol',
|
|
112
|
+
responseLength: '$context.responseLength',
|
|
113
|
+
domainName: '$context.domainName',
|
|
114
|
+
}),
|
|
115
|
+
};
|
|
116
|
+
// Create a logging role
|
|
117
|
+
// Tips: https://github.com/aws/aws-cdk/issues/11100
|
|
118
|
+
const apiGwyLogRole = new iam.Role(this, 'logs-role', {
|
|
119
|
+
managedPolicies: [
|
|
120
|
+
iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AmazonAPIGatewayPushToCloudWatchLogs'),
|
|
121
|
+
],
|
|
122
|
+
assumedBy: new iam.ServicePrincipal('apigateway.amazonaws.com'),
|
|
123
|
+
});
|
|
124
|
+
apiAccessLogs.grantWrite(apiGwyLogRole);
|
|
125
|
+
//
|
|
126
|
+
// Let API Gateway accept requests using domainNameOrigin
|
|
127
|
+
// That is the origin URI that CloudFront uses for this gateway.
|
|
128
|
+
// The gateway will refuse the traffic if it doesn't have the
|
|
129
|
+
// domain name registered.
|
|
130
|
+
//
|
|
131
|
+
if (this._dnAppsOrigin !== undefined) {
|
|
132
|
+
const mappingAppsApis = new apigwy.ApiMapping(this, 'api-map-origin', {
|
|
133
|
+
api: this._httpApi,
|
|
134
|
+
domainName: this._dnAppsOrigin,
|
|
135
|
+
stage,
|
|
136
|
+
});
|
|
137
|
+
// 2022-01-16 - CDK is still generating CloudFormation with no dependency
|
|
138
|
+
// between the R53 RecordSet and the Mapping
|
|
139
|
+
mappingAppsApis.node.addDependency(this._dnAppsOrigin);
|
|
140
|
+
if (removalPolicy !== undefined) {
|
|
141
|
+
mappingAppsApis.applyRemovalPolicy(removalPolicy);
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
//
|
|
145
|
+
// Create the origin name for API Gateway
|
|
146
|
+
//
|
|
147
|
+
if (r53Zone !== undefined && this._dnAppsOrigin) {
|
|
148
|
+
const rrAppsOrigin = new r53.ARecord(this, 'origin-arecord', {
|
|
149
|
+
zone: r53Zone,
|
|
150
|
+
recordName: domainNameOrigin,
|
|
151
|
+
target: r53.RecordTarget.fromAlias(new r53targets.ApiGatewayv2DomainProperties(this._dnAppsOrigin.regionalDomainName, this._dnAppsOrigin.regionalHostedZoneId)),
|
|
152
|
+
});
|
|
153
|
+
if (removalPolicy !== undefined) {
|
|
154
|
+
rrAppsOrigin.applyRemovalPolicy(removalPolicy);
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
/**
|
|
159
|
+
* Domain Name applied to API Gateway origin.
|
|
160
|
+
*
|
|
161
|
+
* @stability stable
|
|
162
|
+
*/
|
|
163
|
+
get dnAppsOrigin() {
|
|
164
|
+
return this._dnAppsOrigin;
|
|
165
|
+
}
|
|
166
|
+
/**
|
|
167
|
+
* API Gateway.
|
|
168
|
+
*
|
|
169
|
+
* @stability stable
|
|
170
|
+
*/
|
|
171
|
+
get httpApi() {
|
|
172
|
+
return this._httpApi;
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
exports.MicroAppsAPIGwy = MicroAppsAPIGwy;
|
|
176
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
177
|
+
MicroAppsAPIGwy[_a] = { fqn: "@pwrdrvr/microapps-cdk.MicroAppsAPIGwy", version: "0.0.29" };
|
|
178
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MicroAppsAPIGwy.js","sourceRoot":"","sources":["../src/MicroAppsAPIGwy.ts"],"names":[],"mappings":"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","sourcesContent":["import * as apigwy from '@aws-cdk/aws-apigatewayv2';\nimport * as acm from '@aws-cdk/aws-certificatemanager';\nimport * as iam from '@aws-cdk/aws-iam';\nimport * as logs from '@aws-cdk/aws-logs';\nimport * as r53 from '@aws-cdk/aws-route53';\nimport * as r53targets from '@aws-cdk/aws-route53-targets';\nimport * as cdk from '@aws-cdk/core';\n\nexport interface MicroAppsAPIGwyProps {\n                                                                                                                                                                                                 \n  readonly removalPolicy?: cdk.RemovalPolicy;\n\n                                                                                                            \n  readonly domainNameEdge?: string;\n\n                                                                                                                      \n  readonly domainNameOrigin?: string;\n\n                                                                                                                   \n  readonly assetNameRoot?: string;\n\n                                                                                            \n  readonly assetNameSuffix?: string;\n\n                                                                                                                                                    \n  readonly certOrigin?: acm.ICertificate;\n\n                                                                                 \n  readonly r53Zone?: r53.IHostedZone;\n\n                                                                                                            \n  readonly rootPathPrefix?: string;\n}\n\nexport interface IMicroAppsAPIGwy {\n                                                          \n  readonly dnAppsOrigin?: apigwy.IDomainName;\n\n                            \n  readonly httpApi: apigwy.HttpApi;\n}\n\nexport class MicroAppsAPIGwy extends cdk.Construct implements IMicroAppsAPIGwy {\n  private _dnAppsOrigin: apigwy.DomainName | undefined;\n  public get dnAppsOrigin(): apigwy.IDomainName | undefined {\n    return this._dnAppsOrigin;\n  }\n\n  private _httpApi: apigwy.HttpApi;\n  public get httpApi(): apigwy.HttpApi {\n    return this._httpApi;\n  }\n\n                                                                                                       \n  constructor(scope: cdk.Construct, id: string, props?: MicroAppsAPIGwyProps) {\n    super(scope, id);\n\n    if (props === undefined) {\n      throw new Error('props cannot be undefined');\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    if (\n      (props.domainNameOrigin === undefined && props.certOrigin !== undefined) ||\n      (props.domainNameOrigin !== undefined && props.certOrigin === undefined)\n    ) {\n      throw new Error(\n        'If either of domainNameOrigin or certOrigin are set then the other must be set',\n      );\n    }\n\n    if (\n      (props.domainNameEdge === undefined && props.certOrigin !== undefined) ||\n      (props.domainNameEdge !== undefined && props.certOrigin === undefined)\n    ) {\n      throw new Error(\n        'If either of domainNameOrigin or certOrigin are set then the other must be set',\n      );\n    }\n\n    const {\n      r53Zone,\n      domainNameEdge,\n      domainNameOrigin,\n      certOrigin,\n      removalPolicy,\n      assetNameRoot,\n      assetNameSuffix,\n      rootPathPrefix,\n    } = props;\n\n    // API Gateway uses the `id` string as the gateway name without\n    // any randomization... we have to make sure the name is unique-ish\n    const apigatewayName = assetNameRoot\n      ? `${assetNameRoot}${assetNameSuffix}`\n      : `${cdk.Stack.of(this).stackName}-microapps`;\n\n    //\n    // APIGateway domain names for CloudFront and origin\n    //\n    this._httpApi = new apigwy.HttpApi(this, 'gwy', {\n      apiName: apigatewayName,\n      createDefaultStage: false,\n    });\n    if (removalPolicy !== undefined) {\n      this._httpApi.applyRemovalPolicy(removalPolicy);\n    }\n\n    // Create the stage\n    const stage = new apigwy.HttpStage(this, 'stage', {\n      httpApi: this._httpApi,\n      autoDeploy: true,\n      // If rootPathPrefix is not defined this will be the $default stage\n      stageName: rootPathPrefix,\n    });\n\n    if (domainNameEdge !== undefined && certOrigin !== undefined) {\n      // Create Custom Domains for API Gateway\n      const dnAppsEdge = new apigwy.DomainName(this, 'microapps-apps-edge-dn', {\n        domainName: domainNameEdge,\n        certificate: certOrigin,\n      });\n      if (removalPolicy !== undefined) {\n        dnAppsEdge.applyRemovalPolicy(removalPolicy);\n      }\n\n      // Create the edge domain name mapping for the API\n      const apiMapping = new apigwy.ApiMapping(this, 'mapping', {\n        api: this._httpApi,\n        domainName: dnAppsEdge,\n        stage,\n      });\n      // 2022-01-16 - CDK is still generating CloudFormation with no dependency\n      // between the R53 RecordSet and the Mapping\n      apiMapping.node.addDependency(dnAppsEdge);\n    }\n\n    if (domainNameOrigin !== undefined && certOrigin !== undefined) {\n      this._dnAppsOrigin = new apigwy.DomainName(this, 'origin-dn', {\n        domainName: domainNameOrigin,\n        certificate: certOrigin,\n      });\n      if (removalPolicy !== undefined) {\n        this._dnAppsOrigin.applyRemovalPolicy(removalPolicy);\n      }\n    }\n\n    // Enable access logs on API Gateway\n    const apiAccessLogs = new logs.LogGroup(this, 'logs', {\n      logGroupName: apigatewayName\n        ? `/aws/apigwy/${apigatewayName}`\n        : `/aws/apigwy/${this.httpApi.httpApiName}`,\n      retention: logs.RetentionDays.TWO_WEEKS,\n    });\n    if (removalPolicy !== undefined) {\n      apiAccessLogs.applyRemovalPolicy(removalPolicy);\n    }\n    // const stage = this._httpApi.defaultStage?.node.defaultChild as apigwy.CfnStage;\n    (stage as unknown as apigwy.CfnStage).accessLogSettings = {\n      destinationArn: apiAccessLogs.logGroupArn,\n      format: JSON.stringify({\n        requestId: '$context.requestId',\n        userAgent: '$context.identity.userAgent',\n        sourceIp: '$context.identity.sourceIp',\n        requestTime: '$context.requestTime',\n        requestTimeEpoch: '$context.requestTimeEpoch',\n        httpMethod: '$context.httpMethod',\n        path: '$context.path',\n        status: '$context.status',\n        protocol: '$context.protocol',\n        responseLength: '$context.responseLength',\n        domainName: '$context.domainName',\n      }),\n    };\n\n    // Create a logging role\n    // Tips: https://github.com/aws/aws-cdk/issues/11100\n    const apiGwyLogRole = new iam.Role(this, 'logs-role', {\n      managedPolicies: [\n        iam.ManagedPolicy.fromAwsManagedPolicyName(\n          'service-role/AmazonAPIGatewayPushToCloudWatchLogs',\n        ),\n      ],\n      assumedBy: new iam.ServicePrincipal('apigateway.amazonaws.com'),\n    });\n    apiAccessLogs.grantWrite(apiGwyLogRole);\n\n    //\n    // Let API Gateway accept requests using domainNameOrigin\n    // That is the origin URI that CloudFront uses for this gateway.\n    // The gateway will refuse the traffic if it doesn't have the\n    // domain name registered.\n    //\n    if (this._dnAppsOrigin !== undefined) {\n      const mappingAppsApis = new apigwy.ApiMapping(this, 'api-map-origin', {\n        api: this._httpApi,\n        domainName: this._dnAppsOrigin,\n        stage,\n      });\n      // 2022-01-16 - CDK is still generating CloudFormation with no dependency\n      // between the R53 RecordSet and the Mapping\n      mappingAppsApis.node.addDependency(this._dnAppsOrigin);\n      if (removalPolicy !== undefined) {\n        mappingAppsApis.applyRemovalPolicy(removalPolicy);\n      }\n    }\n\n    //\n    // Create the origin name for API Gateway\n    //\n    if (r53Zone !== undefined && this._dnAppsOrigin) {\n      const rrAppsOrigin = new r53.ARecord(this, 'origin-arecord', {\n        zone: r53Zone,\n        recordName: domainNameOrigin,\n        target: r53.RecordTarget.fromAlias(\n          new r53targets.ApiGatewayv2DomainProperties(\n            this._dnAppsOrigin.regionalDomainName,\n            this._dnAppsOrigin.regionalHostedZoneId,\n          ),\n        ),\n      });\n      if (removalPolicy !== undefined) {\n        rrAppsOrigin.applyRemovalPolicy(removalPolicy);\n      }\n    }\n  }\n}\n"]}
|
package/lib/MicroAppsCF.d.ts
CHANGED
|
@@ -1,26 +1,188 @@
|
|
|
1
|
+
import * as apigwy from '@aws-cdk/aws-apigatewayv2';
|
|
1
2
|
import * as acm from '@aws-cdk/aws-certificatemanager';
|
|
2
3
|
import * as cf from '@aws-cdk/aws-cloudfront';
|
|
4
|
+
import * as cforigins from '@aws-cdk/aws-cloudfront-origins';
|
|
5
|
+
import * as r53 from '@aws-cdk/aws-route53';
|
|
6
|
+
import * as s3 from '@aws-cdk/aws-s3';
|
|
3
7
|
import * as cdk from '@aws-cdk/core';
|
|
4
|
-
|
|
5
|
-
|
|
8
|
+
/**
|
|
9
|
+
* @stability stable
|
|
10
|
+
*/
|
|
11
|
+
export interface IMicroAppsCF {
|
|
12
|
+
/**
|
|
13
|
+
* @stability stable
|
|
14
|
+
*/
|
|
6
15
|
readonly cloudFrontDistro: cf.Distribution;
|
|
7
16
|
}
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
17
|
+
/**
|
|
18
|
+
* @stability stable
|
|
19
|
+
*/
|
|
20
|
+
export interface MicroAppsCFProps {
|
|
21
|
+
/**
|
|
22
|
+
* RemovalPolicy override for child resources.
|
|
23
|
+
*
|
|
24
|
+
* Note: if set to DESTROY the S3 buckes will have `autoDeleteObjects` set to `true`
|
|
25
|
+
*
|
|
26
|
+
* @default - per resource default
|
|
27
|
+
* @stability stable
|
|
28
|
+
*/
|
|
29
|
+
readonly removalPolicy?: cdk.RemovalPolicy;
|
|
30
|
+
/**
|
|
31
|
+
* S3 bucket origin for deployed applications.
|
|
32
|
+
*
|
|
33
|
+
* @stability stable
|
|
34
|
+
*/
|
|
35
|
+
readonly bucketAppsOrigin: cforigins.S3Origin;
|
|
36
|
+
/**
|
|
37
|
+
* S3 bucket for CloudFront logs.
|
|
38
|
+
*
|
|
39
|
+
* @stability stable
|
|
40
|
+
*/
|
|
41
|
+
readonly bucketLogs?: s3.IBucket;
|
|
42
|
+
/**
|
|
43
|
+
* CloudFront Distribution domain name.
|
|
44
|
+
*
|
|
45
|
+
* @default auto-assigned
|
|
46
|
+
* @stability stable
|
|
47
|
+
* @example
|
|
48
|
+
*
|
|
49
|
+
* apps.pwrdrvr.com
|
|
50
|
+
*/
|
|
51
|
+
readonly domainNameEdge?: string;
|
|
52
|
+
/**
|
|
53
|
+
* API Gateway custom origin domain name.
|
|
54
|
+
*
|
|
55
|
+
* @default - retrieved from httpApi, if possible
|
|
56
|
+
* @stability stable
|
|
57
|
+
* @example
|
|
58
|
+
*
|
|
59
|
+
* apps.pwrdrvr.com
|
|
60
|
+
*/
|
|
61
|
+
readonly domainNameOrigin?: string;
|
|
62
|
+
/**
|
|
63
|
+
* API Gateway v2 HTTP API for apps.
|
|
64
|
+
*
|
|
65
|
+
* @stability stable
|
|
66
|
+
*/
|
|
67
|
+
readonly httpApi: apigwy.HttpApi;
|
|
68
|
+
/**
|
|
69
|
+
* Optional asset name root.
|
|
70
|
+
*
|
|
71
|
+
* @default - resource names auto assigned
|
|
72
|
+
* @stability stable
|
|
73
|
+
* @example
|
|
74
|
+
*
|
|
75
|
+
* microapps
|
|
76
|
+
*/
|
|
77
|
+
readonly assetNameRoot?: string;
|
|
78
|
+
/**
|
|
79
|
+
* Optional asset name suffix.
|
|
80
|
+
*
|
|
81
|
+
* @default none
|
|
82
|
+
* @stability stable
|
|
83
|
+
* @example
|
|
84
|
+
*
|
|
85
|
+
* -dev-pr-12
|
|
86
|
+
*/
|
|
87
|
+
readonly assetNameSuffix?: string;
|
|
88
|
+
/**
|
|
89
|
+
* ACM Certificate that covers `domainNameEdge` name.
|
|
90
|
+
*
|
|
91
|
+
* @stability stable
|
|
92
|
+
*/
|
|
93
|
+
readonly certEdge?: acm.ICertificate;
|
|
94
|
+
/**
|
|
95
|
+
* Route53 zone in which to create optional `domainNameEdge` record.
|
|
96
|
+
*
|
|
97
|
+
* @stability stable
|
|
98
|
+
*/
|
|
99
|
+
readonly r53Zone?: r53.IHostedZone;
|
|
100
|
+
/**
|
|
101
|
+
* Path prefix on the root of the CloudFront distribution.
|
|
102
|
+
*
|
|
103
|
+
* @stability stable
|
|
104
|
+
* @example
|
|
105
|
+
*
|
|
106
|
+
* dev/
|
|
107
|
+
*/
|
|
108
|
+
readonly rootPathPrefix?: string;
|
|
20
109
|
}
|
|
21
|
-
|
|
110
|
+
/**
|
|
111
|
+
* @stability stable
|
|
112
|
+
*/
|
|
113
|
+
export interface CreateAPIOriginPolicyOptions {
|
|
114
|
+
/**
|
|
115
|
+
* @stability stable
|
|
116
|
+
*/
|
|
117
|
+
readonly assetNameRoot?: string;
|
|
118
|
+
/**
|
|
119
|
+
* @stability stable
|
|
120
|
+
*/
|
|
121
|
+
readonly assetNameSuffix?: string;
|
|
122
|
+
/**
|
|
123
|
+
* Edge domain name used by CloudFront - If set a custom OriginRequestPolicy will be created that prevents the Host header from being passed to the origin.
|
|
124
|
+
*
|
|
125
|
+
* @stability stable
|
|
126
|
+
*/
|
|
127
|
+
readonly domainNameEdge?: string;
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* @stability stable
|
|
131
|
+
*/
|
|
132
|
+
export interface AddRoutesOptions {
|
|
133
|
+
/**
|
|
134
|
+
* @stability stable
|
|
135
|
+
*/
|
|
136
|
+
readonly apiGwyOrigin: cf.IOrigin;
|
|
137
|
+
/**
|
|
138
|
+
* @stability stable
|
|
139
|
+
*/
|
|
140
|
+
readonly bucketAppsOrigin: cforigins.S3Origin;
|
|
141
|
+
/**
|
|
142
|
+
* @stability stable
|
|
143
|
+
*/
|
|
144
|
+
readonly distro: cf.Distribution;
|
|
145
|
+
/**
|
|
146
|
+
* @stability stable
|
|
147
|
+
*/
|
|
148
|
+
readonly apigwyOriginRequestPolicy: cf.IOriginRequestPolicy;
|
|
149
|
+
/**
|
|
150
|
+
* @stability stable
|
|
151
|
+
*/
|
|
152
|
+
readonly rootPathPrefix?: string;
|
|
153
|
+
}
|
|
154
|
+
/**
|
|
155
|
+
* @stability stable
|
|
156
|
+
*/
|
|
157
|
+
export declare class MicroAppsCF extends cdk.Construct implements IMicroAppsCF {
|
|
158
|
+
/**
|
|
159
|
+
* Create or get the origin request policy.
|
|
160
|
+
*
|
|
161
|
+
* If a custom domain name is NOT used for the origin then a policy
|
|
162
|
+
* will be created.
|
|
163
|
+
*
|
|
164
|
+
* If a custom domain name IS used for the origin then the ALL_VIEWER
|
|
165
|
+
* policy will be returned. This policy passes the Host header to the
|
|
166
|
+
* origin, which is fine when using a custom domain name on the origin.
|
|
167
|
+
*
|
|
168
|
+
* @stability stable
|
|
169
|
+
*/
|
|
170
|
+
static createAPIOriginPolicy(scope: cdk.Construct, props: CreateAPIOriginPolicyOptions): cf.IOriginRequestPolicy;
|
|
171
|
+
/**
|
|
172
|
+
* Add API Gateway and S3 routes to an existing CloudFront Distribution.
|
|
173
|
+
*
|
|
174
|
+
* @stability stable
|
|
175
|
+
*/
|
|
176
|
+
static addRoutes(_scope: cdk.Construct, props: AddRoutesOptions): void;
|
|
22
177
|
private _cloudFrontDistro;
|
|
178
|
+
/**
|
|
179
|
+
* @stability stable
|
|
180
|
+
*/
|
|
23
181
|
get cloudFrontDistro(): cf.Distribution;
|
|
24
|
-
|
|
182
|
+
/**
|
|
183
|
+
* MicroApps - Create just CloudFront resources.
|
|
184
|
+
*
|
|
185
|
+
* @stability stable
|
|
186
|
+
*/
|
|
187
|
+
constructor(scope: cdk.Construct, id: string, props: MicroAppsCFProps);
|
|
25
188
|
}
|
|
26
|
-
export {};
|