@sylvesterllc/aws-constructs 1.0.30 → 1.0.31
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/dist/config/ServiceBundleConfig.d.ts +16 -0
- package/dist/config/ServiceBundleConfig.js +3 -0
- package/dist/constructs/MicroService.js +10 -2
- package/dist/resources/gateway/createMicroServiceBundle.d.ts +3 -14
- package/dist/resources/gateway/createMicroServiceBundle.js +18 -23
- package/dist/resources/lambda/createLambda.js +2 -2
- package/package.json +1 -1
- package/src/config/ServiceBundleConfig.ts +18 -0
- package/src/constructs/MicroService.ts +8 -2
- package/src/resources/gateway/createMicroServiceBundle.ts +19 -27
- package/src/resources/lambda/createLambda.ts +1 -1
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { IRestApi } from "aws-cdk-lib/aws-apigateway";
|
|
2
|
+
import { Construct } from "constructs";
|
|
3
|
+
import { MicroserviceProps } from "../interfaces/MicroserviceProps";
|
|
4
|
+
import { AppConfig } from "./AppConfig";
|
|
5
|
+
import { Table } from "aws-cdk-lib/aws-dynamodb";
|
|
6
|
+
import { ISecret } from "aws-cdk-lib/aws-secretsmanager";
|
|
7
|
+
import { LayerVersion } from "aws-cdk-lib/aws-lambda";
|
|
8
|
+
export interface ServiceBundleConfig {
|
|
9
|
+
scope: Construct;
|
|
10
|
+
readonly gatewayApi: IRestApi;
|
|
11
|
+
readonly props: MicroserviceProps;
|
|
12
|
+
readonly appConfig: AppConfig;
|
|
13
|
+
readonly tables?: Table[];
|
|
14
|
+
readonly secretMgr?: ISecret;
|
|
15
|
+
readonly layers?: LayerVersion[];
|
|
16
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2VydmljZUJ1bmRsZUNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25maWcvU2VydmljZUJ1bmRsZUNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSVJlc3RBcGkgfSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWFwaWdhdGV3YXlcIjtcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gXCJjb25zdHJ1Y3RzXCI7XG5pbXBvcnQgeyBNaWNyb3NlcnZpY2VQcm9wcyB9IGZyb20gXCIuLi9pbnRlcmZhY2VzL01pY3Jvc2VydmljZVByb3BzXCI7XG5pbXBvcnQgeyBBcHBDb25maWcgfSBmcm9tIFwiLi9BcHBDb25maWdcIjtcbmltcG9ydCB7IFRhYmxlIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1keW5hbW9kYlwiO1xuaW1wb3J0IHsgSVNlY3JldCB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3Mtc2VjcmV0c21hbmFnZXJcIjtcbmltcG9ydCB7IExheWVyVmVyc2lvbiB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtbGFtYmRhXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2VydmljZUJ1bmRsZUNvbmZpZyB7XG4gICAgc2NvcGU6IENvbnN0cnVjdCwgXG4gICAgcmVhZG9ubHkgZ2F0ZXdheUFwaTogSVJlc3RBcGksIFxuICAgIHJlYWRvbmx5IHByb3BzOiBNaWNyb3NlcnZpY2VQcm9wcywgICAgICAgIFxuICAgIHJlYWRvbmx5IGFwcENvbmZpZzogQXBwQ29uZmlnLFxuICAgIHJlYWRvbmx5IHRhYmxlcz86IFRhYmxlW10sIFxuICAgIHJlYWRvbmx5IHNlY3JldE1ncj86IElTZWNyZXQsIFxuICAgIHJlYWRvbmx5IGxheWVycz86IExheWVyVmVyc2lvbltdXG5cbn0iXX0=
|
|
@@ -40,7 +40,15 @@ class MicroService extends constructs_1.Construct {
|
|
|
40
40
|
tables = dynamo.CreatedTables;
|
|
41
41
|
}
|
|
42
42
|
// props.RESOURCES.LAMBDA.forEach((lambdaProp: TsgLambdaProp) => {
|
|
43
|
-
const result = new createMicroServiceBundle_1.CreateMicroServiceBundle(
|
|
43
|
+
const result = new createMicroServiceBundle_1.CreateMicroServiceBundle({
|
|
44
|
+
scope,
|
|
45
|
+
gatewayApi: gateway[0],
|
|
46
|
+
props,
|
|
47
|
+
appConfig: this.appConfig,
|
|
48
|
+
tables,
|
|
49
|
+
secretMgr: undefined,
|
|
50
|
+
layers
|
|
51
|
+
});
|
|
44
52
|
// });
|
|
45
53
|
}
|
|
46
54
|
createTag(scope) {
|
|
@@ -49,4 +57,4 @@ class MicroService extends constructs_1.Construct {
|
|
|
49
57
|
}
|
|
50
58
|
}
|
|
51
59
|
exports.MicroService = MicroService;
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTWljcm9TZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnN0cnVjdHMvTWljcm9TZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLDJDQUF1QztBQUV2Qyw0RkFBeUY7QUFDekYscUVBQW9FO0FBQ3BFLDhEQUFxRDtBQUNyRCxrRUFBZ0U7QUFDaEUsOEVBQTJFO0FBQzNFLG1EQUFnRDtBQUNoRCw2Q0FBbUM7QUFFbkMsTUFBYSxZQUFhLFNBQVEsc0JBQVM7SUFNdkMsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUF3QjtRQUM5RCxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBSkYsb0JBQWUsR0FBWSxLQUFLLENBQUM7UUFNaEQsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLHFCQUFTLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFdEMsSUFBSSxDQUFDLG1CQUFtQixHQUFHLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxNQUFNLEVBQUUsTUFBTTtZQUN0RCxLQUFLLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQztRQUU3RCxJQUFJLENBQUMsZUFBZSxHQUFHLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxhQUFhO1lBQ2pELEtBQUssQ0FBQyxTQUFTLENBQUMsYUFBYSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7UUFFN0QsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBRW5DLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUE7SUFDekIsQ0FBQztJQUVPLE1BQU0sQ0FBQyxLQUFnQixFQUFFLEtBQWdCO1FBRTdDLElBQUksTUFBTSxHQUF3QixTQUFTLENBQUM7UUFDNUMsSUFBSSxZQUFZLEdBQStCLFNBQVMsQ0FBQztRQUV6RCxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCLEVBQUU7WUFDaEMsK0VBQStFO1lBQy9FLHVCQUF1QjtZQUN0QixNQUFNLFNBQVMsR0FBRyxJQUFBLGtDQUFnQixFQUFDLEtBQUssRUFBRSxLQUFLLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1NBQ3JGO1FBRUQsSUFBSSxJQUFJLENBQUMsZUFBZSxFQUFFO1lBQ3RCLFlBQVksR0FBRyxJQUFBLHFDQUFpQixFQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztTQUNsRDtRQUVELE1BQU0sT0FBTyxHQUFHLElBQUksZUFBRyxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBSSxDQUFDO1FBRXBELE1BQU0sTUFBTSxHQUFHLFlBQVksQ0FBQztRQUU1QixzQ0FBc0M7UUFDdEMsSUFBSSxJQUFJLENBQUMsbUJBQW1CLEVBQUU7WUFDMUIsTUFBTSxNQUFNLEdBQUcsSUFBSSw2QkFBYyxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7WUFFekQsTUFBTSxHQUFHLE1BQU0sQ0FBQyxhQUFhLENBQUM7U0FDakM7UUFFRCxrRUFBa0U7UUFFbEUsTUFBTSxNQUFNLEdBQUcsSUFBSSxtREFBd0IsQ0FBQztZQUN4QyxLQUFLO1lBQ0wsVUFBVSxFQUFFLE9BQU8sQ0FBQyxDQUFDLENBQUM7WUFDdEIsS0FBSztZQUNMLFNBQVMsRUFBRSxJQUFJLENBQUMsU0FBUztZQUN6QixNQUFNO1lBQ04sU0FBUyxFQUFFLFNBQVM7WUFDcEIsTUFBTTtTQUFDLENBQUMsQ0FBQztRQUNiLE1BQU07SUFHVixDQUFDO0lBRVMsU0FBUyxDQUFDLEtBQWdCO1FBQ2hDLGtCQUFJLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNsRCxrQkFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHLENBQUMsZUFBZSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDbEUsQ0FBQztDQUNKO0FBbkVELG9DQW1FQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRhYmxlIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1keW5hbW9kYlwiO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcbmltcG9ydCB7IE1pY3Jvc2VydmljZVByb3BzIH0gZnJvbSBcIi4uL2ludGVyZmFjZXMvTWljcm9zZXJ2aWNlUHJvcHNcIjtcbmltcG9ydCB7IENyZWF0ZU1pY3JvU2VydmljZUJ1bmRsZSB9IGZyb20gXCIuLi9yZXNvdXJjZXMvZ2F0ZXdheS9jcmVhdGVNaWNyb1NlcnZpY2VCdW5kbGVcIjtcbmltcG9ydCB7IENyZWF0ZUR5bmFtb0RiIH0gZnJvbSBcIi4uL3Jlc291cmNlcy9keW5hbW9kYi9DcmVhdGVEeW5hbW9cIjtcbmltcG9ydCB7IEFwaSB9IGZyb20gXCIuLi9yZXNvdXJjZXMvZ2F0ZXdheS9jcmVhdGVBcGlcIjtcbmltcG9ydCB7IGdldFNlY3JldE1hbmFnZXIgfSBmcm9tIFwiLi4vcmVzb3VyY2VzL3NlY3VyaXR5TWFuYWdlclwiO1xuaW1wb3J0IHsgY3JlYXRlQ29tbW9uTGF5ZXIgfSBmcm9tIFwiLi4vcmVzb3VyY2VzL2hlbHBlcnMvY3JlYXRlQ29tbW9uTGF5ZXJcIjtcbmltcG9ydCB7IEFwcENvbmZpZyB9IGZyb20gXCIuLi9jb25maWcvQXBwQ29uZmlnXCI7XG5pbXBvcnQgeyBUYWdzIH0gZnJvbSBcImF3cy1jZGstbGliXCI7XG5pbXBvcnQgeyBMYXllclZlcnNpb24gfSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWxhbWJkYVwiO1xuZXhwb3J0IGNsYXNzIE1pY3JvU2VydmljZSBleHRlbmRzIENvbnN0cnVjdCB7XG5cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgcmVxdWlyZUR5bmFtb1RhYmxlczogYm9vbGVhbjtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgaGFzTGFtYmRhTGF5ZXJzOiBib29sZWFuID0gZmFsc2U7ICBcbiAgICBwcm90ZWN0ZWQgYXBwQ29uZmlnOiBBcHBDb25maWc7XG5cbiAgICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogTWljcm9zZXJ2aWNlUHJvcHMpIHtcbiAgICAgICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgICAgICB0aGlzLmFwcENvbmZpZyA9IG5ldyBBcHBDb25maWcocHJvcHMpO1xuXG4gICAgICAgIHRoaXMucmVxdWlyZUR5bmFtb1RhYmxlcyA9IChwcm9wcy5SRVNPVVJDRVMuRFlOQU1PPy5UQUJMRVMgJiZcbiAgICAgICAgICAgIHByb3BzLlJFU09VUkNFUy5EWU5BTU8uVEFCTEVTLmxlbmd0aCA+IDApID8gdHJ1ZSA6IGZhbHNlO1xuXG4gICAgICAgIHRoaXMuaGFzTGFtYmRhTGF5ZXJzID0gKHByb3BzLlJFU09VUkNFUy5MQU1CREFfTEFZRVJTICYmIFxuICAgICAgICAgICAgcHJvcHMuUkVTT1VSQ0VTLkxBTUJEQV9MQVlFUlMubGVuZ3RoID4gMCkgPyB0cnVlIDogZmFsc2U7XG5cbiAgICAgICAgdGhpcy5vbkluaXQoc2NvcGUsIHRoaXMuYXBwQ29uZmlnKTtcblxuICAgICAgICB0aGlzLmNyZWF0ZVRhZyhzY29wZSlcbiAgICB9XG5cbiAgICBwcml2YXRlIG9uSW5pdChzY29wZTogQ29uc3RydWN0LCBwcm9wczogQXBwQ29uZmlnKSB7XG5cbiAgICAgICAgbGV0IHRhYmxlczogVGFibGVbXSB8IHVuZGVmaW5lZCA9IHVuZGVmaW5lZDtcbiAgICAgICAgbGV0IGNvbW1vbkxheWVyczogTGF5ZXJWZXJzaW9uW10gfCB1bmRlZmluZWQgPSB1bmRlZmluZWQ7XG5cbiAgICAgICAgaWYgKHByb2Nlc3MuZW52LlNFQ1JFVF9NQU5BR0VSX0FSTikge1xuICAgICAgICAgICAgLy8gdGhyb3cgbmV3IEVycm9yKGBZb3UgbXVzdCBwcm92aWRlIHRoZSBBUk4gZm9yIHRoZSB5b3VyIENvbmZpZ3VyYXRpb24gU2VjcmV0IFxuICAgICAgICAgICAgLy8gICAgIE1hbmFnZXJgKTsgICAgICBcbiAgICAgICAgICAgICBjb25zdCBzZWNyZXRNZ3IgPSBnZXRTZWNyZXRNYW5hZ2VyKHNjb3BlLCBwcm9wcywgcHJvY2Vzcy5lbnYuU0VDUkVUX01BTkFHRVJfQVJOKTsgICAgICAgICAgICBcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICh0aGlzLmhhc0xhbWJkYUxheWVycykge1xuICAgICAgICAgICAgY29tbW9uTGF5ZXJzID0gY3JlYXRlQ29tbW9uTGF5ZXIoc2NvcGUsIHByb3BzKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IGdhdGV3YXkgPSBuZXcgQXBpKHNjb3BlLCB0aGlzLmFwcENvbmZpZykuQVBJcztcblxuICAgICAgICBjb25zdCBsYXllcnMgPSBjb21tb25MYXllcnM7XG5cbiAgICAgICAgLy8gQ3JlYXRlcyBEeW5hbW9EYiBUYWJsZXMgaWYgcmVxdWlyZWRcbiAgICAgICAgaWYgKHRoaXMucmVxdWlyZUR5bmFtb1RhYmxlcykge1xuICAgICAgICAgICAgY29uc3QgZHluYW1vID0gbmV3IENyZWF0ZUR5bmFtb0RiKHNjb3BlLCB0aGlzLmFwcENvbmZpZyk7XG5cbiAgICAgICAgICAgIHRhYmxlcyA9IGR5bmFtby5DcmVhdGVkVGFibGVzO1xuICAgICAgICB9XG5cbiAgICAgICAgLy8gcHJvcHMuUkVTT1VSQ0VTLkxBTUJEQS5mb3JFYWNoKChsYW1iZGFQcm9wOiBUc2dMYW1iZGFQcm9wKSA9PiB7XG4gICAgICAgICAgICBcbiAgICAgICAgY29uc3QgcmVzdWx0ID0gbmV3IENyZWF0ZU1pY3JvU2VydmljZUJ1bmRsZSh7XG4gICAgICAgICAgICBzY29wZSwgXG4gICAgICAgICAgICBnYXRld2F5QXBpOiBnYXRld2F5WzBdLCBcbiAgICAgICAgICAgIHByb3BzLCBcbiAgICAgICAgICAgIGFwcENvbmZpZzogdGhpcy5hcHBDb25maWcsIFxuICAgICAgICAgICAgdGFibGVzLCBcbiAgICAgICAgICAgIHNlY3JldE1ncjogdW5kZWZpbmVkLCBcbiAgICAgICAgICAgIGxheWVyc30pO1xuICAgICAgICAvLyB9KTtcblxuICAgICAgICBcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgY3JlYXRlVGFnKHNjb3BlOiBDb25zdHJ1Y3QpIHtcbiAgICAgICAgVGFncy5vZihzY29wZSkuYWRkKCdBcHAnLCB0aGlzLmFwcENvbmZpZy5BcHBOYW1lKTtcbiAgICAgICAgVGFncy5vZihzY29wZSkuYWRkKCdSZXNvdWNlUHJlZml4JywgdGhpcy5hcHBDb25maWcuQXBwUHJlZml4KTtcbiAgICB9XG59Il19
|
|
@@ -1,20 +1,9 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { Table } from "aws-cdk-lib/aws-dynamodb";
|
|
3
|
-
import { Construct } from "constructs";
|
|
4
|
-
import { MicroserviceProps } from "../../interfaces/MicroserviceProps";
|
|
5
|
-
import { ISecret } from "aws-cdk-lib/aws-secretsmanager";
|
|
6
|
-
import { LayerVersion } from "aws-cdk-lib/aws-lambda";
|
|
7
|
-
import { AppConfig } from "../../config/AppConfig";
|
|
1
|
+
import { ServiceBundleConfig } from "../../config/ServiceBundleConfig";
|
|
8
2
|
export declare class CreateMicroServiceBundle {
|
|
9
|
-
private
|
|
10
|
-
private readonly props;
|
|
11
|
-
private readonly appConfig;
|
|
12
|
-
private readonly tables?;
|
|
13
|
-
private readonly secretMgr?;
|
|
14
|
-
private readonly layers?;
|
|
3
|
+
private serviceBundleConfig;
|
|
15
4
|
protected readonly requireDynamoTableRefs: boolean;
|
|
16
5
|
protected readonly requireAuthorizer: boolean;
|
|
17
|
-
constructor(
|
|
6
|
+
constructor(serviceBundleConfig: ServiceBundleConfig);
|
|
18
7
|
private onInit;
|
|
19
8
|
private AssignAccessToTables;
|
|
20
9
|
private AssignAccessToTableRefs;
|
|
@@ -9,42 +9,37 @@ const createLambda_1 = require("../lambda/createLambda");
|
|
|
9
9
|
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
10
10
|
const CreateDynamo_1 = require("../dynamodb/CreateDynamo");
|
|
11
11
|
class CreateMicroServiceBundle {
|
|
12
|
-
constructor(
|
|
13
|
-
this.
|
|
14
|
-
this.
|
|
15
|
-
this.
|
|
16
|
-
this.
|
|
17
|
-
this.secretMgr = secretMgr;
|
|
18
|
-
this.layers = layers;
|
|
19
|
-
this.requireDynamoTableRefs = (props.RESOURCES.DYNAMO?.TABLE_REFS?.length ?? 0 > 0) ? true : false;
|
|
20
|
-
this.requireAuthorizer = (props.RESOURCES.AUTHORIZER) ? true : false;
|
|
21
|
-
this.onInit(scope);
|
|
12
|
+
constructor(serviceBundleConfig) {
|
|
13
|
+
this.serviceBundleConfig = serviceBundleConfig;
|
|
14
|
+
this.requireDynamoTableRefs = (this.serviceBundleConfig.props.RESOURCES.DYNAMO?.TABLE_REFS?.length ?? 0 > 0) ? true : false;
|
|
15
|
+
this.requireAuthorizer = (this.serviceBundleConfig.props.RESOURCES.AUTHORIZER) ? true : false;
|
|
16
|
+
this.onInit(this.serviceBundleConfig.scope);
|
|
22
17
|
}
|
|
23
18
|
onInit(scope) {
|
|
24
19
|
let authorizer = undefined;
|
|
25
20
|
// Create Authorizer
|
|
26
21
|
if (this.requireAuthorizer) {
|
|
27
|
-
authorizer = new createAuthorizer_1.CreateAuthorizer(scope, this.appConfig, this.props.RESOURCES.AUTHORIZER).JwtAuthorizer;
|
|
28
|
-
authorizer._attachToApi(this.gatewayApi);
|
|
22
|
+
authorizer = new createAuthorizer_1.CreateAuthorizer(scope, this.serviceBundleConfig.appConfig, this.serviceBundleConfig.props.RESOURCES.AUTHORIZER).JwtAuthorizer;
|
|
23
|
+
authorizer._attachToApi(this.serviceBundleConfig.gatewayApi);
|
|
29
24
|
authorizer.applyRemovalPolicy(aws_cdk_lib_1.RemovalPolicy.DESTROY);
|
|
30
25
|
}
|
|
31
26
|
// Create Lambdas
|
|
32
27
|
const lambdaProp = {
|
|
33
28
|
scope,
|
|
34
|
-
prop: this.props,
|
|
35
|
-
layers: this.layers,
|
|
36
|
-
appConfig: this.appConfig
|
|
29
|
+
prop: this.serviceBundleConfig.props,
|
|
30
|
+
layers: this.serviceBundleConfig.layers,
|
|
31
|
+
appConfig: this.serviceBundleConfig.appConfig
|
|
37
32
|
};
|
|
38
|
-
const lambdas = new createLambda_1.CreateLambda(lambdaProp, this.appConfig);
|
|
39
|
-
if (this.tables) {
|
|
40
|
-
this.AssignAccessToTables(this.tables, lambdas.Lambdas);
|
|
33
|
+
const lambdas = new createLambda_1.CreateLambda(lambdaProp, this.serviceBundleConfig.appConfig);
|
|
34
|
+
if (this.serviceBundleConfig.tables) {
|
|
35
|
+
this.AssignAccessToTables(this.serviceBundleConfig.tables, lambdas.Lambdas);
|
|
41
36
|
}
|
|
42
37
|
// Allow access to existing tables
|
|
43
38
|
// if (this.requireDynamoTableRefs) {
|
|
44
39
|
// this.AssignAccessToTableRefs(scope, this.props.RESOURCES.DYNAMO?.TABLE_REFS, lambdas.Lambdas);
|
|
45
40
|
// }
|
|
46
|
-
if (this.secretMgr) {
|
|
47
|
-
this.AssignAccessToSecretManager(this.secretMgr, lambdas.Lambdas);
|
|
41
|
+
if (this.serviceBundleConfig.secretMgr) {
|
|
42
|
+
this.AssignAccessToSecretManager(this.serviceBundleConfig.secretMgr, lambdas.Lambdas);
|
|
48
43
|
}
|
|
49
44
|
// lambdas.Lambdas.map((lambda) => {
|
|
50
45
|
// lambda.metricErrors({
|
|
@@ -52,7 +47,7 @@ class CreateMicroServiceBundle {
|
|
|
52
47
|
// period: Duration.minutes(3)
|
|
53
48
|
// })
|
|
54
49
|
// });
|
|
55
|
-
this.AddRoutes(this.props, this.gatewayApi, lambdas.Lambdas, authorizer);
|
|
50
|
+
this.AddRoutes(this.serviceBundleConfig.props, this.serviceBundleConfig.gatewayApi, lambdas.Lambdas, authorizer);
|
|
56
51
|
}
|
|
57
52
|
AssignAccessToTables(tables, lambdas) {
|
|
58
53
|
if (tables) {
|
|
@@ -111,7 +106,7 @@ class CreateMicroServiceBundle {
|
|
|
111
106
|
}
|
|
112
107
|
AddRoutes(props, gateway, lambdas, authorizer) {
|
|
113
108
|
props.RESOURCES.LAMBDA?.forEach((prop) => {
|
|
114
|
-
const lambdaId = createLambda_1.CreateLambda.getIdForLambda(prop, this.appConfig);
|
|
109
|
+
const lambdaId = createLambda_1.CreateLambda.getIdForLambda(prop, this.serviceBundleConfig.appConfig);
|
|
115
110
|
if (!lambdaId) {
|
|
116
111
|
throw new Error(`Can't find lambda`);
|
|
117
112
|
}
|
|
@@ -129,4 +124,4 @@ class CreateMicroServiceBundle {
|
|
|
129
124
|
}
|
|
130
125
|
}
|
|
131
126
|
exports.CreateMicroServiceBundle = CreateMicroServiceBundle;
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"createMicroServiceBundle.js","sourceRoot":"","sources":["../../../src/resources/gateway/createMicroServiceBundle.ts"],"names":[],"mappings":"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","sourcesContent":["import { IRestApi, TokenAuthorizer } from \"aws-cdk-lib/aws-apigateway\";\nimport { ITable, Table } from \"aws-cdk-lib/aws-dynamodb\";\nimport { NodejsFunction } from \"aws-cdk-lib/aws-lambda-nodejs\";\nimport { Effect, PolicyStatement } from \"aws-cdk-lib/aws-iam\";\nimport { Construct } from \"constructs\";\nimport { TsgDynamoTableRef, TsgLambdaProp } from \"../../config/types\";\nimport { TsgLambdaProps } from \"../../config/types/TsgLambdaProps\";\nimport { MicroserviceProps } from \"../../interfaces/MicroserviceProps\";\nimport { CreateAuthorizer } from \"../helpers/createAuthorizer\";\nimport { Routes } from \"../helpers/createRoutes\";\nimport { CreateLambda } from \"../lambda/createLambda\";\nimport { Duration, RemovalPolicy, Stack } from \"aws-cdk-lib\";\nimport { CreateDynamoDb } from \"../dynamodb/CreateDynamo\";\nimport { ISecret } from \"aws-cdk-lib/aws-secretsmanager\";\nimport { LayerVersion } from \"aws-cdk-lib/aws-lambda\";\nimport { AppConfig } from \"../../config/AppConfig\";\nimport { MetricOptions } from \"aws-cdk-lib/aws-cloudwatch\";\n\nexport class CreateMicroServiceBundle {\n    \n    protected readonly requireDynamoTableRefs: boolean;\n    protected readonly requireAuthorizer: boolean;\n\n    constructor(scope: Construct, \n        private readonly gatewayApi: IRestApi, \n        private readonly props: MicroserviceProps,        \n        private readonly appConfig: AppConfig,\n        private readonly tables?: Table[], \n        private readonly secretMgr?: ISecret | null, \n        private readonly layers?: LayerVersion[],        \n        ) {\n        \n        this.requireDynamoTableRefs = (props.RESOURCES.DYNAMO?.TABLE_REFS?.length ?? 0 > 0) ? true : false;\n        this.requireAuthorizer = (props.RESOURCES.AUTHORIZER) ? true : false;\n        this.onInit(scope);\n    }\n\n    private onInit(scope: Construct) {\n\n        \n        let authorizer: TokenAuthorizer|undefined = undefined;\n\n        // Create Authorizer\n        if (this.requireAuthorizer) {\n            authorizer = new CreateAuthorizer(scope, this.appConfig, this.props.RESOURCES.AUTHORIZER!).JwtAuthorizer;\n            authorizer._attachToApi(this.gatewayApi);   \n            authorizer.applyRemovalPolicy(RemovalPolicy.DESTROY);\n        }        \n\n        // Create Lambdas\n        const lambdaProp: TsgLambdaProps = {\n            scope,\n            prop: this.props,            \n            layers: this.layers,\n            appConfig: this.appConfig\n        };\n\n        const lambdas = new CreateLambda(lambdaProp, this.appConfig);\n\n        if (this.tables) {\n            this.AssignAccessToTables(this.tables, lambdas.Lambdas);\n        }        \n\n        // Allow access to existing tables\n        // if (this.requireDynamoTableRefs) {\n        //     this.AssignAccessToTableRefs(scope, this.props.RESOURCES.DYNAMO?.TABLE_REFS, lambdas.Lambdas);\n        // }\n\n        if (this.secretMgr) {\n            this.AssignAccessToSecretManager(this.secretMgr, lambdas.Lambdas);\n        }        \n\n        // lambdas.Lambdas.map((lambda) => {\n        //     lambda.metricErrors({                \n        //             label: `${lambda.functionName}-errors`, \n        //             period: Duration.minutes(3)           \n                \n        //     })\n        // });\n\n        this.AddRoutes(this.props, this.gatewayApi, lambdas.Lambdas, authorizer);\n    }\n\n    private AssignAccessToTables(tables: Table[], lambdas: NodejsFunction[]) {\n\n        if (tables) {\n            lambdas.forEach((lambda: NodejsFunction) => {\n            \n                tables.forEach((table: ITable) => {\n\n                \n\n                    //  This is a CDK bug: It doesn't provide\n                    //  access to the indexes.\n                    //table.grantReadWriteData(lambda);\n\n                    //  Workaround:\n                    // lambda.addToRolePolicy(\n                    //     new PolicyStatement({\n                    //         effect: Effect.ALLOW,\n                    //         actions: CreateDynamoDb.ReadWriteActions,\n                    //         resources: [\n                    //             table.tableArn,\n                    //             `${table.tableArn}/*`, // This is not recognized by cdk, but table is.  why?\n                    //         ],\n                    //     })\n                    // );\n\n                    table.grantReadWriteData(lambda);\n                    \n                    \n                });\n\n            });\n        }\n    }\n\n    private AssignAccessToTableRefs(scope: Construct, tableRefs: TsgDynamoTableRef[] | undefined, lambdas: NodejsFunction[]) {\n\n        if (tableRefs) {\n            tableRefs.forEach((tableRef: TsgDynamoTableRef) => {\n\n                if (tableRef.region) {\n                    this.AssignReadWriteAccessToTableInRegion(scope, tableRef, lambdas);\n                }\n                else {\n                    this.AssignReadWriteAccessToTable(scope, tableRef, lambdas);\n                }\n            });\n        }\n    }\n\n    private AssignReadWriteAccessToTableInRegion(scope: Construct, tableRef: TsgDynamoTableRef, lambdas: NodejsFunction[]) {\n        lambdas.forEach((lambda: NodejsFunction) => {\n\n            let tableArn = \"arn:aws:dynamodb:\" + tableRef.region + \":\" + ((scope as Stack).account) + \":table/\" + tableRef.tableName;\n            let statement = new PolicyStatement({\n                effect: Effect.ALLOW,\n                resources: [\n                    tableArn,\n                    tableArn + \"/index/*\",\n                ],\n                actions: CreateDynamoDb.ReadWriteActions,\n            });\n\n            lambda.role?.addToPrincipalPolicy(statement);\n            \n        });\n    }\n\n    private AssignReadWriteAccessToTable(scope: Construct, tableRef: TsgDynamoTableRef, lambdas: NodejsFunction[]) {\n        let table: ITable = Table.fromTableName(scope, tableRef.tableName, tableRef.tableName);\n\n        lambdas.forEach((lambda: NodejsFunction) => {\n            table.grantReadWriteData(lambda)\n            \n        });\n    }\n\n    private AddRoutes(props: MicroserviceProps, \n        gateway: IRestApi, \n        lambdas: NodejsFunction[], \n        authorizer?: TokenAuthorizer) {\n\n        props.RESOURCES.LAMBDA?.forEach((prop: TsgLambdaProp) => {\n\n            const lambdaId = CreateLambda.getIdForLambda(prop, this.appConfig);\n\n            if (!lambdaId) {\n                throw new Error(`Can't find lambda`);\n            }\n            const lambdaNode = lambdas.find(x => x.node.id === lambdaId);\n\n            if (!lambdaNode) {\n                throw new Error(\"Can't find the Lambda Integration\");                \n            }\n\n            Routes.createResource(prop, gateway, lambdaNode, authorizer);\n        \n        });\n    }\n\n    private AssignAccessToSecretManager(secret: ISecret, lambdas: NodejsFunction[]) {\n\n        lambdas.forEach((lambda) => {\n            const result = secret.grantRead(lambda);\n            \n        });\n        \n    }\n\n}"]}
|
|
127
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"createMicroServiceBundle.js","sourceRoot":"","sources":["../../../src/resources/gateway/createMicroServiceBundle.ts"],"names":[],"mappings":"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","sourcesContent":["import { IRestApi, TokenAuthorizer } from \"aws-cdk-lib/aws-apigateway\";\nimport { ITable, Table } from \"aws-cdk-lib/aws-dynamodb\";\nimport { NodejsFunction } from \"aws-cdk-lib/aws-lambda-nodejs\";\nimport { Effect, PolicyStatement } from \"aws-cdk-lib/aws-iam\";\nimport { Construct } from \"constructs\";\nimport { TsgDynamoTableRef, TsgLambdaProp } from \"../../config/types\";\nimport { TsgLambdaProps } from \"../../config/types/TsgLambdaProps\";\nimport { MicroserviceProps } from \"../../interfaces/MicroserviceProps\";\nimport { CreateAuthorizer } from \"../helpers/createAuthorizer\";\nimport { Routes } from \"../helpers/createRoutes\";\nimport { CreateLambda } from \"../lambda/createLambda\";\nimport { RemovalPolicy, Stack } from \"aws-cdk-lib\";\nimport { CreateDynamoDb } from \"../dynamodb/CreateDynamo\";\nimport { ISecret } from \"aws-cdk-lib/aws-secretsmanager\";\n\nimport { ServiceBundleConfig } from \"../../config/ServiceBundleConfig\";\n\nexport class CreateMicroServiceBundle {\n    \n    protected readonly requireDynamoTableRefs: boolean;\n    protected readonly requireAuthorizer: boolean;\n\n    constructor(private serviceBundleConfig: ServiceBundleConfig) {\n        \n        this.requireDynamoTableRefs = (this.serviceBundleConfig.props.RESOURCES.DYNAMO?.TABLE_REFS?.length ?? 0 > 0) ? true : false;\n        this.requireAuthorizer = (this.serviceBundleConfig.props.RESOURCES.AUTHORIZER) ? true : false;\n        this.onInit(this.serviceBundleConfig.scope);\n    }\n\n    private onInit(scope: Construct) {\n\n        \n        let authorizer: TokenAuthorizer|undefined = undefined;\n\n        // Create Authorizer\n        if (this.requireAuthorizer) {\n            authorizer = new CreateAuthorizer(scope, this.serviceBundleConfig.appConfig, this.serviceBundleConfig.props.RESOURCES.AUTHORIZER!).JwtAuthorizer;\n            authorizer._attachToApi(this.serviceBundleConfig.gatewayApi);   \n            authorizer.applyRemovalPolicy(RemovalPolicy.DESTROY);\n        }        \n\n        // Create Lambdas\n        const lambdaProp: TsgLambdaProps = {\n            scope,\n            prop: this.serviceBundleConfig.props,            \n            layers: this.serviceBundleConfig.layers,\n            appConfig: this.serviceBundleConfig.appConfig\n        };\n\n        const lambdas = new CreateLambda(lambdaProp, this.serviceBundleConfig.appConfig);\n\n        if (this.serviceBundleConfig.tables) {\n            this.AssignAccessToTables(this.serviceBundleConfig.tables, lambdas.Lambdas);\n        }        \n\n        // Allow access to existing tables\n        // if (this.requireDynamoTableRefs) {\n        //     this.AssignAccessToTableRefs(scope, this.props.RESOURCES.DYNAMO?.TABLE_REFS, lambdas.Lambdas);\n        // }\n\n        if (this.serviceBundleConfig.secretMgr) {\n            this.AssignAccessToSecretManager(this.serviceBundleConfig.secretMgr, lambdas.Lambdas);\n        }        \n\n        // lambdas.Lambdas.map((lambda) => {\n        //     lambda.metricErrors({                \n        //             label: `${lambda.functionName}-errors`, \n        //             period: Duration.minutes(3)           \n                \n        //     })\n        // });\n\n        this.AddRoutes(this.serviceBundleConfig.props, this.serviceBundleConfig.gatewayApi, lambdas.Lambdas, authorizer);\n    }\n\n    private AssignAccessToTables(tables: Table[], lambdas: NodejsFunction[]) {\n\n        if (tables) {\n            lambdas.forEach((lambda: NodejsFunction) => {\n            \n                tables.forEach((table: ITable) => {\n\n                \n\n                    //  This is a CDK bug: It doesn't provide\n                    //  access to the indexes.\n                    //table.grantReadWriteData(lambda);\n\n                    //  Workaround:\n                    // lambda.addToRolePolicy(\n                    //     new PolicyStatement({\n                    //         effect: Effect.ALLOW,\n                    //         actions: CreateDynamoDb.ReadWriteActions,\n                    //         resources: [\n                    //             table.tableArn,\n                    //             `${table.tableArn}/*`, // This is not recognized by cdk, but table is.  why?\n                    //         ],\n                    //     })\n                    // );\n\n                    table.grantReadWriteData(lambda);\n                    \n                    \n                });\n\n            });\n        }\n    }\n\n    private AssignAccessToTableRefs(scope: Construct, tableRefs: TsgDynamoTableRef[] | undefined, lambdas: NodejsFunction[]) {\n\n        if (tableRefs) {\n            tableRefs.forEach((tableRef: TsgDynamoTableRef) => {\n\n                if (tableRef.region) {\n                    this.AssignReadWriteAccessToTableInRegion(scope, tableRef, lambdas);\n                }\n                else {\n                    this.AssignReadWriteAccessToTable(scope, tableRef, lambdas);\n                }\n            });\n        }\n    }\n\n    private AssignReadWriteAccessToTableInRegion(scope: Construct, tableRef: TsgDynamoTableRef, lambdas: NodejsFunction[]) {\n        lambdas.forEach((lambda: NodejsFunction) => {\n\n            let tableArn = \"arn:aws:dynamodb:\" + tableRef.region + \":\" + ((scope as Stack).account) + \":table/\" + tableRef.tableName;\n            let statement = new PolicyStatement({\n                effect: Effect.ALLOW,\n                resources: [\n                    tableArn,\n                    tableArn + \"/index/*\",\n                ],\n                actions: CreateDynamoDb.ReadWriteActions,\n            });\n\n            lambda.role?.addToPrincipalPolicy(statement);\n            \n        });\n    }\n\n    private AssignReadWriteAccessToTable(scope: Construct, tableRef: TsgDynamoTableRef, lambdas: NodejsFunction[]) {\n        let table: ITable = Table.fromTableName(scope, tableRef.tableName, tableRef.tableName);\n\n        lambdas.forEach((lambda: NodejsFunction) => {\n            table.grantReadWriteData(lambda)\n            \n        });\n    }\n\n    private AddRoutes(props: MicroserviceProps, \n        gateway: IRestApi, \n        lambdas: NodejsFunction[], \n        authorizer?: TokenAuthorizer) {\n\n        props.RESOURCES.LAMBDA?.forEach((prop: TsgLambdaProp) => {\n\n            const lambdaId = CreateLambda.getIdForLambda(prop, this.serviceBundleConfig.appConfig);\n\n            if (!lambdaId) {\n                throw new Error(`Can't find lambda`);\n            }\n            const lambdaNode = lambdas.find(x => x.node.id === lambdaId);\n\n            if (!lambdaNode) {\n                throw new Error(\"Can't find the Lambda Integration\");                \n            }\n\n            Routes.createResource(prop, gateway, lambdaNode, authorizer);\n        \n        });\n    }\n\n    private AssignAccessToSecretManager(secret: ISecret, lambdas: NodejsFunction[]) {\n\n        lambdas.forEach((lambda) => {\n            const result = secret.grantRead(lambda);\n            \n        });\n        \n    }\n\n}"]}
|
|
@@ -79,7 +79,7 @@ class CreateLambda extends baseResource_1.BaseResource {
|
|
|
79
79
|
environment: prop.environment || prop.environment,
|
|
80
80
|
},
|
|
81
81
|
role,
|
|
82
|
-
|
|
82
|
+
layers
|
|
83
83
|
};
|
|
84
84
|
return lambdaProp;
|
|
85
85
|
}
|
|
@@ -134,4 +134,4 @@ class CreateLambda extends baseResource_1.BaseResource {
|
|
|
134
134
|
}
|
|
135
135
|
}
|
|
136
136
|
exports.CreateLambda = CreateLambda;
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"createLambda.js","sourceRoot":"","sources":["../../../src/resources/lambda/createLambda.ts"],"names":[],"mappings":"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","sourcesContent":["import { CfnOutput, Duration } from \"aws-cdk-lib\";\nimport { TokenAuthorizer } from \"aws-cdk-lib/aws-apigateway\";\nimport { Alarm, ComparisonOperator, IAlarmAction } from \"aws-cdk-lib/aws-cloudwatch\";\nimport { IRole, ManagedPolicy } from \"aws-cdk-lib/aws-iam\";\nimport { LayerVersion } from \"aws-cdk-lib/aws-lambda\";\nimport { NodejsFunction, NodejsFunctionProps, SourceMapMode } from \"aws-cdk-lib/aws-lambda-nodejs\";\nimport { Construct } from \"constructs\";\nimport * as path from 'path';\nimport { AppConfig } from \"../../config/AppConfig\";\nimport { TsgLambdaProp } from \"../../config/types\";\n\nimport { TsgLambdaProps } from \"../../config/types/TsgLambdaProps\";\nimport { CreateLambdaFunctionInput } from \"../../interfaces/CreateLambdaFunctionInput\";\nimport { BaseResource } from \"../base/baseResource\";\n\n\nexport class CreateLambda extends BaseResource<NodejsFunction> {\n\n    public Lambdas: NodejsFunction[] = [];\n    \n\n    constructor(private props: TsgLambdaProps, config: AppConfig) {\n        super(props.scope, config);\n\n        const resources = this.createResource(props.scope);\n\n        this.Lambdas = [...resources];\n\n        this.createAlarmsForLambdas(this.Lambdas);\n        \n        this.createOutput(props.scope, resources);\n    }\n\n    protected createResource(scope: Construct): NodejsFunction[] {\n\n        const result = this.createLambdas(this.props);\n        \n        return result;\n    }\n\n    protected createOutput<T>(scope: Construct, createdAssets: T[]): void {\n        createdAssets.forEach((x, idx) => {\n\n            new CfnOutput(scope, `lambda-${idx}`, {\n                // @ts-ignore\n                value: x.functionName\n            });\n        });\n    }\n\n    private createLambdas(props: TsgLambdaProps): NodejsFunction[] {\n        \n        const createdLambdas: NodejsFunction[] = this.createLambdaFunctions(this.scope, props.role, props.layers);\n\n        return createdLambdas;\n    }\n\n    private createLambdaFunctions(scope: Construct, role?: IRole, layers?: LayerVersion[]) {\n        \n        const createdLambdas = this.props.prop.RESOURCES.LAMBDA.map((config:TsgLambdaProp) => {\n            \n            let lambdaProps = this.createLambdaProps(config, role, layers);\n\n            const lambdaId = CreateLambda.getIdForLambda(config, this.config);\n            let fctn = new NodejsFunction(scope, lambdaId, lambdaProps);\n\n            if (lambdaId === fctn.node.id) {\n                console.log(`found Lambda for : ${fctn.node.id}`);\n            }\n\n            \n            //  If we have managed policies, we add them.\n            if (config.managedPolicies && config.managedPolicies?.length > 0) {\n                \n                this.assignManagedPolicies(fctn, config.managedPolicies);\n            }\n\n            return fctn;\n        });\n\n        return createdLambdas || [];\n    }\n\n    private createLambdaProps(prop: TsgLambdaProp, role?: IRole, layers?: LayerVersion[], props?: TsgLambdaProps) {\n\n        return this.createLambdaFunctionProps({\n            prop, \n            role,\n            layers, \n            props\n        });\n    }\n\n    private createLambdaFunctionProps(props: CreateLambdaFunctionInput) {\n        const { prop, role, layers } = props;\n\n        console.log(`function Name: ${this.props.appConfig.AppPrefix}-${prop.name}`);\n\n        const lambdaProp: NodejsFunctionProps = {\n            entry: path.join(prop.codePath),\n            functionName: `${this.props.appConfig.AppPrefix}-${prop.name}`,\n            handler: prop.handler,\n            runtime: prop.runtime || this.config.GLOBALS.stackRuntime,\n            timeout: prop.duration || Duration.minutes(2),\n            memorySize: prop.memory || 512,\n            environment: {\n                \"VERBOSE_LOGGING\": \"true\",                \n                ...prop.environment\n            },\n            bundling: {\n                minify: false,\n                target: 'es2020',\n                sourceMap: true,\n                sourceMapMode: SourceMapMode.EXTERNAL,\n                environment: prop.environment || prop.environment,\n            },\n            role,\n            //layers\n\n        }\n\n        \n        return lambdaProp;\n    };\n\n    private assignManagedPolicies(lambda: NodejsFunction, managedPolicyNames: string[]) {\n\n        managedPolicyNames.forEach((managedPolicyName: string) => {\n\n            let policy = ManagedPolicy.fromAwsManagedPolicyName(managedPolicyName);\n\n            lambda.role?.addManagedPolicy(policy);\n        });\n\n    }\n\n    private createAlarmsForLambdas(lambdas: NodejsFunction[]) {        \n\n        lambdas.forEach((lambda, idx) => {\n\n            const errorMetric = lambda.metricErrors({\n                period: Duration.minutes(3),\n                \n            });\n\n            const durationMetric = lambda.metricDuration({\n                period: Duration.minutes(3),                \n            });\n\n            const invocationMetric = lambda.metricInvocations({\n                period: Duration.minutes(3),                \n            });\n\n            new Alarm(this.props.scope, `${this.config.AppPrefix}-${idx}-error-alarm`, {\n                metric: errorMetric, \n                threshold: 5,\n                comparisonOperator: ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n                evaluationPeriods: 3,\n                alarmDescription: `${this.config.AppPrefix}-${idx} errors over 3 min period`,\n                alarmName: `${this.config.AppPrefix}-${idx}-error-alarm`\n            });\n\n            new Alarm(this.props.scope, `${this.config.AppPrefix}-${idx}-duration-alarm`, {\n                metric: durationMetric, \n                threshold: 1,\n                comparisonOperator: ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n                evaluationPeriods: 3,\n                alarmDescription: `${this.config.AppPrefix}-${idx} duration errors over 3 min period`,\n                alarmName: `${this.config.AppPrefix}-${idx}-duration-alarm`\n            });\n\n            const invocationAlarm = new Alarm(this.props.scope, `${this.config.AppPrefix}-${idx}-invocation-alarm`, {\n                metric: errorMetric, \n                threshold: 1000,\n                comparisonOperator: ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n                evaluationPeriods: 3,\n                alarmDescription: `${this.config.AppPrefix}-${idx} errors over 3 min period`,\n                alarmName: `${this.config.AppPrefix}-${idx}-invocation-Metric-alarm`\n            });\n\n            // const alarmAction: IAlarmAction = {};\n            // invocationAlarm.addAlarmAction(alarmAction);\n        });\n    }\n\n    public static getIdForLambda(lambdaProp: TsgLambdaProp, appConfig: AppConfig) {       \n        return `${appConfig.AppPrefix}-${lambdaProp.name}`.toLowerCase();\n    }\n}"]}
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"createLambda.js","sourceRoot":"","sources":["../../../src/resources/lambda/createLambda.ts"],"names":[],"mappings":"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","sourcesContent":["import { CfnOutput, Duration } from \"aws-cdk-lib\";\nimport { TokenAuthorizer } from \"aws-cdk-lib/aws-apigateway\";\nimport { Alarm, ComparisonOperator, IAlarmAction } from \"aws-cdk-lib/aws-cloudwatch\";\nimport { IRole, ManagedPolicy } from \"aws-cdk-lib/aws-iam\";\nimport { LayerVersion } from \"aws-cdk-lib/aws-lambda\";\nimport { NodejsFunction, NodejsFunctionProps, SourceMapMode } from \"aws-cdk-lib/aws-lambda-nodejs\";\nimport { Construct } from \"constructs\";\nimport * as path from 'path';\nimport { AppConfig } from \"../../config/AppConfig\";\nimport { TsgLambdaProp } from \"../../config/types\";\n\nimport { TsgLambdaProps } from \"../../config/types/TsgLambdaProps\";\nimport { CreateLambdaFunctionInput } from \"../../interfaces/CreateLambdaFunctionInput\";\nimport { BaseResource } from \"../base/baseResource\";\n\n\nexport class CreateLambda extends BaseResource<NodejsFunction> {\n\n    public Lambdas: NodejsFunction[] = [];\n    \n\n    constructor(private props: TsgLambdaProps, config: AppConfig) {\n        super(props.scope, config);\n\n        const resources = this.createResource(props.scope);\n\n        this.Lambdas = [...resources];\n\n        this.createAlarmsForLambdas(this.Lambdas);\n        \n        this.createOutput(props.scope, resources);\n    }\n\n    protected createResource(scope: Construct): NodejsFunction[] {\n\n        const result = this.createLambdas(this.props);\n        \n        return result;\n    }\n\n    protected createOutput<T>(scope: Construct, createdAssets: T[]): void {\n        createdAssets.forEach((x, idx) => {\n\n            new CfnOutput(scope, `lambda-${idx}`, {\n                // @ts-ignore\n                value: x.functionName\n            });\n        });\n    }\n\n    private createLambdas(props: TsgLambdaProps): NodejsFunction[] {\n        \n        const createdLambdas: NodejsFunction[] = this.createLambdaFunctions(this.scope, props.role, props.layers);\n\n        return createdLambdas;\n    }\n\n    private createLambdaFunctions(scope: Construct, role?: IRole, layers?: LayerVersion[]) {\n        \n        const createdLambdas = this.props.prop.RESOURCES.LAMBDA.map((config:TsgLambdaProp) => {\n            \n            let lambdaProps = this.createLambdaProps(config, role, layers);\n\n            const lambdaId = CreateLambda.getIdForLambda(config, this.config);\n            let fctn = new NodejsFunction(scope, lambdaId, lambdaProps);\n\n            if (lambdaId === fctn.node.id) {\n                console.log(`found Lambda for : ${fctn.node.id}`);\n            }\n\n            \n            //  If we have managed policies, we add them.\n            if (config.managedPolicies && config.managedPolicies?.length > 0) {\n                \n                this.assignManagedPolicies(fctn, config.managedPolicies);\n            }\n\n            return fctn;\n        });\n\n        return createdLambdas || [];\n    }\n\n    private createLambdaProps(prop: TsgLambdaProp, role?: IRole, layers?: LayerVersion[], props?: TsgLambdaProps) {\n\n        return this.createLambdaFunctionProps({\n            prop, \n            role,\n            layers, \n            props\n        });\n    }\n\n    private createLambdaFunctionProps(props: CreateLambdaFunctionInput) {\n        const { prop, role, layers } = props;\n\n        console.log(`function Name: ${this.props.appConfig.AppPrefix}-${prop.name}`);\n\n        const lambdaProp: NodejsFunctionProps = {\n            entry: path.join(prop.codePath),\n            functionName: `${this.props.appConfig.AppPrefix}-${prop.name}`,\n            handler: prop.handler,\n            runtime: prop.runtime || this.config.GLOBALS.stackRuntime,\n            timeout: prop.duration || Duration.minutes(2),\n            memorySize: prop.memory || 512,\n            environment: {\n                \"VERBOSE_LOGGING\": \"true\",                \n                ...prop.environment\n            },\n            bundling: {\n                minify: false,\n                target: 'es2020',\n                sourceMap: true,\n                sourceMapMode: SourceMapMode.EXTERNAL,\n                environment: prop.environment || prop.environment,\n            },\n            role,\n            layers\n\n        }\n\n        \n        return lambdaProp;\n    };\n\n    private assignManagedPolicies(lambda: NodejsFunction, managedPolicyNames: string[]) {\n\n        managedPolicyNames.forEach((managedPolicyName: string) => {\n\n            let policy = ManagedPolicy.fromAwsManagedPolicyName(managedPolicyName);\n\n            lambda.role?.addManagedPolicy(policy);\n        });\n\n    }\n\n    private createAlarmsForLambdas(lambdas: NodejsFunction[]) {        \n\n        lambdas.forEach((lambda, idx) => {\n\n            const errorMetric = lambda.metricErrors({\n                period: Duration.minutes(3),\n                \n            });\n\n            const durationMetric = lambda.metricDuration({\n                period: Duration.minutes(3),                \n            });\n\n            const invocationMetric = lambda.metricInvocations({\n                period: Duration.minutes(3),                \n            });\n\n            new Alarm(this.props.scope, `${this.config.AppPrefix}-${idx}-error-alarm`, {\n                metric: errorMetric, \n                threshold: 5,\n                comparisonOperator: ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n                evaluationPeriods: 3,\n                alarmDescription: `${this.config.AppPrefix}-${idx} errors over 3 min period`,\n                alarmName: `${this.config.AppPrefix}-${idx}-error-alarm`\n            });\n\n            new Alarm(this.props.scope, `${this.config.AppPrefix}-${idx}-duration-alarm`, {\n                metric: durationMetric, \n                threshold: 1,\n                comparisonOperator: ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n                evaluationPeriods: 3,\n                alarmDescription: `${this.config.AppPrefix}-${idx} duration errors over 3 min period`,\n                alarmName: `${this.config.AppPrefix}-${idx}-duration-alarm`\n            });\n\n            const invocationAlarm = new Alarm(this.props.scope, `${this.config.AppPrefix}-${idx}-invocation-alarm`, {\n                metric: errorMetric, \n                threshold: 1000,\n                comparisonOperator: ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n                evaluationPeriods: 3,\n                alarmDescription: `${this.config.AppPrefix}-${idx} errors over 3 min period`,\n                alarmName: `${this.config.AppPrefix}-${idx}-invocation-Metric-alarm`\n            });\n\n            // const alarmAction: IAlarmAction = {};\n            // invocationAlarm.addAlarmAction(alarmAction);\n        });\n    }\n\n    public static getIdForLambda(lambdaProp: TsgLambdaProp, appConfig: AppConfig) {       \n        return `${appConfig.AppPrefix}-${lambdaProp.name}`.toLowerCase();\n    }\n}"]}
|
package/package.json
CHANGED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { IRestApi } from "aws-cdk-lib/aws-apigateway";
|
|
2
|
+
import { Construct } from "constructs";
|
|
3
|
+
import { MicroserviceProps } from "../interfaces/MicroserviceProps";
|
|
4
|
+
import { AppConfig } from "./AppConfig";
|
|
5
|
+
import { Table } from "aws-cdk-lib/aws-dynamodb";
|
|
6
|
+
import { ISecret } from "aws-cdk-lib/aws-secretsmanager";
|
|
7
|
+
import { LayerVersion } from "aws-cdk-lib/aws-lambda";
|
|
8
|
+
|
|
9
|
+
export interface ServiceBundleConfig {
|
|
10
|
+
scope: Construct,
|
|
11
|
+
readonly gatewayApi: IRestApi,
|
|
12
|
+
readonly props: MicroserviceProps,
|
|
13
|
+
readonly appConfig: AppConfig,
|
|
14
|
+
readonly tables?: Table[],
|
|
15
|
+
readonly secretMgr?: ISecret,
|
|
16
|
+
readonly layers?: LayerVersion[]
|
|
17
|
+
|
|
18
|
+
}
|
|
@@ -59,8 +59,14 @@ export class MicroService extends Construct {
|
|
|
59
59
|
|
|
60
60
|
// props.RESOURCES.LAMBDA.forEach((lambdaProp: TsgLambdaProp) => {
|
|
61
61
|
|
|
62
|
-
const result = new CreateMicroServiceBundle(
|
|
63
|
-
|
|
62
|
+
const result = new CreateMicroServiceBundle({
|
|
63
|
+
scope,
|
|
64
|
+
gatewayApi: gateway[0],
|
|
65
|
+
props,
|
|
66
|
+
appConfig: this.appConfig,
|
|
67
|
+
tables,
|
|
68
|
+
secretMgr: undefined,
|
|
69
|
+
layers});
|
|
64
70
|
// });
|
|
65
71
|
|
|
66
72
|
|
|
@@ -9,30 +9,22 @@ import { MicroserviceProps } from "../../interfaces/MicroserviceProps";
|
|
|
9
9
|
import { CreateAuthorizer } from "../helpers/createAuthorizer";
|
|
10
10
|
import { Routes } from "../helpers/createRoutes";
|
|
11
11
|
import { CreateLambda } from "../lambda/createLambda";
|
|
12
|
-
import {
|
|
12
|
+
import { RemovalPolicy, Stack } from "aws-cdk-lib";
|
|
13
13
|
import { CreateDynamoDb } from "../dynamodb/CreateDynamo";
|
|
14
14
|
import { ISecret } from "aws-cdk-lib/aws-secretsmanager";
|
|
15
|
-
|
|
16
|
-
import {
|
|
17
|
-
import { MetricOptions } from "aws-cdk-lib/aws-cloudwatch";
|
|
15
|
+
|
|
16
|
+
import { ServiceBundleConfig } from "../../config/ServiceBundleConfig";
|
|
18
17
|
|
|
19
18
|
export class CreateMicroServiceBundle {
|
|
20
19
|
|
|
21
20
|
protected readonly requireDynamoTableRefs: boolean;
|
|
22
21
|
protected readonly requireAuthorizer: boolean;
|
|
23
22
|
|
|
24
|
-
constructor(
|
|
25
|
-
private readonly gatewayApi: IRestApi,
|
|
26
|
-
private readonly props: MicroserviceProps,
|
|
27
|
-
private readonly appConfig: AppConfig,
|
|
28
|
-
private readonly tables?: Table[],
|
|
29
|
-
private readonly secretMgr?: ISecret | null,
|
|
30
|
-
private readonly layers?: LayerVersion[],
|
|
31
|
-
) {
|
|
23
|
+
constructor(private serviceBundleConfig: ServiceBundleConfig) {
|
|
32
24
|
|
|
33
|
-
this.requireDynamoTableRefs = (props.RESOURCES.DYNAMO?.TABLE_REFS?.length ?? 0 > 0) ? true : false;
|
|
34
|
-
this.requireAuthorizer = (props.RESOURCES.AUTHORIZER) ? true : false;
|
|
35
|
-
this.onInit(scope);
|
|
25
|
+
this.requireDynamoTableRefs = (this.serviceBundleConfig.props.RESOURCES.DYNAMO?.TABLE_REFS?.length ?? 0 > 0) ? true : false;
|
|
26
|
+
this.requireAuthorizer = (this.serviceBundleConfig.props.RESOURCES.AUTHORIZER) ? true : false;
|
|
27
|
+
this.onInit(this.serviceBundleConfig.scope);
|
|
36
28
|
}
|
|
37
29
|
|
|
38
30
|
private onInit(scope: Construct) {
|
|
@@ -42,23 +34,23 @@ export class CreateMicroServiceBundle {
|
|
|
42
34
|
|
|
43
35
|
// Create Authorizer
|
|
44
36
|
if (this.requireAuthorizer) {
|
|
45
|
-
authorizer = new CreateAuthorizer(scope, this.appConfig, this.props.RESOURCES.AUTHORIZER!).JwtAuthorizer;
|
|
46
|
-
authorizer._attachToApi(this.gatewayApi);
|
|
37
|
+
authorizer = new CreateAuthorizer(scope, this.serviceBundleConfig.appConfig, this.serviceBundleConfig.props.RESOURCES.AUTHORIZER!).JwtAuthorizer;
|
|
38
|
+
authorizer._attachToApi(this.serviceBundleConfig.gatewayApi);
|
|
47
39
|
authorizer.applyRemovalPolicy(RemovalPolicy.DESTROY);
|
|
48
40
|
}
|
|
49
41
|
|
|
50
42
|
// Create Lambdas
|
|
51
43
|
const lambdaProp: TsgLambdaProps = {
|
|
52
44
|
scope,
|
|
53
|
-
prop: this.props,
|
|
54
|
-
layers: this.layers,
|
|
55
|
-
appConfig: this.appConfig
|
|
45
|
+
prop: this.serviceBundleConfig.props,
|
|
46
|
+
layers: this.serviceBundleConfig.layers,
|
|
47
|
+
appConfig: this.serviceBundleConfig.appConfig
|
|
56
48
|
};
|
|
57
49
|
|
|
58
|
-
const lambdas = new CreateLambda(lambdaProp, this.appConfig);
|
|
50
|
+
const lambdas = new CreateLambda(lambdaProp, this.serviceBundleConfig.appConfig);
|
|
59
51
|
|
|
60
|
-
if (this.tables) {
|
|
61
|
-
this.AssignAccessToTables(this.tables, lambdas.Lambdas);
|
|
52
|
+
if (this.serviceBundleConfig.tables) {
|
|
53
|
+
this.AssignAccessToTables(this.serviceBundleConfig.tables, lambdas.Lambdas);
|
|
62
54
|
}
|
|
63
55
|
|
|
64
56
|
// Allow access to existing tables
|
|
@@ -66,8 +58,8 @@ export class CreateMicroServiceBundle {
|
|
|
66
58
|
// this.AssignAccessToTableRefs(scope, this.props.RESOURCES.DYNAMO?.TABLE_REFS, lambdas.Lambdas);
|
|
67
59
|
// }
|
|
68
60
|
|
|
69
|
-
if (this.secretMgr) {
|
|
70
|
-
this.AssignAccessToSecretManager(this.secretMgr, lambdas.Lambdas);
|
|
61
|
+
if (this.serviceBundleConfig.secretMgr) {
|
|
62
|
+
this.AssignAccessToSecretManager(this.serviceBundleConfig.secretMgr, lambdas.Lambdas);
|
|
71
63
|
}
|
|
72
64
|
|
|
73
65
|
// lambdas.Lambdas.map((lambda) => {
|
|
@@ -78,7 +70,7 @@ export class CreateMicroServiceBundle {
|
|
|
78
70
|
// })
|
|
79
71
|
// });
|
|
80
72
|
|
|
81
|
-
this.AddRoutes(this.props, this.gatewayApi, lambdas.Lambdas, authorizer);
|
|
73
|
+
this.AddRoutes(this.serviceBundleConfig.props, this.serviceBundleConfig.gatewayApi, lambdas.Lambdas, authorizer);
|
|
82
74
|
}
|
|
83
75
|
|
|
84
76
|
private AssignAccessToTables(tables: Table[], lambdas: NodejsFunction[]) {
|
|
@@ -164,7 +156,7 @@ export class CreateMicroServiceBundle {
|
|
|
164
156
|
|
|
165
157
|
props.RESOURCES.LAMBDA?.forEach((prop: TsgLambdaProp) => {
|
|
166
158
|
|
|
167
|
-
const lambdaId = CreateLambda.getIdForLambda(prop, this.appConfig);
|
|
159
|
+
const lambdaId = CreateLambda.getIdForLambda(prop, this.serviceBundleConfig.appConfig);
|
|
168
160
|
|
|
169
161
|
if (!lambdaId) {
|
|
170
162
|
throw new Error(`Can't find lambda`);
|