@sylvesterllc/aws-constructs 1.0.0
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/.github/workflows/publish.yml +36 -0
- package/dist/config/AppConfig.d.ts +24 -0
- package/dist/config/AppConfig.js +62 -0
- package/dist/config/Constants.d.ts +26 -0
- package/dist/config/Constants.js +30 -0
- package/dist/config/Environments.d.ts +2 -0
- package/dist/config/Environments.js +3 -0
- package/dist/config/MicroserviceAppConfig.d.ts +5 -0
- package/dist/config/MicroserviceAppConfig.js +11 -0
- package/dist/config/bishopConfig.d.ts +2 -0
- package/dist/config/bishopConfig.js +81 -0
- package/dist/config/customConfigs/ApiAppConfig.d.ts +5 -0
- package/dist/config/customConfigs/ApiAppConfig.js +4 -0
- package/dist/config/customConfigs/GlobalAppConfig.d.ts +8 -0
- package/dist/config/customConfigs/GlobalAppConfig.js +3 -0
- package/dist/config/customConfigs/IAppConfig.d.ts +10 -0
- package/dist/config/customConfigs/IAppConfig.js +3 -0
- package/dist/config/customConfigs/ResourceAppConfig.d.ts +8 -0
- package/dist/config/customConfigs/ResourceAppConfig.js +3 -0
- package/dist/config/microServiceConfig.d.ts +2 -0
- package/dist/config/microServiceConfig.js +82 -0
- package/dist/config/types/TsgCdkConfigType.d.ts +3 -0
- package/dist/config/types/TsgCdkConfigType.js +3 -0
- package/dist/config/types/TsgCognitoConfig.d.ts +5 -0
- package/dist/config/types/TsgCognitoConfig.js +3 -0
- package/dist/config/types/TsgDnsConfig.d.ts +9 -0
- package/dist/config/types/TsgDnsConfig.js +3 -0
- package/dist/config/types/TsgDynamoDbProp.d.ts +6 -0
- package/dist/config/types/TsgDynamoDbProp.js +3 -0
- package/dist/config/types/TsgDynamoIndex.d.ts +13 -0
- package/dist/config/types/TsgDynamoIndex.js +3 -0
- package/dist/config/types/TsgDynamoProp.d.ts +15 -0
- package/dist/config/types/TsgDynamoProp.js +3 -0
- package/dist/config/types/TsgDynamoTable.d.ts +4 -0
- package/dist/config/types/TsgDynamoTable.js +3 -0
- package/dist/config/types/TsgDynamoTableRef.d.ts +4 -0
- package/dist/config/types/TsgDynamoTableRef.js +3 -0
- package/dist/config/types/TsgLambda.d.ts +4 -0
- package/dist/config/types/TsgLambda.js +3 -0
- package/dist/config/types/TsgLambdaLayerProp.d.ts +5 -0
- package/dist/config/types/TsgLambdaLayerProp.js +3 -0
- package/dist/config/types/TsgLambdaMap.d.ts +3 -0
- package/dist/config/types/TsgLambdaMap.js +3 -0
- package/dist/config/types/TsgLambdaName.d.ts +1 -0
- package/dist/config/types/TsgLambdaName.js +3 -0
- package/dist/config/types/TsgLambdaNode.d.ts +3 -0
- package/dist/config/types/TsgLambdaNode.js +3 -0
- package/dist/config/types/TsgLambdaProp.d.ts +16 -0
- package/dist/config/types/TsgLambdaProp.js +3 -0
- package/dist/config/types/TsgLambdaProps.d.ts +16 -0
- package/dist/config/types/TsgLambdaProps.js +3 -0
- package/dist/config/types/TsgLambdaRoutable.d.ts +6 -0
- package/dist/config/types/TsgLambdaRoutable.js +3 -0
- package/dist/config/types/index.d.ts +8 -0
- package/dist/config/types/index.js +25 -0
- package/dist/constructs/MicroService.d.ts +12 -0
- package/dist/constructs/MicroService.js +47 -0
- package/dist/constructs/index.d.ts +1 -0
- package/dist/constructs/index.js +6 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.js +8 -0
- package/dist/interfaces/CreateLambdaFunctionInput.d.ts +10 -0
- package/dist/interfaces/CreateLambdaFunctionInput.js +3 -0
- package/dist/interfaces/MicroserviceProps.d.ts +10 -0
- package/dist/interfaces/MicroserviceProps.js +3 -0
- package/dist/resources/base/baseResource.d.ts +10 -0
- package/dist/resources/base/baseResource.js +11 -0
- package/dist/resources/certificate/createCertificate.d.ts +9 -0
- package/dist/resources/certificate/createCertificate.js +29 -0
- package/dist/resources/cognito/createCognito.d.ts +7 -0
- package/dist/resources/cognito/createCognito.js +35 -0
- package/dist/resources/cognito/createCognitoProps.d.ts +2 -0
- package/dist/resources/cognito/createCognitoProps.js +47 -0
- package/dist/resources/dynamodb/CreateDynamo.d.ts +15 -0
- package/dist/resources/dynamodb/CreateDynamo.js +87 -0
- package/dist/resources/gateway/createApi.d.ts +19 -0
- package/dist/resources/gateway/createApi.js +104 -0
- package/dist/resources/gateway/createMicroServiceBundle.d.ts +25 -0
- package/dist/resources/gateway/createMicroServiceBundle.js +126 -0
- package/dist/resources/helpers/createAuthorizer.d.ts +15 -0
- package/dist/resources/helpers/createAuthorizer.js +80 -0
- package/dist/resources/helpers/createCommonLayer.d.ts +3 -0
- package/dist/resources/helpers/createCommonLayer.js +15 -0
- package/dist/resources/helpers/createRoutes.d.ts +8 -0
- package/dist/resources/helpers/createRoutes.js +30 -0
- package/dist/resources/lambda/createLambda.d.ts +20 -0
- package/dist/resources/lambda/createLambda.js +135 -0
- package/dist/resources/lambda-layer/createLambdaLayer.d.ts +5 -0
- package/dist/resources/lambda-layer/createLambdaLayer.js +31 -0
- package/dist/resources/layers/common/src/nodejs/api-response/index.d.ts +1 -0
- package/dist/resources/layers/common/src/nodejs/api-response/index.js +18 -0
- package/dist/resources/layers/common/src/nodejs/api-response/responses.d.ts +24 -0
- package/dist/resources/layers/common/src/nodejs/api-response/responses.js +43 -0
- package/dist/resources/layers/common/src/nodejs/index.d.ts +2 -0
- package/dist/resources/layers/common/src/nodejs/index.js +19 -0
- package/dist/resources/layers/common/src/nodejs/logger/IContext.d.ts +5 -0
- package/dist/resources/layers/common/src/nodejs/logger/IContext.js +3 -0
- package/dist/resources/layers/common/src/nodejs/logger/index.d.ts +2 -0
- package/dist/resources/layers/common/src/nodejs/logger/index.js +19 -0
- package/dist/resources/layers/common/src/nodejs/logger/logger.d.ts +2 -0
- package/dist/resources/layers/common/src/nodejs/logger/logger.js +12 -0
- package/dist/resources/resources/iam/policyDocuments/cognitoPolicy.d.ts +4 -0
- package/dist/resources/resources/iam/policyDocuments/cognitoPolicy.js +52 -0
- package/dist/resources/resources/iam/roles/createRole.d.ts +4 -0
- package/dist/resources/resources/iam/roles/createRole.js +22 -0
- package/dist/resources/route53/CreateZone.d.ts +0 -0
- package/dist/resources/route53/CreateZone.js +47 -0
- package/dist/resources/route53/create-zones.d.ts +0 -0
- package/dist/resources/route53/create-zones.js +30 -0
- package/dist/resources/securityManager/index.d.ts +4 -0
- package/dist/resources/securityManager/index.js +18 -0
- package/docs/lambda-config.md +1 -0
- package/package.json +48 -0
- package/readme.md +147 -0
- package/src/config/AppConfig.ts +93 -0
- package/src/config/Constants.ts +27 -0
- package/src/config/Environments.ts +2 -0
- package/src/config/MicroserviceAppConfig.ts +9 -0
- package/src/config/bishopConfig.ts +83 -0
- package/src/config/customConfigs/ApiAppConfig.ts +6 -0
- package/src/config/customConfigs/GlobalAppConfig.ts +11 -0
- package/src/config/customConfigs/IAppConfig.ts +13 -0
- package/src/config/customConfigs/ResourceAppConfig.ts +12 -0
- package/src/config/microServiceConfig.ts +85 -0
- package/src/config/types/TsgCdkConfigType.ts +3 -0
- package/src/config/types/TsgCognitoConfig.ts +6 -0
- package/src/config/types/TsgDnsConfig.ts +9 -0
- package/src/config/types/TsgDynamoDbProp.ts +7 -0
- package/src/config/types/TsgDynamoIndex.ts +16 -0
- package/src/config/types/TsgDynamoProp.ts +17 -0
- package/src/config/types/TsgDynamoTable.ts +5 -0
- package/src/config/types/TsgDynamoTableRef.ts +4 -0
- package/src/config/types/TsgLambda.ts +6 -0
- package/src/config/types/TsgLambdaLayerProp.ts +5 -0
- package/src/config/types/TsgLambdaMap.ts +4 -0
- package/src/config/types/TsgLambdaName.ts +4 -0
- package/src/config/types/TsgLambdaNode.ts +4 -0
- package/src/config/types/TsgLambdaProp.ts +16 -0
- package/src/config/types/TsgLambdaProps.ts +19 -0
- package/src/config/types/TsgLambdaRoutable.ts +6 -0
- package/src/config/types/index.ts +9 -0
- package/src/constructs/MicroService.ts +68 -0
- package/src/constructs/index.ts +1 -0
- package/src/index.ts +4 -0
- package/src/interfaces/CreateLambdaFunctionInput.ts +11 -0
- package/src/interfaces/MicroserviceProps.ts +11 -0
- package/src/resources/.gitkeep +0 -0
- package/src/resources/base/baseResource.ts +15 -0
- package/src/resources/certificate/createCertificate.ts +40 -0
- package/src/resources/cicd/.gitkeep +0 -0
- package/src/resources/cognito/.gitkeep +0 -0
- package/src/resources/cognito/createCognito.ts +47 -0
- package/src/resources/cognito/createCognitoProps.ts +46 -0
- package/src/resources/dynamodb/CreateDynamo.ts +111 -0
- package/src/resources/gateway/createApi.ts +138 -0
- package/src/resources/gateway/createMicroServiceBundle.ts +183 -0
- package/src/resources/helpers/createAuthorizer.ts +106 -0
- package/src/resources/helpers/createCommonLayer.ts +18 -0
- package/src/resources/helpers/createRoutes.ts +43 -0
- package/src/resources/lambda/createLambda.ts +184 -0
- package/src/resources/lambda-layer/createLambdaLayer.ts +40 -0
- package/src/resources/layers/common/package.json +22 -0
- package/src/resources/layers/common/src/nodejs/api-response/index.ts +1 -0
- package/src/resources/layers/common/src/nodejs/api-response/responses.ts +41 -0
- package/src/resources/layers/common/src/nodejs/index.ts +3 -0
- package/src/resources/layers/common/src/nodejs/logger/IContext.ts +7 -0
- package/src/resources/layers/common/src/nodejs/logger/index.ts +2 -0
- package/src/resources/layers/common/src/nodejs/logger/logger.ts +11 -0
- package/src/resources/layers/common/tsconfig.json +7 -0
- package/src/resources/resources/iam/policyDocuments/cognitoPolicy.ts +55 -0
- package/src/resources/resources/iam/roles/createRole.ts +30 -0
- package/src/resources/route53/CreateZone.ts +62 -0
- package/src/resources/route53/create-zones.ts +41 -0
- package/src/resources/securityManager/index.ts +24 -0
- package/tsconfig.json +40 -0
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Api = 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_route53_1 = require("aws-cdk-lib/aws-route53");
|
|
7
|
+
const aws_route53_targets_1 = require("aws-cdk-lib/aws-route53-targets");
|
|
8
|
+
const baseResource_1 = require("../base/baseResource");
|
|
9
|
+
const createCertificate_1 = require("../certificate/createCertificate");
|
|
10
|
+
class Api extends baseResource_1.BaseResource {
|
|
11
|
+
get APIs() {
|
|
12
|
+
return this.createdResources;
|
|
13
|
+
}
|
|
14
|
+
constructor(scope, config) {
|
|
15
|
+
super(scope, config);
|
|
16
|
+
this.corsOptions = this.createDefaultCorsOptions();
|
|
17
|
+
this.createdResources = this.createResource(scope);
|
|
18
|
+
}
|
|
19
|
+
createApi(scope) {
|
|
20
|
+
const zone = this.getZone(this.scope, this.config);
|
|
21
|
+
const api = new aws_apigateway_1.RestApi(this.scope, `${this.config.AppPrefix}-rest-api`, this.createApiProps(zone));
|
|
22
|
+
this.createARecord(scope, zone, api);
|
|
23
|
+
return api;
|
|
24
|
+
}
|
|
25
|
+
createApiProps(zone) {
|
|
26
|
+
const cert = this.createCertificate(this.scope, zone, this.config);
|
|
27
|
+
const props = {
|
|
28
|
+
restApiName: `gs-api-${this.config.AppPrefix}-${this.config.API.Name}`,
|
|
29
|
+
description: this.config.API.Description,
|
|
30
|
+
domainName: {
|
|
31
|
+
domainName: `${this.config.API.DomainPrefix}.${this.config.DNS.ZoneName}`,
|
|
32
|
+
certificate: cert.certificate,
|
|
33
|
+
endpointType: aws_apigateway_1.EndpointType.EDGE,
|
|
34
|
+
securityPolicy: aws_apigateway_1.SecurityPolicy.TLS_1_2
|
|
35
|
+
},
|
|
36
|
+
// TODO: ADD CUSTOM DOMAIN HERE
|
|
37
|
+
// defaultDomainMapping: {
|
|
38
|
+
// domainName: domain,
|
|
39
|
+
// },
|
|
40
|
+
// domainName: '',
|
|
41
|
+
defaultCorsPreflightOptions: this.corsOptions
|
|
42
|
+
};
|
|
43
|
+
return props;
|
|
44
|
+
}
|
|
45
|
+
createDefaultCorsOptions() {
|
|
46
|
+
const corsOptions = {
|
|
47
|
+
allowHeaders: [
|
|
48
|
+
'*',
|
|
49
|
+
],
|
|
50
|
+
allowMethods: aws_apigateway_1.Cors.ALL_METHODS,
|
|
51
|
+
allowCredentials: true,
|
|
52
|
+
allowOrigins: aws_apigateway_1.Cors.ALL_ORIGINS,
|
|
53
|
+
};
|
|
54
|
+
return corsOptions;
|
|
55
|
+
}
|
|
56
|
+
createCustomDomain(scope, config) {
|
|
57
|
+
const domainName = aws_apigateway_1.DomainName.fromDomainNameAttributes(scope, `${config.API.Name}-custom-domain`, {
|
|
58
|
+
domainName: config.DNS.ZoneName,
|
|
59
|
+
domainNameAliasHostedZoneId: config.DNS.ZoneId,
|
|
60
|
+
domainNameAliasTarget: config.API.DomainPrefix,
|
|
61
|
+
});
|
|
62
|
+
return domainName;
|
|
63
|
+
}
|
|
64
|
+
attachDomainToApi(scope, api, domain, config) {
|
|
65
|
+
return new aws_apigateway_1.BasePathMapping(scope, `${config.API.Name}-basePathMapping`, {
|
|
66
|
+
domainName: domain,
|
|
67
|
+
restApi: api,
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
getZone(scope, config) {
|
|
71
|
+
return aws_route53_1.HostedZone.fromHostedZoneAttributes(scope, `${config.DNS.ZoneName}-zone`, {
|
|
72
|
+
zoneName: config.DNS.ZoneName,
|
|
73
|
+
hostedZoneId: config.DNS.ZoneId
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
createCertificate(scope, zone, config) {
|
|
77
|
+
const cert = new createCertificate_1.CreateCertificate(scope, config, zone);
|
|
78
|
+
return cert;
|
|
79
|
+
}
|
|
80
|
+
createARecord(scope, zone, api) {
|
|
81
|
+
return new aws_route53_1.ARecord(scope, "ApiRecord", {
|
|
82
|
+
zone,
|
|
83
|
+
target: aws_route53_1.RecordTarget.fromAlias(new aws_route53_targets_1.ApiGateway(api)),
|
|
84
|
+
recordName: this.config.API.DomainPrefix
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
createResource(scope) {
|
|
88
|
+
const api = this.createApi(scope);
|
|
89
|
+
// TODO: ONLY IF CUSTOM MAPPING IS REQUIRED
|
|
90
|
+
// const domain = this.createCustomDomain(scope, this.config);
|
|
91
|
+
// const mapping = this.attachDomainToApi(scope, api, domain, this.config);
|
|
92
|
+
return [api];
|
|
93
|
+
}
|
|
94
|
+
createOutput(scope, createdAssets) {
|
|
95
|
+
createdAssets.forEach((api, idx) => {
|
|
96
|
+
new aws_cdk_lib_1.CfnOutput(scope, `api${idx}`, {
|
|
97
|
+
// @ts-ignore
|
|
98
|
+
value: api.url
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
exports.Api = Api;
|
|
104
|
+
//# 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, 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\";\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        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        return api;\n    }\n\n    private createApiProps(zone: IHostedZone): RestApiProps {\n        \n        const cert = this.createCertificate(this.scope, zone, this.config);\n\n        const props: RestApiProps = {\n            restApiName: `gs-api-${this.config.AppPrefix}-${this.config.API.Name}`, \n            description: this.config.API.Description,\n            domainName: {\n                domainName: `${this.config.API.DomainPrefix}.${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    }\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 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        return cert;\n    }\n\n    private createARecord(scope: Construct, zone: IHostedZone, api: RestApi) {\n        return new ARecord(scope, \"ApiRecord\", {\n            zone,\n            target: RecordTarget.fromAlias(new ApiGateway(api)),\n            recordName: this.config.API.DomainPrefix\n        });\n            \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}"]}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { IRestApi } from "aws-cdk-lib/aws-apigateway";
|
|
2
|
+
import { Table } from "aws-cdk-lib/aws-dynamodb";
|
|
3
|
+
import { Construct } from "constructs";
|
|
4
|
+
import { MicroserviceProps } from "../../interfaces/MicroserviceProps";
|
|
5
|
+
import { ISecret } from "aws-cdk-lib/aws-secretsmanager";
|
|
6
|
+
import { LayerVersion } from "aws-cdk-lib/aws-lambda";
|
|
7
|
+
import { AppConfig } from "../../config/AppConfig";
|
|
8
|
+
export declare class CreateMicroServiceBundle {
|
|
9
|
+
private readonly gatewayApi;
|
|
10
|
+
private readonly props;
|
|
11
|
+
private readonly appConfig;
|
|
12
|
+
private readonly tables?;
|
|
13
|
+
private readonly secretMgr?;
|
|
14
|
+
private readonly layers?;
|
|
15
|
+
protected readonly requireDynamoTableRefs: boolean;
|
|
16
|
+
protected readonly requireAuthorizer: boolean;
|
|
17
|
+
constructor(scope: Construct, gatewayApi: IRestApi, props: MicroserviceProps, appConfig: AppConfig, tables?: Table[] | undefined, secretMgr?: ISecret | undefined, layers?: LayerVersion[] | undefined);
|
|
18
|
+
private onInit;
|
|
19
|
+
private AssignAccessToTables;
|
|
20
|
+
private AssignAccessToTableRefs;
|
|
21
|
+
private AssignReadWriteAccessToTableInRegion;
|
|
22
|
+
private AssignReadWriteAccessToTable;
|
|
23
|
+
private AddRoutes;
|
|
24
|
+
private AssignAccessToSecretManager;
|
|
25
|
+
}
|
|
@@ -0,0 +1,126 @@
|
|
|
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
|
+
//console.log("ENTER CreateMicroServiceBundle.onInit");
|
|
25
|
+
let authorizer = undefined;
|
|
26
|
+
// Create Authorizer
|
|
27
|
+
if (this.requireAuthorizer) {
|
|
28
|
+
authorizer = new createAuthorizer_1.CreateAuthorizer(scope, this.appConfig, this.props.RESOURCES.AUTHORIZER).JwtAuthorizer;
|
|
29
|
+
}
|
|
30
|
+
// Create Lambdas
|
|
31
|
+
const lambdaProp = {
|
|
32
|
+
scope,
|
|
33
|
+
prop: this.props,
|
|
34
|
+
layers: this.layers,
|
|
35
|
+
appConfig: this.appConfig
|
|
36
|
+
};
|
|
37
|
+
const lambdas = new createLambda_1.CreateLambda(lambdaProp, this.appConfig);
|
|
38
|
+
if (this.tables) {
|
|
39
|
+
this.AssignAccessToTables(this.tables, lambdas.Lambdas);
|
|
40
|
+
}
|
|
41
|
+
// Allow access to existing tables
|
|
42
|
+
if (this.requireDynamoTableRefs) {
|
|
43
|
+
this.AssignAccessToTableRefs(scope, this.props.RESOURCES.DYNAMO?.TABLE_REFS, lambdas.Lambdas);
|
|
44
|
+
}
|
|
45
|
+
if (this.secretMgr) {
|
|
46
|
+
this.AssignAccessToSecretManager(this.secretMgr, lambdas.Lambdas);
|
|
47
|
+
}
|
|
48
|
+
lambdas.Lambdas.map((lambda) => {
|
|
49
|
+
lambda.metricErrors({
|
|
50
|
+
label: `${lambda.functionName}-errors`,
|
|
51
|
+
period: aws_cdk_lib_1.Duration.minutes(3)
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
this.AddRoutes(this.props, this.gatewayApi, lambdas.Lambdas, authorizer);
|
|
55
|
+
}
|
|
56
|
+
AssignAccessToTables(tables, lambdas) {
|
|
57
|
+
if (tables) {
|
|
58
|
+
tables.forEach((table) => {
|
|
59
|
+
lambdas.forEach((lambda) => {
|
|
60
|
+
// This is a CDK bug: It doesn't provide
|
|
61
|
+
// access to the indexes.
|
|
62
|
+
//table.grantReadWriteData(lambda);
|
|
63
|
+
// Workaround:
|
|
64
|
+
lambda.addToRolePolicy(new aws_iam_1.PolicyStatement({
|
|
65
|
+
effect: aws_iam_1.Effect.ALLOW,
|
|
66
|
+
actions: CreateDynamo_1.CreateDynamoDb.ReadWriteActions,
|
|
67
|
+
resources: [
|
|
68
|
+
table.tableArn,
|
|
69
|
+
`${table.tableArn}/*`, // This is not recognized by cdk, but table is. why?
|
|
70
|
+
],
|
|
71
|
+
}));
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
AssignAccessToTableRefs(scope, tableRefs, lambdas) {
|
|
77
|
+
if (tableRefs) {
|
|
78
|
+
tableRefs.forEach((tableRef) => {
|
|
79
|
+
if (tableRef.region) {
|
|
80
|
+
this.AssignReadWriteAccessToTableInRegion(scope, tableRef, lambdas);
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
this.AssignReadWriteAccessToTable(scope, tableRef, lambdas);
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
AssignReadWriteAccessToTableInRegion(scope, tableRef, lambdas) {
|
|
89
|
+
lambdas.forEach((lambda) => {
|
|
90
|
+
let tableArn = "arn:aws:dynamodb:" + tableRef.region + ":" + (scope.account) + ":table/" + tableRef.tableName;
|
|
91
|
+
let statement = new aws_iam_1.PolicyStatement({
|
|
92
|
+
effect: aws_iam_1.Effect.ALLOW,
|
|
93
|
+
resources: [
|
|
94
|
+
tableArn,
|
|
95
|
+
tableArn + "/index/*",
|
|
96
|
+
],
|
|
97
|
+
actions: CreateDynamo_1.CreateDynamoDb.ReadWriteActions,
|
|
98
|
+
});
|
|
99
|
+
lambda.role?.addToPrincipalPolicy(statement);
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
AssignReadWriteAccessToTable(scope, tableRef, lambdas) {
|
|
103
|
+
let table = aws_dynamodb_1.Table.fromTableName(scope, tableRef.tableName, tableRef.tableName);
|
|
104
|
+
lambdas.forEach((lambda) => {
|
|
105
|
+
table.grantReadWriteData(lambda);
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
AddRoutes(props, gateway, lambdas, authorizer) {
|
|
109
|
+
this.appConfig.lambdaConfigs?.forEach((prop) => {
|
|
110
|
+
const lambdaId = createLambda_1.CreateLambda.getIdForLambda(prop);
|
|
111
|
+
const lambdaNode = lambdas.find(x => x.node.id === lambdaId);
|
|
112
|
+
if (!lambdaNode) {
|
|
113
|
+
throw new Error("Can't find the Lambda Integration");
|
|
114
|
+
}
|
|
115
|
+
createRoutes_1.Routes.createResource(prop, gateway, lambdaNode, authorizer);
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
AssignAccessToSecretManager(secret, lambdas) {
|
|
119
|
+
lambdas.forEach((lambda) => {
|
|
120
|
+
const result = secret.grantRead(lambda);
|
|
121
|
+
console.log('Assigning Access to Secret Manager: ', result);
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
exports.CreateMicroServiceBundle = CreateMicroServiceBundle;
|
|
126
|
+
//# 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, 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, \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        //console.log(\"ENTER CreateMicroServiceBundle.onInit\");\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        }        \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            tables.forEach((table: ITable) => {\n\n                lambdas.forEach((lambda: NodejsFunction) => {\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                    \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        this.appConfig.lambdaConfigs?.forEach((prop: TsgLambdaProp) => {\n\n            const lambdaId = CreateLambda.getIdForLambda(prop);\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            console.log('Assigning Access to Secret Manager: ',result);\n        });\n        \n    }\n\n}"]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { TokenAuthorizer } from "aws-cdk-lib/aws-apigateway";
|
|
2
|
+
import { Construct } from "constructs";
|
|
3
|
+
import { AppConfig } from "../../config/AppConfig";
|
|
4
|
+
import { TsgLambdaProp } from "../../config/types";
|
|
5
|
+
import { BaseResource } from "../base/baseResource";
|
|
6
|
+
export declare class CreateAuthorizer extends BaseResource<TokenAuthorizer> {
|
|
7
|
+
protected authProps: TsgLambdaProp;
|
|
8
|
+
get JwtAuthorizer(): TokenAuthorizer;
|
|
9
|
+
constructor(scope: Construct, props: AppConfig, authProps: TsgLambdaProp);
|
|
10
|
+
protected createResource(scope: Construct): TokenAuthorizer[] | null;
|
|
11
|
+
private createLambdaAuthorizer;
|
|
12
|
+
protected createOutput<T>(scope: Construct, createdAssets: T[]): void;
|
|
13
|
+
private createLambdaFunctionProps;
|
|
14
|
+
private assignManagedPolicies;
|
|
15
|
+
}
|
|
@@ -0,0 +1,80 @@
|
|
|
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);
|
|
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 lambdaAuthorizer = new aws_apigateway_1.TokenAuthorizer(scope, `${lambdaConfig.name}-authorizer`, {
|
|
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
|
+
return lambdaAuthorizer;
|
|
42
|
+
}
|
|
43
|
+
createOutput(scope, createdAssets) {
|
|
44
|
+
const entity = createdAssets[0];
|
|
45
|
+
// new CfnOutput(scope, `authorizer`, {
|
|
46
|
+
// value: (entity as TokenAuthorizer).authorizerArn
|
|
47
|
+
// });
|
|
48
|
+
}
|
|
49
|
+
createLambdaFunctionProps(prop) {
|
|
50
|
+
const lambdaProp = {
|
|
51
|
+
entry: path.join(prop.codePath),
|
|
52
|
+
functionName: prop.name,
|
|
53
|
+
handler: prop.handler,
|
|
54
|
+
runtime: prop.runtime || this.config.GLOBALS.stackRuntime,
|
|
55
|
+
timeout: prop.duration || aws_cdk_lib_1.Duration.minutes(2),
|
|
56
|
+
memorySize: prop.memory || 512,
|
|
57
|
+
environment: {
|
|
58
|
+
"VERBOSE_LOGGING": "true",
|
|
59
|
+
...prop.environment
|
|
60
|
+
},
|
|
61
|
+
bundling: {
|
|
62
|
+
minify: false,
|
|
63
|
+
target: 'es2020',
|
|
64
|
+
sourceMap: true,
|
|
65
|
+
sourceMapMode: aws_lambda_nodejs_1.SourceMapMode.INLINE,
|
|
66
|
+
environment: prop.environment || prop.environment,
|
|
67
|
+
},
|
|
68
|
+
};
|
|
69
|
+
return lambdaProp;
|
|
70
|
+
}
|
|
71
|
+
;
|
|
72
|
+
assignManagedPolicies(lambda, managedPolicyNames) {
|
|
73
|
+
managedPolicyNames.forEach((managedPolicyName) => {
|
|
74
|
+
let policy = aws_iam_1.ManagedPolicy.fromAwsManagedPolicyName(managedPolicyName);
|
|
75
|
+
lambda.role?.addManagedPolicy(policy);
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
exports.CreateAuthorizer = CreateAuthorizer;
|
|
80
|
+
//# 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 } 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);\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 lambdaAuthorizer = new TokenAuthorizer(scope, `${lambdaConfig.name}-authorizer`, {\n            handler: lambda,\n            authorizerName: lambdaConfig.name,\n            resultsCacheTtl: Duration.seconds(0), \n            identitySource: IdentitySource.header('Authorization'),\n            \n        });\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}"]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createCommonLayer = void 0;
|
|
4
|
+
const createLambdaLayer_1 = require("../lambda-layer/createLambdaLayer");
|
|
5
|
+
const createCommonLayer = (scope, appProps) => {
|
|
6
|
+
const prop = {
|
|
7
|
+
description: 'Common Lambda layer',
|
|
8
|
+
codePath: './node_modules/@davissylvester/bishop-cdk-constructs/dist',
|
|
9
|
+
name: 'bishop-common-layer'
|
|
10
|
+
};
|
|
11
|
+
const layer = (0, createLambdaLayer_1.createLambdaLayer)(scope, appProps, prop);
|
|
12
|
+
return layer;
|
|
13
|
+
};
|
|
14
|
+
exports.createCommonLayer = createCommonLayer;
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlQ29tbW9uTGF5ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcmVzb3VyY2VzL2hlbHBlcnMvY3JlYXRlQ29tbW9uTGF5ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EseUVBQXNFO0FBSS9ELE1BQU0saUJBQWlCLEdBQUcsQ0FBQyxLQUFnQixFQUFFLFFBQW1CLEVBQUUsRUFBRTtJQUV2RSxNQUFNLElBQUksR0FBdUI7UUFDN0IsV0FBVyxFQUFFLHFCQUFxQjtRQUNsQyxRQUFRLEVBQUUsMkRBQTJEO1FBQ3JFLElBQUksRUFBRSxxQkFBcUI7S0FDOUIsQ0FBQztJQUVGLE1BQU0sS0FBSyxHQUFHLElBQUEscUNBQWlCLEVBQUMsS0FBSyxFQUFFLFFBQVEsRUFBRSxJQUFJLENBQUMsQ0FBQTtJQUV0RCxPQUFPLEtBQUssQ0FBQztBQUNqQixDQUFDLENBQUM7QUFYVyxRQUFBLGlCQUFpQixxQkFXNUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tIFwiY29uc3RydWN0c1wiO1xuaW1wb3J0IHsgY3JlYXRlTGFtYmRhTGF5ZXIgfSBmcm9tIFwiLi4vbGFtYmRhLWxheWVyL2NyZWF0ZUxhbWJkYUxheWVyXCI7XG5pbXBvcnQgeyBUc2dMYW1iZGFMYXllclByb3AgfSBmcm9tIFwiLi4vLi4vY29uZmlnL3R5cGVzL1RzZ0xhbWJkYUxheWVyUHJvcFwiO1xuaW1wb3J0IHsgQXBwQ29uZmlnIH0gZnJvbSBcIi4uLy4uL2NvbmZpZy9BcHBDb25maWdcIjtcblxuZXhwb3J0IGNvbnN0IGNyZWF0ZUNvbW1vbkxheWVyID0gKHNjb3BlOiBDb25zdHJ1Y3QsIGFwcFByb3BzOiBBcHBDb25maWcpID0+IHtcblxuICAgIGNvbnN0IHByb3A6IFRzZ0xhbWJkYUxheWVyUHJvcCA9IHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdDb21tb24gTGFtYmRhIGxheWVyJyxcbiAgICAgICAgY29kZVBhdGg6ICcuL25vZGVfbW9kdWxlcy9AZGF2aXNzeWx2ZXN0ZXIvYmlzaG9wLWNkay1jb25zdHJ1Y3RzL2Rpc3QnLFxuICAgICAgICBuYW1lOiAnYmlzaG9wLWNvbW1vbi1sYXllcidcbiAgICB9OyAgXG4gICAgXG4gICAgY29uc3QgbGF5ZXIgPSBjcmVhdGVMYW1iZGFMYXllcihzY29wZSwgYXBwUHJvcHMsIHByb3ApXG4gICAgXG4gICAgcmV0dXJuIGxheWVyO1xufTtcblxuIl19
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { IRestApi, Resource, TokenAuthorizer } from "aws-cdk-lib/aws-apigateway";
|
|
2
|
+
import { NodejsFunction } from "aws-cdk-lib/aws-lambda-nodejs";
|
|
3
|
+
import { TsgLambdaProp } from "../../config/types";
|
|
4
|
+
export declare class Routes {
|
|
5
|
+
static Resources: Resource[];
|
|
6
|
+
private static routeMap;
|
|
7
|
+
static createResource(prop: TsgLambdaProp, api: IRestApi, lambdaNode: NodejsFunction, authorizer?: TokenAuthorizer): void;
|
|
8
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Routes = void 0;
|
|
4
|
+
const aws_apigateway_1 = require("aws-cdk-lib/aws-apigateway");
|
|
5
|
+
class Routes {
|
|
6
|
+
static createResource(prop, api, lambdaNode, authorizer) {
|
|
7
|
+
const routeMap = new Map();
|
|
8
|
+
// Only attach lambda to an Api Gateway if a route exist
|
|
9
|
+
if (prop.apiGateway?.route) {
|
|
10
|
+
// Note: this now uses the bundle version as the first segment in the path.
|
|
11
|
+
let activeRoutePath = `/${(prop.apiGateway.version) ? prop.apiGateway.version : 1}`;
|
|
12
|
+
let activeResource = Routes.routeMap.get(activeRoutePath) || api.root.addResource(activeRoutePath);
|
|
13
|
+
Routes.routeMap.set(activeRoutePath, activeResource);
|
|
14
|
+
// Now we go through our route segments creating the rest of the path.
|
|
15
|
+
const pathSegments = prop.apiGateway?.route.split("/").filter(x => (x));
|
|
16
|
+
for (let i = 0; i < pathSegments.length; i++) {
|
|
17
|
+
activeRoutePath = `${activeRoutePath}/${pathSegments[i]}`;
|
|
18
|
+
let secondaryResource = Routes.routeMap.get(activeRoutePath) || activeResource.addResource(pathSegments[i]);
|
|
19
|
+
Routes.routeMap.set(activeRoutePath, secondaryResource);
|
|
20
|
+
activeResource = secondaryResource;
|
|
21
|
+
}
|
|
22
|
+
// Finally, we attach our function to the last resource
|
|
23
|
+
activeResource.addMethod(prop.apiGateway.method || 'GET', new aws_apigateway_1.LambdaIntegration(lambdaNode, { proxy: true, }), prop.apiGateway.secure ? { authorizer } : undefined);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
Routes.Resources = [];
|
|
28
|
+
Routes.routeMap = new Map();
|
|
29
|
+
exports.Routes = Routes;
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlUm91dGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3Jlc291cmNlcy9oZWxwZXJzL2NyZWF0ZVJvdXRlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwrREFBb0c7QUFLcEcsTUFBYSxNQUFNO0lBS1IsTUFBTSxDQUFDLGNBQWMsQ0FDeEIsSUFBbUIsRUFDbkIsR0FBYSxFQUNiLFVBQTBCLEVBQzFCLFVBQTRCO1FBRTVCLE1BQU0sUUFBUSxHQUEwQixJQUFJLEdBQUcsRUFBRSxDQUFDO1FBRWxELHlEQUF5RDtRQUN6RCxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUUsS0FBSyxFQUFFO1lBRTVCLDZFQUE2RTtZQUM3RSxJQUFJLGVBQWUsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUUsRUFBRSxDQUFDO1lBQ3JGLElBQUksY0FBYyxHQUFhLE1BQU0sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxJQUFLLEdBQUcsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLGVBQWUsQ0FBQyxDQUFDO1lBQzlHLE1BQU0sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLGVBQWUsRUFBRSxjQUFjLENBQUMsQ0FBQztZQUVyRCx1RUFBdUU7WUFDdkUsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLFVBQVUsRUFBRSxLQUFLLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN4RSxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsWUFBWSxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRTtnQkFDMUMsZUFBZSxHQUFHLEdBQUcsZUFBZSxJQUFJLFlBQVksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO2dCQUMxRCxJQUFJLGlCQUFpQixHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxJQUFJLGNBQWUsQ0FBQyxXQUFXLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQzdHLE1BQU0sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLGVBQWUsRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO2dCQUN4RCxjQUFjLEdBQUcsaUJBQWlCLENBQUM7YUFDdEM7WUFFRCx3REFBd0Q7WUFDeEQsY0FBYyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sSUFBSSxLQUFLLEVBQ3BELElBQUksa0NBQWlCLENBQUMsVUFBVSxFQUFFLEVBQUUsS0FBSyxFQUFFLElBQUksR0FBRyxDQUFDLEVBQ25ELElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQztTQUM1RDtJQUNMLENBQUM7O0FBakNpQixnQkFBUyxHQUFlLEVBQUUsQ0FBQztBQUMxQixlQUFRLEdBQUcsSUFBSSxHQUFHLEVBQUUsQ0FBQztBQUgzQix3QkFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElSZXN0QXBpLCBMYW1iZGFJbnRlZ3JhdGlvbiwgUmVzb3VyY2UsIFRva2VuQXV0aG9yaXplciB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtYXBpZ2F0ZXdheVwiO1xuaW1wb3J0IHsgTm9kZWpzRnVuY3Rpb24gfSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWxhbWJkYS1ub2RlanNcIjtcbmltcG9ydCB7IFRzZ0xhbWJkYVByb3AgfSBmcm9tIFwiLi4vLi4vY29uZmlnL3R5cGVzXCI7XG5cblxuZXhwb3J0IGNsYXNzIFJvdXRlcyB7XG5cbiAgICBwdWJsaWMgc3RhdGljIFJlc291cmNlczogUmVzb3VyY2VbXSA9IFtdOyAgXG4gICAgcHJpdmF0ZSBzdGF0aWMgcm91dGVNYXAgPSBuZXcgTWFwKCk7ICAgICAgIFxuXG4gICAgcHVibGljIHN0YXRpYyBjcmVhdGVSZXNvdXJjZSggICAgICAgIFxuICAgICAgICBwcm9wOiBUc2dMYW1iZGFQcm9wLCBcbiAgICAgICAgYXBpOiBJUmVzdEFwaSwgXG4gICAgICAgIGxhbWJkYU5vZGU6IE5vZGVqc0Z1bmN0aW9uLCBcbiAgICAgICAgYXV0aG9yaXplcj86IFRva2VuQXV0aG9yaXplcikge1xuXG4gICAgICAgIGNvbnN0IHJvdXRlTWFwOiBNYXA8c3RyaW5nLCBSZXNvdXJjZT4gPSBuZXcgTWFwKCk7XG5cbiAgICAgICAgLy8gIE9ubHkgYXR0YWNoIGxhbWJkYSB0byBhbiBBcGkgR2F0ZXdheSBpZiBhIHJvdXRlIGV4aXN0XG4gICAgICAgIGlmIChwcm9wLmFwaUdhdGV3YXk/LnJvdXRlKSB7XG5cbiAgICAgICAgLy8gIE5vdGU6ICB0aGlzIG5vdyB1c2VzIHRoZSBidW5kbGUgdmVyc2lvbiBhcyB0aGUgZmlyc3Qgc2VnbWVudCBpbiB0aGUgcGF0aC5cbiAgICAgICAgbGV0IGFjdGl2ZVJvdXRlUGF0aCA9IGAvJHsocHJvcC5hcGlHYXRld2F5LnZlcnNpb24pID8gcHJvcC5hcGlHYXRld2F5LnZlcnNpb24gOiAxIH1gO1xuICAgICAgICBsZXQgYWN0aXZlUmVzb3VyY2U6IFJlc291cmNlID0gUm91dGVzLnJvdXRlTWFwLmdldChhY3RpdmVSb3V0ZVBhdGgpIHx8ICBhcGkucm9vdC5hZGRSZXNvdXJjZShhY3RpdmVSb3V0ZVBhdGgpO1xuICAgICAgICBSb3V0ZXMucm91dGVNYXAuc2V0KGFjdGl2ZVJvdXRlUGF0aCwgYWN0aXZlUmVzb3VyY2UpO1xuXG4gICAgICAgIC8vICBOb3cgd2UgZ28gdGhyb3VnaCBvdXIgcm91dGUgc2VnbWVudHMgY3JlYXRpbmcgdGhlIHJlc3Qgb2YgdGhlIHBhdGguXG4gICAgICAgIGNvbnN0IHBhdGhTZWdtZW50cyA9IHByb3AuYXBpR2F0ZXdheT8ucm91dGUuc3BsaXQoXCIvXCIpLmZpbHRlcih4ID0+ICh4KSk7XG4gICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgcGF0aFNlZ21lbnRzLmxlbmd0aDsgaSsrKSB7XG4gICAgICAgICAgICBhY3RpdmVSb3V0ZVBhdGggPSBgJHthY3RpdmVSb3V0ZVBhdGh9LyR7cGF0aFNlZ21lbnRzW2ldfWA7XG4gICAgICAgICAgICBsZXQgc2Vjb25kYXJ5UmVzb3VyY2UgPSBSb3V0ZXMucm91dGVNYXAuZ2V0KGFjdGl2ZVJvdXRlUGF0aCkgfHwgYWN0aXZlUmVzb3VyY2UhLmFkZFJlc291cmNlKHBhdGhTZWdtZW50c1tpXSk7ICAgICAgICAgICAgICAgIFxuICAgICAgICAgICAgUm91dGVzLnJvdXRlTWFwLnNldChhY3RpdmVSb3V0ZVBhdGgsIHNlY29uZGFyeVJlc291cmNlKTsgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gICAgICAgICAgICBhY3RpdmVSZXNvdXJjZSA9IHNlY29uZGFyeVJlc291cmNlOyAgICAgICAgICAgICAgICBcbiAgICAgICAgfVxuICAgICAgICBcbiAgICAgICAgLy8gIEZpbmFsbHksIHdlIGF0dGFjaCBvdXIgZnVuY3Rpb24gdG8gdGhlIGxhc3QgcmVzb3VyY2VcbiAgICAgICAgYWN0aXZlUmVzb3VyY2UuYWRkTWV0aG9kKHByb3AuYXBpR2F0ZXdheS5tZXRob2QgfHwgJ0dFVCcsXG4gICAgICAgICAgICBuZXcgTGFtYmRhSW50ZWdyYXRpb24obGFtYmRhTm9kZSwgeyBwcm94eTogdHJ1ZSwgfSksIFxuICAgICAgICAgICAgcHJvcC5hcGlHYXRld2F5LnNlY3VyZSA/IHsgYXV0aG9yaXplciB9IDogdW5kZWZpbmVkKTsgICAgXG4gICAgfVxufVxuXG59Il19
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { NodejsFunction } from "aws-cdk-lib/aws-lambda-nodejs";
|
|
2
|
+
import { Construct } from "constructs";
|
|
3
|
+
import { AppConfig } from "../../config/AppConfig";
|
|
4
|
+
import { TsgLambdaProp } from "../../config/types";
|
|
5
|
+
import { TsgLambdaProps } from "../../config/types/TsgLambdaProps";
|
|
6
|
+
import { BaseResource } from "../base/baseResource";
|
|
7
|
+
export declare class CreateLambda extends BaseResource<NodejsFunction> {
|
|
8
|
+
private props;
|
|
9
|
+
Lambdas: NodejsFunction[];
|
|
10
|
+
constructor(props: TsgLambdaProps, config: AppConfig);
|
|
11
|
+
protected createResource(scope: Construct): NodejsFunction[];
|
|
12
|
+
protected createOutput<T>(scope: Construct, createdAssets: T[]): void;
|
|
13
|
+
private createLambdas;
|
|
14
|
+
private createLambdaFunctions;
|
|
15
|
+
private createLambdaProps;
|
|
16
|
+
private createLambdaFunctionProps;
|
|
17
|
+
private assignManagedPolicies;
|
|
18
|
+
private createAlarmsForLambdas;
|
|
19
|
+
static getIdForLambda(lambdaProp: TsgLambdaProp): string;
|
|
20
|
+
}
|