@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.
@@ -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"]}
@@ -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
- import { IMicroAppsS3Exports } from './MicroAppsS3';
5
- export interface IMicroAppsCFExports {
8
+ /**
9
+ * @stability stable
10
+ */
11
+ export interface IMicroAppsCF {
12
+ /**
13
+ * @stability stable
14
+ */
6
15
  readonly cloudFrontDistro: cf.Distribution;
7
16
  }
8
- interface MicroAppsCFProps extends cdk.ResourceProps {
9
- readonly autoDeleteEverything: boolean;
10
- readonly s3Exports: IMicroAppsS3Exports;
11
- readonly reverseDomainName: string;
12
- readonly domainName: string;
13
- readonly domainNameEdge: string;
14
- readonly domainNameOrigin: string;
15
- readonly assetNameRoot: string;
16
- readonly assetNameSuffix: string;
17
- readonly certEdge: acm.ICertificate;
18
- readonly r53ZoneName: string;
19
- readonly r53ZoneID: string;
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
- export declare class MicroAppsCF extends cdk.Construct implements IMicroAppsCFExports {
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
- constructor(scope: cdk.Construct, id: string, props?: MicroAppsCFProps);
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 {};