@scloud/cdk-patterns
Version:
Serverless CDK patterns for common infrastructure needs
125 lines • 14 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__setModuleDefault(result, mod);
return result;
};
})();
Object.defineProperty(exports, "__esModule", { value: true });
exports.containerFunction = containerFunction;
exports.zipFunction = zipFunction;
exports.edgeFunction = edgeFunction;
const path = __importStar(require("path"));
const logs = __importStar(require("aws-cdk-lib/aws-logs"));
const aws_lambda_1 = require("aws-cdk-lib/aws-lambda");
const cloudfront = __importStar(require("aws-cdk-lib/aws-cloudfront"));
const ecrRepositoryDeprecated_1 = require("./ecrRepositoryDeprecated");
const ghaUserDeprecated_1 = require("./ghaUserDeprecated");
/**
* @deprecated Use ContainerFunction instead
*
* A Lambda function packaged as a container.
* @param construct Parent CDK construct (typically 'this')
* @param initialPass If the infrastructure is being built from scratch: true;
* for incremental deployments: false.
* @param name The name for this function
* @param environment Environment variables for the Lambda function
* @returns The lambda, if created, and associated ECR repository
*/
function containerFunction(construct, initialPass, name, environment, lambdaProps, tagOrDigest, ecr) {
// Repository for function container image
const repository = ecr || (0, ecrRepositoryDeprecated_1.ecrRepository)(construct, name);
// Container
const code = initialPass ? aws_lambda_1.DockerImageCode.fromImageAsset(path.join(__dirname, './container')) : aws_lambda_1.DockerImageCode.fromEcr(repository, {
tagOrDigest: tagOrDigest || 'latest',
});
const lambda = new aws_lambda_1.DockerImageFunction(construct, `${name}Function`, {
code,
logRetention: logs.RetentionDays.THREE_MONTHS,
environment,
description: name,
...lambdaProps,
});
(0, ghaUserDeprecated_1.addGhaLambda)(construct, name, lambda);
return { lambda, repository };
}
/**
* @deprecated Use ZipFunction.typescript() or ZipFunction.python() instead
*
* A Lambda function packaged as a zip file.
* Key defaults are:
* - runtime: Runtime.NODEJS_18_X
* - handler: 'src/lambda.handler'
* - logRetention: logs.RetentionDays.TWO_YEARS
* @param construct Parent CDK construct (typically 'this')
* @param name The name for this function
* @param environment Environment variables for the Lambda function
* @param lambdaProps Override properties for the Lambda function. you may want to pass e.g. { runtime: Runtime.PYTHON_3_10 }
* @returns The lambda, if created, and associated ECR repository
*/
function zipFunction(construct, name, environment, lambdaProps) {
const lambda = new aws_lambda_1.Function(construct, `${name}Function`, {
runtime: aws_lambda_1.Runtime.NODEJS_18_X,
handler: 'src/lambda.handler',
code: aws_lambda_1.Code.fromInline('Placeholder code'), // Asset(path.join(__dirname, './lambda/python')),
logRetention: logs.RetentionDays.TWO_YEARS,
environment,
description: name,
...lambdaProps,
});
(0, ghaUserDeprecated_1.addGhaLambda)(construct, name, lambda);
return lambda;
}
/**
* NB: This pattern is not well developed or maintained at the time of writing.
*
* A key reason for this is that I haven't worked out how to deal well with lambda function versions in CI/CD
* which seemed to be needed when deploying an update to an edge function.
*
* A Lambda@edge function.
* @param construct Parent CDK construct (typically 'this')
* @param name The name for this function
* @param environment Environment variables for the Lambda function
* @returns The lambda, if created, and associated ECR repository
*/
function edgeFunction(construct, name, environment) {
const edge = new cloudfront.experimental.EdgeFunction(construct, `${name}EdgeFunction`, {
functionName: name, // Resolves "...the resource's physical name must be explicit set..."
runtime: aws_lambda_1.Runtime.NODEJS_14_X,
code: aws_lambda_1.Code.fromAsset(path.join(__dirname, './edge')),
handler: 'src/lambda.handler',
memorySize: 256,
logRetention: logs.RetentionDays.THREE_MONTHS,
environment,
});
(0, ghaUserDeprecated_1.addGhaLambda)(construct, name, edge);
return edge;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambdaFunctionDeprecated.js","sourceRoot":"","sources":["../../src/deprecated/lambdaFunctionDeprecated.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAsBA,8CA0BC;AAgBD,kCAiBC;AAcD,oCAoBC;AAnHD,2CAA6B;AAC7B,2DAA6C;AAE7C,uDAEgC;AAEhC,uEAAyD;AACzD,uEAA0D;AAC1D,2DAAmD;AAEnD;;;;;;;;;;GAUG;AACH,SAAgB,iBAAiB,CAC/B,SAAoB,EACpB,WAAoB,EACpB,IAAY,EACZ,WAAwC,EACxC,WAA+C,EAC/C,WAAoB,EACpB,GAAiB;IAEjB,0CAA0C;IAC1C,MAAM,UAAU,GAAG,GAAG,IAAI,IAAA,uCAAa,EAAC,SAAS,EAAE,IAAI,CAAC,CAAC;IAEzD,YAAY;IACZ,MAAM,IAAI,GAAG,WAAW,CAAC,CAAC,CAAC,4BAAe,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,4BAAe,CAAC,OAAO,CAAC,UAAU,EAAE;QACnI,WAAW,EAAE,WAAW,IAAI,QAAQ;KACrC,CAAC,CAAC;IAEH,MAAM,MAAM,GAAG,IAAI,gCAAmB,CAAC,SAAS,EAAE,GAAG,IAAI,UAAU,EAAE;QACnE,IAAI;QACJ,YAAY,EAAE,IAAI,CAAC,aAAa,CAAC,YAAY;QAC7C,WAAW;QACX,WAAW,EAAE,IAAI;QACjB,GAAG,WAAW;KACf,CAAC,CAAC;IACH,IAAA,gCAAY,EAAC,SAAS,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;IACtC,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC;AAChC,CAAC;AAED;;;;;;;;;;;;;GAaG;AACH,SAAgB,WAAW,CACzB,SAAoB,EACpB,IAAY,EACZ,WAAwC,EACxC,WAAoC;IAEpC,MAAM,MAAM,GAAG,IAAI,qBAAQ,CAAC,SAAS,EAAE,GAAG,IAAI,UAAU,EAAE;QACxD,OAAO,EAAE,oBAAO,CAAC,WAAW;QAC5B,OAAO,EAAE,oBAAoB;QAC7B,IAAI,EAAE,iBAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,EAAE,kDAAkD;QAC7F,YAAY,EAAE,IAAI,CAAC,aAAa,CAAC,SAAS;QAC1C,WAAW;QACX,WAAW,EAAE,IAAI;QACjB,GAAG,WAAW;KACf,CAAC,CAAC;IACH,IAAA,gCAAY,EAAC,SAAS,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;IACtC,OAAO,MAAM,CAAC;AAChB,CAAC;AAED;;;;;;;;;;;GAWG;AACH,SAAgB,YAAY,CAC1B,SAAoB,EACpB,IAAY,EACZ,WAAwC;IAExC,MAAM,IAAI,GAAG,IAAI,UAAU,CAAC,YAAY,CAAC,YAAY,CACnD,SAAS,EACT,GAAG,IAAI,cAAc,EACrB;QACE,YAAY,EAAE,IAAI,EAAE,qEAAqE;QACzF,OAAO,EAAE,oBAAO,CAAC,WAAW;QAC5B,IAAI,EAAE,iBAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;QACpD,OAAO,EAAE,oBAAoB;QAC7B,UAAU,EAAE,GAAG;QACf,YAAY,EAAE,IAAI,CAAC,aAAa,CAAC,YAAY;QAC7C,WAAW;KACZ,CACF,CAAC;IACF,IAAA,gCAAY,EAAC,SAAS,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;IACpC,OAAO,IAAI,CAAC;AACd,CAAC","sourcesContent":["import * as path from 'path';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport { Construct } from 'constructs';\nimport {\n  Code, DockerImageCode, DockerImageFunction, DockerImageFunctionProps, Function, FunctionProps, Runtime,\n} from 'aws-cdk-lib/aws-lambda';\nimport { IRepository } from 'aws-cdk-lib/aws-ecr';\nimport * as cloudfront from 'aws-cdk-lib/aws-cloudfront';\nimport { ecrRepository } from './ecrRepositoryDeprecated';\nimport { addGhaLambda } from './ghaUserDeprecated';\n\n/**\n * @deprecated Use ContainerFunction instead\n *\n * A Lambda function packaged as a container.\n * @param construct Parent CDK construct (typically 'this')\n * @param initialPass If the infrastructure is being built from scratch: true;\n * for incremental deployments: false.\n * @param name The name for this function\n * @param environment Environment variables for the Lambda function\n * @returns The lambda, if created, and associated ECR repository\n */\nexport function containerFunction(\n  construct: Construct,\n  initialPass: boolean,\n  name: string,\n  environment?: { [key: string]: string; },\n  lambdaProps?: Partial<DockerImageFunctionProps>,\n  tagOrDigest?: string,\n  ecr?: IRepository,\n): { lambda: Function, repository: IRepository; } {\n  // Repository for function container image\n  const repository = ecr || ecrRepository(construct, name);\n\n  // Container\n  const code = initialPass ? DockerImageCode.fromImageAsset(path.join(__dirname, './container')) : DockerImageCode.fromEcr(repository, {\n    tagOrDigest: tagOrDigest || 'latest',\n  });\n\n  const lambda = new DockerImageFunction(construct, `${name}Function`, {\n    code,\n    logRetention: logs.RetentionDays.THREE_MONTHS,\n    environment,\n    description: name,\n    ...lambdaProps,\n  });\n  addGhaLambda(construct, name, lambda);\n  return { lambda, repository };\n}\n\n/**\n * @deprecated Use ZipFunction.typescript() or ZipFunction.python() instead\n *\n * A Lambda function packaged as a zip file.\n * Key defaults are:\n *  - runtime: Runtime.NODEJS_18_X\n *  - handler: 'src/lambda.handler'\n *  - logRetention: logs.RetentionDays.TWO_YEARS\n * @param construct Parent CDK construct (typically 'this')\n * @param name The name for this function\n * @param environment Environment variables for the Lambda function\n * @param lambdaProps Override properties for the Lambda function. you may want to pass e.g. { runtime: Runtime.PYTHON_3_10 }\n * @returns The lambda, if created, and associated ECR repository\n */\nexport function zipFunction(\n  construct: Construct,\n  name: string,\n  environment?: { [key: string]: string; },\n  lambdaProps?: Partial<FunctionProps>,\n): Function {\n  const lambda = new Function(construct, `${name}Function`, {\n    runtime: Runtime.NODEJS_18_X,\n    handler: 'src/lambda.handler',\n    code: Code.fromInline('Placeholder code'), // Asset(path.join(__dirname, './lambda/python')),\n    logRetention: logs.RetentionDays.TWO_YEARS,\n    environment,\n    description: name,\n    ...lambdaProps,\n  });\n  addGhaLambda(construct, name, lambda);\n  return lambda;\n}\n\n/**\n * NB: This pattern is not well developed or maintained at the time of writing.\n *\n * A key reason for this is that I haven't worked out how to deal well with lambda function versions in CI/CD\n * which seemed to be needed when deploying an update to an edge function.\n *\n * A Lambda@edge function.\n * @param construct Parent CDK construct (typically 'this')\n * @param name The name for this function\n * @param environment Environment variables for the Lambda function\n * @returns The lambda, if created, and associated ECR repository\n */\nexport function edgeFunction(\n  construct: Construct,\n  name: string,\n  environment?: { [key: string]: string; },\n): cloudfront.experimental.EdgeFunction {\n  const edge = new cloudfront.experimental.EdgeFunction(\n    construct,\n    `${name}EdgeFunction`,\n    {\n      functionName: name, // Resolves \"...the resource's physical name must be explicit set...\"\n      runtime: Runtime.NODEJS_14_X,\n      code: Code.fromAsset(path.join(__dirname, './edge')),\n      handler: 'src/lambda.handler',\n      memorySize: 256,\n      logRetention: logs.RetentionDays.THREE_MONTHS,\n      environment,\n    },\n  );\n  addGhaLambda(construct, name, edge);\n  return edge;\n}\n"]}