@mrgrain/cdk-esbuild 3.5.0 → 3.7.2

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/lib/bundler.d.ts CHANGED
@@ -1,7 +1,18 @@
1
1
  import { DockerImage, ILocalBundling } from 'aws-cdk-lib';
2
2
  import { BuildOptions } from './esbuild-types';
3
3
  /**
4
- * A relative path or list or map of relative paths to the entry points of your code from the root of the project. E.g. `src/index.ts`.
4
+ * A path or list or map of paths to the entry points of your code.
5
+ *
6
+ * Relative paths are by default resolved from the current working directory.
7
+ * To change the working directory, see `buildOptions.absWorkingDir`.
8
+ *
9
+ * Absolute paths can be used if files are part of the working directory.
10
+ *
11
+ * Examples:
12
+ * - `'src/index.ts'`
13
+ * - `require.resolve('./lambda')`
14
+ * - `['src/index.ts', 'src/util.ts']`
15
+ * - `{one: 'src/two.ts', two: 'src/one.ts'}`
5
16
  *
6
17
  * @stability stable
7
18
  */
@@ -63,6 +74,14 @@ export interface BundlerProps {
63
74
  * @default esbuild.buildSync
64
75
  */
65
76
  readonly buildFn?: any;
77
+ /**
78
+ * Path to the binary used by esbuild.
79
+ *
80
+ * This is the same as setting the ESBUILD_BINARY_PATH environment variable.
81
+ *
82
+ * @stability experimental
83
+ */
84
+ readonly esbuildBinaryPath?: string;
66
85
  }
67
86
  /**
68
87
  * Low-level construct that can be used where `BundlingOptions` are required.
@@ -72,8 +91,18 @@ export interface BundlerProps {
72
91
  */
