@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
- ...(props.depsLockFilePath && {
61
- depsLockFilePath: props.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
- ...(props.depsLockFilePath && {
68
- depsLockFilePath: props.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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sylvesterllc/aws-constructs",
3
- "version": "1.1.29",
3
+ "version": "1.1.30",
4
4
  "description": "AWS Constructs",
5
5
  "main": "dist/index.js",
6
6
  "keywords": [
@@ -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
- lambdaProps
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
- ...(props.depsLockFilePath && {
86
- depsLockFilePath: props.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(scope, `${tableName}-table-${idx}`, tableName);
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
- ...(props.depsLockFilePath && {
99
- depsLockFilePath: props.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 = (lambda: NodejsFunction, functionName: string) => {
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
  });