@sylvesterllc/aws-constructs 1.0.91 → 1.0.93
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/constructs/MicroService.d.ts +9 -0
- package/dist/constructs/MicroService.js +16 -1
- package/dist/resources/gateway/CreateApiAndAttachLambdas.d.ts +3 -0
- package/dist/resources/gateway/CreateApiAndAttachLambdas.js +6 -1
- package/dist/resources/lambda/createLambda.js +9 -9
- package/package.json +1 -1
- package/src/constructs/MicroService.ts +30 -9
- package/src/resources/gateway/CreateApiAndAttachLambdas.ts +22 -15
- package/src/resources/lambda/createLambda.ts +9 -8
|
@@ -1,6 +1,10 @@
|
|
|
1
|
+
import { Table } from "aws-cdk-lib/aws-dynamodb";
|
|
1
2
|
import { Construct } from "constructs";
|
|
2
3
|
import { MicroserviceProps } from "../interfaces/MicroserviceProps";
|
|
3
4
|
import { AppConfig } from "../config/AppConfig";
|
|
5
|
+
import { LayerVersion } from "aws-cdk-lib/aws-lambda";
|
|
6
|
+
import { ISecret } from "aws-cdk-lib/aws-secretsmanager";
|
|
7
|
+
import { NodejsFunction } from "aws-cdk-lib/aws-lambda-nodejs";
|
|
4
8
|
export declare class MicroService extends Construct {
|
|
5
9
|
protected readonly requireDynamoTables: boolean;
|
|
6
10
|
protected requireSeedDatabase: boolean;
|
|
@@ -10,6 +14,11 @@ export declare class MicroService extends Construct {
|
|
|
10
14
|
private readonly dynamoTables;
|
|
11
15
|
private readonly lambdaLayers;
|
|
12
16
|
private readonly secretManager;
|
|
17
|
+
private readonly lambdas;
|
|
18
|
+
get Tables(): Table[] | undefined;
|
|
19
|
+
get SecretManager(): ISecret | null;
|
|
20
|
+
get LambdaLayers(): LayerVersion[] | undefined;
|
|
21
|
+
get Lambdas(): NodejsFunction[];
|
|
13
22
|
constructor(scope: Construct, id: string, props: MicroserviceProps);
|
|
14
23
|
private onInit;
|
|
15
24
|
protected createTag(scope: Construct): void;
|
|
@@ -19,6 +19,19 @@ class MicroService extends constructs_1.Construct {
|
|
|
19
19
|
dynamoTables;
|
|
20
20
|
lambdaLayers;
|
|
21
21
|
secretManager = null;
|
|
22
|
+
lambdas = [];
|
|
23
|
+
get Tables() {
|
|
24
|
+
return this.dynamoTables;
|
|
25
|
+
}
|
|
26
|
+
get SecretManager() {
|
|
27
|
+
return this.secretManager;
|
|
28
|
+
}
|
|
29
|
+
get LambdaLayers() {
|
|
30
|
+
return this.lambdaLayers;
|
|
31
|
+
}
|
|
32
|
+
get Lambdas() {
|
|
33
|
+
return this.lambdas;
|
|
34
|
+
}
|
|
22
35
|
constructor(scope, id, props) {
|
|
23
36
|
super(scope, id);
|
|
24
37
|
this.appConfig = new AppConfig_1.AppConfig(props);
|
|
@@ -33,6 +46,7 @@ class MicroService extends constructs_1.Construct {
|
|
|
33
46
|
this.dynamoTables = results.dynamoTables;
|
|
34
47
|
this.lambdaLayers = results.lambdaLayers;
|
|
35
48
|
this.secretManager = results.secretManager;
|
|
49
|
+
this.lambdas = results.lambdas;
|
|
36
50
|
this.createTag(scope);
|
|
37
51
|
}
|
|
38
52
|
onInit(scope) {
|
|
@@ -64,6 +78,7 @@ class MicroService extends constructs_1.Construct {
|
|
|
64
78
|
lambdaLayers: layers || null,
|
|
65
79
|
dynamoTables: tables || null,
|
|
66
80
|
secretManager: secretManager,
|
|
81
|
+
lambdas: apiGateway.Lambdas,
|
|
67
82
|
};
|
|
68
83
|
}
|
|
69
84
|
createTag(scope) {
|
|
@@ -72,4 +87,4 @@ class MicroService extends constructs_1.Construct {
|
|
|
72
87
|
}
|
|
73
88
|
}
|
|
74
89
|
exports.MicroService = MicroService;
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MicroService.js","sourceRoot":"","sources":["../../src/constructs/MicroService.ts"],"names":[],"mappings":"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","sourcesContent":["import { Table } from \"aws-cdk-lib/aws-dynamodb\";\nimport { Construct } from \"constructs\";\nimport { MicroserviceProps } from \"../interfaces/MicroserviceProps\";\nimport { CreateDynamoDb } from \"../resources/dynamodb/CreateDynamo\";\nimport { Api } from \"../resources/gateway/createApi\";\nimport { getSecretManager } from \"../resources/securityManager\";\nimport { createCommonLayer } from \"../resources/helpers/createCommonLayer\";\nimport { AppConfig } from \"../config/AppConfig\";\nimport { Tags } from \"aws-cdk-lib\";\nimport { LayerVersion } from \"aws-cdk-lib/aws-lambda\";\nimport { CreateApiAndAttachLambdas } from \"../resources/gateway/CreateApiAndAttachLambdas\";\nimport { createSeedDatabaseCustomResource } from \"../resources/customResource/createSeedDatabaseCustomResource\";\nimport { IRestApi } from \"aws-cdk-lib/aws-apigateway\";\nimport { ISecret } from \"aws-cdk-lib/aws-secretsmanager\";\nexport class MicroService extends Construct {\n\n    protected readonly requireDynamoTables: boolean;\n    protected requireSeedDatabase: boolean = false;\n    protected readonly hasLambdaLayers: boolean = false;  \n    protected appConfig: AppConfig;\n    private readonly api: IRestApi;\n    private readonly dynamoTables: Table[] | undefined;\n    private readonly lambdaLayers: LayerVersion[] | undefined;\n    private readonly secretManager: ISecret | null = null;\n\n    constructor(scope: Construct, id: string, props: MicroserviceProps) {\n        super(scope, id);\n\n        this.appConfig = new AppConfig(props);  \n               \n        this.requireDynamoTables = (props.RESOURCES.DYNAMO?.TABLES &&\n            props.RESOURCES.DYNAMO.TABLES.length > 0) ? true : false;\n\n        this.requireSeedDatabase = (props.RESOURCES.DYNAMO?.USE_SEED_DATABASE && \n            props.RESOURCES.DYNAMO.SEED_LAMBDA) ? true : false;\n\n        this.hasLambdaLayers = (props.RESOURCES.LAMBDA_LAYERS && \n            props.RESOURCES.LAMBDA_LAYERS.length > 0) ? true : false;\n\n        const results = this.onInit(scope);\n\n        this.api = results.restApi!;\n        this.dynamoTables = results.dynamoTables!;\n        this.lambdaLayers = results.lambdaLayers!;\n        this.secretManager = results.secretManager!;\n\n        this.createTag(scope)\n    }\n\n    private onInit(scope: Construct) {\n\n        let secretManager: ISecret | null = null;\n        let tables: Table[] | undefined = undefined;\n        let commonLayers: LayerVersion[] | undefined = undefined;\n\n        if (process.env.SECRET_MANAGER_ARN) {\n            // throw new Error(`You must provide the ARN for the your Configuration Secret \n            //     Manager`);      \n             secretManager = getSecretManager(scope, this.appConfig, process.env.SECRET_MANAGER_ARN);            \n        }\n\n        if (this.hasLambdaLayers) {\n            commonLayers = createCommonLayer(scope, this.appConfig);\n        }\n\n        const gateway = new Api(scope, this.appConfig).APIs;\n\n        const layers = commonLayers;\n\n        // Creates DynamoDb Tables if required\n        if (this.requireDynamoTables) {\n            const dynamo = new CreateDynamoDb(scope, this.appConfig);\n\n            tables = dynamo.CreatedTables;\n        }\n\n        if (this.requireSeedDatabase) {\n            createSeedDatabaseCustomResource(scope, this.appConfig, tables![0], layers);\n        }\n          \n        // CREATE API GATEWAY AND LAMBDA HERE \n        const apiGateway = new CreateApiAndAttachLambdas(scope, this.appConfig, gateway[0], layers,tables);\n\n        return {\n            restApi: (gateway?.length > 0) ? gateway[0] : null,\n            lambdaLayers: layers || null,\n            dynamoTables: tables || null,\n            secretManager: secretManager,\n\n        };\n       \n    }\n\n    protected createTag(scope: Construct) {\n        Tags.of(scope).add('App', this.appConfig.AppName);\n        Tags.of(scope).add('ResoucePrefix', this.appConfig.AppPrefix);\n    }\n}"]}
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MicroService.js","sourceRoot":"","sources":["../../src/constructs/MicroService.ts"],"names":[],"mappings":";;;AACA,2CAAuC;AAEvC,qEAAoE;AACpE,8DAAqD;AACrD,kEAAgE;AAChE,8EAA2E;AAC3E,mDAAgD;AAChD,6CAAmC;AAEnC,8FAA2F;AAC3F,mHAAgH;AAIhH,MAAa,YAAa,SAAQ,sBAAS;IAEpB,mBAAmB,CAAU;IACtC,mBAAmB,GAAY,KAAK,CAAC;IAC5B,eAAe,GAAY,KAAK,CAAC;IAC1C,SAAS,CAAY;IACd,GAAG,CAAW;IACd,YAAY,CAAsB;IAClC,YAAY,CAA6B;IACzC,aAAa,GAAmB,IAAI,CAAC;IACrC,OAAO,GAAqB,EAAE,CAAC;IAEhD,IAAW,MAAM;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IAED,IAAW,aAAa;QACpB,OAAO,IAAI,CAAC,aAAa,CAAC;IAC9B,CAAC;IAED,IAAW,YAAY;QACnB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IAED,IAAW,OAAO;QACd,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAED,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAwB;QAC9D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,IAAI,CAAC,SAAS,GAAG,IAAI,qBAAS,CAAC,KAAK,CAAC,CAAC;QAEtC,IAAI,CAAC,mBAAmB,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE,MAAM;YACtD,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QAE7D,IAAI,CAAC,mBAAmB,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE,iBAAiB;YACjE,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QAEvD,IAAI,CAAC,eAAe,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,aAAa;YACjD,KAAK,CAAC,SAAS,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QAE7D,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAEnC,IAAI,CAAC,GAAG,GAAG,OAAO,CAAC,OAAQ,CAAC;QAC5B,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAa,CAAC;QAC1C,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAa,CAAC;QAC1C,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,aAAc,CAAC;QAE5C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,OAAQ,CAAC;QAEhC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAA;IACzB,CAAC;IAEO,MAAM,CAAC,KAAgB;QAE3B,IAAI,aAAa,GAAmB,IAAI,CAAC;QACzC,IAAI,MAAM,GAAwB,SAAS,CAAC;QAC5C,IAAI,YAAY,GAA+B,SAAS,CAAC;QAEzD,IAAI,OAAO,CAAC,GAAG,CAAC,kBAAkB,EAAE,CAAC;YACjC,+EAA+E;YAC/E,uBAAuB;YACvB,aAAa,GAAG,IAAA,kCAAgB,EAAC,KAAK,EAAE,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;QAC5F,CAAC;QAED,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,YAAY,GAAG,IAAA,qCAAiB,EAAC,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QAC5D,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,eAAG,CAAC,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC;QAEpD,MAAM,MAAM,GAAG,YAAY,CAAC;QAE5B,sCAAsC;QACtC,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,MAAM,MAAM,GAAG,IAAI,6BAAc,CAAC,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;YAEzD,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC;QAClC,CAAC;QAED,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,IAAA,mEAAgC,EAAC,KAAK,EAAE,IAAI,CAAC,SAAS,EAAE,MAAO,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;QAChF,CAAC;QAED,sCAAsC;QACtC,MAAM,UAAU,GAAG,IAAI,qDAAyB,CAAC,KAAK,EAAE,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;QAEpG,OAAO;YACH,OAAO,EAAE,CAAC,OAAO,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI;YAClD,YAAY,EAAE,MAAM,IAAI,IAAI;YAC5B,YAAY,EAAE,MAAM,IAAI,IAAI;YAC5B,aAAa,EAAE,aAAa;YAC5B,OAAO,EAAE,UAAU,CAAC,OAAO;SAE9B,CAAC;IAEN,CAAC;IAES,SAAS,CAAC,KAAgB;QAChC,kBAAI,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAClD,kBAAI,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,eAAe,EAAE,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;IAClE,CAAC;CACJ;AAvGD,oCAuGC","sourcesContent":["import { Table } from \"aws-cdk-lib/aws-dynamodb\";\nimport { Construct } from \"constructs\";\nimport { MicroserviceProps } from \"../interfaces/MicroserviceProps\";\nimport { CreateDynamoDb } from \"../resources/dynamodb/CreateDynamo\";\nimport { Api } from \"../resources/gateway/createApi\";\nimport { getSecretManager } from \"../resources/securityManager\";\nimport { createCommonLayer } from \"../resources/helpers/createCommonLayer\";\nimport { AppConfig } from \"../config/AppConfig\";\nimport { Tags } from \"aws-cdk-lib\";\nimport { LayerVersion } from \"aws-cdk-lib/aws-lambda\";\nimport { CreateApiAndAttachLambdas } from \"../resources/gateway/CreateApiAndAttachLambdas\";\nimport { createSeedDatabaseCustomResource } from \"../resources/customResource/createSeedDatabaseCustomResource\";\nimport { IRestApi } from \"aws-cdk-lib/aws-apigateway\";\nimport { ISecret } from \"aws-cdk-lib/aws-secretsmanager\";\nimport { NodejsFunction } from \"aws-cdk-lib/aws-lambda-nodejs\";\nexport class MicroService extends Construct {\n\n    protected readonly requireDynamoTables: boolean;\n    protected requireSeedDatabase: boolean = false;\n    protected readonly hasLambdaLayers: boolean = false;\n    protected appConfig: AppConfig;\n    private readonly api: IRestApi;\n    private readonly dynamoTables: Table[] | undefined;\n    private readonly lambdaLayers: LayerVersion[] | undefined;\n    private readonly secretManager: ISecret | null = null;\n    private readonly lambdas: NodejsFunction[] = [];\n\n    public get Tables() {\n        return this.dynamoTables;\n    }\n\n    public get SecretManager() {\n        return this.secretManager;\n    }\n\n    public get LambdaLayers() {\n        return this.lambdaLayers;\n    }\n\n    public get Lambdas() {\n        return this.lambdas;\n    }\n\n    constructor(scope: Construct, id: string, props: MicroserviceProps) {\n        super(scope, id);\n\n        this.appConfig = new AppConfig(props);\n\n        this.requireDynamoTables = (props.RESOURCES.DYNAMO?.TABLES &&\n            props.RESOURCES.DYNAMO.TABLES.length > 0) ? true : false;\n\n        this.requireSeedDatabase = (props.RESOURCES.DYNAMO?.USE_SEED_DATABASE &&\n            props.RESOURCES.DYNAMO.SEED_LAMBDA) ? true : false;\n\n        this.hasLambdaLayers = (props.RESOURCES.LAMBDA_LAYERS &&\n            props.RESOURCES.LAMBDA_LAYERS.length > 0) ? true : false;\n\n        const results = this.onInit(scope);\n\n        this.api = results.restApi!;\n        this.dynamoTables = results.dynamoTables!;\n        this.lambdaLayers = results.lambdaLayers!;\n        this.secretManager = results.secretManager!;\n\n        this.lambdas = results.lambdas!;\n\n        this.createTag(scope)\n    }\n\n    private onInit(scope: Construct) {\n\n        let secretManager: ISecret | null = null;\n        let tables: Table[] | undefined = undefined;\n        let commonLayers: LayerVersion[] | undefined = undefined;\n\n        if (process.env.SECRET_MANAGER_ARN) {\n            // throw new Error(`You must provide the ARN for the your Configuration Secret \n            //     Manager`);      \n            secretManager = getSecretManager(scope, this.appConfig, process.env.SECRET_MANAGER_ARN);\n        }\n\n        if (this.hasLambdaLayers) {\n            commonLayers = createCommonLayer(scope, this.appConfig);\n        }\n\n        const gateway = new Api(scope, this.appConfig).APIs;\n\n        const layers = commonLayers;\n\n        // Creates DynamoDb Tables if required\n        if (this.requireDynamoTables) {\n            const dynamo = new CreateDynamoDb(scope, this.appConfig);\n\n            tables = dynamo.CreatedTables;\n        }\n\n        if (this.requireSeedDatabase) {\n            createSeedDatabaseCustomResource(scope, this.appConfig, tables![0], layers);\n        }\n\n        // CREATE API GATEWAY AND LAMBDA HERE \n        const apiGateway = new CreateApiAndAttachLambdas(scope, this.appConfig, gateway[0], layers, tables);\n\n        return {\n            restApi: (gateway?.length > 0) ? gateway[0] : null,\n            lambdaLayers: layers || null,\n            dynamoTables: tables || null,\n            secretManager: secretManager,\n            lambdas: apiGateway.Lambdas,\n\n        };\n\n    }\n\n    protected createTag(scope: Construct) {\n        Tags.of(scope).add('App', this.appConfig.AppName);\n        Tags.of(scope).add('ResoucePrefix', this.appConfig.AppPrefix);\n    }\n}"]}
|
|
@@ -6,12 +6,15 @@ import { ApiLambdaResult } from "../../interfaces/ApiLambdaResult";
|
|
|
6
6
|
import { TsgAuthorizerType } from "../../config/types/TsgAuthorizerType";
|
|
7
7
|
import { IRestApi } from "aws-cdk-lib/aws-apigateway";
|
|
8
8
|
import { LayerVersion } from "aws-cdk-lib/aws-lambda";
|
|
9
|
+
import { NodejsFunction } from "aws-cdk-lib/aws-lambda-nodejs";
|
|
9
10
|
export declare class CreateApiAndAttachLambdas extends BaseResource<ApiLambdaResult> {
|
|
10
11
|
private gatewayApi;
|
|
11
12
|
private layers?;
|
|
12
13
|
private tables?;
|
|
13
14
|
protected requireAuthorizer: boolean;
|
|
14
15
|
protected authorizerType?: TsgAuthorizerType;
|
|
16
|
+
private lambdas;
|
|
17
|
+
get Lambdas(): NodejsFunction[];
|
|
15
18
|
constructor(scope: Construct, config: AppConfig, gatewayApi: IRestApi, layers?: LayerVersion[] | undefined, tables?: ITable[] | undefined);
|
|
16
19
|
protected createResource(scope: Construct): ApiLambdaResult[] | null;
|
|
17
20
|
protected createOutput<T>(scope: Construct, createdAssets: T[]): void;
|
|
@@ -14,6 +14,10 @@ class CreateApiAndAttachLambdas extends baseResource_1.BaseResource {
|
|
|
14
14
|
tables;
|
|
15
15
|
requireAuthorizer;
|
|
16
16
|
authorizerType;
|
|
17
|
+
lambdas = [];
|
|
18
|
+
get Lambdas() {
|
|
19
|
+
return this.lambdas;
|
|
20
|
+
}
|
|
17
21
|
constructor(scope, config, gatewayApi, layers, tables) {
|
|
18
22
|
super(scope, config);
|
|
19
23
|
this.gatewayApi = gatewayApi;
|
|
@@ -43,6 +47,7 @@ class CreateApiAndAttachLambdas extends baseResource_1.BaseResource {
|
|
|
43
47
|
}
|
|
44
48
|
// Create Lambdas
|
|
45
49
|
const lambdas = new createLambda_1.CreateLambda(scope, this.config, this.layers);
|
|
50
|
+
this.lambdas = lambdas.Lambdas;
|
|
46
51
|
// Give Access to Lambdds to All DynamoDb Tables
|
|
47
52
|
if (this.tables) {
|
|
48
53
|
this.assignAccessToTables(this.tables, lambdas.Lambdas);
|
|
@@ -102,4 +107,4 @@ class CreateApiAndAttachLambdas extends baseResource_1.BaseResource {
|
|
|
102
107
|
}
|
|
103
108
|
}
|
|
104
109
|
exports.CreateApiAndAttachLambdas = CreateApiAndAttachLambdas;
|
|
105
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CreateApiAndAttachLambdas.js","sourceRoot":"","sources":["../../../src/resources/gateway/CreateApiAndAttachLambdas.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from \"constructs\";\nimport { BaseResource } from \"../base/baseResource\";\nimport { ITable } from \"aws-cdk-lib/aws-dynamodb\";\nimport { AppConfig } from \"../../config/AppConfig\";\nimport { ApiLambdaResult } from \"../../interfaces/ApiLambdaResult\";\nimport { TsgAuthorizerType } from \"../../config/types/TsgAuthorizerType\";\nimport { IRestApi, RequestAuthorizer, TokenAuthorizer } from \"aws-cdk-lib/aws-apigateway\";\nimport { TsgJwtTokenAuthorizer } from \"../lambda-authorizer/TsgJwtTokenAuthorizer\";\nimport { CfnOutput, RemovalPolicy } from \"aws-cdk-lib\";\nimport { TsgRequestAuthorizer } from \"../lambda-authorizer/TsgRequestAuthorizer\";\nimport { CreateLambda } from \"../lambda/createLambda\";\nimport { LayerVersion } from \"aws-cdk-lib/aws-lambda\";\nimport { NodejsFunction } from \"aws-cdk-lib/aws-lambda-nodejs\";\nimport { TsgLambdaProp } from \"../../config/types\";\nimport { Routes } from \"../helpers/createRoutes\";\n\nexport class CreateApiAndAttachLambdas extends BaseResource<ApiLambdaResult> {\n    \n    protected requireAuthorizer: boolean;\n    protected authorizerType?: TsgAuthorizerType;\n\n    constructor(scope: Construct,\n        config: AppConfig,\n        private gatewayApi: IRestApi,\n        private layers?: LayerVersion[],\n        private tables?: ITable[]) {\n        super(scope, config);\n        \n        this.requireAuthorizer = (this.config.RESOURCES.AUTHORIZER && \n            this.config.RESOURCES.AUTHORIZER.type) ? true : false;       \n\n        if (this.requireAuthorizer) {\n            this.authorizerType = this.config.RESOURCES.AUTHORIZER?.type;\n        } else if (this.config.RESOURCES.AUTHORIZER && !this.config.RESOURCES.AUTHORIZER.type) {\n            throw new Error(`You must provide an authorizer type if a Authorizer is required`);\n        }\n\n        this.createdResources = this.createResource(scope)!;\n    }\n\n    protected createResource(scope: Construct): ApiLambdaResult[] | null {\n\n        let authorizer: TokenAuthorizer | RequestAuthorizer | undefined | null = undefined;\n\n        // Create Authorizer\n        if (this.requireAuthorizer) {\n            authorizer = this.createAuthorizer();\n\n            if (!authorizer) {\n                // console.log('Authorizer Not Created');\n            }\n            else {\n                // console.log('Authorizer Created', authorizer);\n            }\n        }\n\n        // Create Lambdas\n        const lambdas = new CreateLambda(scope, this.config, this.layers);\n        \n        // Give Access to Lambdds to All DynamoDb Tables\n        if (this.tables) {\n            this.assignAccessToTables(this.tables, lambdas.Lambdas);\n        }\n        \n        // Create Routes on API Gateway for Lambdas from config\n        this.AddRoutes(this.config, this.gatewayApi, lambdas.Lambdas, authorizer);\n\n        const result: ApiLambdaResult = {\n            api: this.gatewayApi,\n            authorizer: authorizer\n        };\n        return [result];\n    }\n\n    protected createOutput<T>(scope: Construct, createdAssets: T[]): void {\n        \n        this.createdResources!.forEach((x, idx) => {\n            new CfnOutput(scope, `Authorizerr-${idx}`, {\n                value: x.authorizer?.authorizerArn!\n            });\n        });\n    }    \n\n    private createAuthorizer() {\n\n        let authorizer: TokenAuthorizer | RequestAuthorizer | undefined = undefined;\n\n        if (this.requireAuthorizer && this.authorizerType === TsgAuthorizerType.TOKEN_AUTHORIZER) {\n\n            authorizer = new TsgJwtTokenAuthorizer(this.scope,\n                this.config).JwtAuthorizer;\n\n            (authorizer as TokenAuthorizer)?._attachToApi(this.gatewayApi);\n            (authorizer as TokenAuthorizer)?.applyRemovalPolicy(RemovalPolicy.DESTROY);\n\n            return authorizer;\n\n        } else if (this.requireAuthorizer && this.authorizerType === TsgAuthorizerType.REQUEST_AUTHORIZER) {            \n\n            authorizer = new TsgRequestAuthorizer(this.scope,\n                this.config, this.layers, this.tables).TsgRequestAuthorizer as RequestAuthorizer;\n                \n                (authorizer as RequestAuthorizer)._attachToApi(this.gatewayApi);\n                (authorizer as RequestAuthorizer).applyRemovalPolicy(RemovalPolicy.DESTROY);\n            \n            return authorizer;\n        }\n\n       \n        return authorizer;\n    }\n\n    private assignAccessToTables(tables: ITable[], lambdas: NodejsFunction[]) {\n\n        if (tables) {\n            lambdas.forEach((lambda: NodejsFunction) => {\n\n                tables.forEach((table: ITable) => {\n\n                    table.grantReadWriteData(lambda);\n\n                });\n            });\n        }\n    }\n\n    private AddRoutes(config: AppConfig,\n        gateway: IRestApi,\n        lambdas: NodejsFunction[],\n        authorizer?: TokenAuthorizer|RequestAuthorizer) {\n\n        config.RESOURCES.LAMBDA?.forEach((prop: TsgLambdaProp) => {\n\n            const lambdaId = CreateLambda.getIdForLambda(prop, this.config);\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}"]}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CreateApiAndAttachLambdas.js","sourceRoot":"","sources":["../../../src/resources/gateway/CreateApiAndAttachLambdas.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from \"constructs\";\nimport { BaseResource } from \"../base/baseResource\";\nimport { ITable } from \"aws-cdk-lib/aws-dynamodb\";\nimport { AppConfig } from \"../../config/AppConfig\";\nimport { ApiLambdaResult } from \"../../interfaces/ApiLambdaResult\";\nimport { TsgAuthorizerType } from \"../../config/types/TsgAuthorizerType\";\nimport { IRestApi, RequestAuthorizer, TokenAuthorizer } from \"aws-cdk-lib/aws-apigateway\";\nimport { TsgJwtTokenAuthorizer } from \"../lambda-authorizer/TsgJwtTokenAuthorizer\";\nimport { CfnOutput, RemovalPolicy } from \"aws-cdk-lib\";\nimport { TsgRequestAuthorizer } from \"../lambda-authorizer/TsgRequestAuthorizer\";\nimport { CreateLambda } from \"../lambda/createLambda\";\nimport { LayerVersion } from \"aws-cdk-lib/aws-lambda\";\nimport { NodejsFunction } from \"aws-cdk-lib/aws-lambda-nodejs\";\nimport { TsgLambdaProp } from \"../../config/types\";\nimport { Routes } from \"../helpers/createRoutes\";\n\nexport class CreateApiAndAttachLambdas extends BaseResource<ApiLambdaResult> {\n\n    protected requireAuthorizer: boolean;\n    protected authorizerType?: TsgAuthorizerType;\n\n    private lambdas: NodejsFunction[] = [];\n\n    public get Lambdas() {\n        return this.lambdas;\n    }\n\n    constructor(scope: Construct,\n        config: AppConfig,\n        private gatewayApi: IRestApi,\n        private layers?: LayerVersion[],\n        private tables?: ITable[]) {\n        super(scope, config);\n\n        this.requireAuthorizer = (this.config.RESOURCES.AUTHORIZER &&\n            this.config.RESOURCES.AUTHORIZER.type) ? true : false;\n\n        if (this.requireAuthorizer) {\n            this.authorizerType = this.config.RESOURCES.AUTHORIZER?.type;\n        } else if (this.config.RESOURCES.AUTHORIZER && !this.config.RESOURCES.AUTHORIZER.type) {\n            throw new Error(`You must provide an authorizer type if a Authorizer is required`);\n        }\n\n        this.createdResources = this.createResource(scope)!;\n    }\n\n    protected createResource(scope: Construct): ApiLambdaResult[] | null {\n\n        let authorizer: TokenAuthorizer | RequestAuthorizer | undefined | null = undefined;\n\n        // Create Authorizer\n        if (this.requireAuthorizer) {\n            authorizer = this.createAuthorizer();\n\n            if (!authorizer) {\n                // console.log('Authorizer Not Created');\n            }\n            else {\n                // console.log('Authorizer Created', authorizer);\n            }\n        }\n\n        // Create Lambdas\n        const lambdas = new CreateLambda(scope, this.config, this.layers);\n        this.lambdas = lambdas.Lambdas;\n\n        // Give Access to Lambdds to All DynamoDb Tables\n        if (this.tables) {\n            this.assignAccessToTables(this.tables, lambdas.Lambdas);\n        }\n\n        // Create Routes on API Gateway for Lambdas from config\n        this.AddRoutes(this.config, this.gatewayApi, lambdas.Lambdas, authorizer);\n\n        const result: ApiLambdaResult = {\n            api: this.gatewayApi,\n            authorizer: authorizer\n        };\n        return [result];\n    }\n\n    protected createOutput<T>(scope: Construct, createdAssets: T[]): void {\n\n        this.createdResources!.forEach((x, idx) => {\n            new CfnOutput(scope, `Authorizerr-${idx}`, {\n                value: x.authorizer?.authorizerArn!\n            });\n        });\n    }\n\n    private createAuthorizer() {\n\n        let authorizer: TokenAuthorizer | RequestAuthorizer | undefined = undefined;\n\n        if (this.requireAuthorizer && this.authorizerType === TsgAuthorizerType.TOKEN_AUTHORIZER) {\n\n            authorizer = new TsgJwtTokenAuthorizer(this.scope,\n                this.config).JwtAuthorizer;\n\n            (authorizer as TokenAuthorizer)?._attachToApi(this.gatewayApi);\n            (authorizer as TokenAuthorizer)?.applyRemovalPolicy(RemovalPolicy.DESTROY);\n\n            return authorizer;\n\n        } else if (this.requireAuthorizer && this.authorizerType === TsgAuthorizerType.REQUEST_AUTHORIZER) {\n\n            authorizer = new TsgRequestAuthorizer(this.scope,\n                this.config, this.layers, this.tables).TsgRequestAuthorizer as RequestAuthorizer;\n\n            (authorizer as RequestAuthorizer)._attachToApi(this.gatewayApi);\n            (authorizer as RequestAuthorizer).applyRemovalPolicy(RemovalPolicy.DESTROY);\n\n            return authorizer;\n        }\n\n\n        return authorizer;\n    }\n\n    private assignAccessToTables(tables: ITable[], lambdas: NodejsFunction[]) {\n\n        if (tables) {\n            lambdas.forEach((lambda: NodejsFunction) => {\n\n                tables.forEach((table: ITable) => {\n\n                    table.grantReadWriteData(lambda);\n\n                });\n            });\n        }\n    }\n\n    private AddRoutes(config: AppConfig,\n        gateway: IRestApi,\n        lambdas: NodejsFunction[],\n        authorizer?: TokenAuthorizer | RequestAuthorizer) {\n\n        config.RESOURCES.LAMBDA?.forEach((prop: TsgLambdaProp) => {\n\n            const lambdaId = CreateLambda.getIdForLambda(prop, this.config);\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}"]}
|
|
@@ -95,29 +95,29 @@ class CreateLambda extends baseResource_1.BaseResource {
|
|
|
95
95
|
period: aws_cdk_lib_1.Duration.minutes(3),
|
|
96
96
|
});
|
|
97
97
|
const uuid = (0, util_helper_1.getUUID)().split('-')[0];
|
|
98
|
-
new aws_cloudwatch_1.Alarm(this.scope, `${this.config.AppPrefix}-${
|
|
98
|
+
new aws_cloudwatch_1.Alarm(this.scope, `${this.config.AppPrefix}-${lambda.functionName}-error-alarm`, {
|
|
99
99
|
metric: errorMetric,
|
|
100
100
|
threshold: 5,
|
|
101
101
|
comparisonOperator: aws_cloudwatch_1.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,
|
|
102
102
|
evaluationPeriods: 3,
|
|
103
103
|
alarmDescription: `${this.config.AppPrefix} errors over 3 min period`,
|
|
104
|
-
alarmName: `${this.config.AppPrefix}-${
|
|
104
|
+
alarmName: `${this.config.AppPrefix}-${lambda.functionName}-error-alarm`
|
|
105
105
|
});
|
|
106
|
-
new aws_cloudwatch_1.Alarm(this.scope, `${this.config.AppPrefix}-${
|
|
106
|
+
new aws_cloudwatch_1.Alarm(this.scope, `${this.config.AppPrefix}-${lambda.functionName}-duration-alarm`, {
|
|
107
107
|
metric: durationMetric,
|
|
108
108
|
threshold: 1,
|
|
109
109
|
comparisonOperator: aws_cloudwatch_1.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,
|
|
110
110
|
evaluationPeriods: 3,
|
|
111
|
-
alarmDescription: `${this.config.AppPrefix}-${
|
|
112
|
-
alarmName: `${this.config.AppPrefix}-${
|
|
111
|
+
alarmDescription: `${this.config.AppPrefix}-${lambda.functionName} duration errors over 3 min period`,
|
|
112
|
+
alarmName: `${this.config.AppPrefix}-${lambda.functionName}-duration-alarm`
|
|
113
113
|
});
|
|
114
|
-
const invocationAlarm = new aws_cloudwatch_1.Alarm(this.scope, `${this.config.AppPrefix}-${
|
|
114
|
+
const invocationAlarm = new aws_cloudwatch_1.Alarm(this.scope, `${this.config.AppPrefix}-${lambda.functionName}-invocation-alarm`, {
|
|
115
115
|
metric: errorMetric,
|
|
116
116
|
threshold: 1000,
|
|
117
117
|
comparisonOperator: aws_cloudwatch_1.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,
|
|
118
118
|
evaluationPeriods: 3,
|
|
119
|
-
alarmDescription: `${this.config.AppPrefix}-${
|
|
120
|
-
alarmName: `${this.config.AppPrefix}-${
|
|
119
|
+
alarmDescription: `${this.config.AppPrefix}-${lambda.functionName} errors over 3 min period`,
|
|
120
|
+
alarmName: `${this.config.AppPrefix}-${lambda.functionName}-invocation-Metric-alarm`
|
|
121
121
|
});
|
|
122
122
|
});
|
|
123
123
|
}
|
|
@@ -137,4 +137,4 @@ class CreateLambda extends baseResource_1.BaseResource {
|
|
|
137
137
|
}
|
|
138
138
|
}
|
|
139
139
|
exports.CreateLambda = CreateLambda;
|
|
140
|
-
//# 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\";\nimport { RetentionDays } from \"aws-cdk-lib/aws-logs\";\nimport { LambdaHelper } from \"./lambdaHelper\";\nimport { getUUID } from \"../../helpers/util-helper\";\n\n\nexport class CreateLambda extends BaseResource<NodejsFunction> {\n\n    public Lambdas: NodejsFunction[] = [];\n    public LambdaRecords: Record<string, NodejsFunction> = {};\n\n    constructor(scope: Construct, config: AppConfig, private layers?: LayerVersion[]) {\n        super(scope, config);\n\n        const resources = this.createResource(scope);\n\n        this.createdResources = [...resources];\n\n        this.Lambdas = [...resources];\n\n        this.createAlarmsForLambdas(this.Lambdas);\n\n        this.LambdaRecords = this.createRecordForLambda(this.Lambdas);\n\n        this.createOutput(scope, resources);\n    }\n\n    protected createResource(scope: Construct): NodejsFunction[] {\n\n        const result = this.createLambdas(this.config);\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(config: AppConfig): NodejsFunction[] {\n\n        const createdLambdas: NodejsFunction[] = this.createLambdaFunctions(this.scope, undefined, this.layers);\n\n        return createdLambdas;\n    }\n\n    private createLambdaFunctions(scope: Construct, role?: IRole, layers?: LayerVersion[]) {\n\n        const createdLambdas = this.config.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            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        const lambdaProp: NodejsFunctionProps = {\n            entry: path.join(prop.codePath),\n            functionName: `${this.config.AppPrefix}-${prop.name}`,\n            handler: prop.handler,\n            logRetention: (!prop.logDuration) ? RetentionDays.FIVE_DAYS : LambdaHelper.getDayToSaveLogs(prop.logDuration),\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        return lambdaProp;\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            const uuid = getUUID().split('-')[0];\n            new Alarm(this.scope, `${this.config.AppPrefix}-${uuid}-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} errors over 3 min period`,\n                alarmName: `${this.config.AppPrefix}-${uuid}-error-alarm`\n            });\n\n            new Alarm(this.scope, `${this.config.AppPrefix}-${uuid}-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}-${uuid} duration errors over 3 min period`,\n                alarmName: `${this.config.AppPrefix}-${uuid}-duration-alarm`\n            });\n\n            const invocationAlarm = new Alarm(this.scope, `${this.config.AppPrefix}-${uuid}-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}-${uuid} errors over 3 min period`,\n                alarmName: `${this.config.AppPrefix}-${uuid}-invocation-Metric-alarm`\n            });\n        });\n    }\n\n    public static getIdForLambda(lambdaProp: TsgLambdaProp, appConfig: AppConfig) {\n        return `${appConfig.AppPrefix}-${lambdaProp.name}`.toLowerCase();\n    }\n\n    private createRecordForLambda(lambdas: NodejsFunction[]) {\n\n        const names = this.config.RESOURCES.LAMBDA.map((lambda) => {\n            return lambda.name;\n        });\n\n        const lambdaNames = [...names] as const;\n\n        type LambdaName = typeof lambdaNames[number];\n\n\n        const lambdaRecord: Record<LambdaName, NodejsFunction> = {} as Record<LambdaName, NodejsFunction>;\n\n        lambdas.forEach((lambda, idx) => {\n            lambdaRecord[lambdaNames[idx] as LambdaName] = lambdas[idx];\n        });\n\n        return lambdaRecord;\n    }\n}\n\n\n"]}
|
|
140
|
+
//# 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\";\nimport { RetentionDays } from \"aws-cdk-lib/aws-logs\";\nimport { LambdaHelper } from \"./lambdaHelper\";\nimport { getUUID } from \"../../helpers/util-helper\";\n\n\nexport class CreateLambda extends BaseResource<NodejsFunction> {\n\n    public Lambdas: NodejsFunction[] = [];\n    public LambdaRecords: Record<string, NodejsFunction> = {};\n\n    constructor(scope: Construct, config: AppConfig, private layers?: LayerVersion[]) {\n        super(scope, config);\n\n        const resources = this.createResource(scope);\n\n        this.createdResources = [...resources];\n\n        this.Lambdas = [...resources];\n\n        this.createAlarmsForLambdas(this.Lambdas);\n\n        this.LambdaRecords = this.createRecordForLambda(this.Lambdas);\n\n        this.createOutput(scope, resources);\n    }\n\n    protected createResource(scope: Construct): NodejsFunction[] {\n\n        const result = this.createLambdas(this.config);\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(config: AppConfig): NodejsFunction[] {\n\n        const createdLambdas: NodejsFunction[] = this.createLambdaFunctions(this.scope, undefined, this.layers);\n\n        return createdLambdas;\n    }\n\n    private createLambdaFunctions(scope: Construct, role?: IRole, layers?: LayerVersion[]) {\n\n        const createdLambdas = this.config.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            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        const lambdaProp: NodejsFunctionProps = {\n            entry: path.join(prop.codePath),\n            functionName: `${this.config.AppPrefix}-${prop.name}`,\n            handler: prop.handler,\n            logRetention: (!prop.logDuration) ? RetentionDays.FIVE_DAYS : LambdaHelper.getDayToSaveLogs(prop.logDuration),\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        return lambdaProp;\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            const uuid = getUUID().split('-')[0];\n\n            new Alarm(this.scope, `${this.config.AppPrefix}-${lambda.functionName}-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} errors over 3 min period`,\n                alarmName: `${this.config.AppPrefix}-${lambda.functionName}-error-alarm`\n            });\n\n            new Alarm(this.scope, `${this.config.AppPrefix}-${lambda.functionName}-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}-${lambda.functionName} duration errors over 3 min period`,\n                alarmName: `${this.config.AppPrefix}-${lambda.functionName}-duration-alarm`\n            });\n\n            const invocationAlarm = new Alarm(this.scope, `${this.config.AppPrefix}-${lambda.functionName}-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}-${lambda.functionName} errors over 3 min period`,\n                alarmName: `${this.config.AppPrefix}-${lambda.functionName}-invocation-Metric-alarm`\n            });\n        });\n    }\n\n    public static getIdForLambda(lambdaProp: TsgLambdaProp, appConfig: AppConfig) {\n        return `${appConfig.AppPrefix}-${lambdaProp.name}`.toLowerCase();\n    }\n\n    private createRecordForLambda(lambdas: NodejsFunction[]) {\n\n        const names = this.config.RESOURCES.LAMBDA.map((lambda) => {\n            return lambda.name;\n        });\n\n        const lambdaNames = [...names] as const;\n\n        type LambdaName = typeof lambdaNames[number];\n\n\n        const lambdaRecord: Record<LambdaName, NodejsFunction> = {} as Record<LambdaName, NodejsFunction>;\n\n        lambdas.forEach((lambda, idx) => {\n            lambdaRecord[lambdaNames[idx] as LambdaName] = lambdas[idx];\n        });\n\n        return lambdaRecord;\n    }\n}\n\n\n"]}
|
package/package.json
CHANGED
|
@@ -12,29 +12,47 @@ import { CreateApiAndAttachLambdas } from "../resources/gateway/CreateApiAndAtta
|
|
|
12
12
|
import { createSeedDatabaseCustomResource } from "../resources/customResource/createSeedDatabaseCustomResource";
|
|
13
13
|
import { IRestApi } from "aws-cdk-lib/aws-apigateway";
|
|
14
14
|
import { ISecret } from "aws-cdk-lib/aws-secretsmanager";
|
|
15
|
+
import { NodejsFunction } from "aws-cdk-lib/aws-lambda-nodejs";
|
|
15
16
|
export class MicroService extends Construct {
|
|
16
17
|
|
|
17
18
|
protected readonly requireDynamoTables: boolean;
|
|
18
19
|
protected requireSeedDatabase: boolean = false;
|
|
19
|
-
protected readonly hasLambdaLayers: boolean = false;
|
|
20
|
+
protected readonly hasLambdaLayers: boolean = false;
|
|
20
21
|
protected appConfig: AppConfig;
|
|
21
22
|
private readonly api: IRestApi;
|
|
22
23
|
private readonly dynamoTables: Table[] | undefined;
|
|
23
24
|
private readonly lambdaLayers: LayerVersion[] | undefined;
|
|
24
25
|
private readonly secretManager: ISecret | null = null;
|
|
26
|
+
private readonly lambdas: NodejsFunction[] = [];
|
|
27
|
+
|
|
28
|
+
public get Tables() {
|
|
29
|
+
return this.dynamoTables;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
public get SecretManager() {
|
|
33
|
+
return this.secretManager;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
public get LambdaLayers() {
|
|
37
|
+
return this.lambdaLayers;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
public get Lambdas() {
|
|
41
|
+
return this.lambdas;
|
|
42
|
+
}
|
|
25
43
|
|
|
26
44
|
constructor(scope: Construct, id: string, props: MicroserviceProps) {
|
|
27
45
|
super(scope, id);
|
|
28
46
|
|
|
29
|
-
this.appConfig = new AppConfig(props);
|
|
30
|
-
|
|
47
|
+
this.appConfig = new AppConfig(props);
|
|
48
|
+
|
|
31
49
|
this.requireDynamoTables = (props.RESOURCES.DYNAMO?.TABLES &&
|
|
32
50
|
props.RESOURCES.DYNAMO.TABLES.length > 0) ? true : false;
|
|
33
51
|
|
|
34
|
-
this.requireSeedDatabase = (props.RESOURCES.DYNAMO?.USE_SEED_DATABASE &&
|
|
52
|
+
this.requireSeedDatabase = (props.RESOURCES.DYNAMO?.USE_SEED_DATABASE &&
|
|
35
53
|
props.RESOURCES.DYNAMO.SEED_LAMBDA) ? true : false;
|
|
36
54
|
|
|
37
|
-
this.hasLambdaLayers = (props.RESOURCES.LAMBDA_LAYERS &&
|
|
55
|
+
this.hasLambdaLayers = (props.RESOURCES.LAMBDA_LAYERS &&
|
|
38
56
|
props.RESOURCES.LAMBDA_LAYERS.length > 0) ? true : false;
|
|
39
57
|
|
|
40
58
|
const results = this.onInit(scope);
|
|
@@ -44,6 +62,8 @@ export class MicroService extends Construct {
|
|
|
44
62
|
this.lambdaLayers = results.lambdaLayers!;
|
|
45
63
|
this.secretManager = results.secretManager!;
|
|
46
64
|
|
|
65
|
+
this.lambdas = results.lambdas!;
|
|
66
|
+
|
|
47
67
|
this.createTag(scope)
|
|
48
68
|
}
|
|
49
69
|
|
|
@@ -56,7 +76,7 @@ export class MicroService extends Construct {
|
|
|
56
76
|
if (process.env.SECRET_MANAGER_ARN) {
|
|
57
77
|
// throw new Error(`You must provide the ARN for the your Configuration Secret
|
|
58
78
|
// Manager`);
|
|
59
|
-
|
|
79
|
+
secretManager = getSecretManager(scope, this.appConfig, process.env.SECRET_MANAGER_ARN);
|
|
60
80
|
}
|
|
61
81
|
|
|
62
82
|
if (this.hasLambdaLayers) {
|
|
@@ -77,18 +97,19 @@ export class MicroService extends Construct {
|
|
|
77
97
|
if (this.requireSeedDatabase) {
|
|
78
98
|
createSeedDatabaseCustomResource(scope, this.appConfig, tables![0], layers);
|
|
79
99
|
}
|
|
80
|
-
|
|
100
|
+
|
|
81
101
|
// CREATE API GATEWAY AND LAMBDA HERE
|
|
82
|
-
const apiGateway = new CreateApiAndAttachLambdas(scope, this.appConfig, gateway[0], layers,tables);
|
|
102
|
+
const apiGateway = new CreateApiAndAttachLambdas(scope, this.appConfig, gateway[0], layers, tables);
|
|
83
103
|
|
|
84
104
|
return {
|
|
85
105
|
restApi: (gateway?.length > 0) ? gateway[0] : null,
|
|
86
106
|
lambdaLayers: layers || null,
|
|
87
107
|
dynamoTables: tables || null,
|
|
88
108
|
secretManager: secretManager,
|
|
109
|
+
lambdas: apiGateway.Lambdas,
|
|
89
110
|
|
|
90
111
|
};
|
|
91
|
-
|
|
112
|
+
|
|
92
113
|
}
|
|
93
114
|
|
|
94
115
|
protected createTag(scope: Construct) {
|
|
@@ -15,19 +15,25 @@ import { TsgLambdaProp } from "../../config/types";
|
|
|
15
15
|
import { Routes } from "../helpers/createRoutes";
|
|
16
16
|
|
|
17
17
|
export class CreateApiAndAttachLambdas extends BaseResource<ApiLambdaResult> {
|
|
18
|
-
|
|
18
|
+
|
|
19
19
|
protected requireAuthorizer: boolean;
|
|
20
20
|
protected authorizerType?: TsgAuthorizerType;
|
|
21
21
|
|
|
22
|
+
private lambdas: NodejsFunction[] = [];
|
|
23
|
+
|
|
24
|
+
public get Lambdas() {
|
|
25
|
+
return this.lambdas;
|
|
26
|
+
}
|
|
27
|
+
|
|
22
28
|
constructor(scope: Construct,
|
|
23
29
|
config: AppConfig,
|
|
24
30
|
private gatewayApi: IRestApi,
|
|
25
31
|
private layers?: LayerVersion[],
|
|
26
32
|
private tables?: ITable[]) {
|
|
27
33
|
super(scope, config);
|
|
28
|
-
|
|
29
|
-
this.requireAuthorizer = (this.config.RESOURCES.AUTHORIZER &&
|
|
30
|
-
this.config.RESOURCES.AUTHORIZER.type) ? true : false;
|
|
34
|
+
|
|
35
|
+
this.requireAuthorizer = (this.config.RESOURCES.AUTHORIZER &&
|
|
36
|
+
this.config.RESOURCES.AUTHORIZER.type) ? true : false;
|
|
31
37
|
|
|
32
38
|
if (this.requireAuthorizer) {
|
|
33
39
|
this.authorizerType = this.config.RESOURCES.AUTHORIZER?.type;
|
|
@@ -56,12 +62,13 @@ export class CreateApiAndAttachLambdas extends BaseResource<ApiLambdaResult> {
|
|
|
56
62
|
|
|
57
63
|
// Create Lambdas
|
|
58
64
|
const lambdas = new CreateLambda(scope, this.config, this.layers);
|
|
59
|
-
|
|
65
|
+
this.lambdas = lambdas.Lambdas;
|
|
66
|
+
|
|
60
67
|
// Give Access to Lambdds to All DynamoDb Tables
|
|
61
68
|
if (this.tables) {
|
|
62
69
|
this.assignAccessToTables(this.tables, lambdas.Lambdas);
|
|
63
70
|
}
|
|
64
|
-
|
|
71
|
+
|
|
65
72
|
// Create Routes on API Gateway for Lambdas from config
|
|
66
73
|
this.AddRoutes(this.config, this.gatewayApi, lambdas.Lambdas, authorizer);
|
|
67
74
|
|
|
@@ -73,13 +80,13 @@ export class CreateApiAndAttachLambdas extends BaseResource<ApiLambdaResult> {
|
|
|
73
80
|
}
|
|
74
81
|
|
|
75
82
|
protected createOutput<T>(scope: Construct, createdAssets: T[]): void {
|
|
76
|
-
|
|
83
|
+
|
|
77
84
|
this.createdResources!.forEach((x, idx) => {
|
|
78
85
|
new CfnOutput(scope, `Authorizerr-${idx}`, {
|
|
79
86
|
value: x.authorizer?.authorizerArn!
|
|
80
87
|
});
|
|
81
88
|
});
|
|
82
|
-
}
|
|
89
|
+
}
|
|
83
90
|
|
|
84
91
|
private createAuthorizer() {
|
|
85
92
|
|
|
@@ -95,18 +102,18 @@ export class CreateApiAndAttachLambdas extends BaseResource<ApiLambdaResult> {
|
|
|
95
102
|
|
|
96
103
|
return authorizer;
|
|
97
104
|
|
|
98
|
-
} else if (this.requireAuthorizer && this.authorizerType === TsgAuthorizerType.REQUEST_AUTHORIZER) {
|
|
105
|
+
} else if (this.requireAuthorizer && this.authorizerType === TsgAuthorizerType.REQUEST_AUTHORIZER) {
|
|
99
106
|
|
|
100
107
|
authorizer = new TsgRequestAuthorizer(this.scope,
|
|
101
108
|
this.config, this.layers, this.tables).TsgRequestAuthorizer as RequestAuthorizer;
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
109
|
+
|
|
110
|
+
(authorizer as RequestAuthorizer)._attachToApi(this.gatewayApi);
|
|
111
|
+
(authorizer as RequestAuthorizer).applyRemovalPolicy(RemovalPolicy.DESTROY);
|
|
112
|
+
|
|
106
113
|
return authorizer;
|
|
107
114
|
}
|
|
108
115
|
|
|
109
|
-
|
|
116
|
+
|
|
110
117
|
return authorizer;
|
|
111
118
|
}
|
|
112
119
|
|
|
@@ -127,7 +134,7 @@ export class CreateApiAndAttachLambdas extends BaseResource<ApiLambdaResult> {
|
|
|
127
134
|
private AddRoutes(config: AppConfig,
|
|
128
135
|
gateway: IRestApi,
|
|
129
136
|
lambdas: NodejsFunction[],
|
|
130
|
-
authorizer?: TokenAuthorizer|RequestAuthorizer) {
|
|
137
|
+
authorizer?: TokenAuthorizer | RequestAuthorizer) {
|
|
131
138
|
|
|
132
139
|
config.RESOURCES.LAMBDA?.forEach((prop: TsgLambdaProp) => {
|
|
133
140
|
|
|
@@ -135,31 +135,32 @@ export class CreateLambda extends BaseResource<NodejsFunction> {
|
|
|
135
135
|
});
|
|
136
136
|
|
|
137
137
|
const uuid = getUUID().split('-')[0];
|
|
138
|
-
|
|
138
|
+
|
|
139
|
+
new Alarm(this.scope, `${this.config.AppPrefix}-${lambda.functionName}-error-alarm`, {
|
|
139
140
|
metric: errorMetric,
|
|
140
141
|
threshold: 5,
|
|
141
142
|
comparisonOperator: ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,
|
|
142
143
|
evaluationPeriods: 3,
|
|
143
144
|
alarmDescription: `${this.config.AppPrefix} errors over 3 min period`,
|
|
144
|
-
alarmName: `${this.config.AppPrefix}-${
|
|
145
|
+
alarmName: `${this.config.AppPrefix}-${lambda.functionName}-error-alarm`
|
|
145
146
|
});
|
|
146
147
|
|
|
147
|
-
new Alarm(this.scope, `${this.config.AppPrefix}-${
|
|
148
|
+
new Alarm(this.scope, `${this.config.AppPrefix}-${lambda.functionName}-duration-alarm`, {
|
|
148
149
|
metric: durationMetric,
|
|
149
150
|
threshold: 1,
|
|
150
151
|
comparisonOperator: ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,
|
|
151
152
|
evaluationPeriods: 3,
|
|
152
|
-
alarmDescription: `${this.config.AppPrefix}-${
|
|
153
|
-
alarmName: `${this.config.AppPrefix}-${
|
|
153
|
+
alarmDescription: `${this.config.AppPrefix}-${lambda.functionName} duration errors over 3 min period`,
|
|
154
|
+
alarmName: `${this.config.AppPrefix}-${lambda.functionName}-duration-alarm`
|
|
154
155
|
});
|
|
155
156
|
|
|
156
|
-
const invocationAlarm = new Alarm(this.scope, `${this.config.AppPrefix}-${
|
|
157
|
+
const invocationAlarm = new Alarm(this.scope, `${this.config.AppPrefix}-${lambda.functionName}-invocation-alarm`, {
|
|
157
158
|
metric: errorMetric,
|
|
158
159
|
threshold: 1000,
|
|
159
160
|
comparisonOperator: ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,
|
|
160
161
|
evaluationPeriods: 3,
|
|
161
|
-
alarmDescription: `${this.config.AppPrefix}-${
|
|
162
|
-
alarmName: `${this.config.AppPrefix}-${
|
|
162
|
+
alarmDescription: `${this.config.AppPrefix}-${lambda.functionName} errors over 3 min period`,
|
|
163
|
+
alarmName: `${this.config.AppPrefix}-${lambda.functionName}-invocation-Metric-alarm`
|
|
163
164
|
});
|
|
164
165
|
});
|
|
165
166
|
}
|