@sylvesterllc/aws-constructs 1.0.30 → 1.0.32

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.
Files changed (68) hide show
  1. package/__tests__/data/testConfig.tsx +136 -0
  2. package/__tests__/mocks/ResourceMock.ts +10 -0
  3. package/__tests__/router.test.ts +195 -0
  4. package/dist/config/ServiceBundleConfig.d.ts +16 -0
  5. package/dist/config/ServiceBundleConfig.js +3 -0
  6. package/dist/config/customConfigs/ResourceAppConfig.d.ts +4 -1
  7. package/dist/config/customConfigs/ResourceAppConfig.js +1 -1
  8. package/dist/config/types/LogDuration.d.ts +8 -0
  9. package/dist/config/types/LogDuration.js +13 -0
  10. package/dist/config/types/TsgAuthorizerProp.d.ts +6 -0
  11. package/dist/config/types/TsgAuthorizerProp.js +3 -0
  12. package/dist/config/types/TsgAuthorizerType.d.ts +4 -0
  13. package/dist/config/types/TsgAuthorizerType.js +9 -0
  14. package/dist/config/types/TsgEc2Prop.d.ts +7 -0
  15. package/dist/config/types/TsgEc2Prop.js +3 -0
  16. package/dist/config/types/TsgKeyPair.d.ts +4 -0
  17. package/dist/config/types/TsgKeyPair.js +3 -0
  18. package/dist/config/types/TsgLambdaProp.d.ts +2 -0
  19. package/dist/config/types/TsgLambdaProp.js +1 -1
  20. package/dist/config/types/TsgLambdaProps.d.ts +0 -2
  21. package/dist/config/types/TsgLambdaProps.js +1 -1
  22. package/dist/config/types/index.d.ts +1 -0
  23. package/dist/config/types/index.js +2 -1
  24. package/dist/constructs/MicroService.js +4 -5
  25. package/dist/interfaces/ApiLambdaResult.d.ts +4 -0
  26. package/dist/interfaces/ApiLambdaResult.js +3 -0
  27. package/dist/resources/dynamodb/CreateDynamo.js +3 -3
  28. package/dist/resources/ec2/create-ec2-instance.d.ts +9 -0
  29. package/dist/resources/ec2/create-ec2-instance.js +42 -0
  30. package/dist/resources/gateway/CreateApiAndAttachLambdas.d.ts +24 -0
  31. package/dist/resources/gateway/CreateApiAndAttachLambdas.js +89 -0
  32. package/dist/resources/helpers/createRoutes.d.ts +2 -2
  33. package/dist/resources/helpers/createRoutes.js +3 -3
  34. package/dist/resources/lambda/createLambda.d.ts +5 -4
  35. package/dist/resources/lambda/createLambda.js +50 -29
  36. package/dist/resources/{helpers/createAuthorizer.d.ts → lambda-authorizer/TsgJwtTokenAuthorizer.d.ts} +2 -4
  37. package/dist/resources/lambda-authorizer/TsgJwtTokenAuthorizer.js +80 -0
  38. package/dist/resources/lambda-authorizer/TsgRequestAuthorizer.d.ts +12 -0
  39. package/dist/resources/lambda-authorizer/TsgRequestAuthorizer.js +32 -0
  40. package/dist/resources/lambda-authorizer/createAuthorizerHelpers.d.ts +5 -0
  41. package/dist/resources/lambda-authorizer/createAuthorizerHelpers.js +50 -0
  42. package/jest.config.js +9 -0
  43. package/jest.config.ts.old +20 -0
  44. package/package.json +13 -11
  45. package/src/config/ServiceBundleConfig.ts +18 -0
  46. package/src/config/customConfigs/ResourceAppConfig.ts +5 -1
  47. package/src/config/types/LogDuration.ts +8 -0
  48. package/src/config/types/TsgAuthorizerProp.ts +9 -0
  49. package/src/config/types/TsgAuthorizerType.ts +5 -0
  50. package/src/config/types/TsgEc2Prop.ts +9 -0
  51. package/src/config/types/TsgKeyPair.ts +6 -0
  52. package/src/config/types/TsgLambdaProp.ts +4 -0
  53. package/src/config/types/TsgLambdaProps.ts +0 -1
  54. package/src/config/types/index.ts +1 -1
  55. package/src/constructs/MicroService.ts +4 -8
  56. package/src/interfaces/ApiLambdaResult.ts +6 -0
  57. package/src/resources/dynamodb/CreateDynamo.ts +1 -1
  58. package/src/resources/ec2/create-ec2-instance.ts +53 -0
  59. package/src/resources/gateway/CreateApiAndAttachLambdas.ts +137 -0
  60. package/src/resources/helpers/createRoutes.ts +3 -3
  61. package/src/resources/lambda/createLambda.ts +84 -56
  62. package/src/resources/{helpers/createAuthorizer.ts → lambda-authorizer/TsgJwtTokenAuthorizer.ts} +3 -3
  63. package/src/resources/lambda-authorizer/TsgRequestAuthorizer.ts +36 -0
  64. package/src/resources/lambda-authorizer/createAuthorizerHelpers.ts +69 -0
  65. package/dist/resources/gateway/createMicroServiceBundle.d.ts +0 -25
  66. package/dist/resources/gateway/createMicroServiceBundle.js +0 -132
  67. package/dist/resources/helpers/createAuthorizer.js +0 -81
  68. package/src/resources/gateway/createMicroServiceBundle.ts +0 -192
