@sylvesterllc/aws-constructs 1.1.29 → 1.1.30
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.
|
@@ -18,6 +18,7 @@ const createBasicLambda = (scope, props) => {
|
|
|
18
18
|
exports.createBasicLambda = createBasicLambda;
|
|
19
19
|
const createBasicLambdaProps = (props) => {
|
|
20
20
|
let resolvedEntry;
|
|
21
|
+
let depsLockFilePath = props.depsLockFilePath;
|
|
21
22
|
if (props.codePath && path.isAbsolute(props.codePath)) {
|
|
22
23
|
resolvedEntry = props.codePath;
|
|
23
24
|
}
|
|
@@ -37,6 +38,17 @@ const createBasicLambdaProps = (props) => {
|
|
|
37
38
|
// Default path without projectRoot
|
|
38
39
|
resolvedEntry = path.join(`./resources/lambdas/${props.functionName}/main.mts`);
|
|
39
40
|
}
|
|
41
|
+
// When projectRoot is provided, override depsLockFilePath to point to the projectRoot's lock file
|
|
42
|
+
if (props.projectRoot && !depsLockFilePath) {
|
|
43
|
+
const lockFiles = ["pnpm-lock.yaml", "yarn.lock", "package-lock.json"];
|
|
44
|
+
for (const lockFile of lockFiles) {
|
|
45
|
+
const lockPath = path.join(props.projectRoot, lockFile);
|
|
46
|
+
if (require("fs").existsSync(lockPath)) {
|
|
47
|
+
depsLockFilePath = lockPath;
|
|
48
|
+
break;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
40
52
|
const lambdaProp = {
|
|
41
53
|
entry: resolvedEntry,
|
|
42
54
|
functionName: `${props.appPrefix ? `${props.appPrefix}-` : ""}${props.functionName}`,
|
|
@@ -57,8 +69,8 @@ const createBasicLambdaProps = (props) => {
|
|
|
57
69
|
...props.envs,
|
|
58
70
|
},
|
|
59
71
|
...(props.projectRoot && { projectRoot: props.projectRoot }),
|
|
60
|
-
...(
|
|
61
|
-
depsLockFilePath:
|
|
72
|
+
...(depsLockFilePath && {
|
|
73
|
+
depsLockFilePath: depsLockFilePath,
|
|
62
74
|
}),
|
|
63
75
|
},
|
|
64
76
|
role: props.role,
|
|
@@ -82,4 +94,4 @@ const addLambdaLayers = (scope, lambda, functionName, layerArns) => {
|
|
|
82
94
|
});
|
|
83
95
|
}
|
|
84
96
|
};
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-basic-lambda-helper.js","sourceRoot":"","sources":["../../../src/resources/lambda/create-basic-lambda-helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration } from \"aws-cdk-lib\";\nimport { ServicePrincipal } from \"aws-cdk-lib/aws-iam\";\nimport { LayerVersion, Runtime } from \"aws-cdk-lib/aws-lambda\";\nimport {\n  NodejsFunction,\n  NodejsFunctionProps,\n  SourceMapMode,\n} from \"aws-cdk-lib/aws-lambda-nodejs\";\nimport { RetentionDays } from \"aws-cdk-lib/aws-logs\";\nimport path = require(\"path\");\nimport { LambdaProps } from \"../../interfaces/lambda\";\nimport { Construct } from \"constructs\";\nimport { Table } from \"aws-cdk-lib/aws-dynamodb\";\n\nexport const createBasicLambda = (\n  scope: Construct,\n  props: LambdaProps\n): NodejsFunction => {\n  const lambdaProps = createBasicLambdaProps(props);\n\n  const functionName = `${props.appPrefix || \"\"}${props.functionName}`;\n\n  let lambdaFunction = new NodejsFunction(\n    scope,\n    functionName,\n    lambdaProps\n  );\n\n  grantAccessToDynamoTables(scope, lambdaFunction, functionName, props.dynamoTableNames);\n\n  addLambdaLayers(scope, lambdaFunction, functionName, props.lambdaLayerArn);\n\n  return lambdaFunction;\n};\n\nconst createBasicLambdaProps = (props: LambdaProps): NodejsFunctionProps => {\n  let resolvedEntry: string;\n\n  if (props.codePath && path.isAbsolute(props.codePath)) {\n    resolvedEntry = props.codePath;\n  } else if (props.codePath && props.projectRoot) {\n    // codePath is relative, resolve from current directory + projectRoot\n    resolvedEntry = path.resolve(process.cwd(), props.codePath);\n  } else if (props.projectRoot) {\n    // No codePath, use default path with projectRoot\n    resolvedEntry = path.resolve(\n      process.cwd(),\n      props.projectRoot,\n      `resources/lambdas/${props.functionName}/main.mts`\n    );\n  } else if (props.codePath) {\n    // codePath without projectRoot\n    resolvedEntry = path.resolve(process.cwd(), props.codePath);\n  } else {\n    // Default path without projectRoot\n    resolvedEntry = path.join(\n      `./resources/lambdas/${props.functionName}/main.mts`\n    );\n  }\n\n  const lambdaProp: NodejsFunctionProps = {\n    entry: resolvedEntry,\n    functionName: `${props.appPrefix ? `${props.appPrefix}-` : \"\"}${\n      props.functionName\n    }`,\n    handler: \"main.ts\",\n    logRetention: RetentionDays.TWO_WEEKS,\n    runtime: Runtime.NODEJS_LATEST,\n    timeout: Duration.minutes(\n      props.timeoutInMinutes ? props.timeoutInMinutes : 1\n    ),\n    memorySize: props.memory,\n    environment: {\n      ...props.envs,\n    },\n    bundling: {\n      minify: true,\n      target: `esnext`,\n      sourceMap: true,\n      sourceMapMode: SourceMapMode.EXTERNAL,\n      environment: {\n        ...props.envs,\n      },\n      ...(props.projectRoot && { projectRoot: props.projectRoot }),\n      ...(props.depsLockFilePath && {\n        depsLockFilePath: props.depsLockFilePath,\n      }),\n    },\n    role: props.role,\n    layers: undefined,\n  };\n\n  return lambdaProp;\n};\n\nconst grantAccessToDynamoTables = (\n  scope: Construct,\n  lambda: NodejsFunction,\n  functionName: string,\n  tableNames?: string[],\n) => {\n  if (tableNames && tableNames.length > 0) {\n    tableNames.forEach((tableName, idx) => {\n      const table = Table.fromTableName(scope, `${tableName}-table-${idx}`, tableName);\n\n      table.grantReadWriteData(lambda);\n    });\n  }\n};\n\nconst addLambdaLayers = (\n  scope: Construct,\n  lambda: NodejsFunction,\n  functionName: string,\n  layerArns?: string[]\n) => {\n  if (layerArns && layerArns.length > 0) {\n    layerArns.forEach((arn: string, idx: number) => {\n      const layer = LayerVersion.fromLayerVersionArn(\n        scope,\n        `common-layer-${idx}`,\n        arn\n      );\n\n      lambda.addLayers(layer);\n    });\n  }\n};\n"]}
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-basic-lambda-helper.js","sourceRoot":"","sources":["../../../src/resources/lambda/create-basic-lambda-helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration } from \"aws-cdk-lib\";\nimport { ServicePrincipal } from \"aws-cdk-lib/aws-iam\";\nimport { LayerVersion, Runtime } from \"aws-cdk-lib/aws-lambda\";\nimport {\n  NodejsFunction,\n  NodejsFunctionProps,\n  SourceMapMode,\n} from \"aws-cdk-lib/aws-lambda-nodejs\";\nimport { RetentionDays } from \"aws-cdk-lib/aws-logs\";\nimport path = require(\"path\");\nimport { LambdaProps } from \"../../interfaces/lambda\";\nimport { Construct } from \"constructs\";\nimport { Table } from \"aws-cdk-lib/aws-dynamodb\";\n\nexport const createBasicLambda = (\n  scope: Construct,\n  props: LambdaProps\n): NodejsFunction => {\n  const lambdaProps = createBasicLambdaProps(props);\n\n  const functionName = `${props.appPrefix || \"\"}${props.functionName}`;\n\n  let lambdaFunction = new NodejsFunction(scope, functionName, lambdaProps);\n\n  grantAccessToDynamoTables(\n    scope,\n    lambdaFunction,\n    functionName,\n    props.dynamoTableNames\n  );\n\n  addLambdaLayers(scope, lambdaFunction, functionName, props.lambdaLayerArn);\n\n  return lambdaFunction;\n};\n\nconst createBasicLambdaProps = (props: LambdaProps): NodejsFunctionProps => {\n  let resolvedEntry: string;\n  let depsLockFilePath: string | undefined = props.depsLockFilePath;\n\n  if (props.codePath && path.isAbsolute(props.codePath)) {\n    resolvedEntry = props.codePath;\n  } else if (props.codePath && props.projectRoot) {\n    // codePath is relative, resolve from current directory + projectRoot\n    resolvedEntry = path.resolve(process.cwd(), props.codePath);\n  } else if (props.projectRoot) {\n    // No codePath, use default path with projectRoot\n    resolvedEntry = path.resolve(\n      process.cwd(),\n      props.projectRoot,\n      `resources/lambdas/${props.functionName}/main.mts`\n    );\n  } else if (props.codePath) {\n    // codePath without projectRoot\n    resolvedEntry = path.resolve(process.cwd(), props.codePath);\n  } else {\n    // Default path without projectRoot\n    resolvedEntry = path.join(\n      `./resources/lambdas/${props.functionName}/main.mts`\n    );\n  }\n\n  // When projectRoot is provided, override depsLockFilePath to point to the projectRoot's lock file\n  if (props.projectRoot && !depsLockFilePath) {\n    const lockFiles = [\"pnpm-lock.yaml\", \"yarn.lock\", \"package-lock.json\"];\n    for (const lockFile of lockFiles) {\n      const lockPath = path.join(props.projectRoot, lockFile);\n      if (require(\"fs\").existsSync(lockPath)) {\n        depsLockFilePath = lockPath;\n        break;\n      }\n    }\n  }\n\n  const lambdaProp: NodejsFunctionProps = {\n    entry: resolvedEntry,\n    functionName: `${props.appPrefix ? `${props.appPrefix}-` : \"\"}${\n      props.functionName\n    }`,\n    handler: \"main.ts\",\n    logRetention: RetentionDays.TWO_WEEKS,\n    runtime: Runtime.NODEJS_LATEST,\n    timeout: Duration.minutes(\n      props.timeoutInMinutes ? props.timeoutInMinutes : 1\n    ),\n    memorySize: props.memory,\n    environment: {\n      ...props.envs,\n    },\n    bundling: {\n      minify: true,\n      target: `esnext`,\n      sourceMap: true,\n      sourceMapMode: SourceMapMode.EXTERNAL,\n      environment: {\n        ...props.envs,\n      },\n      ...(props.projectRoot && { projectRoot: props.projectRoot }),\n      ...(depsLockFilePath && {\n        depsLockFilePath: depsLockFilePath,\n      }),\n    },\n    role: props.role,\n    layers: undefined,\n  };\n\n  return lambdaProp;\n};\n\nconst grantAccessToDynamoTables = (\n  scope: Construct,\n  lambda: NodejsFunction,\n  functionName: string,\n  tableNames?: string[]\n) => {\n  if (tableNames && tableNames.length > 0) {\n    tableNames.forEach((tableName, idx) => {\n      const table = Table.fromTableName(\n        scope,\n        `${tableName}-table-${idx}`,\n        tableName\n      );\n\n      table.grantReadWriteData(lambda);\n    });\n  }\n};\n\nconst addLambdaLayers = (\n  scope: Construct,\n  lambda: NodejsFunction,\n  functionName: string,\n  layerArns?: string[]\n) => {\n  if (layerArns && layerArns.length > 0) {\n    layerArns.forEach((arn: string, idx: number) => {\n      const layer = LayerVersion.fromLayerVersionArn(\n        scope,\n        `common-layer-${idx}`,\n        arn\n      );\n\n      lambda.addLayers(layer);\n    });\n  }\n};\n"]}
|
|
@@ -25,6 +25,7 @@ const createBasicLambdaTimerJob = (scope, props) => {
|
|
|
25
25
|
exports.createBasicLambdaTimerJob = createBasicLambdaTimerJob;
|
|
26
26
|
const createBasicLambdaProps = (props) => {
|
|
27
27
|
let resolvedEntry;
|
|
28
|
+
let depsLockFilePath = props.depsLockFilePath;
|
|
28
29
|
if (props.codePath && path.isAbsolute(props.codePath)) {
|
|
29
30
|
resolvedEntry = props.codePath;
|
|
30
31
|
}
|
|
@@ -44,6 +45,17 @@ const createBasicLambdaProps = (props) => {
|
|
|
44
45
|
// Default path without projectRoot
|
|
45
46
|
resolvedEntry = path.join(`./resources/lambdas/timer-jobs/${props.functionName}/main.mts`);
|
|
46
47
|
}
|
|
48
|
+
// When projectRoot is provided, override depsLockFilePath to point to the projectRoot's lock file
|
|
49
|
+
if (props.projectRoot && !depsLockFilePath) {
|
|
50
|
+
const lockFiles = ["pnpm-lock.yaml", "yarn.lock", "package-lock.json"];
|
|
51
|
+
for (const lockFile of lockFiles) {
|
|
52
|
+
const lockPath = path.join(props.projectRoot, lockFile);
|
|
53
|
+
if (require("fs").existsSync(lockPath)) {
|
|
54
|
+
depsLockFilePath = lockPath;
|
|
55
|
+
break;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
47
59
|
const lambdaProp = {
|
|
48
60
|
entry: resolvedEntry,
|
|
49
61
|
functionName: `${props.appPrefix ? `${props.appPrefix}-` : ""}${props.functionName}`,
|
|
@@ -64,8 +76,8 @@ const createBasicLambdaProps = (props) => {
|
|
|
64
76
|
...props.envs,
|
|
65
77
|
},
|
|
66
78
|
...(props.projectRoot && { projectRoot: props.projectRoot }),
|
|
67
|
-
...(
|
|
68
|
-
depsLockFilePath:
|
|
79
|
+
...(depsLockFilePath && {
|
|
80
|
+
depsLockFilePath: depsLockFilePath,
|
|
69
81
|
}),
|
|
70
82
|
},
|
|
71
83
|
role: props.role,
|
|
@@ -100,4 +112,4 @@ const addLambdaLayers = (scope, lambda, layerArns) => {
|
|
|
100
112
|
});
|
|
101
113
|
}
|
|
102
114
|
};
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-basic-lambda.js","sourceRoot":"","sources":["../../../src/resources/lambda/create-basic-lambda.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration } from \"aws-cdk-lib\";\nimport { ServicePrincipal } from \"aws-cdk-lib/aws-iam\";\nimport { LayerVersion, Runtime } from \"aws-cdk-lib/aws-lambda\";\nimport {\n  NodejsFunction,\n  NodejsFunctionProps,\n  SourceMapMode,\n} from \"aws-cdk-lib/aws-lambda-nodejs\";\nimport { RetentionDays } from \"aws-cdk-lib/aws-logs\";\nimport path = require(\"path\");\nimport { TimerJobProps } from \"../../interfaces/timer-job\";\nimport { Construct } from \"constructs\";\nimport { SERVICE_PRINCIPAL } from \"../../constants/aws-service-principal-constants\";\nimport { CronOptions, Rule, Schedule } from \"aws-cdk-lib/aws-events\";\nimport { LambdaFunction } from \"aws-cdk-lib/aws-events-targets\";\nimport { Table } from \"aws-cdk-lib/aws-dynamodb\";\n\nexport const createBasicLambdaTimerJob = (\n  scope: Construct,\n  props: TimerJobProps\n): NodejsFunction => {\n  const lambdaProps = createBasicLambdaProps(props);\n\n  const functionName = `${props.appPrefix}${props.functionName}`;\n\n  let lambdaFunction = new NodejsFunction(\n    scope,\n    functionName,\n    lambdaProps\n  );\n\n  addInvokePermissionToLambdaForEvents(lambdaFunction, functionName);\n\n  const eventRule = createEventRuleForLambda(\n    scope,\n    lambdaFunction,\n    props.cronOptions\n  );\n\n  eventRule.addTarget(new LambdaFunction(lambdaFunction));\n\n  grantAccessToDynamoTables(scope, lambdaFunction, props.dynamoTableNames);\n\n  addLambdaLayers(scope, lambdaFunction, props.lambdaLayerArn);\n\n  return lambdaFunction;\n};\n\nconst createBasicLambdaProps = (props: TimerJobProps): NodejsFunctionProps => {\n  let resolvedEntry: string;\n\n  if (props.codePath && path.isAbsolute(props.codePath)) {\n    resolvedEntry = props.codePath;\n  } else if (props.codePath && props.projectRoot) {\n    // codePath is relative, resolve from current directory + projectRoot\n    resolvedEntry = path.resolve(process.cwd(), props.codePath);\n  } else if (props.projectRoot) {\n    // No codePath, use default path with projectRoot\n    resolvedEntry = path.resolve(\n      process.cwd(),\n      props.projectRoot,\n      `resources/lambdas/timer-jobs/${props.functionName}/main.mts`\n    );\n  } else if (props.codePath) {\n    // codePath without projectRoot\n    resolvedEntry = path.resolve(process.cwd(), props.codePath);\n  } else {\n    // Default path without projectRoot\n    resolvedEntry = path.join(\n      `./resources/lambdas/timer-jobs/${props.functionName}/main.mts`\n    );\n  }\n\n  const lambdaProp: NodejsFunctionProps = {\n    entry: resolvedEntry,\n    functionName: `${props.appPrefix ? `${props.appPrefix}-` : \"\"}${\n      props.functionName\n    }`,\n    handler: \"main.ts\",\n    logRetention: RetentionDays.TWO_WEEKS,\n    runtime: Runtime.NODEJS_LATEST,\n    timeout: Duration.minutes(\n      props.timeoutInMinutes ? props.timeoutInMinutes : 1\n    ),\n    memorySize: props.memory,\n    environment: {\n      ...props.envs,\n    },\n    bundling: {\n      minify: true,\n      target: `esnext`,\n      sourceMap: true,\n      sourceMapMode: SourceMapMode.EXTERNAL,\n      environment: {\n        ...props.envs,\n      },\n      ...(props.projectRoot && { projectRoot: props.projectRoot }),\n      ...(props.depsLockFilePath && {\n        depsLockFilePath: props.depsLockFilePath,\n      }),\n    },\n    role: props.role,\n    layers: undefined,\n  };\n\n  return lambdaProp;\n};\n\nconst addInvokePermissionToLambdaForEvents = (lambda: NodejsFunction, functionName: string) => {\n  lambda.addPermission(`InvokePermission-${functionName}`, {\n    principal: new ServicePrincipal(SERVICE_PRINCIPAL.EVENTS),\n  });\n};\n\nconst createEventRuleForLambda = (\n  scope: Construct,\n  lambda: NodejsFunction,\n  options: CronOptions\n) => {\n  const eventRule = new Rule(\n    scope,\n    `scheduleRule-${lambda?.node.id || \"010\"}`,\n    {\n      schedule: Schedule.cron(options),\n    }\n  );\n\n  return eventRule;\n};\n\nconst grantAccessToDynamoTables = (\n  scope: Construct,\n  lambda: NodejsFunction,\n  tableNames?: string[]\n) => {\n  if (tableNames && tableNames.length > 0) {\n    tableNames.forEach((tableName) => {\n      const table = Table.fromTableName(scope, `${tableName}-table`, tableName);\n\n      table.grantReadWriteData(lambda);\n    });\n  }\n};\n\nconst addLambdaLayers = (\n  scope: Construct,\n  lambda: NodejsFunction,\n  layerArns?: string[]\n) => {\n  if (layerArns && layerArns.length > 0) {\n    layerArns.forEach((arn: string, idx: number) => {\n      const layer = LayerVersion.fromLayerVersionArn(\n        scope,\n        `common-layer-${idx}`,\n        arn\n      );\n\n      lambda.addLayers(layer);\n    });\n  }\n};\n"]}
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-basic-lambda.js","sourceRoot":"","sources":["../../../src/resources/lambda/create-basic-lambda.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration } from \"aws-cdk-lib\";\nimport { ServicePrincipal } from \"aws-cdk-lib/aws-iam\";\nimport { LayerVersion, Runtime } from \"aws-cdk-lib/aws-lambda\";\nimport {\n  NodejsFunction,\n  NodejsFunctionProps,\n  SourceMapMode,\n} from \"aws-cdk-lib/aws-lambda-nodejs\";\nimport { RetentionDays } from \"aws-cdk-lib/aws-logs\";\nimport path = require(\"path\");\nimport { TimerJobProps } from \"../../interfaces/timer-job\";\nimport { Construct } from \"constructs\";\nimport { SERVICE_PRINCIPAL } from \"../../constants/aws-service-principal-constants\";\nimport { CronOptions, Rule, Schedule } from \"aws-cdk-lib/aws-events\";\nimport { LambdaFunction } from \"aws-cdk-lib/aws-events-targets\";\nimport { Table } from \"aws-cdk-lib/aws-dynamodb\";\n\nexport const createBasicLambdaTimerJob = (\n  scope: Construct,\n  props: TimerJobProps\n): NodejsFunction => {\n  const lambdaProps = createBasicLambdaProps(props);\n\n  const functionName = `${props.appPrefix}${props.functionName}`;\n\n  let lambdaFunction = new NodejsFunction(scope, functionName, lambdaProps);\n\n  addInvokePermissionToLambdaForEvents(lambdaFunction, functionName);\n\n  const eventRule = createEventRuleForLambda(\n    scope,\n    lambdaFunction,\n    props.cronOptions\n  );\n\n  eventRule.addTarget(new LambdaFunction(lambdaFunction));\n\n  grantAccessToDynamoTables(scope, lambdaFunction, props.dynamoTableNames);\n\n  addLambdaLayers(scope, lambdaFunction, props.lambdaLayerArn);\n\n  return lambdaFunction;\n};\n\nconst createBasicLambdaProps = (props: TimerJobProps): NodejsFunctionProps => {\n  let resolvedEntry: string;\n  let depsLockFilePath: string | undefined = props.depsLockFilePath;\n\n  if (props.codePath && path.isAbsolute(props.codePath)) {\n    resolvedEntry = props.codePath;\n  } else if (props.codePath && props.projectRoot) {\n    // codePath is relative, resolve from current directory + projectRoot\n    resolvedEntry = path.resolve(process.cwd(), props.codePath);\n  } else if (props.projectRoot) {\n    // No codePath, use default path with projectRoot\n    resolvedEntry = path.resolve(\n      process.cwd(),\n      props.projectRoot,\n      `resources/lambdas/timer-jobs/${props.functionName}/main.mts`\n    );\n  } else if (props.codePath) {\n    // codePath without projectRoot\n    resolvedEntry = path.resolve(process.cwd(), props.codePath);\n  } else {\n    // Default path without projectRoot\n    resolvedEntry = path.join(\n      `./resources/lambdas/timer-jobs/${props.functionName}/main.mts`\n    );\n  }\n\n  // When projectRoot is provided, override depsLockFilePath to point to the projectRoot's lock file\n  if (props.projectRoot && !depsLockFilePath) {\n    const lockFiles = [\"pnpm-lock.yaml\", \"yarn.lock\", \"package-lock.json\"];\n    for (const lockFile of lockFiles) {\n      const lockPath = path.join(props.projectRoot, lockFile);\n      if (require(\"fs\").existsSync(lockPath)) {\n        depsLockFilePath = lockPath;\n        break;\n      }\n    }\n  }\n\n  const lambdaProp: NodejsFunctionProps = {\n    entry: resolvedEntry,\n    functionName: `${props.appPrefix ? `${props.appPrefix}-` : \"\"}${\n      props.functionName\n    }`,\n    handler: \"main.ts\",\n    logRetention: RetentionDays.TWO_WEEKS,\n    runtime: Runtime.NODEJS_LATEST,\n    timeout: Duration.minutes(\n      props.timeoutInMinutes ? props.timeoutInMinutes : 1\n    ),\n    memorySize: props.memory,\n    environment: {\n      ...props.envs,\n    },\n    bundling: {\n      minify: true,\n      target: `esnext`,\n      sourceMap: true,\n      sourceMapMode: SourceMapMode.EXTERNAL,\n      environment: {\n        ...props.envs,\n      },\n      ...(props.projectRoot && { projectRoot: props.projectRoot }),\n      ...(depsLockFilePath && {\n        depsLockFilePath: depsLockFilePath,\n      }),\n    },\n    role: props.role,\n    layers: undefined,\n  };\n\n  return lambdaProp;\n};\n\nconst addInvokePermissionToLambdaForEvents = (\n  lambda: NodejsFunction,\n  functionName: string\n) => {\n  lambda.addPermission(`InvokePermission-${functionName}`, {\n    principal: new ServicePrincipal(SERVICE_PRINCIPAL.EVENTS),\n  });\n};\n\nconst createEventRuleForLambda = (\n  scope: Construct,\n  lambda: NodejsFunction,\n  options: CronOptions\n) => {\n  const eventRule = new Rule(\n    scope,\n    `scheduleRule-${lambda?.node.id || \"010\"}`,\n    {\n      schedule: Schedule.cron(options),\n    }\n  );\n\n  return eventRule;\n};\n\nconst grantAccessToDynamoTables = (\n  scope: Construct,\n  lambda: NodejsFunction,\n  tableNames?: string[]\n) => {\n  if (tableNames && tableNames.length > 0) {\n    tableNames.forEach((tableName) => {\n      const table = Table.fromTableName(scope, `${tableName}-table`, tableName);\n\n      table.grantReadWriteData(lambda);\n    });\n  }\n};\n\nconst addLambdaLayers = (\n  scope: Construct,\n  lambda: NodejsFunction,\n  layerArns?: string[]\n) => {\n  if (layerArns && layerArns.length > 0) {\n    layerArns.forEach((arn: string, idx: number) => {\n      const layer = LayerVersion.fromLayerVersionArn(\n        scope,\n        `common-layer-${idx}`,\n        arn\n      );\n\n      lambda.addLayers(layer);\n    });\n  }\n};\n"]}
|
package/package.json
CHANGED
|
@@ -20,14 +20,15 @@ export const createBasicLambda = (
|
|
|
20
20
|
|
|
21
21
|
const functionName = `${props.appPrefix || ""}${props.functionName}`;
|
|
22
22
|
|
|
23
|
-
let lambdaFunction = new NodejsFunction(
|
|
23
|
+
let lambdaFunction = new NodejsFunction(scope, functionName, lambdaProps);
|
|
24
|
+
|
|
25
|
+
grantAccessToDynamoTables(
|
|
24
26
|
scope,
|
|
27
|
+
lambdaFunction,
|
|
25
28
|
functionName,
|
|
26
|
-
|
|
29
|
+
props.dynamoTableNames
|
|
27
30
|
);
|
|
28
31
|
|
|
29
|
-
grantAccessToDynamoTables(scope, lambdaFunction, functionName, props.dynamoTableNames);
|
|
30
|
-
|
|
31
32
|
addLambdaLayers(scope, lambdaFunction, functionName, props.lambdaLayerArn);
|
|
32
33
|
|
|
33
34
|
return lambdaFunction;
|
|
@@ -35,6 +36,7 @@ export const createBasicLambda = (
|
|
|
35
36
|
|
|
36
37
|
const createBasicLambdaProps = (props: LambdaProps): NodejsFunctionProps => {
|
|
37
38
|
let resolvedEntry: string;
|
|
39
|
+
let depsLockFilePath: string | undefined = props.depsLockFilePath;
|
|
38
40
|
|
|
39
41
|
if (props.codePath && path.isAbsolute(props.codePath)) {
|
|
40
42
|
resolvedEntry = props.codePath;
|
|
@@ -58,6 +60,18 @@ const createBasicLambdaProps = (props: LambdaProps): NodejsFunctionProps => {
|
|
|
58
60
|
);
|
|
59
61
|
}
|
|
60
62
|
|
|
63
|
+
// When projectRoot is provided, override depsLockFilePath to point to the projectRoot's lock file
|
|
64
|
+
if (props.projectRoot && !depsLockFilePath) {
|
|
65
|
+
const lockFiles = ["pnpm-lock.yaml", "yarn.lock", "package-lock.json"];
|
|
66
|
+
for (const lockFile of lockFiles) {
|
|
67
|
+
const lockPath = path.join(props.projectRoot, lockFile);
|
|
68
|
+
if (require("fs").existsSync(lockPath)) {
|
|
69
|
+
depsLockFilePath = lockPath;
|
|
70
|
+
break;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
|
|
61
75
|
const lambdaProp: NodejsFunctionProps = {
|
|
62
76
|
entry: resolvedEntry,
|
|
63
77
|
functionName: `${props.appPrefix ? `${props.appPrefix}-` : ""}${
|
|
@@ -82,8 +96,8 @@ const createBasicLambdaProps = (props: LambdaProps): NodejsFunctionProps => {
|
|
|
82
96
|
...props.envs,
|
|
83
97
|
},
|
|
84
98
|
...(props.projectRoot && { projectRoot: props.projectRoot }),
|
|
85
|
-
...(
|
|
86
|
-
depsLockFilePath:
|
|
99
|
+
...(depsLockFilePath && {
|
|
100
|
+
depsLockFilePath: depsLockFilePath,
|
|
87
101
|
}),
|
|
88
102
|
},
|
|
89
103
|
role: props.role,
|
|
@@ -97,11 +111,15 @@ const grantAccessToDynamoTables = (
|
|
|
97
111
|
scope: Construct,
|
|
98
112
|
lambda: NodejsFunction,
|
|
99
113
|
functionName: string,
|
|
100
|
-
tableNames?: string[]
|
|
114
|
+
tableNames?: string[]
|
|
101
115
|
) => {
|
|
102
116
|
if (tableNames && tableNames.length > 0) {
|
|
103
117
|
tableNames.forEach((tableName, idx) => {
|
|
104
|
-
const table = Table.fromTableName(
|
|
118
|
+
const table = Table.fromTableName(
|
|
119
|
+
scope,
|
|
120
|
+
`${tableName}-table-${idx}`,
|
|
121
|
+
tableName
|
|
122
|
+
);
|
|
105
123
|
|
|
106
124
|
table.grantReadWriteData(lambda);
|
|
107
125
|
});
|
|
@@ -23,11 +23,7 @@ export const createBasicLambdaTimerJob = (
|
|
|
23
23
|
|
|
24
24
|
const functionName = `${props.appPrefix}${props.functionName}`;
|
|
25
25
|
|
|
26
|
-
let lambdaFunction = new NodejsFunction(
|
|
27
|
-
scope,
|
|
28
|
-
functionName,
|
|
29
|
-
lambdaProps
|
|
30
|
-
);
|
|
26
|
+
let lambdaFunction = new NodejsFunction(scope, functionName, lambdaProps);
|
|
31
27
|
|
|
32
28
|
addInvokePermissionToLambdaForEvents(lambdaFunction, functionName);
|
|
33
29
|
|
|
@@ -48,6 +44,7 @@ export const createBasicLambdaTimerJob = (
|
|
|
48
44
|
|
|
49
45
|
const createBasicLambdaProps = (props: TimerJobProps): NodejsFunctionProps => {
|
|
50
46
|
let resolvedEntry: string;
|
|
47
|
+
let depsLockFilePath: string | undefined = props.depsLockFilePath;
|
|
51
48
|
|
|
52
49
|
if (props.codePath && path.isAbsolute(props.codePath)) {
|
|
53
50
|
resolvedEntry = props.codePath;
|
|
@@ -71,6 +68,18 @@ const createBasicLambdaProps = (props: TimerJobProps): NodejsFunctionProps => {
|
|
|
71
68
|
);
|
|
72
69
|
}
|
|
73
70
|
|
|
71
|
+
// When projectRoot is provided, override depsLockFilePath to point to the projectRoot's lock file
|
|
72
|
+
if (props.projectRoot && !depsLockFilePath) {
|
|
73
|
+
const lockFiles = ["pnpm-lock.yaml", "yarn.lock", "package-lock.json"];
|
|
74
|
+
for (const lockFile of lockFiles) {
|
|
75
|
+
const lockPath = path.join(props.projectRoot, lockFile);
|
|
76
|
+
if (require("fs").existsSync(lockPath)) {
|
|
77
|
+
depsLockFilePath = lockPath;
|
|
78
|
+
break;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
74
83
|
const lambdaProp: NodejsFunctionProps = {
|
|
75
84
|
entry: resolvedEntry,
|
|
76
85
|
functionName: `${props.appPrefix ? `${props.appPrefix}-` : ""}${
|
|
@@ -95,8 +104,8 @@ const createBasicLambdaProps = (props: TimerJobProps): NodejsFunctionProps => {
|
|
|
95
104
|
...props.envs,
|
|
96
105
|
},
|
|
97
106
|
...(props.projectRoot && { projectRoot: props.projectRoot }),
|
|
98
|
-
...(
|
|
99
|
-
depsLockFilePath:
|
|
107
|
+
...(depsLockFilePath && {
|
|
108
|
+
depsLockFilePath: depsLockFilePath,
|
|
100
109
|
}),
|
|
101
110
|
},
|
|
102
111
|
role: props.role,
|
|
@@ -106,7 +115,10 @@ const createBasicLambdaProps = (props: TimerJobProps): NodejsFunctionProps => {
|
|
|
106
115
|
return lambdaProp;
|
|
107
116
|
};
|
|
108
117
|
|
|
109
|
-
const addInvokePermissionToLambdaForEvents = (
|
|
118
|
+
const addInvokePermissionToLambdaForEvents = (
|
|
119
|
+
lambda: NodejsFunction,
|
|
120
|
+
functionName: string
|
|
121
|
+
) => {
|
|
110
122
|
lambda.addPermission(`InvokePermission-${functionName}`, {
|
|
111
123
|
principal: new ServicePrincipal(SERVICE_PRINCIPAL.EVENTS),
|
|
112
124
|
});
|