@sylvesterllc/aws-constructs 1.0.114 → 1.0.116
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 +3 -2
- package/dist/constructs/MicroService.js +9 -6
- package/dist/helpers/logger.d.ts +5 -0
- package/dist/helpers/logger.js +16 -0
- package/dist/helpers/util-helper.d.ts +1 -0
- package/dist/helpers/util-helper.js +5 -2
- package/dist/resources/gateway/createApi.d.ts +1 -3
- package/dist/resources/gateway/createApi.js +6 -9
- package/dist/resources/helpers/createRoutes.js +2 -2
- package/dist/resources/lambda/lambdaHelper.js +2 -2
- package/package.json +1 -1
- package/src/constructs/MicroService.ts +7 -5
- package/src/helpers/logger.ts +14 -0
- package/src/helpers/util-helper.ts +6 -1
- package/src/resources/gateway/createApi.ts +5 -5
- package/src/resources/helpers/createRoutes.ts +5 -2
- package/src/resources/lambda/lambdaHelper.ts +1 -1
|
@@ -6,8 +6,9 @@ import { LayerVersion } from "aws-cdk-lib/aws-lambda";
|
|
|
6
6
|
import { IRestApi } from "aws-cdk-lib/aws-apigateway";
|
|
7
7
|
import { ISecret } from "aws-cdk-lib/aws-secretsmanager";
|
|
8
8
|
import { NodejsFunction } from "aws-cdk-lib/aws-lambda-nodejs";
|
|
9
|
-
import {
|
|
9
|
+
import { Logger } from "../helpers/logger";
|
|
10
10
|
export declare class MicroService extends Construct {
|
|
11
|
+
private logger;
|
|
11
12
|
protected readonly requireDynamoTables: boolean;
|
|
12
13
|
protected requireSeedDatabase: boolean;
|
|
13
14
|
protected readonly hasLambdaLayers: boolean;
|
|
@@ -24,7 +25,7 @@ export declare class MicroService extends Construct {
|
|
|
24
25
|
get Lambdas(): NodejsFunction[];
|
|
25
26
|
get LambdaRecords(): Record<string, NodejsFunction>;
|
|
26
27
|
get RestApi(): IRestApi;
|
|
27
|
-
constructor(scope: Construct, id: string, props: MicroserviceProps,
|
|
28
|
+
constructor(scope: Construct, id: string, props: MicroserviceProps, logger?: Logger);
|
|
28
29
|
private onInit;
|
|
29
30
|
protected createTag(scope: Construct): void;
|
|
30
31
|
}
|
|
@@ -10,7 +10,9 @@ const AppConfig_1 = require("../config/AppConfig");
|
|
|
10
10
|
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
11
11
|
const CreateApiAndAttachLambdas_1 = require("../resources/gateway/CreateApiAndAttachLambdas");
|
|
12
12
|
const createSeedDatabaseCustomResource_1 = require("../resources/customResource/createSeedDatabaseCustomResource");
|
|
13
|
+
const logger_1 = require("../helpers/logger");
|
|
13
14
|
class MicroService extends constructs_1.Construct {
|
|
15
|
+
logger;
|
|
14
16
|
requireDynamoTables;
|
|
15
17
|
requireSeedDatabase = false;
|
|
16
18
|
hasLambdaLayers = false;
|
|
@@ -39,8 +41,9 @@ class MicroService extends constructs_1.Construct {
|
|
|
39
41
|
get RestApi() {
|
|
40
42
|
return this.api;
|
|
41
43
|
}
|
|
42
|
-
constructor(scope, id, props,
|
|
44
|
+
constructor(scope, id, props, logger = new logger_1.Logger()) {
|
|
43
45
|
super(scope, id);
|
|
46
|
+
this.logger = logger;
|
|
44
47
|
this.appConfig = new AppConfig_1.AppConfig(props);
|
|
45
48
|
this.requireDynamoTables = (props.RESOURCES.DYNAMO?.TABLES &&
|
|
46
49
|
props.RESOURCES.DYNAMO.TABLES.length > 0) ? true : false;
|
|
@@ -48,7 +51,7 @@ class MicroService extends constructs_1.Construct {
|
|
|
48
51
|
props.RESOURCES.DYNAMO.SEED_LAMBDA) ? true : false;
|
|
49
52
|
this.hasLambdaLayers = (props.RESOURCES.LAMBDA_LAYERS &&
|
|
50
53
|
props.RESOURCES.LAMBDA_LAYERS.length > 0) ? true : false;
|
|
51
|
-
const results = this.onInit(scope
|
|
54
|
+
const results = this.onInit(scope);
|
|
52
55
|
this.api = results.restApi;
|
|
53
56
|
this.dynamoTables = results.dynamoTables;
|
|
54
57
|
this.lambdaLayers = results.lambdaLayers;
|
|
@@ -56,7 +59,7 @@ class MicroService extends constructs_1.Construct {
|
|
|
56
59
|
this.lambdas = results.lambdas;
|
|
57
60
|
this.createTag(scope);
|
|
58
61
|
}
|
|
59
|
-
onInit(scope
|
|
62
|
+
onInit(scope) {
|
|
60
63
|
let secretManager = null;
|
|
61
64
|
let tables = undefined;
|
|
62
65
|
let commonLayers = undefined;
|
|
@@ -68,7 +71,7 @@ class MicroService extends constructs_1.Construct {
|
|
|
68
71
|
if (this.hasLambdaLayers) {
|
|
69
72
|
commonLayers = (0, createCommonLayer_1.createCommonLayer)(scope, this.appConfig);
|
|
70
73
|
}
|
|
71
|
-
const gateway = new createApi_1.Api(scope, this.appConfig
|
|
74
|
+
const gateway = new createApi_1.Api(scope, this.appConfig).APIs;
|
|
72
75
|
const layers = commonLayers;
|
|
73
76
|
// Creates DynamoDb Tables if required
|
|
74
77
|
if (this.requireDynamoTables) {
|
|
@@ -81,7 +84,7 @@ class MicroService extends constructs_1.Construct {
|
|
|
81
84
|
// CREATE API GATEWAY AND LAMBDA HERE
|
|
82
85
|
const apiGateway = new CreateApiAndAttachLambdas_1.CreateApiAndAttachLambdas(scope, this.appConfig, gateway[0], layers, tables);
|
|
83
86
|
this.lambdaRecords = apiGateway.LambdaRecords;
|
|
84
|
-
|
|
87
|
+
this.logger.log(`lambda Records: ${this.lambdaRecords}`);
|
|
85
88
|
return {
|
|
86
89
|
restApi: (gateway?.length > 0) ? gateway[0] : null,
|
|
87
90
|
lambdaLayers: layers || null,
|
|
@@ -96,4 +99,4 @@ class MicroService extends constructs_1.Construct {
|
|
|
96
99
|
}
|
|
97
100
|
}
|
|
98
101
|
exports.MicroService = MicroService;
|
|
99
|
-
//# 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\";\nimport { NodejsFunction } from \"aws-cdk-lib/aws-lambda-nodejs\";\nimport { Environment } from \"../config/Environments\";\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    private lambdaRecords: Record<string, 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    public get LambdaRecords() {\n        return this.lambdaRecords;\n    }\n\n    public get RestApi() {\n        return this.api;\n    }\n\n    constructor(scope: Construct, id: string, props: MicroserviceProps,\n        env: Environment = \"prod\") {\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, env);\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, env: Environment) {\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, env).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        this.lambdaRecords = apiGateway.LambdaRecords;\n\n        // console.log('lambda Records:', this.lambdaRecords)\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}"]}
|
|
102
|
+
//# 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\";\nimport { NodejsFunction } from \"aws-cdk-lib/aws-lambda-nodejs\";\nimport { Environment } from \"../config/Environments\";\nimport { Logger } from \"../helpers/logger\";\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    private lambdaRecords: Record<string, 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    public get LambdaRecords() {\n        return this.lambdaRecords;\n    }\n\n    public get RestApi() {\n        return this.api;\n    }\n\n    constructor(scope: Construct, id: string, props: MicroserviceProps,\n        private logger: Logger = new Logger()) {\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        this.lambdaRecords = apiGateway.LambdaRecords;\n\n\n        this.logger.log(`lambda Records: ${this.lambdaRecords}`);\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}"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Logger = void 0;
|
|
4
|
+
class Logger {
|
|
5
|
+
debug;
|
|
6
|
+
constructor(debug = false) {
|
|
7
|
+
this.debug = debug;
|
|
8
|
+
}
|
|
9
|
+
log(message) {
|
|
10
|
+
if (this.debug) {
|
|
11
|
+
console.log(message);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
exports.Logger = Logger;
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlbHBlcnMvbG9nZ2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLE1BQWEsTUFBTTtJQUVLO0lBQXBCLFlBQW9CLFFBQWlCLEtBQUs7UUFBdEIsVUFBSyxHQUFMLEtBQUssQ0FBaUI7SUFBSSxDQUFDO0lBRXhDLEdBQUcsQ0FBQyxPQUFlO1FBRXRCLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ2IsT0FBTyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUN6QixDQUFDO0lBRUwsQ0FBQztDQUNKO0FBWEQsd0JBV0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBkZWJ1ZyB9IGZyb20gXCJjb25zb2xlXCI7XG5cbmV4cG9ydCBjbGFzcyBMb2dnZXIge1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBkZWJ1ZzogYm9vbGVhbiA9IGZhbHNlKSB7IH1cblxuICAgIHB1YmxpYyBsb2cobWVzc2FnZTogc3RyaW5nKSB7XG5cbiAgICAgICAgaWYgKHRoaXMuZGVidWcpIHtcbiAgICAgICAgICAgIGNvbnNvbGUubG9nKG1lc3NhZ2UpO1xuICAgICAgICB9XG5cbiAgICB9XG59Il19
|
|
@@ -2,3 +2,4 @@ import { Environment } from '../config/Environments';
|
|
|
2
2
|
export declare const getUUID: () => string;
|
|
3
3
|
export declare const environmentSuffix: (env?: Environment) => "" | "-qa" | "-dev";
|
|
4
4
|
export declare const environmentSuffixForDomain: (env?: Environment) => "." | ".qa" | ".dev";
|
|
5
|
+
export declare const clog: (message: string) => void;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.environmentSuffixForDomain = exports.environmentSuffix = exports.getUUID = void 0;
|
|
3
|
+
exports.clog = exports.environmentSuffixForDomain = exports.environmentSuffix = exports.getUUID = void 0;
|
|
4
4
|
const uuid_1 = require("uuid");
|
|
5
5
|
const getUUID = () => {
|
|
6
6
|
return (0, uuid_1.v4)();
|
|
@@ -14,4 +14,7 @@ const environmentSuffixForDomain = (env = "prod") => {
|
|
|
14
14
|
return env === 'prod' ? '.' : env === 'qa' ? '.qa' : '.dev';
|
|
15
15
|
};
|
|
16
16
|
exports.environmentSuffixForDomain = environmentSuffixForDomain;
|
|
17
|
-
|
|
17
|
+
const clog = (message) => {
|
|
18
|
+
};
|
|
19
|
+
exports.clog = clog;
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC1oZWxwZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaGVscGVycy91dGlsLWhlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwrQkFBb0M7QUFHN0IsTUFBTSxPQUFPLEdBQUcsR0FBRyxFQUFFO0lBRXhCLE9BQU8sSUFBQSxTQUFNLEdBQUUsQ0FBQztBQUNwQixDQUFDLENBQUM7QUFIVyxRQUFBLE9BQU8sV0FHbEI7QUFFSyxNQUFNLGlCQUFpQixHQUFHLENBQUMsTUFBbUIsTUFBTSxFQUFFLEVBQUU7SUFDM0QsT0FBTyxHQUFHLEtBQUssTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDO0FBQy9ELENBQUMsQ0FBQTtBQUZZLFFBQUEsaUJBQWlCLHFCQUU3QjtBQUVNLE1BQU0sMEJBQTBCLEdBQUcsQ0FBQyxNQUFtQixNQUFNLEVBQUUsRUFBRTtJQUNwRSxPQUFPLEdBQUcsS0FBSyxNQUFNLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUM7QUFDaEUsQ0FBQyxDQUFBO0FBRlksUUFBQSwwQkFBMEIsOEJBRXRDO0FBRU0sTUFBTSxJQUFJLEdBQUcsQ0FBQyxPQUFlLEVBQUUsRUFBRTtBQUd4QyxDQUFDLENBQUM7QUFIVyxRQUFBLElBQUksUUFHZiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHY0IGFzIHV1aWR2NCB9IGZyb20gJ3V1aWQnO1xuaW1wb3J0IHsgRW52aXJvbm1lbnQgfSBmcm9tICcuLi9jb25maWcvRW52aXJvbm1lbnRzJztcblxuZXhwb3J0IGNvbnN0IGdldFVVSUQgPSAoKSA9PiB7XG5cbiAgICByZXR1cm4gdXVpZHY0KCk7XG59O1xuXG5leHBvcnQgY29uc3QgZW52aXJvbm1lbnRTdWZmaXggPSAoZW52OiBFbnZpcm9ubWVudCA9IFwicHJvZFwiKSA9PiB7XG4gICAgcmV0dXJuIGVudiA9PT0gJ3Byb2QnID8gJycgOiBlbnYgPT09ICdxYScgPyAnLXFhJyA6ICctZGV2Jztcbn1cblxuZXhwb3J0IGNvbnN0IGVudmlyb25tZW50U3VmZml4Rm9yRG9tYWluID0gKGVudjogRW52aXJvbm1lbnQgPSBcInByb2RcIikgPT4ge1xuICAgIHJldHVybiBlbnYgPT09ICdwcm9kJyA/ICcuJyA6IGVudiA9PT0gJ3FhJyA/ICcucWEnIDogJy5kZXYnO1xufVxuXG5leHBvcnQgY29uc3QgY2xvZyA9IChtZXNzYWdlOiBzdHJpbmcpID0+IHtcblxuXG59OyJdfQ==
|
|
@@ -2,12 +2,10 @@ import { IRestApi, RestApi } from "aws-cdk-lib/aws-apigateway";
|
|
|
2
2
|
import { Construct } from "constructs";
|
|
3
3
|
import { AppConfig } from "../../config/AppConfig";
|
|
4
4
|
import { BaseResource } from "../base/baseResource";
|
|
5
|
-
import { Environment } from "../../config/Environments";
|
|
6
5
|
export declare class Api extends BaseResource<IRestApi> {
|
|
7
|
-
private env;
|
|
8
6
|
private corsOptions;
|
|
9
7
|
get APIs(): IRestApi[];
|
|
10
|
-
constructor(scope: Construct, config: AppConfig
|
|
8
|
+
constructor(scope: Construct, config: AppConfig);
|
|
11
9
|
private createApi;
|
|
12
10
|
private createApiProps;
|
|
13
11
|
private createDefaultCorsOptions;
|
|
@@ -8,16 +8,13 @@ const aws_route53_targets_1 = require("aws-cdk-lib/aws-route53-targets");
|
|
|
8
8
|
const baseResource_1 = require("../base/baseResource");
|
|
9
9
|
const createCertificate_1 = require("../certificate/createCertificate");
|
|
10
10
|
const createApiKey_1 = require("./createApiKey");
|
|
11
|
-
const util_helper_1 = require("../../helpers/util-helper");
|
|
12
11
|
class Api extends baseResource_1.BaseResource {
|
|
13
|
-
env;
|
|
14
12
|
corsOptions;
|
|
15
13
|
get APIs() {
|
|
16
14
|
return this.createdResources;
|
|
17
15
|
}
|
|
18
|
-
constructor(scope, config
|
|
16
|
+
constructor(scope, config) {
|
|
19
17
|
super(scope, config);
|
|
20
|
-
this.env = env;
|
|
21
18
|
this.corsOptions = this.createDefaultCorsOptions();
|
|
22
19
|
this.createdResources = this.createResource(scope);
|
|
23
20
|
}
|
|
@@ -25,25 +22,25 @@ class Api extends baseResource_1.BaseResource {
|
|
|
25
22
|
if (this.config.DNS) {
|
|
26
23
|
console.log('### DNS is true ###');
|
|
27
24
|
const zone = this.getZone(this.scope, this.config);
|
|
28
|
-
const api = new aws_apigateway_1.RestApi(this.scope, `${this.config.AppPrefix}-rest-api
|
|
25
|
+
const api = new aws_apigateway_1.RestApi(this.scope, `${this.config.AppPrefix}-rest-api`, this.createApiProps(zone));
|
|
29
26
|
this.createARecord(scope, zone, api);
|
|
30
27
|
this.createApiKey(this.config, api);
|
|
31
28
|
return api;
|
|
32
29
|
}
|
|
33
30
|
else {
|
|
34
|
-
const api = new aws_apigateway_1.RestApi(this.scope, `${this.config.AppPrefix}-rest-api
|
|
31
|
+
const api = new aws_apigateway_1.RestApi(this.scope, `${this.config.AppPrefix}-rest-api-without-DNS`, this.createApiProps());
|
|
35
32
|
this.createApiKey(this.config, api);
|
|
36
33
|
return api;
|
|
37
34
|
}
|
|
38
35
|
}
|
|
39
|
-
createApiProps(
|
|
36
|
+
createApiProps(zone) {
|
|
40
37
|
if (this.config.DNS) {
|
|
41
38
|
const cert = this.createCertificate(this.scope, zone, this.config);
|
|
42
39
|
const props = {
|
|
43
40
|
restApiName: `${this.config.AppPrefix}-${this.config.API.Name}`,
|
|
44
41
|
description: this.config.API.Description,
|
|
45
42
|
domainName: {
|
|
46
|
-
domainName: `${this.config.
|
|
43
|
+
domainName: `${this.config.DNS.SubDomainNameForApi}.${this.config.DNS.SubDomainName}`,
|
|
47
44
|
certificate: cert.certificate,
|
|
48
45
|
endpointType: aws_apigateway_1.EndpointType.EDGE,
|
|
49
46
|
securityPolicy: aws_apigateway_1.SecurityPolicy.TLS_1_2
|
|
@@ -139,4 +136,4 @@ class Api extends baseResource_1.BaseResource {
|
|
|
139
136
|
}
|
|
140
137
|
}
|
|
141
138
|
exports.Api = Api;
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"createApi.js","sourceRoot":"","sources":["../../../src/resources/gateway/createApi.ts"],"names":[],"mappings":";;;AAAA,6CAA4D;AAC5D,+DAAuL;AACvL,yDAAyF;AACzF,yEAA+E;AAK/E,uDAAoD;AACpD,wEAAqE;AACrE,iDAA2C;AAE3C,2DAA8D;AAE9D,MAAa,GAAI,SAAQ,2BAAsB;IASc;IAPjD,WAAW,CAAc;IAGjC,IAAI,IAAI;QACJ,OAAO,IAAI,CAAC,gBAAgB,CAAC;IACjC,CAAC;IAED,YAAY,KAAgB,EAAE,MAAiB,EAAU,MAAmB,MAAM;QAC9E,KAAK,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QADgC,QAAG,GAAH,GAAG,CAAsB;QAG9E,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAEnD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;IACvD,CAAC;IAEO,SAAS,CAAC,KAAgB;QAC9B,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC;YAElB,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;YAEnC,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;YAEnD,MAAM,GAAG,GAAG,IAAI,wBAAO,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,YAAY,IAAA,+BAAiB,EAAC,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;YAE5I,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC;YAErC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;YAEpC,OAAO,GAAG,CAAC;QAEf,CAAC;aAAM,CAAC;YAEJ,MAAM,GAAG,GAAG,IAAI,wBAAO,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,YAAY,IAAA,+BAAiB,EAAC,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;YAEtI,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;YAEpC,OAAO,GAAG,CAAC;QACf,CAAC;IACL,CAAC;IAEO,cAAc,CAAC,GAAgB,EAAE,IAAkB;QAEvD,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC;YAElB,MAAM,IAAI,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;YAEpE,MAAM,KAAK,GAAiB;gBACxB,WAAW,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE;gBAC/D,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,WAAW;gBACxC,UAAU,EAAE;oBACR,UAAU,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,YAAY,IAAI,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE;oBAChF,WAAW,EAAE,IAAI,CAAC,WAAW;oBAC7B,YAAY,EAAE,6BAAY,CAAC,IAAI;oBAC/B,cAAc,EAAE,+BAAc,CAAC,OAAO;iBACzC;gBACD,gCAAgC;gBAChC,0BAA0B;gBAC1B,sCAAsC;gBACtC,OAAO;gBACP,kBAAkB;gBAClB,2BAA2B,EAAE,IAAI,CAAC,WAAW;aAChD,CAAC;YAEF,OAAO,KAAK,CAAC;QACjB,CAAC;aAAM,CAAC;YACJ,MAAM,KAAK,GAAiB;gBACxB,WAAW,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE;gBAC/D,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,WAAW;gBACxC,2BAA2B,EAAE,IAAI,CAAC,WAAW;aAChD,CAAC;YAEF,OAAO,KAAK,CAAC;QACjB,CAAC;IACL,CAAC;IAEO,wBAAwB;QAE5B,MAAM,WAAW,GAAgB;YAC7B,YAAY,EAAE;gBACV,GAAG;aACN;YACD,YAAY,EAAE,qBAAI,CAAC,WAAW;YAC9B,gBAAgB,EAAE,IAAI;YACtB,YAAY,EAAE,qBAAI,CAAC,WAAW;SACjC,CAAC;QAEF,OAAO,WAAW,CAAC;IACvB,CAAC;IAEO,cAAc,CAAC,MAAiB;QACpC,qDAAqD;QACrD,OAAO,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,UAAU,EAAE,aAAa,KAAK,IAAI,CAAC,CAAC;IAC/F,CAAC;IAEO,YAAY,CAAC,MAAiB,EAAE,GAAY;QAEhD,IAAI,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;YACnC,MAAM,MAAM,GAAG,IAAI,wBAAS,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;YAC1D,OAAO,MAAM,CAAC;QAClB,CAAC;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IACD,4EAA4E;IAC5E,0GAA0G;IAC1G,4CAA4C;IAC5C,2DAA2D;IAC3D,2DAA2D;IAC3D,UAAU;IAEV,wBAAwB;IACxB,IAAI;IAEJ,+GAA+G;IAC/G,gFAAgF;IAChF,8BAA8B;IAC9B,wBAAwB;IACxB,UAAU;IACV,IAAI;IAEI,OAAO,CAAC,KAAgB,EAAE,MAAyB;QACvD,OAAO,wBAAU,CAAC,wBAAwB,CAAC,KAAK,EAAE,GAAG,MAAM,CAAC,GAAG,EAAE,QAAQ,OAAO,EAAE;YAC9E,QAAQ,EAAE,MAAM,CAAC,GAAG,EAAE,QAAS;YAC/B,YAAY,EAAE,MAAM,CAAC,GAAG,EAAE,MAAO;SACpC,CAAC,CAAC;IACP,CAAC;IAEO,iBAAiB,CAAC,KAAgB,EAAE,IAAiB,EAAE,MAAyB;QACpF,MAAM,IAAI,GAAG,IAAI,qCAAiB,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC;QAExD,IAAI,CAAC,WAAW,CAAC,kBAAkB,CAAC,2BAAa,CAAC,OAAO,CAAC,CAAC;QAC3D,OAAO,IAAI,CAAC;IAChB,CAAC;IAEO,aAAa,CAAC,KAAgB,EAAE,IAAiB,EAAE,GAAY;QACnE,MAAM,OAAO,GAAG,IAAI,qBAAO,CAAC,KAAK,EAAE,WAAW,EAAE;YAC5C,IAAI;YACJ,MAAM,EAAE,0BAAY,CAAC,SAAS,CAAC,IAAI,gCAAU,CAAC,GAAG,CAAC,CAAC;YACnD,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,YAAY;SAC3C,CAAC,CAAC;QAEH,OAAO,CAAC,kBAAkB,CAAC,2BAAa,CAAC,OAAO,CAAC,CAAC;QAClD,OAAO,OAAO,CAAC;IACnB,CAAC;IAES,cAAc,CAAC,KAAgB;QAErC,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAClC,4CAA4C;QAC5C,8DAA8D;QAE9D,2EAA2E;QAI3E,OAAO,CAAC,GAAG,CAAC,CAAC;IACjB,CAAC;IAES,YAAY,CAAI,KAAgB,EAAE,aAAkB;QAC1D,aAAa,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;YAE/B,IAAI,uBAAS,CAAC,KAAK,EAAE,MAAM,GAAG,EAAE,EAAE;gBAC9B,aAAa;gBACb,KAAK,EAAE,GAAG,CAAC,GAAG;aACjB,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;CAEJ;AAzKD,kBAyKC","sourcesContent":["import { CfnOutput, RemovalPolicy, Tag } from \"aws-cdk-lib\";\nimport { BasePathMapping, Cors, CorsOptions, DomainName, EndpointType, IDomainName, IRestApi, MethodOptions, RestApi, RestApiProps, SecurityPolicy } from \"aws-cdk-lib/aws-apigateway\";\nimport { ARecord, HostedZone, IHostedZone, RecordTarget } from \"aws-cdk-lib/aws-route53\";\nimport { ApiGateway, ApiGatewayDomain } from \"aws-cdk-lib/aws-route53-targets\";\nimport { Construct } from \"constructs\";\nimport { AppConfig } from \"../../config/AppConfig\";\nimport { MicroserviceProps } from \"../../interfaces/MicroserviceProps\";\n\nimport { BaseResource } from \"../base/baseResource\";\nimport { CreateCertificate } from \"../certificate/createCertificate\";\nimport { TsgApiKey } from \"./createApiKey\";\nimport { Environment } from \"../../config/Environments\";\nimport { environmentSuffix } from \"../../helpers/util-helper\";\n\nexport class Api extends BaseResource<IRestApi> {\n\n    private corsOptions: CorsOptions;\n\n\n    get APIs() {\n        return this.createdResources;\n    }\n\n    constructor(scope: Construct, config: AppConfig, private env: Environment = \"prod\") {\n        super(scope, config);\n\n        this.corsOptions = this.createDefaultCorsOptions();\n\n        this.createdResources = this.createResource(scope);\n    }\n\n    private createApi(scope: Construct) {\n        if (this.config.DNS) {\n\n            console.log('### DNS is true ###');\n\n            const zone = this.getZone(this.scope, this.config);\n\n            const api = new RestApi(this.scope, `${this.config.AppPrefix}-rest-api${environmentSuffix(this.env)}`, this.createApiProps(this.env, zone));\n\n            this.createARecord(scope, zone, api);\n\n            this.createApiKey(this.config, api);\n\n            return api;\n\n        } else {\n\n            const api = new RestApi(this.scope, `${this.config.AppPrefix}-rest-api${environmentSuffix(this.env)}`, this.createApiProps(this.env));\n\n            this.createApiKey(this.config, api);\n\n            return api;\n        }\n    }\n\n    private createApiProps(env: Environment, zone?: IHostedZone,): RestApiProps {\n\n        if (this.config.DNS) {\n\n            const cert = this.createCertificate(this.scope, zone!, this.config);\n\n            const props: RestApiProps = {\n                restApiName: `${this.config.AppPrefix}-${this.config.API.Name}`,\n                description: this.config.API.Description,\n                domainName: {\n                    domainName: `${this.config.API.DomainPrefix}.${env}.${this.config.DNS.ZoneName}`,\n                    certificate: cert.certificate,\n                    endpointType: EndpointType.EDGE,\n                    securityPolicy: SecurityPolicy.TLS_1_2\n                },\n                // TODO:  ADD CUSTOM DOMAIN HERE\n                // defaultDomainMapping: {\n                //     domainName: domain,            \n                //   },\n                // domainName: '',\n                defaultCorsPreflightOptions: this.corsOptions\n            };\n\n            return props;\n        } else {\n            const props: RestApiProps = {\n                restApiName: `${this.config.AppPrefix}-${this.config.API.Name}`,\n                description: this.config.API.Description,\n                defaultCorsPreflightOptions: this.corsOptions\n            };\n\n            return props;\n        }\n    }\n\n    private createDefaultCorsOptions() {\n\n        const corsOptions: CorsOptions = {\n            allowHeaders: [\n                '*',\n            ],\n            allowMethods: Cors.ALL_METHODS,\n            allowCredentials: true,\n            allowOrigins: Cors.ALL_ORIGINS,\n        };\n\n        return corsOptions;\n    }\n\n    private requiresApiKey(config: AppConfig) {\n        // Determine if any of the lambdas require an API Key\n        return config.RESOURCES.LAMBDA.some((lambda) => lambda.apiGateway?.requireApiKey === true);\n    }\n\n    private createApiKey(config: AppConfig, api: RestApi) {\n\n        if (this.requiresApiKey(this.config)) {\n            const apiKey = new TsgApiKey(this.scope, this.config, api)\n            return apiKey;\n        }\n        return null;\n    }\n    // private createCustomDomain(scope: Construct, config: MicroserviceProps) {\n    //     const domainName = DomainName.fromDomainNameAttributes(scope, `${config.API.Name}-custom-domain`, {\n    //         domainName: config.DNS?.ZoneName,\n    //         domainNameAliasHostedZoneId: config.DNS.ZoneId!,\n    //         domainNameAliasTarget: config.API.DomainPrefix!,\n    //     });\n\n    //     return domainName\n    // }\n\n    // private attachDomainToApi(scope: Construct, api: IRestApi, domain: IDomainName, config: MicroserviceProps) {\n    //     return new BasePathMapping(scope, `${config.API.Name}-basePathMapping`, {\n    //         domainName: domain,\n    //         restApi: api,\n    //     });\n    // }\n\n    private getZone(scope: Construct, config: MicroserviceProps) {\n        return HostedZone.fromHostedZoneAttributes(scope, `${config.DNS?.ZoneName}-zone`, {\n            zoneName: config.DNS?.ZoneName!,\n            hostedZoneId: config.DNS?.ZoneId!\n        });\n    }\n\n    private createCertificate(scope: Construct, zone: IHostedZone, config: MicroserviceProps) {\n        const cert = new CreateCertificate(scope, config, zone);\n\n        cert.certificate.applyRemovalPolicy(RemovalPolicy.DESTROY);\n        return cert;\n    }\n\n    private createARecord(scope: Construct, zone: IHostedZone, api: RestApi) {\n        const aRecord = new ARecord(scope, \"ApiRecord\", {\n            zone,\n            target: RecordTarget.fromAlias(new ApiGateway(api)),\n            recordName: this.config.API.DomainPrefix\n        });\n\n        aRecord.applyRemovalPolicy(RemovalPolicy.DESTROY);\n        return aRecord;\n    }\n\n    protected createResource(scope: Construct) {\n\n        const api = this.createApi(scope);\n        // TODO:  ONLY IF CUSTOM MAPPING IS REQUIRED\n        // const domain = this.createCustomDomain(scope, this.config);\n\n        // const mapping = this.attachDomainToApi(scope, api, domain, this.config);\n\n\n\n        return [api];\n    }\n\n    protected createOutput<T>(scope: Construct, createdAssets: T[]): void {\n        createdAssets.forEach((api, idx) => {\n\n            new CfnOutput(scope, `api${idx}`, {\n                // @ts-ignore\n                value: api.url\n            });\n        });\n    }\n\n}"]}
|
|
139
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"createApi.js","sourceRoot":"","sources":["../../../src/resources/gateway/createApi.ts"],"names":[],"mappings":"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","sourcesContent":["import { CfnOutput, RemovalPolicy, Tag } from \"aws-cdk-lib\";\nimport { BasePathMapping, Cors, CorsOptions, DomainName, EndpointType, IDomainName, IRestApi, MethodOptions, RestApi, RestApiProps, SecurityPolicy } from \"aws-cdk-lib/aws-apigateway\";\nimport { ARecord, HostedZone, IHostedZone, RecordTarget } from \"aws-cdk-lib/aws-route53\";\nimport { ApiGateway, ApiGatewayDomain } from \"aws-cdk-lib/aws-route53-targets\";\nimport { Construct } from \"constructs\";\nimport { AppConfig } from \"../../config/AppConfig\";\nimport { MicroserviceProps } from \"../../interfaces/MicroserviceProps\";\n\nimport { BaseResource } from \"../base/baseResource\";\nimport { CreateCertificate } from \"../certificate/createCertificate\";\nimport { TsgApiKey } from \"./createApiKey\";\nimport { Environment } from \"../../config/Environments\";\nimport { environmentSuffix } from \"../../helpers/util-helper\";\n\nexport class Api extends BaseResource<IRestApi> {\n\n    private corsOptions: CorsOptions;\n\n\n    get APIs() {\n        return this.createdResources;\n    }\n\n    constructor(scope: Construct, config: AppConfig) {\n        super(scope, config);\n\n        this.corsOptions = this.createDefaultCorsOptions();\n\n        this.createdResources = this.createResource(scope);\n    }\n\n    private createApi(scope: Construct) {\n        if (this.config.DNS) {\n\n            console.log('### DNS is true ###');\n\n            const zone = this.getZone(this.scope, this.config);\n\n            const api = new RestApi(this.scope, `${this.config.AppPrefix}-rest-api`, this.createApiProps(zone));\n\n            this.createARecord(scope, zone, api);\n\n            this.createApiKey(this.config, api);\n\n            return api;\n\n        } else {\n\n            const api = new RestApi(this.scope, `${this.config.AppPrefix}-rest-api-without-DNS`, this.createApiProps());\n\n            this.createApiKey(this.config, api);\n\n            return api;\n        }\n    }\n\n    private createApiProps(zone?: IHostedZone): RestApiProps {\n\n        if (this.config.DNS) {\n\n            const cert = this.createCertificate(this.scope, zone!, this.config);\n\n            const props: RestApiProps = {\n                restApiName: `${this.config.AppPrefix}-${this.config.API.Name}`,\n                description: this.config.API.Description,\n                domainName: {\n                    domainName: `${this.config.DNS.SubDomainNameForApi}.${this.config.DNS.SubDomainName}`,\n                    certificate: cert.certificate,\n                    endpointType: EndpointType.EDGE,\n                    securityPolicy: SecurityPolicy.TLS_1_2\n                },\n                // TODO:  ADD CUSTOM DOMAIN HERE\n                // defaultDomainMapping: {\n                //     domainName: domain,            \n                //   },\n                // domainName: '',\n                defaultCorsPreflightOptions: this.corsOptions\n            };\n\n            return props;\n        } else {\n            const props: RestApiProps = {\n                restApiName: `${this.config.AppPrefix}-${this.config.API.Name}`,\n                description: this.config.API.Description,\n                defaultCorsPreflightOptions: this.corsOptions\n            };\n\n            return props;\n        }\n    }\n\n    private createDefaultCorsOptions() {\n\n        const corsOptions: CorsOptions = {\n            allowHeaders: [\n                '*',\n            ],\n            allowMethods: Cors.ALL_METHODS,\n            allowCredentials: true,\n            allowOrigins: Cors.ALL_ORIGINS,\n        };\n\n        return corsOptions;\n    }\n\n    private requiresApiKey(config: AppConfig) {\n        // Determine if any of the lambdas require an API Key\n        return config.RESOURCES.LAMBDA.some((lambda) => lambda.apiGateway?.requireApiKey === true);\n    }\n\n    private createApiKey(config: AppConfig, api: RestApi) {\n\n        if (this.requiresApiKey(this.config)) {\n            const apiKey = new TsgApiKey(this.scope, this.config, api)\n            return apiKey;\n        }\n        return null;\n    }\n    // private createCustomDomain(scope: Construct, config: MicroserviceProps) {\n    //     const domainName = DomainName.fromDomainNameAttributes(scope, `${config.API.Name}-custom-domain`, {\n    //         domainName: config.DNS?.ZoneName,\n    //         domainNameAliasHostedZoneId: config.DNS.ZoneId!,\n    //         domainNameAliasTarget: config.API.DomainPrefix!,\n    //     });\n\n    //     return domainName\n    // }\n\n    // private attachDomainToApi(scope: Construct, api: IRestApi, domain: IDomainName, config: MicroserviceProps) {\n    //     return new BasePathMapping(scope, `${config.API.Name}-basePathMapping`, {\n    //         domainName: domain,\n    //         restApi: api,\n    //     });\n    // }\n\n    private getZone(scope: Construct, config: MicroserviceProps) {\n        return HostedZone.fromHostedZoneAttributes(scope, `${config.DNS?.ZoneName}-zone`, {\n            zoneName: config.DNS?.ZoneName!,\n            hostedZoneId: config.DNS?.ZoneId!\n        });\n    }\n\n    private createCertificate(scope: Construct, zone: IHostedZone, config: MicroserviceProps) {\n        const cert = new CreateCertificate(scope, config, zone);\n\n        cert.certificate.applyRemovalPolicy(RemovalPolicy.DESTROY);\n        return cert;\n    }\n\n    private createARecord(scope: Construct, zone: IHostedZone, api: RestApi) {\n        const aRecord = new ARecord(scope, \"ApiRecord\", {\n            zone,\n            target: RecordTarget.fromAlias(new ApiGateway(api)),\n            recordName: this.config.API.DomainPrefix\n        });\n\n        aRecord.applyRemovalPolicy(RemovalPolicy.DESTROY);\n        return aRecord;\n    }\n\n    protected createResource(scope: Construct) {\n\n        const api = this.createApi(scope);\n        // TODO:  ONLY IF CUSTOM MAPPING IS REQUIRED\n        // const domain = this.createCustomDomain(scope, this.config);\n\n        // const mapping = this.attachDomainToApi(scope, api, domain, this.config);\n\n\n\n        return [api];\n    }\n\n    protected createOutput<T>(scope: Construct, createdAssets: T[]): void {\n        createdAssets.forEach((api, idx) => {\n\n            new CfnOutput(scope, `api${idx}`, {\n                // @ts-ignore\n                value: api.url\n            });\n        });\n    }\n\n}"]}
|
|
@@ -26,7 +26,7 @@ class Routes {
|
|
|
26
26
|
Routes.routeMap.set(activeRoutePath, secondaryResource);
|
|
27
27
|
activeResource = secondaryResource;
|
|
28
28
|
}
|
|
29
|
-
console.log(`Route: ${prop.apiGateway.method}\t Lambda Name: ${lambdaNode.node.id}\t Path: ${activeRoutePath}`);
|
|
29
|
+
// console.log(`Route: ${prop.apiGateway.method}\t Lambda Name: ${lambdaNode.node.id}\t Path: ${activeRoutePath}`);
|
|
30
30
|
// Finally, we attach our function to the last resource
|
|
31
31
|
activeResource?.addMethod(prop.apiGateway.method || 'GET', new aws_apigateway_1.LambdaIntegration(lambdaNode, { proxy: true, }), {
|
|
32
32
|
requestParameters: Routes.createQueryStringObject(prop.apiGateway.queryStrings),
|
|
@@ -48,4 +48,4 @@ class Routes {
|
|
|
48
48
|
}
|
|
49
49
|
}
|
|
50
50
|
exports.Routes = Routes;
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlUm91dGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3Jlc291cmNlcy9oZWxwZXJzL2NyZWF0ZVJvdXRlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwrREFBMEk7QUFPMUksTUFBYSxNQUFNO0lBRVIsTUFBTSxDQUFDLFNBQVMsR0FBZSxFQUFFLENBQUM7SUFDakMsTUFBTSxDQUFDLFFBQVEsR0FBRyxJQUFJLEdBQUcsRUFBRSxDQUFDO0lBRTdCLE1BQU0sQ0FBQyxjQUFjLENBQ3hCLElBQW1CLEVBQ25CLEdBQWEsRUFDYixVQUEwQixFQUMxQixVQUFnRDtRQUdoRCxNQUFNLFFBQVEsR0FBMEIsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUVsRCxJQUFJLGVBQWUsR0FBRyxFQUFFLENBQUM7UUFDekIsSUFBSSxjQUFjLEdBQXlCLFNBQVMsQ0FBQztRQUVyRCx5REFBeUQ7UUFDekQsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFLEtBQUssRUFBRSxDQUFDO1lBRXpCLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLGdCQUFnQixFQUFFLENBQUM7Z0JBQ3BDLDBEQUEwRDtnQkFDMUQsNkVBQTZFO2dCQUM3RSxlQUFlLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztnQkFDakYsY0FBYyxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLGVBQWUsQ0FBQyxDQUFDO2dCQUMvRixNQUFNLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxlQUFlLEVBQUUsY0FBYyxDQUFDLENBQUM7WUFDekQsQ0FBQztZQUdELHVFQUF1RTtZQUN2RSxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsVUFBVSxFQUFFLEtBQUssQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBRXhFLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxZQUFZLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7Z0JBQzNDLGVBQWUsR0FBRyxHQUFHLGVBQWUsSUFBSSxZQUFZLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztnQkFDMUQsSUFBSSxpQkFBaUIsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsSUFBSSxjQUFjLEVBQUUsV0FBVyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUN0SixNQUFNLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxlQUFlLEVBQUUsaUJBQWlCLENBQUMsQ0FBQztnQkFDeEQsY0FBYyxHQUFHLGlCQUFpQixDQUFDO1lBQ3ZDLENBQUM7WUFFRCxzSEFBc0g7WUFDdEgsd0RBQXdEO1lBQ3hELGNBQWMsRUFBRSxTQUFTLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNLElBQUksS0FBSyxFQUNyRCxJQUFJLGtDQUFpQixDQUFDLFVBQVUsRUFBRSxFQUFFLEtBQUssRUFBRSxJQUFJLEdBQUcsQ0FBQyxFQUNuRDtnQkFDSSxpQkFBaUIsRUFBRSxNQUFNLENBQUMsdUJBQXVCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxZQUFZLENBQUM7Z0JBQy9FLGNBQWMsRUFBRSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSztnQkFDOUQsVUFBVSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLFNBQVM7Z0JBQzNELGlCQUFpQixFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxrQ0FBaUIsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLFNBQVM7YUFDbkYsQ0FBQyxDQUFDO1FBQ1gsQ0FBQztJQUNMLENBQUM7SUFFTSxNQUFNLENBQUMsdUJBQXVCLENBQUMsWUFBa0M7UUFFcEUsSUFBSSxDQUFDLFlBQVksSUFBSSxZQUFZLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRSxDQUFDO1lBQzdDLE9BQU8sRUFBRSxDQUFDO1FBQ2QsQ0FBQztRQUVELE1BQU0sR0FBRyxHQUErQixFQUFFLENBQUM7UUFFM0MsWUFBWSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEVBQVUsRUFBRSxFQUFFO1lBQ2hDLEdBQUcsQ0FBQyw4QkFBOEIsRUFBRSxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUM7UUFDbkQsQ0FBQyxDQUFDLENBQUM7UUFFSCxPQUFPLEdBQUcsQ0FBQztJQUNmLENBQUM7O0FBakVMLHdCQW1FQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEF1dGhvcml6YXRpb25UeXBlLCBJUmVzdEFwaSwgTGFtYmRhSW50ZWdyYXRpb24sIFJlcXVlc3RBdXRob3JpemVyLCBSZXNvdXJjZSwgVG9rZW5BdXRob3JpemVyIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1hcGlnYXRld2F5XCI7XG5pbXBvcnQgeyBOb2RlanNGdW5jdGlvbiB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtbGFtYmRhLW5vZGVqc1wiO1xuaW1wb3J0IHsgVHNnTGFtYmRhUHJvcCB9IGZyb20gXCIuLi8uLi9jb25maWcvdHlwZXNcIjtcbmltcG9ydCB7IExvZ2dlciB9IGZyb20gXCIuLi8uLi9oZWxwZXJzL2xvZ2dlclwiO1xuaW1wb3J0IHsgbG9nZ2VyIH0gZnJvbSBcIi4uL2xheWVycy9jb21tb24vc3JjL25vZGVqc1wiO1xuXG5cbmV4cG9ydCBjbGFzcyBSb3V0ZXMge1xuXG4gICAgcHVibGljIHN0YXRpYyBSZXNvdXJjZXM6IFJlc291cmNlW10gPSBbXTtcbiAgICBwcml2YXRlIHN0YXRpYyByb3V0ZU1hcCA9IG5ldyBNYXAoKTtcblxuICAgIHB1YmxpYyBzdGF0aWMgY3JlYXRlUmVzb3VyY2UoXG4gICAgICAgIHByb3A6IFRzZ0xhbWJkYVByb3AsXG4gICAgICAgIGFwaTogSVJlc3RBcGksXG4gICAgICAgIGxhbWJkYU5vZGU6IE5vZGVqc0Z1bmN0aW9uLFxuICAgICAgICBhdXRob3JpemVyPzogVG9rZW5BdXRob3JpemVyIHwgUmVxdWVzdEF1dGhvcml6ZXIsXG4gICAgKTogdm9pZCB7XG5cbiAgICAgICAgY29uc3Qgcm91dGVNYXA6IE1hcDxzdHJpbmcsIFJlc291cmNlPiA9IG5ldyBNYXAoKTtcblxuICAgICAgICBsZXQgYWN0aXZlUm91dGVQYXRoID0gXCJcIjtcbiAgICAgICAgbGV0IGFjdGl2ZVJlc291cmNlOiBSZXNvdXJjZSB8IHVuZGVmaW5lZCA9IHVuZGVmaW5lZDtcblxuICAgICAgICAvLyAgT25seSBhdHRhY2ggbGFtYmRhIHRvIGFuIEFwaSBHYXRld2F5IGlmIGEgcm91dGUgZXhpc3RcbiAgICAgICAgaWYgKHByb3AuYXBpR2F0ZXdheT8ucm91dGUpIHtcblxuICAgICAgICAgICAgaWYgKCFwcm9wLmFwaUdhdGV3YXkudXNlUm91dGVPdmVycmlkZSkge1xuICAgICAgICAgICAgICAgIC8vICBGaXJzdCB3ZSBjcmVhdGUgdGhlIHJvb3QgcmVzb3VyY2UgaWYgaXQgZG9lc24ndCBleGlzdC5cbiAgICAgICAgICAgICAgICAvLyAgTm90ZTogIHRoaXMgbm93IHVzZXMgdGhlIGJ1bmRsZSB2ZXJzaW9uIGFzIHRoZSBmaXJzdCBzZWdtZW50IGluIHRoZSBwYXRoLlxuICAgICAgICAgICAgICAgIGFjdGl2ZVJvdXRlUGF0aCA9IGB2JHsocHJvcC5hcGlHYXRld2F5Py52ZXJzaW9uKSA/IHByb3AuYXBpR2F0ZXdheS52ZXJzaW9uIDogMX1gO1xuICAgICAgICAgICAgICAgIGFjdGl2ZVJlc291cmNlID0gUm91dGVzLnJvdXRlTWFwLmdldChhY3RpdmVSb3V0ZVBhdGgpIHx8IGFwaS5yb290LmFkZFJlc291cmNlKGFjdGl2ZVJvdXRlUGF0aCk7XG4gICAgICAgICAgICAgICAgUm91dGVzLnJvdXRlTWFwLnNldChhY3RpdmVSb3V0ZVBhdGgsIGFjdGl2ZVJlc291cmNlKTtcbiAgICAgICAgICAgIH1cblxuXG4gICAgICAgICAgICAvLyAgTm93IHdlIGdvIHRocm91Z2ggb3VyIHJvdXRlIHNlZ21lbnRzIGNyZWF0aW5nIHRoZSByZXN0IG9mIHRoZSBwYXRoLlxuICAgICAgICAgICAgY29uc3QgcGF0aFNlZ21lbnRzID0gcHJvcC5hcGlHYXRld2F5Py5yb3V0ZS5zcGxpdChcIi9cIikuZmlsdGVyKHggPT4gKHgpKTtcblxuICAgICAgICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCBwYXRoU2VnbWVudHMubGVuZ3RoOyBpKyspIHtcbiAgICAgICAgICAgICAgICBhY3RpdmVSb3V0ZVBhdGggPSBgJHthY3RpdmVSb3V0ZVBhdGh9LyR7cGF0aFNlZ21lbnRzW2ldfWA7XG4gICAgICAgICAgICAgICAgbGV0IHNlY29uZGFyeVJlc291cmNlID0gUm91dGVzLnJvdXRlTWFwLmdldChhY3RpdmVSb3V0ZVBhdGgpIHx8IGFjdGl2ZVJlc291cmNlPy5hZGRSZXNvdXJjZShwYXRoU2VnbWVudHNbaV0pIHx8IGFwaS5yb290LmFkZFJlc291cmNlKHBhdGhTZWdtZW50c1tpXSk7XG4gICAgICAgICAgICAgICAgUm91dGVzLnJvdXRlTWFwLnNldChhY3RpdmVSb3V0ZVBhdGgsIHNlY29uZGFyeVJlc291cmNlKTtcbiAgICAgICAgICAgICAgICBhY3RpdmVSZXNvdXJjZSA9IHNlY29uZGFyeVJlc291cmNlO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAvLyAgICBjb25zb2xlLmxvZyhgUm91dGU6ICR7cHJvcC5hcGlHYXRld2F5Lm1ldGhvZH1cXHQgTGFtYmRhIE5hbWU6ICR7bGFtYmRhTm9kZS5ub2RlLmlkfVxcdCBQYXRoOiAke2FjdGl2ZVJvdXRlUGF0aH1gKTtcbiAgICAgICAgICAgIC8vICBGaW5hbGx5LCB3ZSBhdHRhY2ggb3VyIGZ1bmN0aW9uIHRvIHRoZSBsYXN0IHJlc291cmNlXG4gICAgICAgICAgICBhY3RpdmVSZXNvdXJjZT8uYWRkTWV0aG9kKHByb3AuYXBpR2F0ZXdheS5tZXRob2QgfHwgJ0dFVCcsXG4gICAgICAgICAgICAgICAgbmV3IExhbWJkYUludGVncmF0aW9uKGxhbWJkYU5vZGUsIHsgcHJveHk6IHRydWUsIH0pLFxuICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgcmVxdWVzdFBhcmFtZXRlcnM6IFJvdXRlcy5jcmVhdGVRdWVyeVN0cmluZ09iamVjdChwcm9wLmFwaUdhdGV3YXkucXVlcnlTdHJpbmdzKSxcbiAgICAgICAgICAgICAgICAgICAgYXBpS2V5UmVxdWlyZWQ6IChwcm9wLmFwaUdhdGV3YXkucmVxdWlyZUFwaUtleSkgPyB0cnVlIDogZmFsc2UsXG4gICAgICAgICAgICAgICAgICAgIGF1dGhvcml6ZXI6IHByb3AuYXBpR2F0ZXdheS5zZWN1cmUgPyBhdXRob3JpemVyIDogdW5kZWZpbmVkLFxuICAgICAgICAgICAgICAgICAgICBhdXRob3JpemF0aW9uVHlwZTogcHJvcC5hcGlHYXRld2F5LnNlY3VyZSA/IEF1dGhvcml6YXRpb25UeXBlLkNVU1RPTSA6IHVuZGVmaW5lZCxcbiAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHB1YmxpYyBzdGF0aWMgY3JlYXRlUXVlcnlTdHJpbmdPYmplY3QocXVlcnlTdHJpbmdzOiBzdHJpbmdbXSB8IHVuZGVmaW5lZCk6IHsgW2tleTogc3RyaW5nXTogYm9vbGVhbiB9IHtcblxuICAgICAgICBpZiAoIXF1ZXJ5U3RyaW5ncyB8fCBxdWVyeVN0cmluZ3MubGVuZ3RoID09PSAwKSB7XG4gICAgICAgICAgICByZXR1cm4ge307XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBvYmo6IHsgW2tleTogc3RyaW5nXTogYm9vbGVhbiB9ID0ge307XG5cbiAgICAgICAgcXVlcnlTdHJpbmdzLmZvckVhY2goKHFzOiBzdHJpbmcpID0+IHtcbiAgICAgICAgICAgIG9ialtgbWV0aG9kLnJlcXVlc3QucXVlcnlzdHJpbmcuJHtxc31gXSA9IHRydWU7XG4gICAgICAgIH0pO1xuXG4gICAgICAgIHJldHVybiBvYmo7XG4gICAgfVxuXG59Il19
|
|
@@ -30,7 +30,7 @@ class LambdaHelper {
|
|
|
30
30
|
const lambdaId = this.getIdForLambda(config, appConfig);
|
|
31
31
|
let fctn = new aws_lambda_nodejs_1.NodejsFunction(scope, lambdaId, lambdaProps);
|
|
32
32
|
if (lambdaId !== fctn.node.id) {
|
|
33
|
-
console.
|
|
33
|
+
console.error(`can not find Lambda for : ${fctn.node.id}`);
|
|
34
34
|
}
|
|
35
35
|
return fctn;
|
|
36
36
|
}
|
|
@@ -94,4 +94,4 @@ class LambdaHelper {
|
|
|
94
94
|
}
|
|
95
95
|
}
|
|
96
96
|
exports.LambdaHelper = LambdaHelper;
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambdaHelper.js","sourceRoot":"","sources":["../../../src/resources/lambda/lambdaHelper.ts"],"names":[],"mappings":"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","sourcesContent":["import { IRole } from \"aws-cdk-lib/aws-iam\";\nimport { LayerVersion } from \"aws-cdk-lib/aws-lambda\";\nimport { Construct } from \"constructs\";\nimport { TsgLambdaProp } from \"../../config/types\";\nimport { NodejsFunction, NodejsFunctionProps, SourceMapMode } from \"aws-cdk-lib/aws-lambda-nodejs\";\nimport { TsgLambdaProps } from \"../../config/types/TsgLambdaProps\";\nimport { CreateLambdaFunctionInput } from \"../../interfaces/CreateLambdaFunctionInput\";\nimport * as path from \"node:path\";\nimport { AppConfig } from \"../../config/AppConfig\";\nimport { RetentionDays } from \"aws-cdk-lib/aws-logs\";\nimport { Duration } from \"aws-cdk-lib\";\nimport { LogDuration } from \"../../config/types/LogDuration\";\n\n\nexport class LambdaHelper {\n\n    public static createLambdaFunctions(scope: Construct,\n        config: AppConfig,\n        lambdaConfigs: TsgLambdaProp | TsgLambdaProp[],\n        role?: IRole,\n        layers?: LayerVersion[]) {\n\n        const isArrayOfLambdaProps = Array.isArray(lambdaConfigs);\n\n        const appConfig = config;\n\n        if (isArrayOfLambdaProps) {\n            const createdLambdas = lambdaConfigs.map((config: TsgLambdaProp) => {\n\n                return LambdaHelper.createLambda(config, role, layers, appConfig, scope);\n            });\n            return createdLambdas || [];\n        } else {\n            return LambdaHelper.createLambda(lambdaConfigs as TsgLambdaProp, role, layers, config, scope);\n        }\n    }\n\n    private static createLambda(config: TsgLambdaProp,\n        role: IRole | undefined,\n        layers: LayerVersion[] | undefined,\n        appConfig: AppConfig,\n        scope: Construct) {\n\n        let lambdaProps = this.createLambdaProps(config, role, layers, {\n            appConfig: appConfig,\n            role,\n            layers,\n            scope\n        });\n\n        const lambdaId = this.getIdForLambda(config, appConfig);\n        let fctn = new NodejsFunction(scope, lambdaId, lambdaProps);\n\n        if (lambdaId !== fctn.node.id) {\n            console.log(`can not find Lambda for : ${fctn.node.id}`);\n        }\n\n        return fctn;\n    }\n\n    private static createLambdaProps(prop: TsgLambdaProp,\n        role?: IRole,\n        layers?: LayerVersion[],\n        props?: TsgLambdaProps) {\n\n        return this.createLambdaFunctionProps({\n            prop,\n            role,\n            layers,\n            props\n        });\n    }\n\n    private static createLambdaFunctionProps(props: CreateLambdaFunctionInput) {\n        const { prop, role, layers } = props;\n\n        const config = props.props?.appConfig;\n\n        const lambdaProp: NodejsFunctionProps = {\n            entry: path.join(prop.codePath),\n            functionName: `${config?.AppPrefix}-${prop.name}`,\n            handler: prop.handler,\n            logRetention: (!prop.logDuration) ? RetentionDays.FIVE_DAYS :\n                LambdaHelper.getDayToSaveLogs(prop.logDuration),\n            runtime: prop.runtime || 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: true,\n                target: \"ESNext\",\n                sourceMap: true,\n                sourceMapMode: SourceMapMode.EXTERNAL,\n                environment: prop.environment || prop.environment,\n            },\n            role,\n            layers\n\n        }\n        return lambdaProp;\n    };\n\n    public static getDayToSaveLogs(saveLogDuration: LogDuration): RetentionDays {\n\n        switch (saveLogDuration) {\n            case LogDuration.ONE_DAY:\n                return RetentionDays.ONE_DAY;\n\n            case LogDuration.ONE_WEEK:\n                return RetentionDays.ONE_WEEK;\n\n            case LogDuration.ONE_MONTH:\n                return RetentionDays.ONE_MONTH;\n\n            case LogDuration.ONE_YEAR:\n                return RetentionDays.ONE_YEAR;\n\n            case LogDuration.FIVE_YEARS:\n                return RetentionDays.FIVE_YEARS;\n\n            case LogDuration.FOREVER:\n                return RetentionDays.INFINITE;\n            default:\n                return RetentionDays.FIVE_DAYS;\n        }\n    }\n\n    public static getIdForLambda(lambdaProp: TsgLambdaProp, appConfig: AppConfig) {\n        return `${appConfig.AppPrefix}-${lambdaProp.name}`.toLowerCase();\n    }\n}"]}
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambdaHelper.js","sourceRoot":"","sources":["../../../src/resources/lambda/lambdaHelper.ts"],"names":[],"mappings":"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","sourcesContent":["import { IRole } from \"aws-cdk-lib/aws-iam\";\nimport { LayerVersion } from \"aws-cdk-lib/aws-lambda\";\nimport { Construct } from \"constructs\";\nimport { TsgLambdaProp } from \"../../config/types\";\nimport { NodejsFunction, NodejsFunctionProps, SourceMapMode } from \"aws-cdk-lib/aws-lambda-nodejs\";\nimport { TsgLambdaProps } from \"../../config/types/TsgLambdaProps\";\nimport { CreateLambdaFunctionInput } from \"../../interfaces/CreateLambdaFunctionInput\";\nimport * as path from \"node:path\";\nimport { AppConfig } from \"../../config/AppConfig\";\nimport { RetentionDays } from \"aws-cdk-lib/aws-logs\";\nimport { Duration } from \"aws-cdk-lib\";\nimport { LogDuration } from \"../../config/types/LogDuration\";\n\n\nexport class LambdaHelper {\n\n    public static createLambdaFunctions(scope: Construct,\n        config: AppConfig,\n        lambdaConfigs: TsgLambdaProp | TsgLambdaProp[],\n        role?: IRole,\n        layers?: LayerVersion[]) {\n\n        const isArrayOfLambdaProps = Array.isArray(lambdaConfigs);\n\n        const appConfig = config;\n\n        if (isArrayOfLambdaProps) {\n            const createdLambdas = lambdaConfigs.map((config: TsgLambdaProp) => {\n\n                return LambdaHelper.createLambda(config, role, layers, appConfig, scope);\n            });\n            return createdLambdas || [];\n        } else {\n            return LambdaHelper.createLambda(lambdaConfigs as TsgLambdaProp, role, layers, config, scope);\n        }\n    }\n\n    private static createLambda(config: TsgLambdaProp,\n        role: IRole | undefined,\n        layers: LayerVersion[] | undefined,\n        appConfig: AppConfig,\n        scope: Construct) {\n\n        let lambdaProps = this.createLambdaProps(config, role, layers, {\n            appConfig: appConfig,\n            role,\n            layers,\n            scope\n        });\n\n        const lambdaId = this.getIdForLambda(config, appConfig);\n        let fctn = new NodejsFunction(scope, lambdaId, lambdaProps);\n\n        if (lambdaId !== fctn.node.id) {\n            console.error(`can not find Lambda for : ${fctn.node.id}`);\n        }\n\n        return fctn;\n    }\n\n    private static createLambdaProps(prop: TsgLambdaProp,\n        role?: IRole,\n        layers?: LayerVersion[],\n        props?: TsgLambdaProps) {\n\n        return this.createLambdaFunctionProps({\n            prop,\n            role,\n            layers,\n            props\n        });\n    }\n\n    private static createLambdaFunctionProps(props: CreateLambdaFunctionInput) {\n        const { prop, role, layers } = props;\n\n        const config = props.props?.appConfig;\n\n        const lambdaProp: NodejsFunctionProps = {\n            entry: path.join(prop.codePath),\n            functionName: `${config?.AppPrefix}-${prop.name}`,\n            handler: prop.handler,\n            logRetention: (!prop.logDuration) ? RetentionDays.FIVE_DAYS :\n                LambdaHelper.getDayToSaveLogs(prop.logDuration),\n            runtime: prop.runtime || 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: true,\n                target: \"ESNext\",\n                sourceMap: true,\n                sourceMapMode: SourceMapMode.EXTERNAL,\n                environment: prop.environment || prop.environment,\n            },\n            role,\n            layers\n\n        }\n        return lambdaProp;\n    };\n\n    public static getDayToSaveLogs(saveLogDuration: LogDuration): RetentionDays {\n\n        switch (saveLogDuration) {\n            case LogDuration.ONE_DAY:\n                return RetentionDays.ONE_DAY;\n\n            case LogDuration.ONE_WEEK:\n                return RetentionDays.ONE_WEEK;\n\n            case LogDuration.ONE_MONTH:\n                return RetentionDays.ONE_MONTH;\n\n            case LogDuration.ONE_YEAR:\n                return RetentionDays.ONE_YEAR;\n\n            case LogDuration.FIVE_YEARS:\n                return RetentionDays.FIVE_YEARS;\n\n            case LogDuration.FOREVER:\n                return RetentionDays.INFINITE;\n            default:\n                return RetentionDays.FIVE_DAYS;\n        }\n    }\n\n    public static getIdForLambda(lambdaProp: TsgLambdaProp, appConfig: AppConfig) {\n        return `${appConfig.AppPrefix}-${lambdaProp.name}`.toLowerCase();\n    }\n}"]}
|
package/package.json
CHANGED
|
@@ -14,6 +14,7 @@ import { IRestApi } from "aws-cdk-lib/aws-apigateway";
|
|
|
14
14
|
import { ISecret } from "aws-cdk-lib/aws-secretsmanager";
|
|
15
15
|
import { NodejsFunction } from "aws-cdk-lib/aws-lambda-nodejs";
|
|
16
16
|
import { Environment } from "../config/Environments";
|
|
17
|
+
import { Logger } from "../helpers/logger";
|
|
17
18
|
export class MicroService extends Construct {
|
|
18
19
|
|
|
19
20
|
protected readonly requireDynamoTables: boolean;
|
|
@@ -52,7 +53,7 @@ export class MicroService extends Construct {
|
|
|
52
53
|
}
|
|
53
54
|
|
|
54
55
|
constructor(scope: Construct, id: string, props: MicroserviceProps,
|
|
55
|
-
|
|
56
|
+
private logger: Logger = new Logger()) {
|
|
56
57
|
super(scope, id);
|
|
57
58
|
|
|
58
59
|
this.appConfig = new AppConfig(props);
|
|
@@ -66,7 +67,7 @@ export class MicroService extends Construct {
|
|
|
66
67
|
this.hasLambdaLayers = (props.RESOURCES.LAMBDA_LAYERS &&
|
|
67
68
|
props.RESOURCES.LAMBDA_LAYERS.length > 0) ? true : false;
|
|
68
69
|
|
|
69
|
-
const results = this.onInit(scope
|
|
70
|
+
const results = this.onInit(scope);
|
|
70
71
|
|
|
71
72
|
this.api = results.restApi!;
|
|
72
73
|
this.dynamoTables = results.dynamoTables!;
|
|
@@ -78,7 +79,7 @@ export class MicroService extends Construct {
|
|
|
78
79
|
this.createTag(scope)
|
|
79
80
|
}
|
|
80
81
|
|
|
81
|
-
private onInit(scope: Construct
|
|
82
|
+
private onInit(scope: Construct) {
|
|
82
83
|
|
|
83
84
|
let secretManager: ISecret | null = null;
|
|
84
85
|
let tables: Table[] | undefined = undefined;
|
|
@@ -94,7 +95,7 @@ export class MicroService extends Construct {
|
|
|
94
95
|
commonLayers = createCommonLayer(scope, this.appConfig);
|
|
95
96
|
}
|
|
96
97
|
|
|
97
|
-
const gateway = new Api(scope, this.appConfig
|
|
98
|
+
const gateway = new Api(scope, this.appConfig).APIs;
|
|
98
99
|
|
|
99
100
|
const layers = commonLayers;
|
|
100
101
|
|
|
@@ -114,7 +115,8 @@ export class MicroService extends Construct {
|
|
|
114
115
|
|
|
115
116
|
this.lambdaRecords = apiGateway.LambdaRecords;
|
|
116
117
|
|
|
117
|
-
|
|
118
|
+
|
|
119
|
+
this.logger.log(`lambda Records: ${this.lambdaRecords}`);
|
|
118
120
|
|
|
119
121
|
return {
|
|
120
122
|
restApi: (gateway?.length > 0) ? gateway[0] : null,
|
|
@@ -12,4 +12,9 @@ export const environmentSuffix = (env: Environment = "prod") => {
|
|
|
12
12
|
|
|
13
13
|
export const environmentSuffixForDomain = (env: Environment = "prod") => {
|
|
14
14
|
return env === 'prod' ? '.' : env === 'qa' ? '.qa' : '.dev';
|
|
15
|
-
}
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export const clog = (message: string) => {
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
};
|
|
@@ -21,7 +21,7 @@ export class Api extends BaseResource<IRestApi> {
|
|
|
21
21
|
return this.createdResources;
|
|
22
22
|
}
|
|
23
23
|
|
|
24
|
-
constructor(scope: Construct, config: AppConfig
|
|
24
|
+
constructor(scope: Construct, config: AppConfig) {
|
|
25
25
|
super(scope, config);
|
|
26
26
|
|
|
27
27
|
this.corsOptions = this.createDefaultCorsOptions();
|
|
@@ -36,7 +36,7 @@ export class Api extends BaseResource<IRestApi> {
|
|
|
36
36
|
|
|
37
37
|
const zone = this.getZone(this.scope, this.config);
|
|
38
38
|
|
|
39
|
-
const api = new RestApi(this.scope, `${this.config.AppPrefix}-rest-api
|
|
39
|
+
const api = new RestApi(this.scope, `${this.config.AppPrefix}-rest-api`, this.createApiProps(zone));
|
|
40
40
|
|
|
41
41
|
this.createARecord(scope, zone, api);
|
|
42
42
|
|
|
@@ -46,7 +46,7 @@ export class Api extends BaseResource<IRestApi> {
|
|
|
46
46
|
|
|
47
47
|
} else {
|
|
48
48
|
|
|
49
|
-
const api = new RestApi(this.scope, `${this.config.AppPrefix}-rest-api
|
|
49
|
+
const api = new RestApi(this.scope, `${this.config.AppPrefix}-rest-api-without-DNS`, this.createApiProps());
|
|
50
50
|
|
|
51
51
|
this.createApiKey(this.config, api);
|
|
52
52
|
|
|
@@ -54,7 +54,7 @@ export class Api extends BaseResource<IRestApi> {
|
|
|
54
54
|
}
|
|
55
55
|
}
|
|
56
56
|
|
|
57
|
-
private createApiProps(
|
|
57
|
+
private createApiProps(zone?: IHostedZone): RestApiProps {
|
|
58
58
|
|
|
59
59
|
if (this.config.DNS) {
|
|
60
60
|
|
|
@@ -64,7 +64,7 @@ export class Api extends BaseResource<IRestApi> {
|
|
|
64
64
|
restApiName: `${this.config.AppPrefix}-${this.config.API.Name}`,
|
|
65
65
|
description: this.config.API.Description,
|
|
66
66
|
domainName: {
|
|
67
|
-
domainName: `${this.config.
|
|
67
|
+
domainName: `${this.config.DNS.SubDomainNameForApi}.${this.config.DNS.SubDomainName}`,
|
|
68
68
|
certificate: cert.certificate,
|
|
69
69
|
endpointType: EndpointType.EDGE,
|
|
70
70
|
securityPolicy: SecurityPolicy.TLS_1_2
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { AuthorizationType, IRestApi, LambdaIntegration, RequestAuthorizer, Resource, TokenAuthorizer } from "aws-cdk-lib/aws-apigateway";
|
|
2
2
|
import { NodejsFunction } from "aws-cdk-lib/aws-lambda-nodejs";
|
|
3
3
|
import { TsgLambdaProp } from "../../config/types";
|
|
4
|
+
import { Logger } from "../../helpers/logger";
|
|
5
|
+
import { logger } from "../layers/common/src/nodejs";
|
|
4
6
|
|
|
5
7
|
|
|
6
8
|
export class Routes {
|
|
@@ -12,7 +14,8 @@ export class Routes {
|
|
|
12
14
|
prop: TsgLambdaProp,
|
|
13
15
|
api: IRestApi,
|
|
14
16
|
lambdaNode: NodejsFunction,
|
|
15
|
-
authorizer?: TokenAuthorizer | RequestAuthorizer
|
|
17
|
+
authorizer?: TokenAuthorizer | RequestAuthorizer,
|
|
18
|
+
): void {
|
|
16
19
|
|
|
17
20
|
const routeMap: Map<string, Resource> = new Map();
|
|
18
21
|
|
|
@@ -41,7 +44,7 @@ export class Routes {
|
|
|
41
44
|
activeResource = secondaryResource;
|
|
42
45
|
}
|
|
43
46
|
|
|
44
|
-
console.log(`Route: ${prop.apiGateway.method}\t Lambda Name: ${lambdaNode.node.id}\t Path: ${activeRoutePath}`);
|
|
47
|
+
// console.log(`Route: ${prop.apiGateway.method}\t Lambda Name: ${lambdaNode.node.id}\t Path: ${activeRoutePath}`);
|
|
45
48
|
// Finally, we attach our function to the last resource
|
|
46
49
|
activeResource?.addMethod(prop.apiGateway.method || 'GET',
|
|
47
50
|
new LambdaIntegration(lambdaNode, { proxy: true, }),
|
|
@@ -52,7 +52,7 @@ export class LambdaHelper {
|
|
|
52
52
|
let fctn = new NodejsFunction(scope, lambdaId, lambdaProps);
|
|
53
53
|
|
|
54
54
|
if (lambdaId !== fctn.node.id) {
|
|
55
|
-
console.
|
|
55
|
+
console.error(`can not find Lambda for : ${fctn.node.id}`);
|
|
56
56
|
}
|
|
57
57
|
|
|
58
58
|
return fctn;
|