@@ -1,132 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CreateMicroServiceBundle = void 0;
4
- const aws_dynamodb_1 = require("aws-cdk-lib/aws-dynamodb");
5
- const aws_iam_1 = require("aws-cdk-lib/aws-iam");
6
- const createAuthorizer_1 = require("../helpers/createAuthorizer");
7
- const createRoutes_1 = require("../helpers/createRoutes");
8
- const createLambda_1 = require("../lambda/createLambda");
9
- const aws_cdk_lib_1 = require("aws-cdk-lib");
10
- const CreateDynamo_1 = require("../dynamodb/CreateDynamo");
11
- class CreateMicroServiceBundle {
12
- constructor(scope, gatewayApi, props, appConfig, tables, secretMgr, layers) {
13
- this.gatewayApi = gatewayApi;
14
- this.props = props;
15
- this.appConfig = appConfig;
16
- this.tables = tables;
17
- this.secretMgr = secretMgr;
18
- this.layers = layers;
19
- this.requireDynamoTableRefs = (props.RESOURCES.DYNAMO?.TABLE_REFS?.length ?? 0 > 0) ? true : false;
20
- this.requireAuthorizer = (props.RESOURCES.AUTHORIZER) ? true : false;
21
- this.onInit(scope);
22
- }
23
- onInit(scope) {
24
- let authorizer = undefined;
25
- // Create Authorizer
26
- if (this.requireAuthorizer) {
27
- authorizer = new createAuthorizer_1.CreateAuthorizer(scope, this.appConfig, this.props.RESOURCES.AUTHORIZER).JwtAuthorizer;
28
- authorizer._attachToApi(this.gatewayApi);
29
- authorizer.applyRemovalPolicy(aws_cdk_lib_1.RemovalPolicy.DESTROY);
30
- }
31
- // Create Lambdas
32
- const lambdaProp = {
33
- scope,
34
- prop: this.props,
35
- layers: this.layers,
36
- appConfig: this.appConfig
37
- };
38
- const lambdas = new createLambda_1.CreateLambda(lambdaProp, this.appConfig);
39
- if (this.tables) {
40
- this.AssignAccessToTables(this.tables, lambdas.Lambdas);
41
- }
42
- // Allow access to existing tables
43
- // if (this.requireDynamoTableRefs) {
44
- // this.AssignAccessToTableRefs(scope, this.props.RESOURCES.DYNAMO?.TABLE_REFS, lambdas.Lambdas);
45
- // }
46
- if (this.secretMgr) {
47
- this.AssignAccessToSecretManager(this.secretMgr, lambdas.Lambdas);
48
- }
49
- // lambdas.Lambdas.map((lambda) => {
50
- // lambda.metricErrors({
51
- // label: `${lambda.functionName}-errors`,
52
- // period: Duration.minutes(3)
53
- // })
54
- // });
55
- this.AddRoutes(this.props, this.gatewayApi, lambdas.Lambdas, authorizer);
56
- }
57
- AssignAccessToTables(tables, lambdas) {
58
- if (tables) {
59
- lambdas.forEach((lambda) => {
60
- tables.forEach((table) => {
61
- // This is a CDK bug: It doesn't provide
62
- // access to the indexes.
63
- //table.grantReadWriteData(lambda);
64
- // Workaround:
65
- // lambda.addToRolePolicy(
66
- // new PolicyStatement({
67
- // effect: Effect.ALLOW,
68
- // actions: CreateDynamoDb.ReadWriteActions,
69
- // resources: [
70
- // table.tableArn,
71
- // `${table.tableArn}/*`, // This is not recognized by cdk, but table is. why?
72
- // ],
73
- // })
74
- // );
75
- table.grantReadWriteData(lambda);
76
- });
77
- });
78
- }
79
- }
80
- AssignAccessToTableRefs(scope, tableRefs, lambdas) {
81
- if (tableRefs) {
82
- tableRefs.forEach((tableRef) => {
83
- if (tableRef.region) {
84
- this.AssignReadWriteAccessToTableInRegion(scope, tableRef, lambdas);
85
- }
86
- else {
87
- this.AssignReadWriteAccessToTable(scope, tableRef, lambdas);
88
- }
89
- });
90
- }
91
- }
92
- AssignReadWriteAccessToTableInRegion(scope, tableRef, lambdas) {
93
- lambdas.forEach((lambda) => {
94
- let tableArn = "arn:aws:dynamodb:" + tableRef.region + ":" + (scope.account) + ":table/" + tableRef.tableName;
95
- let statement = new aws_iam_1.PolicyStatement({
96
- effect: aws_iam_1.Effect.ALLOW,
97
- resources: [
98
- tableArn,
99
- tableArn + "/index/*",
100
- ],
101
- actions: CreateDynamo_1.CreateDynamoDb.ReadWriteActions,
102
- });
103
- lambda.role?.addToPrincipalPolicy(statement);
104
- });
105
- }
106
- AssignReadWriteAccessToTable(scope, tableRef, lambdas) {
107
- let table = aws_dynamodb_1.Table.fromTableName(scope, tableRef.tableName, tableRef.tableName);
108
- lambdas.forEach((lambda) => {
109
- table.grantReadWriteData(lambda);
110
- });
111
- }
112
- AddRoutes(props, gateway, lambdas, authorizer) {
113
- props.RESOURCES.LAMBDA?.forEach((prop) => {
114
- const lambdaId = createLambda_1.CreateLambda.getIdForLambda(prop, this.appConfig);
115
- if (!lambdaId) {
116
- throw new Error(`Can't find lambda`);
117
- }
118
- const lambdaNode = lambdas.find(x => x.node.id === lambdaId);
119
- if (!lambdaNode) {
120
- throw new Error("Can't find the Lambda Integration");
121
- }
122
- createRoutes_1.Routes.createResource(prop, gateway, lambdaNode, authorizer);
123
- });
124
- }
125
- AssignAccessToSecretManager(secret, lambdas) {
126
- lambdas.forEach((lambda) => {
127
- const result = secret.grantRead(lambda);
128
- });
129
- }
130
- }
131
- exports.CreateMicroServiceBundle = CreateMicroServiceBundle;
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"createMicroServiceBundle.js","sourceRoot":"","sources":["../../../src/resources/gateway/createMicroServiceBundle.ts"],"names":[],"mappings":"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","sourcesContent":["import { IRestApi, TokenAuthorizer } from \"aws-cdk-lib/aws-apigateway\";\nimport { ITable, Table } from \"aws-cdk-lib/aws-dynamodb\";\nimport { NodejsFunction } from \"aws-cdk-lib/aws-lambda-nodejs\";\nimport { Effect, PolicyStatement } from \"aws-cdk-lib/aws-iam\";\nimport { Construct } from \"constructs\";\nimport { TsgDynamoTableRef, TsgLambdaProp } from \"../../config/types\";\nimport { TsgLambdaProps } from \"../../config/types/TsgLambdaProps\";\nimport { MicroserviceProps } from \"../../interfaces/MicroserviceProps\";\nimport { CreateAuthorizer } from \"../helpers/createAuthorizer\";\nimport { Routes } from \"../helpers/createRoutes\";\nimport { CreateLambda } from \"../lambda/createLambda\";\nimport { Duration, RemovalPolicy, Stack } from \"aws-cdk-lib\";\nimport { CreateDynamoDb } from \"../dynamodb/CreateDynamo\";\nimport { ISecret } from \"aws-cdk-lib/aws-secretsmanager\";\nimport { LayerVersion } from \"aws-cdk-lib/aws-lambda\";\nimport { AppConfig } from \"../../config/AppConfig\";\nimport { MetricOptions } from \"aws-cdk-lib/aws-cloudwatch\";\n\nexport class CreateMicroServiceBundle {\n    \n    protected readonly requireDynamoTableRefs: boolean;\n    protected readonly requireAuthorizer: boolean;\n\n    constructor(scope: Construct, \n        private readonly gatewayApi: IRestApi, \n        private readonly props: MicroserviceProps,        \n        private readonly appConfig: AppConfig,\n        private readonly tables?: Table[], \n        private readonly secretMgr?: ISecret | null, \n        private readonly layers?: LayerVersion[],        \n        ) {\n        \n        this.requireDynamoTableRefs = (props.RESOURCES.DYNAMO?.TABLE_REFS?.length ?? 0 > 0) ? true : false;\n        this.requireAuthorizer = (props.RESOURCES.AUTHORIZER) ? true : false;\n        this.onInit(scope);\n    }\n\n    private onInit(scope: Construct) {\n\n        \n        let authorizer: TokenAuthorizer|undefined = undefined;\n\n        // Create Authorizer\n        if (this.requireAuthorizer) {\n            authorizer = new CreateAuthorizer(scope, this.appConfig, this.props.RESOURCES.AUTHORIZER!).JwtAuthorizer;\n            authorizer._attachToApi(this.gatewayApi);   \n            authorizer.applyRemovalPolicy(RemovalPolicy.DESTROY);\n        }        \n\n        // Create Lambdas\n        const lambdaProp: TsgLambdaProps = {\n            scope,\n            prop: this.props,            \n            layers: this.layers,\n            appConfig: this.appConfig\n        };\n\n        const lambdas = new CreateLambda(lambdaProp, this.appConfig);\n\n        if (this.tables) {\n            this.AssignAccessToTables(this.tables, lambdas.Lambdas);\n        }        \n\n        // Allow access to existing tables\n        // if (this.requireDynamoTableRefs) {\n        //     this.AssignAccessToTableRefs(scope, this.props.RESOURCES.DYNAMO?.TABLE_REFS, lambdas.Lambdas);\n        // }\n\n        if (this.secretMgr) {\n            this.AssignAccessToSecretManager(this.secretMgr, lambdas.Lambdas);\n        }        \n\n        // lambdas.Lambdas.map((lambda) => {\n        //     lambda.metricErrors({                \n        //             label: `${lambda.functionName}-errors`, \n        //             period: Duration.minutes(3)           \n                \n        //     })\n        // });\n\n        this.AddRoutes(this.props, this.gatewayApi, lambdas.Lambdas, authorizer);\n    }\n\n    private AssignAccessToTables(tables: Table[], lambdas: NodejsFunction[]) {\n\n        if (tables) {\n            lambdas.forEach((lambda: NodejsFunction) => {\n            \n                tables.forEach((table: ITable) => {\n\n                \n\n                    //  This is a CDK bug: It doesn't provide\n                    //  access to the indexes.\n                    //table.grantReadWriteData(lambda);\n\n                    //  Workaround:\n                    // lambda.addToRolePolicy(\n                    //     new PolicyStatement({\n                    //         effect: Effect.ALLOW,\n                    //         actions: CreateDynamoDb.ReadWriteActions,\n                    //         resources: [\n                    //             table.tableArn,\n                    //             `${table.tableArn}/*`, // This is not recognized by cdk, but table is.  why?\n                    //         ],\n                    //     })\n                    // );\n\n                    table.grantReadWriteData(lambda);\n                    \n                    \n                });\n\n            });\n        }\n    }\n\n    private AssignAccessToTableRefs(scope: Construct, tableRefs: TsgDynamoTableRef[] | undefined, lambdas: NodejsFunction[]) {\n\n        if (tableRefs) {\n            tableRefs.forEach((tableRef: TsgDynamoTableRef) => {\n\n                if (tableRef.region) {\n                    this.AssignReadWriteAccessToTableInRegion(scope, tableRef, lambdas);\n                }\n                else {\n                    this.AssignReadWriteAccessToTable(scope, tableRef, lambdas);\n                }\n            });\n        }\n    }\n\n    private AssignReadWriteAccessToTableInRegion(scope: Construct, tableRef: TsgDynamoTableRef, lambdas: NodejsFunction[]) {\n        lambdas.forEach((lambda: NodejsFunction) => {\n\n            let tableArn = \"arn:aws:dynamodb:\" + tableRef.region + \":\" + ((scope as Stack).account) + \":table/\" + tableRef.tableName;\n            let statement = new PolicyStatement({\n                effect: Effect.ALLOW,\n                resources: [\n                    tableArn,\n                    tableArn + \"/index/*\",\n                ],\n                actions: CreateDynamoDb.ReadWriteActions,\n            });\n\n            lambda.role?.addToPrincipalPolicy(statement);\n            \n        });\n    }\n\n    private AssignReadWriteAccessToTable(scope: Construct, tableRef: TsgDynamoTableRef, lambdas: NodejsFunction[]) {\n        let table: ITable = Table.fromTableName(scope, tableRef.tableName, tableRef.tableName);\n\n        lambdas.forEach((lambda: NodejsFunction) => {\n            table.grantReadWriteData(lambda)\n            \n        });\n    }\n\n    private AddRoutes(props: MicroserviceProps, \n        gateway: IRestApi, \n        lambdas: NodejsFunction[], \n        authorizer?: TokenAuthorizer) {\n\n        props.RESOURCES.LAMBDA?.forEach((prop: TsgLambdaProp) => {\n\n            const lambdaId = CreateLambda.getIdForLambda(prop, this.appConfig);\n\n            if (!lambdaId) {\n                throw new Error(`Can't find lambda`);\n            }\n            const lambdaNode = lambdas.find(x => x.node.id === lambdaId);\n\n            if (!lambdaNode) {\n                throw new Error(\"Can't find the Lambda Integration\");                \n            }\n\n            Routes.createResource(prop, gateway, lambdaNode, authorizer);\n        \n        });\n    }\n\n    private AssignAccessToSecretManager(secret: ISecret, lambdas: NodejsFunction[]) {\n\n        lambdas.forEach((lambda) => {\n            const result = secret.grantRead(lambda);\n            \n        });\n        \n    }\n\n}"]}
@@ -1,81 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CreateAuthorizer = void 0;
4
- const aws_cdk_lib_1 = require("aws-cdk-lib");
5
- const aws_apigateway_1 = require("aws-cdk-lib/aws-apigateway");
6
- const aws_iam_1 = require("aws-cdk-lib/aws-iam");
7
- const aws_lambda_nodejs_1 = require("aws-cdk-lib/aws-lambda-nodejs");
8
- const path = require("path");
9
- const baseResource_1 = require("../base/baseResource");
10
- const createLambda_1 = require("../lambda/createLambda");
11
- class CreateAuthorizer extends baseResource_1.BaseResource {
12
- get JwtAuthorizer() {
13
- return this.createdResources[0];
14
- }
15
- constructor(scope, props, authProps) {
16
- super(scope, props);
17
- this.authProps = authProps;
18
- this.createdResources = this.createResource(scope);
19
- if (this.createdResources) {
20
- this.createOutput(scope, this.createdResources);
21
- }
22
- }
23
- createResource(scope) {
24
- return [this.createLambdaAuthorizer(scope, this.authProps)];
25
- }
26
- createLambdaAuthorizer(scope, lambdaConfig) {
27
- //console.log("ENTER createLambdaAuthorizer");
28
- const authorizerProps = this.createLambdaFunctionProps(lambdaConfig);
29
- const lambdaId = createLambda_1.CreateLambda.getIdForLambda(lambdaConfig, this.config);
30
- const lambda = new aws_lambda_nodejs_1.NodejsFunction(scope, lambdaId, authorizerProps);
31
- lambda.grantInvoke(new aws_iam_1.ServicePrincipal('apigateway.amazonaws.com'));
32
- if (lambdaConfig?.managedPolicies && lambdaConfig.managedPolicies.length > 0) {
33
- this.assignManagedPolicies(lambda, lambdaConfig.managedPolicies);
34
- }
35
- const props = {
36
- handler: lambda,
37
- authorizerName: lambdaConfig.name,
38
- resultsCacheTtl: aws_cdk_lib_1.Duration.seconds(0),
39
- identitySource: aws_apigateway_1.IdentitySource.header('Authorization'),
40
- };
41
- const lambdaAuthorizer = new aws_apigateway_1.TokenAuthorizer(scope, `${lambdaConfig.name}-authorizer`, props);
42
- return lambdaAuthorizer;
43
- }
44
- createOutput(scope, createdAssets) {
45
- const entity = createdAssets[0];
46
- // new CfnOutput(scope, `authorizer`, {
47
- // value: (entity as TokenAuthorizer).authorizerArn
48
- // });
49
- }
50
- createLambdaFunctionProps(prop) {
51
- const lambdaProp = {
52
- entry: path.join(prop.codePath),
53
- functionName: prop.name,
54
- handler: prop.handler,
55
- runtime: prop.runtime || this.config.GLOBALS.stackRuntime,
56
- timeout: prop.duration || aws_cdk_lib_1.Duration.minutes(2),
57
- memorySize: prop.memory || 512,
58
- environment: {
59
- "VERBOSE_LOGGING": "true",
60
- ...prop.environment
61
- },
62
- bundling: {
63
- minify: false,
64
- target: 'es2020',
65
- sourceMap: true,
66
- sourceMapMode: aws_lambda_nodejs_1.SourceMapMode.INLINE,
67
- environment: prop.environment || prop.environment,
68
- },
69
- };
70
- return lambdaProp;
71
- }
72
- ;
73
- assignManagedPolicies(lambda, managedPolicyNames) {
74
- managedPolicyNames.forEach((managedPolicyName) => {
75
- let policy = aws_iam_1.ManagedPolicy.fromAwsManagedPolicyName(managedPolicyName);
76
- lambda.role?.addManagedPolicy(policy);
77
- });
78
- }
79
- }
80
- exports.CreateAuthorizer = CreateAuthorizer;
81
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"createAuthorizer.js","sourceRoot":"","sources":["../../../src/resources/helpers/createAuthorizer.ts"],"names":[],"mappings":"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","sourcesContent":["import { CfnOutput, Duration } from \"aws-cdk-lib\";\nimport { IdentitySource, TokenAuthorizer, TokenAuthorizerProps } from \"aws-cdk-lib/aws-apigateway\";\nimport { ManagedPolicy, ServicePrincipal } from \"aws-cdk-lib/aws-iam\";\nimport { NodejsFunction, NodejsFunctionProps, SourceMapMode } from \"aws-cdk-lib/aws-lambda-nodejs\";\nimport { Construct } from \"constructs\";\nimport * as path from 'path';\nimport { AppConfig } from \"../../config/AppConfig\";\n\nimport { TsgLambdaProp } from \"../../config/types\";\nimport { MicroserviceProps } from \"../../interfaces/MicroserviceProps\";\nimport { BaseResource } from \"../base/baseResource\";\nimport { CreateLambda } from \"../lambda/createLambda\";\n\nexport class CreateAuthorizer extends BaseResource<TokenAuthorizer> {\n\n    get JwtAuthorizer() {\n        return this.createdResources[0];\n    }\n\n    constructor(scope: Construct, props: AppConfig, protected authProps: TsgLambdaProp) {\n\n        super(scope, props);\n\n        this.createdResources = this.createResource(scope)!;\n\n        if (this.createdResources) {\n            this.createOutput<TokenAuthorizer>(scope, this.createdResources);\n        }\n\n    }\n\n    protected createResource(scope: Construct): TokenAuthorizer[] | null {\n        return [this.createLambdaAuthorizer(scope, this.authProps)];\n    }\n\n    private createLambdaAuthorizer(scope: Construct, lambdaConfig: TsgLambdaProp) {\n        //console.log(\"ENTER createLambdaAuthorizer\");\n\n        const authorizerProps = this.createLambdaFunctionProps(lambdaConfig!);\n\n        const lambdaId = CreateLambda.getIdForLambda(lambdaConfig, this.config);\n        const lambda = new NodejsFunction(scope, lambdaId, authorizerProps);\n\n        lambda.grantInvoke(new ServicePrincipal('apigateway.amazonaws.com'));\n\n        if (lambdaConfig?.managedPolicies && lambdaConfig.managedPolicies.length > 0) {\n            this.assignManagedPolicies(lambda, lambdaConfig.managedPolicies);\n        }\n\n        const props: TokenAuthorizerProps = {\n            handler: lambda,\n            authorizerName: lambdaConfig.name,\n            resultsCacheTtl: Duration.seconds(0), \n            identitySource: IdentitySource.header('Authorization'),\n            \n        };\n\n        const lambdaAuthorizer = new TokenAuthorizer(scope, `${lambdaConfig.name}-authorizer`, props);\n\n        return lambdaAuthorizer;\n    }\n\n    protected createOutput<T>(scope: Construct, createdAssets: T[]): void {\n\n        const entity = createdAssets[0];\n\n        // new CfnOutput(scope, `authorizer`, {\n        //     value: (entity as TokenAuthorizer).authorizerArn\n        // });\n\n    }\n\n    private createLambdaFunctionProps(prop: TsgLambdaProp) {       \n\n        const lambdaProp: NodejsFunctionProps = {\n            entry: path.join(prop.codePath),\n            functionName: prop.name,\n            handler: prop.handler,\n            runtime: prop.runtime || this.config.GLOBALS.stackRuntime,\n            timeout: prop.duration || Duration.minutes(2),\n            memorySize: prop.memory || 512,\n            environment: {\n                \"VERBOSE_LOGGING\": \"true\",                \n                ...prop.environment\n            },\n            bundling: {\n                minify: false,\n                target: 'es2020',\n                sourceMap: true,\n                sourceMapMode: SourceMapMode.INLINE,\n                environment: prop.environment || prop.environment,\n            },\n        }\n        return lambdaProp;\n    };\n\n    private assignManagedPolicies(lambda: NodejsFunction, managedPolicyNames: string[]) {\n\n        managedPolicyNames.forEach((managedPolicyName: string) => {\n\n            let policy = ManagedPolicy.fromAwsManagedPolicyName(managedPolicyName);\n\n            lambda.role?.addManagedPolicy(policy);\n        });\n\n    }\n\n}"]}
@@ -1,192 +0,0 @@
1
- import { IRestApi, TokenAuthorizer } from "aws-cdk-lib/aws-apigateway";
2
- import { ITable, Table } from "aws-cdk-lib/aws-dynamodb";
3
- import { NodejsFunction } from "aws-cdk-lib/aws-lambda-nodejs";
4
- import { Effect, PolicyStatement } from "aws-cdk-lib/aws-iam";
5
- import { Construct } from "constructs";
6
- import { TsgDynamoTableRef, TsgLambdaProp } from "../../config/types";
7
- import { TsgLambdaProps } from "../../config/types/TsgLambdaProps";
8
- import { MicroserviceProps } from "../../interfaces/MicroserviceProps";
9
- import { CreateAuthorizer } from "../helpers/createAuthorizer";
10
- import { Routes } from "../helpers/createRoutes";
11
- import { CreateLambda } from "../lambda/createLambda";
12
- import { Duration, RemovalPolicy, Stack } from "aws-cdk-lib";
13
- import { CreateDynamoDb } from "../dynamodb/CreateDynamo";
14
- import { ISecret } from "aws-cdk-lib/aws-secretsmanager";
15
- import { LayerVersion } from "aws-cdk-lib/aws-lambda";
16
- import { AppConfig } from "../../config/AppConfig";
17
- import { MetricOptions } from "aws-cdk-lib/aws-cloudwatch";
18
-
19
- export class CreateMicroServiceBundle {
20
-
21
- protected readonly requireDynamoTableRefs: boolean;
22
- protected readonly requireAuthorizer: boolean;
23
-
24
- constructor(scope: Construct,
25
- private readonly gatewayApi: IRestApi,
26
- private readonly props: MicroserviceProps,
27
- private readonly appConfig: AppConfig,
28
- private readonly tables?: Table[],
29
- private readonly secretMgr?: ISecret | null,
30
- private readonly layers?: LayerVersion[],
31
- ) {
32
-
33
- this.requireDynamoTableRefs = (props.RESOURCES.DYNAMO?.TABLE_REFS?.length ?? 0 > 0) ? true : false;
34
- this.requireAuthorizer = (props.RESOURCES.AUTHORIZER) ? true : false;
35
- this.onInit(scope);
36
- }
37
-
38
- private onInit(scope: Construct) {
39
-
40
-
41
- let authorizer: TokenAuthorizer|undefined = undefined;
42
-
43
- // Create Authorizer
44
- if (this.requireAuthorizer) {
45
- authorizer = new CreateAuthorizer(scope, this.appConfig, this.props.RESOURCES.AUTHORIZER!).JwtAuthorizer;
46
- authorizer._attachToApi(this.gatewayApi);
47
- authorizer.applyRemovalPolicy(RemovalPolicy.DESTROY);
48
- }
49
-
50
- // Create Lambdas
51
- const lambdaProp: TsgLambdaProps = {
52
- scope,
53
- prop: this.props,
54
- layers: this.layers,
55
- appConfig: this.appConfig
56
- };
57
-
58
- const lambdas = new CreateLambda(lambdaProp, this.appConfig);
59
-
60
- if (this.tables) {
61
- this.AssignAccessToTables(this.tables, lambdas.Lambdas);
62
- }
63
-
64
- // Allow access to existing tables
65
- // if (this.requireDynamoTableRefs) {
66
- // this.AssignAccessToTableRefs(scope, this.props.RESOURCES.DYNAMO?.TABLE_REFS, lambdas.Lambdas);
67
- // }
68
-
69
- if (this.secretMgr) {
70
- this.AssignAccessToSecretManager(this.secretMgr, lambdas.Lambdas);
71
- }
72
-
73
- // lambdas.Lambdas.map((lambda) => {
74
- // lambda.metricErrors({
75
- // label: `${lambda.functionName}-errors`,
76
- // period: Duration.minutes(3)
77
-
78
- // })
79
- // });
80
-
81
- this.AddRoutes(this.props, this.gatewayApi, lambdas.Lambdas, authorizer);
82
- }
83
-
84
- private AssignAccessToTables(tables: Table[], lambdas: NodejsFunction[]) {
85
-
86
- if (tables) {
87
- lambdas.forEach((lambda: NodejsFunction) => {
88
-
89
- tables.forEach((table: ITable) => {
90
-
91
-
92
-
93
- // This is a CDK bug: It doesn't provide
94
- // access to the indexes.
95
- //table.grantReadWriteData(lambda);
96
-
97
- // Workaround:
98
- // lambda.addToRolePolicy(
99
- // new PolicyStatement({
100
- // effect: Effect.ALLOW,
101
- // actions: CreateDynamoDb.ReadWriteActions,
102
- // resources: [
103
- // table.tableArn,
104
- // `${table.tableArn}/*`, // This is not recognized by cdk, but table is. why?
105
- // ],
106
- // })
107
- // );
108
-
109
- table.grantReadWriteData(lambda);
110
-
111
-
112
- });
113
-
114
- });
115
- }
116
- }
117
-
118
- private AssignAccessToTableRefs(scope: Construct, tableRefs: TsgDynamoTableRef[] | undefined, lambdas: NodejsFunction[]) {
119
-
120
- if (tableRefs) {
121
- tableRefs.forEach((tableRef: TsgDynamoTableRef) => {
122
-
123
- if (tableRef.region) {
124
- this.AssignReadWriteAccessToTableInRegion(scope, tableRef, lambdas);
125
- }
126
- else {
127
- this.AssignReadWriteAccessToTable(scope, tableRef, lambdas);
128
- }
129
- });
130
- }
131
- }
132
-
133
- private AssignReadWriteAccessToTableInRegion(scope: Construct, tableRef: TsgDynamoTableRef, lambdas: NodejsFunction[]) {
134
- lambdas.forEach((lambda: NodejsFunction) => {
135
-
136
- let tableArn = "arn:aws:dynamodb:" + tableRef.region + ":" + ((scope as Stack).account) + ":table/" + tableRef.tableName;
137
- let statement = new PolicyStatement({
138
- effect: Effect.ALLOW,
139
- resources: [
140
- tableArn,
141
- tableArn + "/index/*",
142
- ],
143
- actions: CreateDynamoDb.ReadWriteActions,
144
- });
145
-
146
- lambda.role?.addToPrincipalPolicy(statement);
147
-
148
- });
149
- }
150
-
151
- private AssignReadWriteAccessToTable(scope: Construct, tableRef: TsgDynamoTableRef, lambdas: NodejsFunction[]) {
152
- let table: ITable = Table.fromTableName(scope, tableRef.tableName, tableRef.tableName);
153
-
154
- lambdas.forEach((lambda: NodejsFunction) => {
155
- table.grantReadWriteData(lambda)
156
-
157
- });
158
- }
159
-
160
- private AddRoutes(props: MicroserviceProps,
161
- gateway: IRestApi,
162
- lambdas: NodejsFunction[],
163
- authorizer?: TokenAuthorizer) {
164
-
165
- props.RESOURCES.LAMBDA?.forEach((prop: TsgLambdaProp) => {
166
-
167
- const lambdaId = CreateLambda.getIdForLambda(prop, this.appConfig);
168
-
169
- if (!lambdaId) {
170
- throw new Error(`Can't find lambda`);
171
- }
172
- const lambdaNode = lambdas.find(x => x.node.id === lambdaId);
173
-
174
- if (!lambdaNode) {
175
- throw new Error("Can't find the Lambda Integration");
176
- }
177
-
178
- Routes.createResource(prop, gateway, lambdaNode, authorizer);
179
-
180
- });
181
- }
182
-
183
- private AssignAccessToSecretManager(secret: ISecret, lambdas: NodejsFunction[]) {
184
-
185
- lambdas.forEach((lambda) => {
186
- const result = secret.grantRead(lambda);
187
-
188
- });
189
-
190
- }
191
-
192
- }