73
92
  export declare class EsbuildBundler {
74
93
  /**
75
- * A relative path or list or map of relative paths to the entry points of your code from the root of the project.
76
- * E.g. `src/index.ts`.
94
+ * A path or list or map of paths to the entry points of your code.
95
+ *
96
+ * Relative paths are by default resolved from the current working directory.
97
+ * To change the working directory, see `buildOptions.absWorkingDir`.
98
+ *
99
+ * Absolute paths can be used if files are part of the working directory.
100
+ *
101
+ * Examples:
102
+ * - `'src/index.ts'`
103
+ * - `require.resolve('./lambda')`
104
+ * - `['src/index.ts', 'src/util.ts']`
105
+ * - `{one: 'src/two.ts', two: 'src/one.ts'}`
77
106
  *
78
107
  * @stability experimental
79
108
  */
@@ -101,8 +130,18 @@ export declare class EsbuildBundler {
101
130
  */
102
131
  constructor(
103
132
  /**
104
- * A relative path or list or map of relative paths to the entry points of your code from the root of the project.
105
- * E.g. `src/index.ts`.
133
+ * A path or list or map of paths to the entry points of your code.
134
+ *
135
+ * Relative paths are by default resolved from the current working directory.
136
+ * To change the working directory, see `buildOptions.absWorkingDir`.
137
+ *
138
+ * Absolute paths can be used if files are part of the working directory.
139
+ *
140
+ * Examples:
141
+ * - `'src/index.ts'`
142
+ * - `require.resolve('./lambda')`
143
+ * - `['src/index.ts', 'src/util.ts']`
144
+ * - `{one: 'src/two.ts', two: 'src/one.ts'}`
106
145
  *
107
146
  * @stability experimental
108
147
  */
@@ -116,4 +155,3 @@ export declare class EsbuildBundler {
116
155
  private getCopyDirList;
117
156
  private getOutputOptions;
118
157
  }
119
- //# sourceMappingURL=bundler.d.ts.map
package/lib/bundler.js CHANGED
@@ -20,8 +20,18 @@ class EsbuildBundler {
20
20
  */
21
21
  constructor(
22
22
  /**
23
- * A relative path or list or map of relative paths to the entry points of your code from the root of the project.
24
- * E.g. `src/index.ts`.
23
+ * A path or list or map of paths to the entry points of your code.
24
+ *
25
+ * Relative paths are by default resolved from the current working directory.
26
+ * To change the working directory, see `buildOptions.absWorkingDir`.
27
+ *
28
+ * Absolute paths can be used if files are part of the working directory.
29
+ *
30
+ * Examples:
31
+ * - `'src/index.ts'`
32
+ * - `require.resolve('./lambda')`
33
+ * - `['src/index.ts', 'src/util.ts']`
34
+ * - `{one: 'src/two.ts', two: 'src/one.ts'}`
25
35
  *
26
36
  * @stability experimental
27
37
  */
@@ -32,7 +42,6 @@ class EsbuildBundler {
32
42
  * @stability experimental
33
43
  */
34
44
  props) {
35
- var _b, _c;
36
45
  this.entryPoints = entryPoints;
37
46
  this.props = props;
38
47
  /**
@@ -41,18 +50,16 @@ class EsbuildBundler {
41
50
  * @stability deprecated
42
51
  */
43
52
  this.image = aws_cdk_lib_1.DockerImage.fromRegistry('scratch');
44
- if (((_b = props === null || props === void 0 ? void 0 : props.buildOptions) === null || _b === void 0 ? void 0 : _b.outfile) && ((_c = props === null || props === void 0 ? void 0 : props.buildOptions) === null || _c === void 0 ? void 0 : _c.outdir)) {
53
+ if (props?.buildOptions?.outfile && props?.buildOptions?.outdir) {
45
54
  throw new Error('Cannot use both "outfile" and "outdir"');
46
55
  }
47
56
  const { buildFn = esbuild_wrapper_1.buildSync } = this.props;
48
57
  this.local = {
49
58
  tryBundle: (outputDir, _options) => {
50
- var _b;
51
59
  if (this.props.copyDir) {
52
60
  const copyDir = this.getCopyDirList(this.props.copyDir);
53
61
  copyDir.forEach(([dest, src]) => {
54
- var _b, _c, _d;
55
- const srcDir = path_1.resolve((_d = (_c = (_b = this.props) === null || _b === void 0 ? void 0 : _b.buildOptions) === null || _c === void 0 ? void 0 : _c.absWorkingDir) !== null && _d !== void 0 ? _d : process.cwd(), src);
62
+ const srcDir = path_1.resolve(this.props?.buildOptions?.absWorkingDir ?? process.cwd(), src);
56
63
  const destDir = path_1.resolve(outputDir, dest);
57
64
  const destToOutput = path_1.relative(outputDir, destDir);
58
65
  if (destToOutput.startsWith('..') || path_1.isAbsolute(destToOutput)) {
@@ -62,10 +69,14 @@ class EsbuildBundler {
62
69
  aws_cdk_lib_1.FileSystem.copyDirectory(srcDir, destDir);
63
70
  });
64
71
  }
72
+ const originalEsbuildBinaryPath = process.env.ESBUILD_BINARY_PATH;
73
+ if (this.props.esbuildBinaryPath) {
74
+ process.env.ESBUILD_BINARY_PATH = this.props.esbuildBinaryPath;
75
+ }
65
76
  try {
66
77
  const buildResult = buildFn({
67
78
  entryPoints,
68
- ...(((_b = this.props) === null || _b === void 0 ? void 0 : _b.buildOptions) || {}),
79
+ ...(this.props?.buildOptions || {}),
69
80
  ...this.getOutputOptions(outputDir, { normalize: path_1.normalize, join: path_1.join }),
70
81
  });
71
82
  formatMessages_1.printBuildMessages(buildResult, { prefix: 'Build ' });
@@ -73,6 +84,13 @@ class EsbuildBundler {
73
84
  catch (error) {
74
85
  formatMessages_1.printBuildMessages(error, { prefix: 'Build ' });
75
86
  }
87
+ /**
88
+ * only reset `ESBUILD_BINARY_PATH` if it was explicitly set via the construct props
89
+ * since `esbuild` itself sometimes sets it (eg. when running in yarn 2 plug&play)
90
+ */
91
+ if (this.props.esbuildBinaryPath) {
92
+ process.env.ESBUILD_BINARY_PATH = originalEsbuildBinaryPath;
93
+ }
76
94
  return true;
77
95
  },
78
96
  };
@@ -103,20 +121,19 @@ class EsbuildBundler {
103
121
  return [['.', copyDir]];
104
122
  }
105
123
  getOutputOptions(cdkOutputDir, path = path_1.posix) {
106
- var _b, _c, _d, _e, _f, _g;
107
- if ((_c = (_b = this.props) === null || _b === void 0 ? void 0 : _b.buildOptions) === null || _c === void 0 ? void 0 : _c.outfile) {
124
+ if (this.props?.buildOptions?.outfile) {
108
125
  return {
109
126
  outdir: undefined,
110
- outfile: path.normalize(path.join(...[cdkOutputDir, (_e = (_d = this.props) === null || _d === void 0 ? void 0 : _d.buildOptions) === null || _e === void 0 ? void 0 : _e.outfile].filter(Boolean))),
127
+ outfile: path.normalize(path.join(...[cdkOutputDir, this.props?.buildOptions?.outfile].filter(Boolean))),
111
128
  };
112
129
  }
113
130
  return {
114
- outdir: path.normalize(path.join(...[cdkOutputDir, (_g = (_f = this.props) === null || _f === void 0 ? void 0 : _f.buildOptions) === null || _g === void 0 ? void 0 : _g.outdir].filter(Boolean))),
131
+ outdir: path.normalize(path.join(...[cdkOutputDir, this.props?.buildOptions?.outdir].filter(Boolean))),
115
132
  outfile: undefined,
116
133
  };
117
134
  }
118
135
  }
119
136
  exports.EsbuildBundler = EsbuildBundler;
120
137
  _a = JSII_RTTI_SYMBOL_1;
121
- EsbuildBundler[_a] = { fqn: "@mrgrain/cdk-esbuild.EsbuildBundler", version: "3.5.0" };
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundler.js","sourceRoot":"","sources":["../src/bundler.ts"],"names":[],"mappings":"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","sourcesContent":["import { mkdirSync } from 'fs';\nimport { join, normalize, relative, resolve, posix, isAbsolute } from 'path';\nimport {\n  BundlingOptions,\n  DockerImage,\n  FileSystem,\n  ILocalBundling,\n} from 'aws-cdk-lib';\nimport { BuildFailure, BuildOptions, BuildResult } from './esbuild-types';\nimport { buildSync } from './esbuild-wrapper';\nimport { printBuildMessages } from './formatMessages';\n\n/**\n * A relative path or list or map of relative paths to the entry points of your code from the root of the project. E.g. `src/index.ts`.\n *\n * @stability stable\n */\nexport type EntryPoints = string | string[] | Record<string, string>;\n\n/**\n * @stability stable\n */\nexport interface BundlerProps {\n  /**\n   * Build options passed on to esbuild. Please refer to the esbuild Build API docs for details.\n   *\n   * * `buildOptions.outdir: string`\n   * The actual path for the output directory is defined by CDK. However setting this option allows to write files into a subdirectory. \\\n   * For example `{ outdir: 'js' }` will create an asset with a single directory called `js`, which contains all built files. This approach can be useful for static website deployments, where JavaScript code should be placed into a subdirectory. \\\n   * *Cannot be used together with `outfile`*.\n   * * `buildOptions.outfile: string`\n   * Relative path to a file inside the CDK asset output directory.\n   * For example `{ outfile: 'js/index.js' }` will create an asset with a single directory called `js`, which contains a single file `index.js`. This can be useful to rename the entry point. \\\n   * *Cannot be used with multiple entryPoints or together with `outdir`.*\n   * * `buildOptions.absWorkingDir: string`\n   * Absolute path to the [esbuild working directory](https://esbuild.github.io/api/#working-directory) and defaults to the [current working directory](https://en.wikipedia.org/wiki/Working_directory). \\\n   * If paths cannot be found, a good starting point is to look at the concatenation of `absWorkingDir + entryPoint`. It must always be a valid absolute path pointing to the entry point. When needed, the probably easiest way to set absWorkingDir is to use a combination of `resolve` and `__dirname` (see \"Library authors\" section in the documentation).\n   *\n   * @see https://esbuild.github.io/api/#build-api\n   * @stability stable\n   */\n  readonly buildOptions?: BuildOptions;\n\n  /**\n   * Copy additional files to the code [asset staging directory](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.AssetStaging.html#absolutestagedpath), before the build runs.\n   * Files copied like this will be overwritten by esbuild if they share the same name as any of the outputs.\n   *\n   * * When provided with a `string` or `array`, all files are copied to the root of asset staging directory.\n   * * When given a `map`, the key indicates the destination relative to the asset staging directory and the value is a list of all sources to be copied.\n   *\n   * Therefore the following values for `copyDir` are all equivalent:\n   * ```ts\n   * { copyDir: \"path/to/source\" }\n   * { copyDir: [\"path/to/source\"] }\n   * { copyDir: { \".\": \"path/to/source\" } }\n   * { copyDir: { \".\": [\"path/to/source\"] } }\n   * ```\n   * The destination cannot be outside of the asset staging directory.\n   * If you are receiving the error \"Cannot copy files to outside of the asset staging directory.\"\n   * you are likely using `..` or an absolute path as key on the `copyDir` map.\n   * Instead use only relative paths and avoid `..`.\n   *\n   * @stability stable\n   */\n  readonly copyDir?: string | string[] | Record<string, string | string []>;\n\n\n  /**\n   * Escape hatch to provide the bundler with a custom build function.\n   * The function will receive the computed options from the bundler. It can use with these options as it wishes, however `outdir`/`outfile` must be respected to integrate with CDK.\n   * Must throw a `BuildFailure` on failure to correctly inform the bundler.\n   *\n   * @stability experimental\n   * @type esbuild.buildSync\n   * @returns esbuild.BuildResult\n   * @throws esbuild.BuildFailure\n   * @default esbuild.buildSync\n   */\n  readonly buildFn?: any;\n}\n\n/**\n * Low-level construct that can be used where `BundlingOptions` are required.\n * This class directly interfaces with esbuild and provides almost no configuration safeguards.\n *\n * @stability experimental\n */\nexport class EsbuildBundler {\n  /**\n   * Implementation of `ILocalBundling` interface, responsible for calling esbuild functions.\n   *\n   * @stability experimental\n   */\n  public readonly local: ILocalBundling;\n\n  /**\n   * @deprecated This value is ignored since the bundler is always using a locally installed version of esbuild. However the property is required to comply with the `BundlingOptions` interface.\n   *\n   * @stability deprecated\n   */\n  public readonly image = DockerImage.fromRegistry('scratch');\n\n  /**\n   * @stability experimental\n   */\n  public constructor(\n    /**\n     * A relative path or list or map of relative paths to the entry points of your code from the root of the project.\n     * E.g. `src/index.ts`.\n     *\n     * @stability experimental\n     */\n    public readonly entryPoints: EntryPoints,\n\n    /**\n     * Props to change the behaviour of the bundler.\n     *\n     * @stability experimental\n     */\n    public readonly props: BundlerProps,\n  ) {\n    if (props?.buildOptions?.outfile && props?.buildOptions?.outdir) {\n      throw new Error('Cannot use both \"outfile\" and \"outdir\"');\n    }\n\n    const { buildFn = buildSync } = this.props;\n\n    this.local = {\n      tryBundle: (outputDir: string, _options: BundlingOptions): boolean => {\n\n        if (this.props.copyDir) {\n          const copyDir = this.getCopyDirList(this.props.copyDir);\n\n          copyDir.forEach(([dest, src]) => {\n            const srcDir = resolve(\n              this.props?.buildOptions?.absWorkingDir ?? process.cwd(),\n              src,\n            );\n            const destDir = resolve(outputDir, dest) ;\n\n            const destToOutput = relative(outputDir, destDir);\n            if (destToOutput.startsWith('..') || isAbsolute(destToOutput)) {\n              throw new Error('Cannot copy files to outside of the asset staging directory. See docs for details.');\n            }\n\n            mkdirSync(destDir, { recursive: true });\n            FileSystem.copyDirectory(srcDir, destDir);\n          });\n        }\n\n        try {\n          const buildResult: BuildResult = buildFn({\n            entryPoints,\n            ...(this.props?.buildOptions || {}),\n            ...this.getOutputOptions(outputDir, { normalize, join }),\n          });\n\n          printBuildMessages(buildResult, { prefix: 'Build ' });\n        } catch (error) {\n          printBuildMessages(error as BuildFailure, { prefix: 'Build ' });\n        }\n\n        return true;\n      },\n    };\n  }\n\n  private getCopyDirList(copyDir: BundlerProps['copyDir']): Array<[string, string]> {\n    // Nothing to copy\n    if (!copyDir) {\n      return [];\n    }\n\n    // List of strings\n    if (Array.isArray(copyDir)) {\n      return copyDir.map((src: string) => ['.', src]);\n    }\n\n    // A map\n    if (\n      typeof copyDir === 'object' &&\n      !Array.isArray(copyDir) &&\n      copyDir !== null\n    ) {\n      return Object\n        .entries(copyDir)\n        .flatMap(([dest, sources]) => {\n          if (Array.isArray(sources)) {\n            return sources.map((src) => [dest, src]) as Array<[string, string]>;\n          }\n\n          return [[dest, sources]];\n        });\n    }\n\n    // A single string\n    return [['.', copyDir as string]];\n  }\n\n  private getOutputOptions(\n    cdkOutputDir: string,\n    path: Pick<typeof posix, 'normalize' | 'join'> = posix,\n  ): BuildOptions {\n    if (this.props?.buildOptions?.outfile) {\n      return {\n        outdir: undefined,\n        outfile: path.normalize(\n          path.join(\n            ...([cdkOutputDir, this.props?.buildOptions?.outfile].filter(\n              Boolean,\n            ) as string[]),\n          ),\n        ),\n      };\n    }\n\n    return {\n      outdir: path.normalize(\n        path.join(\n          ...([cdkOutputDir, this.props?.buildOptions?.outdir].filter(\n            Boolean,\n          ) as string[]),\n        ),\n      ),\n      outfile: undefined,\n    };\n  }\n}\n"]}
138
+ EsbuildBundler[_a] = { fqn: "@mrgrain/cdk-esbuild.EsbuildBundler", version: "3.7.2" };
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundler.js","sourceRoot":"","sources":["../src/bundler.ts"],"names":[],"mappings":"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","sourcesContent":["import { mkdirSync } from 'fs';\nimport { join, normalize, relative, resolve, posix, isAbsolute } from 'path';\nimport {\n  BundlingOptions,\n  DockerImage,\n  FileSystem,\n  ILocalBundling,\n} from 'aws-cdk-lib';\nimport { BuildFailure, BuildOptions, BuildResult } from './esbuild-types';\nimport { buildSync } from './esbuild-wrapper';\nimport { printBuildMessages } from './formatMessages';\n\n/**\n * A path or list or map of paths to the entry points of your code.\n *\n * Relative paths are by default resolved from the current working directory.\n * To change the working directory, see `buildOptions.absWorkingDir`.\n *\n * Absolute paths can be used if files are part of the working directory.\n *\n * Examples:\n *  - `'src/index.ts'`\n *  - `require.resolve('./lambda')`\n *  - `['src/index.ts', 'src/util.ts']`\n *  - `{one: 'src/two.ts', two: 'src/one.ts'}`\n *\n * @stability stable\n */\nexport type EntryPoints = string | string[] | Record<string, string>;\n\n/**\n * @stability stable\n */\nexport interface BundlerProps {\n  /**\n   * Build options passed on to esbuild. Please refer to the esbuild Build API docs for details.\n   *\n   * * `buildOptions.outdir: string`\n   * The actual path for the output directory is defined by CDK. However setting this option allows to write files into a subdirectory. \\\n   * For example `{ outdir: 'js' }` will create an asset with a single directory called `js`, which contains all built files. This approach can be useful for static website deployments, where JavaScript code should be placed into a subdirectory. \\\n   * *Cannot be used together with `outfile`*.\n   * * `buildOptions.outfile: string`\n   * Relative path to a file inside the CDK asset output directory.\n   * For example `{ outfile: 'js/index.js' }` will create an asset with a single directory called `js`, which contains a single file `index.js`. This can be useful to rename the entry point. \\\n   * *Cannot be used with multiple entryPoints or together with `outdir`.*\n   * * `buildOptions.absWorkingDir: string`\n   * Absolute path to the [esbuild working directory](https://esbuild.github.io/api/#working-directory) and defaults to the [current working directory](https://en.wikipedia.org/wiki/Working_directory). \\\n   * If paths cannot be found, a good starting point is to look at the concatenation of `absWorkingDir + entryPoint`. It must always be a valid absolute path pointing to the entry point. When needed, the probably easiest way to set absWorkingDir is to use a combination of `resolve` and `__dirname` (see \"Library authors\" section in the documentation).\n   *\n   * @see https://esbuild.github.io/api/#build-api\n   * @stability stable\n   */\n  readonly buildOptions?: BuildOptions;\n\n  /**\n   * Copy additional files to the code [asset staging directory](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.AssetStaging.html#absolutestagedpath), before the build runs.\n   * Files copied like this will be overwritten by esbuild if they share the same name as any of the outputs.\n   *\n   * * When provided with a `string` or `array`, all files are copied to the root of asset staging directory.\n   * * When given a `map`, the key indicates the destination relative to the asset staging directory and the value is a list of all sources to be copied.\n   *\n   * Therefore the following values for `copyDir` are all equivalent:\n   * ```ts\n   * { copyDir: \"path/to/source\" }\n   * { copyDir: [\"path/to/source\"] }\n   * { copyDir: { \".\": \"path/to/source\" } }\n   * { copyDir: { \".\": [\"path/to/source\"] } }\n   * ```\n   * The destination cannot be outside of the asset staging directory.\n   * If you are receiving the error \"Cannot copy files to outside of the asset staging directory.\"\n   * you are likely using `..` or an absolute path as key on the `copyDir` map.\n   * Instead use only relative paths and avoid `..`.\n   *\n   * @stability stable\n   */\n  readonly copyDir?: string | string[] | Record<string, string | string []>;\n\n\n  /**\n   * Escape hatch to provide the bundler with a custom build function.\n   * The function will receive the computed options from the bundler. It can use with these options as it wishes, however `outdir`/`outfile` must be respected to integrate with CDK.\n   * Must throw a `BuildFailure` on failure to correctly inform the bundler.\n   *\n   * @stability experimental\n   * @type esbuild.buildSync\n   * @returns esbuild.BuildResult\n   * @throws esbuild.BuildFailure\n   * @default esbuild.buildSync\n   */\n  readonly buildFn?: any;\n\n  /**\n   * Path to the binary used by esbuild.\n   *\n   * This is the same as setting the ESBUILD_BINARY_PATH environment variable.\n   *\n   * @stability experimental\n   */\n  readonly esbuildBinaryPath?: string;\n}\n\n/**\n * Low-level construct that can be used where `BundlingOptions` are required.\n * This class directly interfaces with esbuild and provides almost no configuration safeguards.\n *\n * @stability experimental\n */\nexport class EsbuildBundler {\n  /**\n   * Implementation of `ILocalBundling` interface, responsible for calling esbuild functions.\n   *\n   * @stability experimental\n   */\n  public readonly local: ILocalBundling;\n\n  /**\n   * @deprecated This value is ignored since the bundler is always using a locally installed version of esbuild. However the property is required to comply with the `BundlingOptions` interface.\n   *\n   * @stability deprecated\n   */\n  public readonly image = DockerImage.fromRegistry('scratch');\n\n  /**\n   * @stability experimental\n   */\n  public constructor(\n    /**\n     * A path or list or map of paths to the entry points of your code.\n     *\n     * Relative paths are by default resolved from the current working directory.\n     * To change the working directory, see `buildOptions.absWorkingDir`.\n     *\n     * Absolute paths can be used if files are part of the working directory.\n     *\n     * Examples:\n     *  - `'src/index.ts'`\n     *  - `require.resolve('./lambda')`\n     *  - `['src/index.ts', 'src/util.ts']`\n     *  - `{one: 'src/two.ts', two: 'src/one.ts'}`\n     *\n     * @stability experimental\n     */\n    public readonly entryPoints: EntryPoints,\n\n    /**\n     * Props to change the behaviour of the bundler.\n     *\n     * @stability experimental\n     */\n    public readonly props: BundlerProps,\n  ) {\n    if (props?.buildOptions?.outfile && props?.buildOptions?.outdir) {\n      throw new Error('Cannot use both \"outfile\" and \"outdir\"');\n    }\n\n    const { buildFn = buildSync } = this.props;\n\n    this.local = {\n      tryBundle: (outputDir: string, _options: BundlingOptions): boolean => {\n\n        if (this.props.copyDir) {\n          const copyDir = this.getCopyDirList(this.props.copyDir);\n\n          copyDir.forEach(([dest, src]) => {\n            const srcDir = resolve(\n              this.props?.buildOptions?.absWorkingDir ?? process.cwd(),\n              src,\n            );\n            const destDir = resolve(outputDir, dest) ;\n\n            const destToOutput = relative(outputDir, destDir);\n            if (destToOutput.startsWith('..') || isAbsolute(destToOutput)) {\n              throw new Error('Cannot copy files to outside of the asset staging directory. See docs for details.');\n            }\n\n            mkdirSync(destDir, { recursive: true });\n            FileSystem.copyDirectory(srcDir, destDir);\n          });\n        }\n\n        const originalEsbuildBinaryPath = process.env.ESBUILD_BINARY_PATH;\n        if (this.props.esbuildBinaryPath) {\n          process.env.ESBUILD_BINARY_PATH = this.props.esbuildBinaryPath;\n        }\n\n        try {\n          const buildResult: BuildResult = buildFn({\n            entryPoints,\n            ...(this.props?.buildOptions || {}),\n            ...this.getOutputOptions(outputDir, { normalize, join }),\n          });\n\n          printBuildMessages(buildResult, { prefix: 'Build ' });\n        } catch (error) {\n          printBuildMessages(error as BuildFailure, { prefix: 'Build ' });\n        }\n\n        /**\n         * only reset `ESBUILD_BINARY_PATH` if it was explicitly set via the construct props\n         * since `esbuild` itself sometimes sets it (eg. when running in yarn 2 plug&play)\n         */\n        if (this.props.esbuildBinaryPath) {\n          process.env.ESBUILD_BINARY_PATH = originalEsbuildBinaryPath;\n        }\n\n        return true;\n      },\n    };\n  }\n\n  private getCopyDirList(copyDir: BundlerProps['copyDir']): Array<[string, string]> {\n    // Nothing to copy\n    if (!copyDir) {\n      return [];\n    }\n\n    // List of strings\n    if (Array.isArray(copyDir)) {\n      return copyDir.map((src: string) => ['.', src]);\n    }\n\n    // A map\n    if (\n      typeof copyDir === 'object' &&\n      !Array.isArray(copyDir) &&\n      copyDir !== null\n    ) {\n      return Object\n        .entries(copyDir)\n        .flatMap(([dest, sources]) => {\n          if (Array.isArray(sources)) {\n            return sources.map((src) => [dest, src]) as Array<[string, string]>;\n          }\n\n          return [[dest, sources]];\n        });\n    }\n\n    // A single string\n    return [['.', copyDir as string]];\n  }\n\n  private getOutputOptions(\n    cdkOutputDir: string,\n    path: Pick<typeof posix, 'normalize' | 'join'> = posix,\n  ): BuildOptions {\n    if (this.props?.buildOptions?.outfile) {\n      return {\n        outdir: undefined,\n        outfile: path.normalize(\n          path.join(\n            ...([cdkOutputDir, this.props?.buildOptions?.outfile].filter(\n              Boolean,\n            ) as string[]),\n          ),\n        ),\n      };\n    }\n\n    return {\n      outdir: path.normalize(\n        path.join(\n          ...([cdkOutputDir, this.props?.buildOptions?.outdir].filter(\n            Boolean,\n          ) as string[]),\n        ),\n      ),\n      outfile: undefined,\n    };\n  }\n}\n"]}
package/lib/code.d.ts CHANGED
@@ -1,38 +1,76 @@
1
1
  import { CfnResource } from 'aws-cdk-lib';
2
- import { ResourceBindOptions } from 'aws-cdk-lib/aws-lambda';
3
- import { Location } from 'aws-cdk-lib/aws-s3';
2
+ import { ResourceBindOptions, Code, CodeConfig } from 'aws-cdk-lib/aws-lambda';
4
3
  import { Construct } from 'constructs';
5
- import { AssetBaseProps, AssetProps, JavaScriptAsset as JSAsset, TypeScriptAsset as TSAsset } from './asset';
4
+ import { EsbuildAsset, AssetBaseProps, AssetProps } from './asset';
6
5
  import { EntryPoints } from './bundler';
7
- export interface CodeConfig {
8
- /**
9
- * The location of the code in S3.
10
- *
11
- * @stability stable
12
- */
13
- readonly s3Location: Location;
14
- }
6
+ export { CodeConfig } from 'aws-cdk-lib/aws-lambda';
15
7
  export interface JavaScriptCodeProps extends AssetBaseProps {
16
8
  }
17
9
  export interface TypeScriptCodeProps extends AssetBaseProps {
18
10
  }
19
- declare abstract class Code<Props extends JavaScriptCodeProps | TypeScriptCodeProps, Asset extends JSAsset | TSAsset> {
11
+ /**
12
+ * Represents a generic esbuild code bundle.
13
+ *
14
+ * You should always use `TypeScriptCode` or `JavaScriptCode`.
15
+ *
16
+ * @stability experimental
17
+ */
18
+ export declare class EsbuildCode<Props extends JavaScriptCodeProps | TypeScriptCodeProps> extends Code {
19
+ /**
20
+ * A path or list or map of paths to the entry points of your code.
21
+ *
22
+ * Relative paths are by default resolved from the current working directory.
23
+ * To change the working directory, see `buildOptions.absWorkingDir`.
24
+ *
25
+ * Absolute paths can be used if files are part of the working directory.
26
+ *
27
+ * Examples:
28
+ * - `'src/index.ts'`
29
+ * - `require.resolve('./lambda')`
30
+ * - `['src/index.ts', 'src/util.ts']`
31
+ * - `{one: 'src/two.ts', two: 'src/one.ts'}`
32
+ *
33
+ * @stability stable
34
+ */
20
35
  readonly entryPoints: EntryPoints;
21
- protected abstract readonly assetClass: new (scope: Construct, id: string, props: AssetProps) => Asset;
36
+ protected getAsset(scope: Construct): EsbuildAsset<AssetProps>;
22
37
  protected props: AssetProps;
23
- protected asset: Asset;
38
+ protected asset: EsbuildAsset<AssetProps>;
24
39
  /**
25
40
  * Determines whether this Code is inline code or not.
26
41
  *
27
42
  * @deprecated this value is ignored since inline is now determined based on the the inlineCode field of CodeConfig returned from bind().
28
43
  */
29
44
  isInline: boolean;
45
+ constructor(
46
+ /**
47
+ * A path or list or map of paths to the entry points of your code.
48
+ *
49
+ * Relative paths are by default resolved from the current working directory.
50
+ * To change the working directory, see `buildOptions.absWorkingDir`.
51
+ *
52
+ * Absolute paths can be used if files are part of the working directory.
53
+ *
54
+ * Examples:
55
+ * - `'src/index.ts'`
56
+ * - `require.resolve('./lambda')`
57
+ * - `['src/index.ts', 'src/util.ts']`
58
+ * - `{one: 'src/two.ts', two: 'src/one.ts'}`
59
+ *
60
+ * @stability stable
61
+ */
62
+ entryPoints: EntryPoints,
30
63
  /**
64
+ * Props to change the behavior of the bundler.
31
65
  *
32
- * @param entryPoints - Relative path to the asset code. Use `props.buildOptions.absWorkingDir` if an absolute path is required.
33
- * @param props - Asset properties.
66
+ * Default values for `props.buildOptions`:
67
+ * - `bundle=true`
68
+ * - `platform=node`
69
+ * - `target=nodeX` with X being the major node version running locally
70
+ *
71
+ * @stability stable
34
72
  */
35
- constructor(entryPoints: EntryPoints, props: Props);
73
+ props: Props);
36
74
  bind(scope: Construct): CodeConfig;
37
75
  /**
38
76
  * Called after the CFN function resource has been created to allow the code class to bind to it.
@@ -49,12 +87,22 @@ declare abstract class Code<Props extends JavaScriptCodeProps | TypeScriptCodePr
49
87
  *
50
88
  * @stability stable
51
89
  */
52
- export declare class JavaScriptCode extends Code<JavaScriptCodeProps, JSAsset> {
53
- protected readonly assetClass: typeof JSAsset;
90
+ export declare class JavaScriptCode extends EsbuildCode<JavaScriptCodeProps> {
91
+ protected getAsset(scope: Construct): EsbuildAsset<AssetProps>;
54
92
  constructor(
55
93
  /**
56
- * A relative path or list or map of relative paths to the entry points of your code from the root of the project.
57
- * E.g. `src/index.ts`.
94
+ * A path or list or map of paths to the entry points of your code.
95
+ *
96
+ * Relative paths are by default resolved from the current working directory.
97
+ * To change the working directory, see `buildOptions.absWorkingDir`.
98
+ *
99
+ * Absolute paths can be used if files are part of the working directory.
100
+ *
101
+ * Examples:
102
+ * - `'src/index.ts'`
103
+ * - `require.resolve('./lambda')`
104
+ * - `['src/index.ts', 'src/util.ts']`
105
+ * - `{one: 'src/two.ts', two: 'src/one.ts'}`
58
106
  *
59
107
  * @stability stable
60
108
  */
@@ -76,12 +124,22 @@ export declare class JavaScriptCode extends Code<JavaScriptCodeProps, JSAsset> {
76
124
  *
77
125
  * @stability stable
78
126
  */
79
- export declare class TypeScriptCode extends Code<TypeScriptCodeProps, TSAsset> {
80
- protected readonly assetClass: typeof TSAsset;
127
+ export declare class TypeScriptCode extends EsbuildCode<TypeScriptCodeProps> {
128
+ protected getAsset(scope: Construct): EsbuildAsset<AssetProps>;
81
129
  constructor(
82
130
  /**
83
- * A relative path or list or map of relative paths to the entry points of your code from the root of the project.
84
- * E.g. `src/index.ts`.
131
+ * A path or list or map of paths to the entry points of your code.
132
+ *
133
+ * Relative paths are by default resolved from the current working directory.
134
+ * To change the working directory, see `buildOptions.absWorkingDir`.
135
+ *
136
+ * Absolute paths can be used if files are part of the working directory.
137
+ *
138
+ * Examples:
139
+ * - `'src/index.ts'`
140
+ * - `require.resolve('./lambda')`
141
+ * - `['src/index.ts', 'src/util.ts']`
142
+ * - `{one: 'src/two.ts', two: 'src/one.ts'}`
85
143
  *
86
144
  * @stability stable
87
145
  */
@@ -98,5 +156,3 @@ export declare class TypeScriptCode extends Code<TypeScriptCodeProps, TSAsset> {
98
156
  */
99
157
  props?: TypeScriptCodeProps);
100
158
  }
101
- export {};
102
- //# sourceMappingURL=code.d.ts.map
package/lib/code.js CHANGED
@@ -1,23 +1,54 @@
1
1
  "use strict";
2
- var _a, _b;
2
+ var _a, _b, _c;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.TypeScriptCode = exports.JavaScriptCode = void 0;
4
+ exports.TypeScriptCode = exports.JavaScriptCode = exports.EsbuildCode = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const aws_cdk_lib_1 = require("aws-cdk-lib");
7
+ const aws_lambda_1 = require("aws-cdk-lib/aws-lambda");
7
8
  const asset_1 = require("./asset");
8
9
  function nodeMajorVersion() {
9
10
  return parseInt(process.versions.node.split('.')[0], 10);
10
11
  }
11
12
  ;
12
13
  ;
13
- class Code {
14
+ /**
15
+ * Represents a generic esbuild code bundle.
16
+ *
17
+ * You should always use `TypeScriptCode` or `JavaScriptCode`.
18
+ *
19
+ * @stability experimental
20
+ */
21
+ class EsbuildCode extends aws_lambda_1.Code {
22
+ constructor(
14
23
  /**
24
+ * A path or list or map of paths to the entry points of your code.
15
25
  *
16
- * @param entryPoints - Relative path to the asset code. Use `props.buildOptions.absWorkingDir` if an absolute path is required.
17
- * @param props - Asset properties.
26
+ * Relative paths are by default resolved from the current working directory.
27
+ * To change the working directory, see `buildOptions.absWorkingDir`.
28
+ *
29
+ * Absolute paths can be used if files are part of the working directory.
30
+ *
31
+ * Examples:
32
+ * - `'src/index.ts'`
33
+ * - `require.resolve('./lambda')`
34
+ * - `['src/index.ts', 'src/util.ts']`
35
+ * - `{one: 'src/two.ts', two: 'src/one.ts'}`
36
+ *
37
+ * @stability stable
18
38
  */
19
- constructor(entryPoints, props) {
20
- var _c, _d;
39
+ entryPoints,
40
+ /**
41
+ * Props to change the behavior of the bundler.
42
+ *
43
+ * Default values for `props.buildOptions`:
44
+ * - `bundle=true`
45
+ * - `platform=node`
46
+ * - `target=nodeX` with X being the major node version running locally
47
+ *
48
+ * @stability stable
49
+ */
50
+ props) {
51
+ super();
21
52
  this.entryPoints = entryPoints;
22
53
  /**
23
54
  * Determines whether this Code is inline code or not.
@@ -26,8 +57,8 @@ class Code {
26
57
  */
27
58
  this.isInline = false;
28
59
  const defaultOptions = {
29
- ...(!((_c = props.buildOptions) === null || _c === void 0 ? void 0 : _c.platform) ||
30
- ((_d = props.buildOptions) === null || _d === void 0 ? void 0 : _d.platform) === 'node'
60
+ ...(!props.buildOptions?.platform ||
61
+ props.buildOptions?.platform === 'node'
31
62
  ? { platform: 'node', target: 'node' + nodeMajorVersion() }
32
63
  : {}),
33
64
  };
@@ -40,10 +71,13 @@ class Code {
40
71
  },
41
72
  };
42
73
  }
74
+ getAsset(scope) {
75
+ return new asset_1.EsbuildAsset(scope, this.constructor.name, this.props);
76
+ }
43
77
  bind(scope) {
44
78
  // If the same AssetCode is used multiple times, retain only the first instantiation.
45
79
  if (!this.asset) {
46
- this.asset = new this.assetClass(scope, this.constructor.name, this.props);
80
+ this.asset = this.getAsset(scope);
47
81
  }
48
82
  else if (aws_cdk_lib_1.Stack.of(this.asset) !== aws_cdk_lib_1.Stack.of(scope)) {
49
83
  throw new Error(`Asset is already associated with another stack '${aws_cdk_lib_1.Stack.of(this.asset).stackName}'. ` + 'Create a new Asset instance for every stack.');
@@ -67,21 +101,34 @@ class Code {
67
101
  if (!this.asset) {
68
102
  throw new Error('bindToResource() must be called after bind()');
69
103
  }
70
- const resourceProperty = (options === null || options === void 0 ? void 0 : options.resourceProperty) || this.constructor.name;
104
+ const resourceProperty = options?.resourceProperty || this.constructor.name;
71
105
  // https://github.com/aws/aws-cdk/issues/1432
72
106
  this.asset.addResourceMetadata(resource, resourceProperty);
73
107
  }
74
108
  }
109
+ exports.EsbuildCode = EsbuildCode;
110
+ _a = JSII_RTTI_SYMBOL_1;
111
+ EsbuildCode[_a] = { fqn: "@mrgrain/cdk-esbuild.EsbuildCode", version: "3.7.2" };
75
112
  /**
76
113
  * Represents the deployed JavaScript Code.
77
114
  *
78
115
  * @stability stable
79
116
  */
80
- class JavaScriptCode extends Code {
117
+ class JavaScriptCode extends EsbuildCode {
81
118
  constructor(
82
119
  /**
83
- * A relative path or list or map of relative paths to the entry points of your code from the root of the project.
84
- * E.g. `src/index.ts`.
120
+ * A path or list or map of paths to the entry points of your code.
121
+ *
122
+ * Relative paths are by default resolved from the current working directory.
123
+ * To change the working directory, see `buildOptions.absWorkingDir`.
124
+ *
125
+ * Absolute paths can be used if files are part of the working directory.
126
+ *
127
+ * Examples:
128
+ * - `'src/index.ts'`
129
+ * - `require.resolve('./lambda')`
130
+ * - `['src/index.ts', 'src/util.ts']`
131
+ * - `{one: 'src/two.ts', two: 'src/one.ts'}`
85
132
  *
86
133
  * @stability stable
87
134
  */
@@ -98,22 +145,34 @@ class JavaScriptCode extends Code {
98
145
  */
99
146
  props = {}) {
100
147
  super(entryPoints, props);
101
- this.assetClass = asset_1.JavaScriptAsset;
148
+ }
149
+ getAsset(scope) {
150
+ return new asset_1.JavaScriptAsset(scope, this.constructor.name, this.props);
102
151
  }
103
152
  }
104
153
  exports.JavaScriptCode = JavaScriptCode;
105
- _a = JSII_RTTI_SYMBOL_1;
106
- JavaScriptCode[_a] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptCode", version: "3.5.0" };
154
+ _b = JSII_RTTI_SYMBOL_1;
155
+ JavaScriptCode[_b] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptCode", version: "3.7.2" };
107
156
  /**
108
157
  * Represents the deployed TypeScript Code.
109
158
  *
110
159
  * @stability stable
111
160
  */
112
- class TypeScriptCode extends Code {
161
+ class TypeScriptCode extends EsbuildCode {
113
162
  constructor(
114
163
  /**
115
- * A relative path or list or map of relative paths to the entry points of your code from the root of the project.
116
- * E.g. `src/index.ts`.
164
+ * A path or list or map of paths to the entry points of your code.
165
+ *
166
+ * Relative paths are by default resolved from the current working directory.
167
+ * To change the working directory, see `buildOptions.absWorkingDir`.
168
+ *
169
+ * Absolute paths can be used if files are part of the working directory.
170
+ *
171
+ * Examples:
172
+ * - `'src/index.ts'`
173
+ * - `require.resolve('./lambda')`
174
+ * - `['src/index.ts', 'src/util.ts']`
175
+ * - `{one: 'src/two.ts', two: 'src/one.ts'}`
117
176
  *
118
177
  * @stability stable
119
178
  */
@@ -130,10 +189,12 @@ class TypeScriptCode extends Code {
130
189
  */
131
190
  props = {}) {
132
191
  super(entryPoints, props);
133
- this.assetClass = asset_1.TypeScriptAsset;
192
+ }
193
+ getAsset(scope) {
194
+ return new asset_1.TypeScriptAsset(scope, this.constructor.name, this.props);
134
195
  }
135
196
  }
136
197
  exports.TypeScriptCode = TypeScriptCode;
137
- _b = JSII_RTTI_SYMBOL_1;
138
- TypeScriptCode[_b] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptCode", version: "3.5.0" };
139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code.js","sourceRoot":"","sources":["../src/code.ts"],"names":[],"mappings":";;;;;AAAA,6CAAiD;AAIjD,mCAKiB;AAIjB,SAAS,gBAAgB;IACvB,OAAO,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;AAC3D,CAAC;AAW6D,CAAC;AACD,CAAC;AAE/D,MAAe,IAAI;IAqBjB;;;;OAIG;IACH,YAA4B,WAAwB,EAAE,KAAY;;QAAtC,gBAAW,GAAX,WAAW,CAAa;QAZpD;;;;WAIG;QACI,aAAQ,GAAY,KAAK,CAAC;QAQ/B,MAAM,cAAc,GAA0B;YAC5C,GAAG,CAAC,QAAC,KAAK,CAAC,YAAY,0CAAE,QAAQ,CAAA;gBACjC,OAAA,KAAK,CAAC,YAAY,0CAAE,QAAQ,MAAK,MAAM;gBACrC,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,gBAAgB,EAAE,EAAE;gBAC3D,CAAC,CAAC,EAAE,CAAC;SACR,CAAC;QAEF,IAAI,CAAC,KAAK,GAAG;YACX,GAAG,KAAK;YACR,WAAW;YACX,YAAY,EAAE;gBACZ,GAAG,cAAc;gBACjB,GAAG,KAAK,CAAC,YAAY;aACtB;SACF,CAAC;IACJ,CAAC;IAED,IAAI,CAAC,KAAgB;QACnB,qFAAqF;QACrF,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACf,IAAI,CAAC,KAAK,GAAG,IAAI,IAAI,CAAC,UAAU,CAC9B,KAAK,EACL,IAAI,CAAC,WAAW,CAAC,IAAI,EACrB,IAAI,CAAC,KAAK,CACX,CAAC;SACH;aAAM,IAAI,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,mBAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE;YACnD,MAAM,IAAI,KAAK,CACb,mDACE,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,SACvB,KAAK,GAAG,8CAA8C,CACvD,CAAC;SACH;QAED,OAAO;YACL,UAAU,EAAE;gBACV,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,YAAY;gBACnC,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW;aAClC;SACF,CAAC;IACJ,CAAC;IAED;;;;;;;OAOG;IACH,cAAc,CAAC,QAAqB,EAAE,OAA6B;QACjE,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACf,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;SACjE;QACD,MAAM,gBAAgB,GAAG,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,gBAAgB,KAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;QAC5E,6CAA6C;QAC7C,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,QAAQ,EAAE,gBAAgB,CAAC,CAAC;IAC7D,CAAC;CACF;AAED;;;;GAIG;AACH,MAAa,cAAe,SAAQ,IAAkC;IAGpE;IACE;;;;;OAKG;IACH,WAAwB;IACxB;;;;;;;;;OASG;IACH,QAA6B,EAAE;QAE/B,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;QAtBT,eAAU,GAAG,uBAAO,CAAC;IAuBxC,CAAC;;AAxBH,wCAyBC;;;AAED;;;;GAIG;AACH,MAAa,cAAe,SAAQ,IAAkC;IAGpE;IACE;;;;;OAKG;IACH,WAAwB;IACxB;;;;;;;;;OASG;IACH,QAA6B,EAAE;QAE/B,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;QAtBT,eAAU,GAAG,uBAAO,CAAC;IAuBxC,CAAC;;AAxBH,wCAyBC","sourcesContent":["import { CfnResource, Stack } from 'aws-cdk-lib';\nimport { ResourceBindOptions } from 'aws-cdk-lib/aws-lambda';\nimport { Location } from 'aws-cdk-lib/aws-s3';\nimport { Construct } from 'constructs';\nimport {\n  AssetBaseProps,\n  AssetProps,\n  JavaScriptAsset as JSAsset,\n  TypeScriptAsset as TSAsset,\n} from './asset';\nimport { EntryPoints } from './bundler';\nimport { BuildOptions } from './esbuild-types';\n\nfunction nodeMajorVersion(): number {\n  return parseInt(process.versions.node.split('.')[0], 10);\n}\n\nexport interface CodeConfig {\n  /**\n   * The location of the code in S3.\n   *\n   * @stability stable\n   */\n  readonly s3Location: Location;\n}\n\nexport interface JavaScriptCodeProps extends AssetBaseProps {};\nexport interface TypeScriptCodeProps extends AssetBaseProps {};\n\nabstract class Code<\n  Props extends JavaScriptCodeProps | TypeScriptCodeProps,\n  Asset extends JSAsset | TSAsset\n> {\n  protected abstract readonly assetClass: new (\n    scope: Construct,\n    id: string,\n    props: AssetProps\n  ) => Asset;\n\n  protected props: AssetProps;\n\n  protected asset!: Asset;\n\n  /**\n   * Determines whether this Code is inline code or not.\n   *\n   * @deprecated this value is ignored since inline is now determined based on the the inlineCode field of CodeConfig returned from bind().\n   */\n  public isInline: boolean = false;\n\n  /**\n   *\n   * @param entryPoints - Relative path to the asset code. Use `props.buildOptions.absWorkingDir` if an absolute path is required.\n   * @param props - Asset properties.\n   */\n  constructor(public readonly entryPoints: EntryPoints, props: Props) {\n    const defaultOptions: Partial<BuildOptions> = {\n      ...(!props.buildOptions?.platform ||\n      props.buildOptions?.platform === 'node'\n        ? { platform: 'node', target: 'node' + nodeMajorVersion() }\n        : {}),\n    };\n\n    this.props = {\n      ...props,\n      entryPoints,\n      buildOptions: {\n        ...defaultOptions,\n        ...props.buildOptions,\n      },\n    };\n  }\n\n  bind(scope: Construct): CodeConfig {\n    // If the same AssetCode is used multiple times, retain only the first instantiation.\n    if (!this.asset) {\n      this.asset = new this.assetClass(\n        scope,\n        this.constructor.name,\n        this.props,\n      );\n    } else if (Stack.of(this.asset) !== Stack.of(scope)) {\n      throw new Error(\n        `Asset is already associated with another stack '${\n          Stack.of(this.asset).stackName\n        }'. ` + 'Create a new Asset instance for every stack.',\n      );\n    }\n\n    return {\n      s3Location: {\n        bucketName: this.asset.s3BucketName,\n        objectKey: this.asset.s3ObjectKey,\n      },\n    };\n  }\n\n  /**\n   * Called after the CFN function resource has been created to allow the code class to bind to it.\n   *\n   * Specifically it's required to allow assets to add\n   * metadata for tooling like SAM CLI to be able to find their origins.\n   *\n   * @stability stable\n   */\n  bindToResource(resource: CfnResource, options?: ResourceBindOptions) {\n    if (!this.asset) {\n      throw new Error('bindToResource() must be called after bind()');\n    }\n    const resourceProperty = options?.resourceProperty || this.constructor.name;\n    // https://github.com/aws/aws-cdk/issues/1432\n    this.asset.addResourceMetadata(resource, resourceProperty);\n  }\n}\n\n/**\n * Represents the deployed JavaScript Code.\n *\n * @stability stable\n */\nexport class JavaScriptCode extends Code<JavaScriptCodeProps, JSAsset> {\n  protected readonly assetClass = JSAsset;\n\n  constructor(\n    /**\n     * A relative path or list or map of relative paths to the entry points of your code from the root of the project.\n     * E.g. `src/index.ts`.\n     *\n     * @stability stable\n     */\n    entryPoints: EntryPoints,\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=node`\n     * - `target=nodeX` with X being the major node version running locally\n     *\n     * @stability stable\n     */\n    props: JavaScriptCodeProps = {},\n  ) {\n    super(entryPoints, props);\n  }\n}\n\n/**\n * Represents the deployed TypeScript Code.\n *\n * @stability stable\n */\nexport class TypeScriptCode extends Code<TypeScriptCodeProps, TSAsset> {\n  protected readonly assetClass = TSAsset;\n\n  constructor(\n    /**\n     * A relative path or list or map of relative paths to the entry points of your code from the root of the project.\n     * E.g. `src/index.ts`.\n     *\n     * @stability stable\n     */\n    entryPoints: EntryPoints,\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=node`\n     * - `target=nodeX` with X being the major node version running locally\n     *\n     * @stability stable\n     */\n    props: TypeScriptCodeProps = {},\n  ) {\n    super(entryPoints, props);\n  }\n}\n"]}
198
+ _c = JSII_RTTI_SYMBOL_1;
199
+ TypeScriptCode[_c] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptCode", version: "3.7.2" };
200
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code.js","sourceRoot":"","sources":["../src/code.ts"],"names":[],"mappings":"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","sourcesContent":["import { CfnResource, Stack } from 'aws-cdk-lib';\nimport { ResourceBindOptions, Code, CodeConfig } from 'aws-cdk-lib/aws-lambda';\nimport { Construct } from 'constructs';\nimport {\n  EsbuildAsset,\n  AssetBaseProps,\n  AssetProps,\n  JavaScriptAsset as JSAsset,\n  TypeScriptAsset as TSAsset,\n} from './asset';\nimport { EntryPoints } from './bundler';\nimport { BuildOptions } from './esbuild-types';\n\nfunction nodeMajorVersion(): number {\n  return parseInt(process.versions.node.split('.')[0], 10);\n}\n\nexport { CodeConfig } from 'aws-cdk-lib/aws-lambda';\nexport interface JavaScriptCodeProps extends AssetBaseProps {};\nexport interface TypeScriptCodeProps extends AssetBaseProps {};\n\n/**\n * Represents a generic esbuild code bundle.\n *\n * You should always use `TypeScriptCode` or `JavaScriptCode`.\n *\n * @stability experimental\n */\nexport class EsbuildCode<\n  Props extends JavaScriptCodeProps | TypeScriptCodeProps,\n> extends Code {\n  protected getAsset(scope: Construct): EsbuildAsset<AssetProps> {\n    return new EsbuildAsset(\n      scope,\n      this.constructor.name,\n      this.props,\n    );\n  }\n\n  protected props: AssetProps;\n\n  protected asset!: EsbuildAsset<AssetProps>;\n\n  /**\n   * Determines whether this Code is inline code or not.\n   *\n   * @deprecated this value is ignored since inline is now determined based on the the inlineCode field of CodeConfig returned from bind().\n   */\n  public isInline: boolean = false;\n\n  constructor(\n    /**\n     * A path or list or map of paths to the entry points of your code.\n     *\n     * Relative paths are by default resolved from the current working directory.\n     * To change the working directory, see `buildOptions.absWorkingDir`.\n     *\n     * Absolute paths can be used if files are part of the working directory.\n     *\n     * Examples:\n     *  - `'src/index.ts'`\n     *  - `require.resolve('./lambda')`\n     *  - `['src/index.ts', 'src/util.ts']`\n     *  - `{one: 'src/two.ts', two: 'src/one.ts'}`\n     *\n     * @stability stable\n     */\n    readonly entryPoints: EntryPoints,\n\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=node`\n     * - `target=nodeX` with X being the major node version running locally\n     *\n     * @stability stable\n     */\n    props: Props,\n  ) {\n    super();\n\n    const defaultOptions: Partial<BuildOptions> = {\n      ...(!props.buildOptions?.platform ||\n      props.buildOptions?.platform === 'node'\n        ? { platform: 'node', target: 'node' + nodeMajorVersion() }\n        : {}),\n    };\n\n    this.props = {\n      ...props,\n      entryPoints,\n      buildOptions: {\n        ...defaultOptions,\n        ...props.buildOptions,\n      },\n    };\n  }\n\n  bind(scope: Construct): CodeConfig {\n    // If the same AssetCode is used multiple times, retain only the first instantiation.\n    if (!this.asset) {\n      this.asset = this.getAsset(scope);\n    } else if (Stack.of(this.asset) !== Stack.of(scope)) {\n      throw new Error(\n        `Asset is already associated with another stack '${\n          Stack.of(this.asset).stackName\n        }'. ` + 'Create a new Asset instance for every stack.',\n      );\n    }\n\n    return {\n      s3Location: {\n        bucketName: this.asset.s3BucketName,\n        objectKey: this.asset.s3ObjectKey,\n      },\n    };\n  }\n\n  /**\n   * Called after the CFN function resource has been created to allow the code class to bind to it.\n   *\n   * Specifically it's required to allow assets to add\n   * metadata for tooling like SAM CLI to be able to find their origins.\n   *\n   * @stability stable\n   */\n  bindToResource(resource: CfnResource, options?: ResourceBindOptions) {\n    if (!this.asset) {\n      throw new Error('bindToResource() must be called after bind()');\n    }\n    const resourceProperty = options?.resourceProperty || this.constructor.name;\n    // https://github.com/aws/aws-cdk/issues/1432\n    this.asset.addResourceMetadata(resource, resourceProperty);\n  }\n}\n\n/**\n * Represents the deployed JavaScript Code.\n *\n * @stability stable\n */\nexport class JavaScriptCode extends EsbuildCode<JavaScriptCodeProps> {\n  protected getAsset(scope: Construct): EsbuildAsset<AssetProps> {\n    return new JSAsset(\n      scope,\n      this.constructor.name,\n      this.props,\n    );\n  }\n\n  constructor(\n    /**\n     * A path or list or map of paths to the entry points of your code.\n     *\n     * Relative paths are by default resolved from the current working directory.\n     * To change the working directory, see `buildOptions.absWorkingDir`.\n     *\n     * Absolute paths can be used if files are part of the working directory.\n     *\n     * Examples:\n     *  - `'src/index.ts'`\n     *  - `require.resolve('./lambda')`\n     *  - `['src/index.ts', 'src/util.ts']`\n     *  - `{one: 'src/two.ts', two: 'src/one.ts'}`\n     *\n     * @stability stable\n     */\n    entryPoints: EntryPoints,\n\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=node`\n     * - `target=nodeX` with X being the major node version running locally\n     *\n     * @stability stable\n     */\n    props: JavaScriptCodeProps = {},\n  ) {\n    super(entryPoints, props);\n  }\n}\n\n/**\n * Represents the deployed TypeScript Code.\n *\n * @stability stable\n */\nexport class TypeScriptCode extends EsbuildCode<TypeScriptCodeProps> {\n  protected getAsset(scope: Construct): EsbuildAsset<AssetProps> {\n    return new TSAsset(\n      scope,\n      this.constructor.name,\n      this.props,\n    );\n  }\n\n  constructor(\n    /**\n     * A path or list or map of paths to the entry points of your code.\n     *\n     * Relative paths are by default resolved from the current working directory.\n     * To change the working directory, see `buildOptions.absWorkingDir`.\n     *\n     * Absolute paths can be used if files are part of the working directory.\n     *\n     * Examples:\n     *  - `'src/index.ts'`\n     *  - `require.resolve('./lambda')`\n     *  - `['src/index.ts', 'src/util.ts']`\n     *  - `{one: 'src/two.ts', two: 'src/one.ts'}`\n     *\n     * @stability stable\n     */\n    entryPoints: EntryPoints,\n\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=node`\n     * - `target=nodeX` with X being the major node version running locally\n     *\n     * @stability stable\n     */\n    props: TypeScriptCodeProps = {},\n  ) {\n    super(entryPoints, props);\n  }\n}\n"]}