@sylvesterllc/aws-constructs 1.0.115 → 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.
@@ -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 { Logger } from "../helpers/logger";
9
10
  export declare class MicroService extends Construct {
10
- private debug;
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, debug?: boolean);
28
+ constructor(scope: Construct, id: string, props: MicroserviceProps, logger?: Logger);
28
29
  private onInit;
29
30
  protected createTag(scope: Construct): void;
30
31
  }
@@ -10,8 +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 {
14
- debug;
15
+ logger;
15
16
  requireDynamoTables;
16
17
  requireSeedDatabase = false;
17
18
  hasLambdaLayers = false;
@@ -40,9 +41,9 @@ class MicroService extends constructs_1.Construct {
40
41
  get RestApi() {
41
42
  return this.api;
42
43
  }
43
- constructor(scope, id, props, debug = false) {
44
+ constructor(scope, id, props, logger = new logger_1.Logger()) {
44
45
  super(scope, id);
45
- this.debug = debug;
46
+ this.logger = logger;
46
47
  this.appConfig = new AppConfig_1.AppConfig(props);
47
48
  this.requireDynamoTables = (props.RESOURCES.DYNAMO?.TABLES &&
48
49
  props.RESOURCES.DYNAMO.TABLES.length > 0) ? true : false;
@@ -83,7 +84,7 @@ class MicroService extends constructs_1.Construct {
83
84
  // CREATE API GATEWAY AND LAMBDA HERE
84
85
  const apiGateway = new CreateApiAndAttachLambdas_1.CreateApiAndAttachLambdas(scope, this.appConfig, gateway[0], layers, tables);
85
86
  this.lambdaRecords = apiGateway.LambdaRecords;
86
- // console.log('lambda Records:', this.lambdaRecords)
87
+ this.logger.log(`lambda Records: ${this.lambdaRecords}`);
87
88
  return {
88
89
  restApi: (gateway?.length > 0) ? gateway[0] : null,
89
90
  lambdaLayers: layers || null,
@@ -98,4 +99,4 @@ class MicroService extends constructs_1.Construct {
98
99
  }
99
100
  }
100
101
  exports.MicroService = MicroService;
101
- //# 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        private debug: boolean = false) {\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        // 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,5 @@
1
+ export declare class Logger {
2
+ private debug;
3
+ constructor(debug?: boolean);
4
+ log(message: string): void;
5
+ }
@@ -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
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlUm91dGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3Jlc291cmNlcy9oZWxwZXJzL2NyZWF0ZVJvdXRlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwrREFBMEk7QUFLMUksTUFBYSxNQUFNO0lBRVIsTUFBTSxDQUFDLFNBQVMsR0FBZSxFQUFFLENBQUM7SUFDakMsTUFBTSxDQUFDLFFBQVEsR0FBRyxJQUFJLEdBQUcsRUFBRSxDQUFDO0lBRTdCLE1BQU0sQ0FBQyxjQUFjLENBQ3hCLElBQW1CLEVBQ25CLEdBQWEsRUFDYixVQUEwQixFQUMxQixVQUFnRDtRQUVoRCxNQUFNLFFBQVEsR0FBMEIsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUVsRCxJQUFJLGVBQWUsR0FBRyxFQUFFLENBQUM7UUFDekIsSUFBSSxjQUFjLEdBQXlCLFNBQVMsQ0FBQztRQUVyRCx5REFBeUQ7UUFDekQsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFLEtBQUssRUFBRSxDQUFDO1lBRXpCLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLGdCQUFnQixFQUFFLENBQUM7Z0JBQ3BDLDBEQUEwRDtnQkFDMUQsNkVBQTZFO2dCQUM3RSxlQUFlLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztnQkFDakYsY0FBYyxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLGVBQWUsQ0FBQyxDQUFDO2dCQUMvRixNQUFNLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxlQUFlLEVBQUUsY0FBYyxDQUFDLENBQUM7WUFDekQsQ0FBQztZQUdELHVFQUF1RTtZQUN2RSxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsVUFBVSxFQUFFLEtBQUssQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBRXhFLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxZQUFZLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7Z0JBQzNDLGVBQWUsR0FBRyxHQUFHLGVBQWUsSUFBSSxZQUFZLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztnQkFDMUQsSUFBSSxpQkFBaUIsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsSUFBSSxjQUFjLEVBQUUsV0FBVyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUN0SixNQUFNLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxlQUFlLEVBQUUsaUJBQWlCLENBQUMsQ0FBQztnQkFDeEQsY0FBYyxHQUFHLGlCQUFpQixDQUFDO1lBQ3ZDLENBQUM7WUFFRCxPQUFPLENBQUMsR0FBRyxDQUFDLFVBQVUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNLG1CQUFtQixVQUFVLENBQUMsSUFBSSxDQUFDLEVBQUUsWUFBWSxlQUFlLEVBQUUsQ0FBQyxDQUFDO1lBQ2hILHdEQUF3RDtZQUN4RCxjQUFjLEVBQUUsU0FBUyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxJQUFJLEtBQUssRUFDckQsSUFBSSxrQ0FBaUIsQ0FBQyxVQUFVLEVBQUUsRUFBRSxLQUFLLEVBQUUsSUFBSSxHQUFHLENBQUMsRUFDbkQ7Z0JBQ0ksaUJBQWlCLEVBQUUsTUFBTSxDQUFDLHVCQUF1QixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsWUFBWSxDQUFDO2dCQUMvRSxjQUFjLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUs7Z0JBQzlELFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxTQUFTO2dCQUMzRCxpQkFBaUIsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsa0NBQWlCLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxTQUFTO2FBQ25GLENBQUMsQ0FBQztRQUNYLENBQUM7SUFDTCxDQUFDO0lBRU0sTUFBTSxDQUFDLHVCQUF1QixDQUFDLFlBQWtDO1FBRXBFLElBQUksQ0FBQyxZQUFZLElBQUksWUFBWSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUM3QyxPQUFPLEVBQUUsQ0FBQztRQUNkLENBQUM7UUFFRCxNQUFNLEdBQUcsR0FBK0IsRUFBRSxDQUFDO1FBRTNDLFlBQVksQ0FBQyxPQUFPLENBQUMsQ0FBQyxFQUFVLEVBQUUsRUFBRTtZQUNoQyxHQUFHLENBQUMsOEJBQThCLEVBQUUsRUFBRSxDQUFDLEdBQUcsSUFBSSxDQUFDO1FBQ25ELENBQUMsQ0FBQyxDQUFDO1FBRUgsT0FBTyxHQUFHLENBQUM7SUFDZixDQUFDOztBQWhFTCx3QkFrRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBdXRob3JpemF0aW9uVHlwZSwgSVJlc3RBcGksIExhbWJkYUludGVncmF0aW9uLCBSZXF1ZXN0QXV0aG9yaXplciwgUmVzb3VyY2UsIFRva2VuQXV0aG9yaXplciB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtYXBpZ2F0ZXdheVwiO1xuaW1wb3J0IHsgTm9kZWpzRnVuY3Rpb24gfSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWxhbWJkYS1ub2RlanNcIjtcbmltcG9ydCB7IFRzZ0xhbWJkYVByb3AgfSBmcm9tIFwiLi4vLi4vY29uZmlnL3R5cGVzXCI7XG5cblxuZXhwb3J0IGNsYXNzIFJvdXRlcyB7XG5cbiAgICBwdWJsaWMgc3RhdGljIFJlc291cmNlczogUmVzb3VyY2VbXSA9IFtdO1xuICAgIHByaXZhdGUgc3RhdGljIHJvdXRlTWFwID0gbmV3IE1hcCgpO1xuXG4gICAgcHVibGljIHN0YXRpYyBjcmVhdGVSZXNvdXJjZShcbiAgICAgICAgcHJvcDogVHNnTGFtYmRhUHJvcCxcbiAgICAgICAgYXBpOiBJUmVzdEFwaSxcbiAgICAgICAgbGFtYmRhTm9kZTogTm9kZWpzRnVuY3Rpb24sXG4gICAgICAgIGF1dGhvcml6ZXI/OiBUb2tlbkF1dGhvcml6ZXIgfCBSZXF1ZXN0QXV0aG9yaXplcik6IHZvaWQge1xuXG4gICAgICAgIGNvbnN0IHJvdXRlTWFwOiBNYXA8c3RyaW5nLCBSZXNvdXJjZT4gPSBuZXcgTWFwKCk7XG5cbiAgICAgICAgbGV0IGFjdGl2ZVJvdXRlUGF0aCA9IFwiXCI7XG4gICAgICAgIGxldCBhY3RpdmVSZXNvdXJjZTogUmVzb3VyY2UgfCB1bmRlZmluZWQgPSB1bmRlZmluZWQ7XG5cbiAgICAgICAgLy8gIE9ubHkgYXR0YWNoIGxhbWJkYSB0byBhbiBBcGkgR2F0ZXdheSBpZiBhIHJvdXRlIGV4aXN0XG4gICAgICAgIGlmIChwcm9wLmFwaUdhdGV3YXk/LnJvdXRlKSB7XG5cbiAgICAgICAgICAgIGlmICghcHJvcC5hcGlHYXRld2F5LnVzZVJvdXRlT3ZlcnJpZGUpIHtcbiAgICAgICAgICAgICAgICAvLyAgRmlyc3Qgd2UgY3JlYXRlIHRoZSByb290IHJlc291cmNlIGlmIGl0IGRvZXNuJ3QgZXhpc3QuXG4gICAgICAgICAgICAgICAgLy8gIE5vdGU6ICB0aGlzIG5vdyB1c2VzIHRoZSBidW5kbGUgdmVyc2lvbiBhcyB0aGUgZmlyc3Qgc2VnbWVudCBpbiB0aGUgcGF0aC5cbiAgICAgICAgICAgICAgICBhY3RpdmVSb3V0ZVBhdGggPSBgdiR7KHByb3AuYXBpR2F0ZXdheT8udmVyc2lvbikgPyBwcm9wLmFwaUdhdGV3YXkudmVyc2lvbiA6IDF9YDtcbiAgICAgICAgICAgICAgICBhY3RpdmVSZXNvdXJjZSA9IFJvdXRlcy5yb3V0ZU1hcC5nZXQoYWN0aXZlUm91dGVQYXRoKSB8fCBhcGkucm9vdC5hZGRSZXNvdXJjZShhY3RpdmVSb3V0ZVBhdGgpO1xuICAgICAgICAgICAgICAgIFJvdXRlcy5yb3V0ZU1hcC5zZXQoYWN0aXZlUm91dGVQYXRoLCBhY3RpdmVSZXNvdXJjZSk7XG4gICAgICAgICAgICB9XG5cblxuICAgICAgICAgICAgLy8gIE5vdyB3ZSBnbyB0aHJvdWdoIG91ciByb3V0ZSBzZWdtZW50cyBjcmVhdGluZyB0aGUgcmVzdCBvZiB0aGUgcGF0aC5cbiAgICAgICAgICAgIGNvbnN0IHBhdGhTZWdtZW50cyA9IHByb3AuYXBpR2F0ZXdheT8ucm91dGUuc3BsaXQoXCIvXCIpLmZpbHRlcih4ID0+ICh4KSk7XG5cbiAgICAgICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgcGF0aFNlZ21lbnRzLmxlbmd0aDsgaSsrKSB7XG4gICAgICAgICAgICAgICAgYWN0aXZlUm91dGVQYXRoID0gYCR7YWN0aXZlUm91dGVQYXRofS8ke3BhdGhTZWdtZW50c1tpXX1gO1xuICAgICAgICAgICAgICAgIGxldCBzZWNvbmRhcnlSZXNvdXJjZSA9IFJvdXRlcy5yb3V0ZU1hcC5nZXQoYWN0aXZlUm91dGVQYXRoKSB8fCBhY3RpdmVSZXNvdXJjZT8uYWRkUmVzb3VyY2UocGF0aFNlZ21lbnRzW2ldKSB8fCBhcGkucm9vdC5hZGRSZXNvdXJjZShwYXRoU2VnbWVudHNbaV0pO1xuICAgICAgICAgICAgICAgIFJvdXRlcy5yb3V0ZU1hcC5zZXQoYWN0aXZlUm91dGVQYXRoLCBzZWNvbmRhcnlSZXNvdXJjZSk7XG4gICAgICAgICAgICAgICAgYWN0aXZlUmVzb3VyY2UgPSBzZWNvbmRhcnlSZXNvdXJjZTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgY29uc29sZS5sb2coYFJvdXRlOiAke3Byb3AuYXBpR2F0ZXdheS5tZXRob2R9XFx0IExhbWJkYSBOYW1lOiAke2xhbWJkYU5vZGUubm9kZS5pZH1cXHQgUGF0aDogJHthY3RpdmVSb3V0ZVBhdGh9YCk7XG4gICAgICAgICAgICAvLyAgRmluYWxseSwgd2UgYXR0YWNoIG91ciBmdW5jdGlvbiB0byB0aGUgbGFzdCByZXNvdXJjZVxuICAgICAgICAgICAgYWN0aXZlUmVzb3VyY2U/LmFkZE1ldGhvZChwcm9wLmFwaUdhdGV3YXkubWV0aG9kIHx8ICdHRVQnLFxuICAgICAgICAgICAgICAgIG5ldyBMYW1iZGFJbnRlZ3JhdGlvbihsYW1iZGFOb2RlLCB7IHByb3h5OiB0cnVlLCB9KSxcbiAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgIHJlcXVlc3RQYXJhbWV0ZXJzOiBSb3V0ZXMuY3JlYXRlUXVlcnlTdHJpbmdPYmplY3QocHJvcC5hcGlHYXRld2F5LnF1ZXJ5U3RyaW5ncyksXG4gICAgICAgICAgICAgICAgICAgIGFwaUtleVJlcXVpcmVkOiAocHJvcC5hcGlHYXRld2F5LnJlcXVpcmVBcGlLZXkpID8gdHJ1ZSA6IGZhbHNlLFxuICAgICAgICAgICAgICAgICAgICBhdXRob3JpemVyOiBwcm9wLmFwaUdhdGV3YXkuc2VjdXJlID8gYXV0aG9yaXplciA6IHVuZGVmaW5lZCxcbiAgICAgICAgICAgICAgICAgICAgYXV0aG9yaXphdGlvblR5cGU6IHByb3AuYXBpR2F0ZXdheS5zZWN1cmUgPyBBdXRob3JpemF0aW9uVHlwZS5DVVNUT00gOiB1bmRlZmluZWQsXG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwdWJsaWMgc3RhdGljIGNyZWF0ZVF1ZXJ5U3RyaW5nT2JqZWN0KHF1ZXJ5U3RyaW5nczogc3RyaW5nW10gfCB1bmRlZmluZWQpOiB7IFtrZXk6IHN0cmluZ106IGJvb2xlYW4gfSB7XG5cbiAgICAgICAgaWYgKCFxdWVyeVN0cmluZ3MgfHwgcXVlcnlTdHJpbmdzLmxlbmd0aCA9PT0gMCkge1xuICAgICAgICAgICAgcmV0dXJuIHt9O1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3Qgb2JqOiB7IFtrZXk6IHN0cmluZ106IGJvb2xlYW4gfSA9IHt9O1xuXG4gICAgICAgIHF1ZXJ5U3RyaW5ncy5mb3JFYWNoKChxczogc3RyaW5nKSA9PiB7XG4gICAgICAgICAgICBvYmpbYG1ldGhvZC5yZXF1ZXN0LnF1ZXJ5c3RyaW5nLiR7cXN9YF0gPSB0cnVlO1xuICAgICAgICB9KTtcblxuICAgICAgICByZXR1cm4gb2JqO1xuICAgIH1cblxufSJdfQ==
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.log(`can not find Lambda for : ${fctn.node.id}`);
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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sylvesterllc/aws-constructs",
3
- "version": "1.0.115",
3
+ "version": "1.0.116",
4
4
  "description": "AWS Constructs",
5
5
  "main": "dist/index.js",
6
6
  "keywords": [
@@ -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
- private debug: boolean = false) {
56
+ private logger: Logger = new Logger()) {
56
57
  super(scope, id);
57
58
 
58
59
  this.appConfig = new AppConfig(props);
@@ -114,7 +115,8 @@ export class MicroService extends Construct {
114
115
 
115
116
  this.lambdaRecords = apiGateway.LambdaRecords;
116
117
 
117
- // console.log('lambda Records:', this.lambdaRecords)
118
+
119
+ this.logger.log(`lambda Records: ${this.lambdaRecords}`);
118
120
 
119
121
  return {
120
122
  restApi: (gateway?.length > 0) ? gateway[0] : null,
@@ -0,0 +1,14 @@
1
+ import { debug } from "console";
2
+
3
+ export class Logger {
4
+
5
+ constructor(private debug: boolean = false) { }
6
+
7
+ public log(message: string) {
8
+
9
+ if (this.debug) {
10
+ console.log(message);
11
+ }
12
+
13
+ }
14
+ }
@@ -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): void {
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.log(`can not find Lambda for : ${fctn.node.id}`);
55
+ console.error(`can not find Lambda for : ${fctn.node.id}`);
56
56
  }
57
57
 
58
58
  return fctn;