@mrgrain/cdk-esbuild 4.3.0 → 5.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -24,11 +24,11 @@ Install `cdk-esbuild` for Node.js using your favorite package manager:
24
24
 
25
25
  ```sh
26
26
  # npm
27
- npm install @mrgrain/cdk-esbuild@4
27
+ npm install @mrgrain/cdk-esbuild@5
28
28
  # Yarn
29
- yarn add @mrgrain/cdk-esbuild@4
29
+ yarn add @mrgrain/cdk-esbuild@5
30
30
  # pnpm
31
- pnpm add @mrgrain/cdk-esbuild@4
31
+ pnpm add @mrgrain/cdk-esbuild@5
32
32
  ```
33
33
 
34
34
  For Python, .NET or Go, use these commands:
@@ -41,12 +41,12 @@ pip install mrgrain.cdk-esbuild
41
41
  dotnet add package Mrgrain.CdkEsbuild
42
42
 
43
43
  # Go
44
- go get github.com/mrgrain/cdk-esbuild-go/cdkesbuild/v4
44
+ go get github.com/mrgrain/cdk-esbuild-go/cdkesbuild/v5
45
45
  ```
46
46
 
47
47
  ### AWS Lambda: Serverless function
48
48
 
49
- > 💡 See [Lambda (TypeScript)](examples/typescript/lambda) and [Lambda (Python)](examples/typescript/lambda) for complete working examples of a how to deploy an AWS Lambda Function.
49
+ > 💡 See [Lambda (TypeScript)](examples/typescript/lambda) and [Lambda (Python)](examples/typescript/lambda) for working examples of a how to deploy an AWS Lambda Function.
50
50
 
51
51
  Use `TypeScriptCode` as the `code` of a [lambda function](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_lambda.Function.html#code):
52
52
 
@@ -62,7 +62,7 @@ const fn = new lambda.Function(stack, "MyFunction", {
62
62
 
63
63
  ### AWS S3: Static Website
64
64
 
65
- > 💡 See [React App (TypeScript)](examples/typescript/website) for a complete working example of a how to deploy a React app to S3.
65
+ > 💡 See [React App (TypeScript)](examples/typescript/website) for a working example of a how to deploy a React app to S3.
66
66
 
67
67
  Use `TypeScriptSource` as one of the `sources` of a [static website deployment](https://docs.aws.amazon.com/cdk/api/latest/docs/aws-s3-deployment-readme.html#roadmap):
68
68
 
@@ -84,7 +84,7 @@ new s3deploy.BucketDeployment(stack, "DeployWebsite", {
84
84
 
85
85
  ### Amazon CloudWatch Synthetics: Canary monitoring
86
86
 
87
- > 💡 See [Monitored Website (TypeScript)](examples/typescript/website) for a complete working example of a deployed and monitored website.
87
+ > 💡 See [Monitored Website (TypeScript)](examples/typescript/website) for a working example of a deployed and monitored website.
88
88
 
89
89
  Synthetics runs a canary to produce traffic to an application for monitoring purposes. Use `TypeScriptCode` as the `code` of a Canary test:
90
90
 
@@ -100,7 +100,7 @@ const bundledCode = new TypeScriptCode("src/canary.ts", {
100
100
  });
101
101
 
102
102
  const canary = new synthetics.Canary(stack, "MyCanary", {
103
- runtime: synthetics.Runtime.SYNTHETICS_NODEJS_PUPPETEER_3_2,
103
+ runtime: synthetics.Runtime.SYNTHETICS_NODEJS_PUPPETEER_5_1,
104
104
  test: synthetics.Test.custom({
105
105
  code: bundledCode,
106
106
  handler: "index.handler",
@@ -110,25 +110,27 @@ const canary = new synthetics.Canary(stack, "MyCanary", {
110
110
 
111
111
  ## Documentation
112
112
 
113
- The package exports various different constructs for use with AWS CDK features. The guiding design principal for this package is _"extend, don't replace"_. Expect constructs that you can provide as props, not complete replacements.
113
+ The package exports constructs for use with AWS CDK features.
114
+ The guiding design principal of this package is _"extend, don't replace"_.
115
+ Expect constructs that you can provide as props, not complete replacements.
114
116
 
115
- For use in **Lambda Functions** and **Synthetic Canaries**, the following classes implement `lambda.Code` ([reference](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_lambda.Code.html)) and `synthetics.Code` ([reference](https://docs.aws.amazon.com/cdk/api/v2/docs/@aws-cdk_aws-synthetics-alpha.Code.html)):
117
+ For use with **Lambda Functions** and **Synthetic Canaries**, implementing `lambda.Code` ([reference](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_lambda.Code.html)) and `synthetics.Code` ([reference](https://docs.aws.amazon.com/cdk/api/v2/docs/@aws-cdk_aws-synthetics-alpha.Code.html)):
116
118
 
117
- - `TypeScriptCode` & `JavaScriptCode`
119
+ - `TypeScriptCode`
118
120
 
119
121
  Inline code is only supported by **Lambda**:
120
122
 
121
- - `InlineTypeScriptCode` & `InlineJavaScriptCode`
123
+ - `InlineTypeScriptCode`
122
124
 
123
- For use with **S3 bucket deployments**, classes implementing `s3deploy.ISource` ([reference](https://docs.aws.amazon.com/cdk/api/latest/docs/aws-s3-deployment-readme.html)):
125
+ For use with **S3 bucket deployments**, implementing `s3deploy.ISource` ([reference](https://docs.aws.amazon.com/cdk/api/latest/docs/aws-s3-deployment-readme.html)):
124
126
 
125
- - `TypeScriptSource` & `JavaScriptSource`
127
+ - `TypeScriptSource`
126
128
 
127
- > _Code and Source constructs seamlessly plug-in to other high-level CDK constructs. They share the same set of parameters, props and build options._
129
+ > _`Code` and `Source` constructs seamlessly plug-in to other high-level CDK constructs. They share the same set of parameters, props and build options._
128
130
 
129
131
  The following classes power the other features. You normally won't have to use them, but they are there if you need them:
130
132
 
131
- - `TypeScriptAsset` & `JavaScriptAsset` implements `s3.Asset` ([reference](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_s3_assets.Asset.html)) \
133
+ - `TypeScriptAsset` implements `s3.Asset` ([reference](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_s3_assets.Asset.html)) \
132
134
  creates an asset uploaded to S3 which can be referenced by other constructs
133
135
 
134
136
  - `EsbuildBundler` implements `core.BundlingOptions` ([reference](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.BundlingOptions.html)) \
@@ -270,7 +272,7 @@ If you are a Python, .NET or Go user, refer to the language specific guide for a
270
272
 
271
273
  #### Custom Build and Transform API implementations
272
274
 
273
- > 💡 See [esbuild plugins w/ TypeScript](examples/typescript/esbuild-with-plugins) for a complete working example of a custom Build API implementation.
275
+ > 💡 See [esbuild plugins w/ TypeScript](examples/typescript/esbuild-with-plugins) for a working example of a custom Build API implementation.
274
276
 
275
277
  A custom implementation can be provided by implementing `IBuildProvider` or `ITransformProvider`:
276
278
 
@@ -339,9 +341,9 @@ Note that _esbuild_ minor version upgrades are also introduced in **minor versio
339
341
  Since _esbuild_ is pre v1, these versions typically introduce breaking changes and this package will inherit them.
340
342
  To avoid this behavior, add the desired _esbuild_ version as a dependency to your package.
341
343
 
342
- ### How do I upgrade from `cdk-esbuild` v3?
344
+ ### How do I upgrade from `cdk-esbuild` v4?
343
345
 
344
- Please refer to the [v4 release notes](https://github.com/mrgrain/cdk-esbuild/releases/tag/v4.0.0) for a list of backwards incompatible changes and respective upgrade instructions.
346
+ Please refer to the [v5 release notes](https://github.com/mrgrain/cdk-esbuild/releases/tag/v5.0.0) for a list of backwards incompatible changes and respective upgrade instructions.
345
347
 
346
348
  ### [TS/JS] Why am I getting the error `Cannot find module 'esbuild'`?
347
349
 
@@ -399,10 +401,14 @@ const props = {
399
401
  };
400
402
  ```
401
403
 
402
- This will dynamically resolve to the correct path, wherever the package is installed. Please open an issue if you encounter any difficulties.
404
+ This will dynamically resolve to the correct path, wherever the package is installed.
405
+ Please open an issue if you encounter any difficulties.
403
406
 
404
407
  ### Can I use this package with AWS CDK v1?
405
408
 
406
- Yes, the `2.x.x` line of `cdk-esbuild` is compatible with AWS CDK v1. You can find the [documentation for it on the v2 branch](https://github.com/mrgrain/cdk-esbuild/tree/v2).
409
+ Yes, `v2` of `cdk-esbuild` is compatible with AWS CDK v1.
410
+ You can find the [documentation for it on the v2 branch](https://github.com/mrgrain/cdk-esbuild/tree/v2).
407
411
 
408
- However, in line with AWS CDK v2, this version release now only receives security updates and critical bug fixes and support will fully end on June 1, 2023.
412
+ Support for AWS CDK v1 and `cdk-esbuild` v2 has ended on June 1, 2023.
413
+ Both packages are not receiving any updates or bug fixes, including for security related issues.
414
+ You are strongly advised to upgrade to a supported version of these packages.
package/VERSIONS.md CHANGED
@@ -1,3 +1,20 @@
1
1
  # Supported Versions
2
2
 
3
- See [VERSIONS.md](https://github.com/mrgrain/cdk-esbuild/blob/v5/VERSIONS.md) on `v5`.
3
+ Only the latest release of each major version is supported.
4
+
5
+ | Package version | CDK version | Node.js versions | Support |
6
+ | --------------- | ----------- | ---------------- | -------------------------------------------------------------- |
7
+ | v5 | ^2.51.0 | >=18 | :white_check_mark: |
8
+ | v4 | ^2.12.0 | >=14 | Security updates and critical bug fixes until October 1, 2024 |
9
+ | v3 | ^2.0.0 | >=14 | Security updates and critical bug fixes until February 1, 2024 |
10
+ | v2 | ^1.99.0 | >=14 | :x: Support ended on June 1, 2023 |
11
+ | v1 | ^1.99.0 | >=12 | :x: |
12
+
13
+ ## Tags on npm
14
+
15
+ | Tag | Description | Major version | Will the version change? |
16
+ | ----------- | ---------------------------------------------------- | ------------- | ---------------------------- |
17
+ | `latest` | The latest stable release of the package | `v5` | Yes, with new major versions |
18
+ | `latest-v*` | The latest stable release of each major version | n/a | No |
19
+ | `cdk-v2` | The latest stable release compatible with AWS CDK v2 | `v5` | Yes, with new major versions |
20
+ | `cdk-v1` | The latest stable release compatible with AWS CDK v1 | `v2` | No |
package/lib/asset.d.ts CHANGED
@@ -1,22 +1,8 @@
1
1
  import { Asset as S3Asset } from 'aws-cdk-lib/aws-s3-assets';
2
2
  import { Construct } from 'constructs';
3
- import { BundlerProps, EntryPoints } from './bundler';
4
- /**
5
- * @internal
6
- */
7
- export interface AssetBaseProps extends BundlerProps {
8
- /**
9
- * A hash of this asset, which is available at construction time.
10
- *
11
- * As this is a plain string, it can be used in construct IDs in order to enforce creation of a new resource when the content hash has changed.
12
- *
13
- * Defaults to a hash of all files in the resulting bundle.
14
- *
15
- * @stability stable
16
- */
17
- readonly assetHash?: string;
18
- }
19
- export interface AssetProps extends AssetBaseProps {
3
+ import { EntryPoints } from './bundler';
4
+ import { TypeScriptCodeProps } from './code';
5
+ export interface TypeScriptAssetProps extends TypeScriptCodeProps {
20
6
  /**
21
7
  * A path or list or map of paths to the entry points of your code.
22
8
  *
@@ -35,30 +21,6 @@ export interface AssetProps extends AssetBaseProps {
35
21
  */
36
22
  readonly entryPoints: EntryPoints;
37
23
  }
38
- declare type JavaScriptAssetProps = AssetProps;
39
- declare type TypeScriptAssetProps = AssetProps;
40
- /**
41
- * Represents a generic esbuild asset.
42
- *
43
- * You should always use `TypeScriptAsset` or `JavaScriptAsset`.
44
- *
45
- * @stability experimental
46
- */
47
- export declare class EsbuildAsset<Props extends AssetProps> extends S3Asset {
48
- /**
49
- * @stability stable
50
- */
51
- constructor(scope: Construct, id: string, props: Props);
52
- }
53
- /**
54
- * Bundles the entry points and creates a CDK asset which is uploaded to the bootstrapped CDK S3 bucket during deployment.
55
- *
56
- * The asset can be used by other constructs.
57
- *
58
- * @stability stable
59
- */
60
- export declare class JavaScriptAsset extends EsbuildAsset<JavaScriptAssetProps> {
61
- }
62
24
  /**
63
25
  * Bundles the entry points and creates a CDK asset which is uploaded to the bootstrapped CDK S3 bucket during deployment.
64
26
  *
@@ -66,6 +28,9 @@ export declare class JavaScriptAsset extends EsbuildAsset<JavaScriptAssetProps>
66
28
  *
67
29
  * @stability stable
68
30
  */
69
- export declare class TypeScriptAsset extends EsbuildAsset<TypeScriptAssetProps> {
31
+ export declare class TypeScriptAsset extends S3Asset {
32
+ /**
33
+ * @stability stable
34
+ */
35
+ constructor(scope: Construct, id: string, props: TypeScriptAssetProps);
70
36
  }
71
- export {};
package/lib/asset.js CHANGED
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
- var _a, _b, _c;
2
+ var _a;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.TypeScriptAsset = exports.JavaScriptAsset = exports.EsbuildAsset = void 0;
4
+ exports.TypeScriptAsset = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const path_1 = require("path");
7
7
  const aws_cdk_lib_1 = require("aws-cdk-lib");
@@ -9,13 +9,13 @@ const aws_s3_assets_1 = require("aws-cdk-lib/aws-s3-assets");
9
9
  const constructs_1 = require("constructs");
10
10
  const bundler_1 = require("./bundler");
11
11
  /**
12
- * Represents a generic esbuild asset.
12
+ * Bundles the entry points and creates a CDK asset which is uploaded to the bootstrapped CDK S3 bucket during deployment.
13
13
  *
14
- * You should always use `TypeScriptAsset` or `JavaScriptAsset`.
14
+ * The asset can be used by other constructs.
15
15
  *
16
- * @stability experimental
16
+ * @stability stable
17
17
  */
18
- class EsbuildAsset extends aws_s3_assets_1.Asset {
18
+ class TypeScriptAsset extends aws_s3_assets_1.Asset {
19
19
  /**
20
20
  * @stability stable
21
21
  */
@@ -25,11 +25,11 @@ class EsbuildAsset extends aws_s3_assets_1.Asset {
25
25
  const name = scope.node.path + constructs_1.Node.PATH_SEP + id;
26
26
  const absWorkingDir = options.absWorkingDir ?? process.cwd();
27
27
  const forceRelativeEntrypointPath = (entryPoint) => {
28
- if (!path_1.isAbsolute(entryPoint)) {
28
+ if (!(0, path_1.isAbsolute)(entryPoint)) {
29
29
  return entryPoint;
30
30
  }
31
- const relativeEntryPoint = path_1.relative(absWorkingDir, entryPoint);
32
- if (relativeEntryPoint.startsWith('..') || path_1.isAbsolute(relativeEntryPoint)) {
31
+ const relativeEntryPoint = (0, path_1.relative)(absWorkingDir, entryPoint);
32
+ if (relativeEntryPoint.startsWith('..') || (0, path_1.isAbsolute)(relativeEntryPoint)) {
33
33
  throw new Error(`${name}: Entry points must be part of the working directory. See \`buildOptions.absWorkingDir\` to set a working directory different to the current one.`);
34
34
  }
35
35
  return relativeEntryPoint;
@@ -54,31 +54,7 @@ class EsbuildAsset extends aws_s3_assets_1.Asset {
54
54
  });
55
55
  }
56
56
  }
57
- exports.EsbuildAsset = EsbuildAsset;
58
- _a = JSII_RTTI_SYMBOL_1;
59
- EsbuildAsset[_a] = { fqn: "@mrgrain/cdk-esbuild.EsbuildAsset", version: "4.3.0" };
60
- /**
61
- * Bundles the entry points and creates a CDK asset which is uploaded to the bootstrapped CDK S3 bucket during deployment.
62
- *
63
- * The asset can be used by other constructs.
64
- *
65
- * @stability stable
66
- */
67
- class JavaScriptAsset extends EsbuildAsset {
68
- }
69
- exports.JavaScriptAsset = JavaScriptAsset;
70
- _b = JSII_RTTI_SYMBOL_1;
71
- JavaScriptAsset[_b] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptAsset", version: "4.3.0" };
72
- /**
73
- * Bundles the entry points and creates a CDK asset which is uploaded to the bootstrapped CDK S3 bucket during deployment.
74
- *
75
- * The asset can be used by other constructs.
76
- *
77
- * @stability stable
78
- */
79
- class TypeScriptAsset extends EsbuildAsset {
80
- }
81
57
  exports.TypeScriptAsset = TypeScriptAsset;
82
- _c = JSII_RTTI_SYMBOL_1;
83
- TypeScriptAsset[_c] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptAsset", version: "4.3.0" };
84
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvYXNzZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSwrQkFBNEM7QUFDNUMsNkNBQTRDO0FBQzVDLDZEQUE2RDtBQUM3RCwyQ0FBNkM7QUFDN0MsdUNBQXNFO0FBeUN0RTs7Ozs7O0dBTUc7QUFDSCxNQUFhLFlBQXVDLFNBQVEscUJBQU87SUFDakU7O09BRUc7SUFDSCxZQUNFLEtBQWdCLEVBQ2hCLEVBQVUsRUFDVixLQUFZO1FBRVosTUFBTSxFQUNKLFNBQVMsRUFDVCxZQUFZLEVBQUUsT0FBTyxHQUFHLEVBQUUsR0FDM0IsR0FBRyxLQUFLLENBQUM7UUFDVixNQUFNLFdBQVcsR0FDZixPQUFPLEtBQUssQ0FBQyxXQUFXLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQztRQUVsRixNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksR0FBRyxpQkFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7UUFFbEQsTUFBTSxhQUFhLEdBQUcsT0FBTyxDQUFDLGFBQWEsSUFBSSxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7UUFFN0QsTUFBTSwyQkFBMkIsR0FBRyxDQUFDLFVBQWtCLEVBQVUsRUFBRTtZQUNqRSxJQUFJLENBQUMsaUJBQVUsQ0FBQyxVQUFVLENBQUMsRUFBRTtnQkFDM0IsT0FBTyxVQUFVLENBQUM7YUFDbkI7WUFFRCxNQUFNLGtCQUFrQixHQUFHLGVBQVEsQ0FBQyxhQUFhLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDL0QsSUFBSSxrQkFBa0IsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLElBQUksaUJBQVUsQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFO2dCQUN6RSxNQUFNLElBQUksS0FBSyxDQUNiLEdBQUcsSUFBSSxtSkFBbUosQ0FDM0osQ0FBQzthQUNIO1lBRUQsT0FBTyxrQkFBa0IsQ0FBQztRQUM1QixDQUFDLENBQUM7UUFFRixNQUFNLG1CQUFtQixHQUN2QixLQUFLLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUM7WUFDMUIsV0FBVyxDQUFDLEdBQUcsQ0FBQywyQkFBMkIsQ0FBQyxDQUFDLENBQUM7WUFDOUMsTUFBTSxDQUFDLFdBQVcsQ0FDaEIsTUFBTSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUM7aUJBQ3hCLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxFQUFFLFVBQVUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxFQUFFLDJCQUEyQixDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FDM0UsQ0FDSixDQUFDO1FBR04sTUFBTSxZQUFZLEdBQUc7WUFDbkIsTUFBTSxFQUFFLElBQUk7WUFDWixHQUFHLE9BQU87WUFDVixhQUFhO1NBQ2QsQ0FBQztRQUVGLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFO1lBQ2YsSUFBSSxFQUFFLGFBQWE7WUFDbkIsU0FBUztZQUNULGFBQWEsRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDLDJCQUFhLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQywyQkFBYSxDQUFDLE1BQU07WUFDdEUsUUFBUSxFQUFFLElBQUksd0JBQWMsQ0FDMUIsbUJBQW1CLEVBQ25CO2dCQUNFLEdBQUcsS0FBSztnQkFDUixZQUFZO2FBQ2IsQ0FDRjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7O0FBL0RILG9DQWdFQzs7O0FBRUQ7Ozs7OztHQU1HO0FBQ0gsTUFBYSxlQUFnQixTQUFRLFlBQWtDOztBQUF2RSwwQ0FBMEU7OztBQUUxRTs7Ozs7O0dBTUc7QUFDSCxNQUFhLGVBQWdCLFNBQVEsWUFBa0M7O0FBQXZFLDBDQUEwRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzQWJzb2x1dGUsIHJlbGF0aXZlIH0gZnJvbSAncGF0aCc7XG5pbXBvcnQgeyBBc3NldEhhc2hUeXBlIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0IHsgQXNzZXQgYXMgUzNBc3NldCB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1zMy1hc3NldHMnO1xuaW1wb3J0IHsgQ29uc3RydWN0LCBOb2RlIH0gZnJvbSAnY29uc3RydWN0cyc7XG5pbXBvcnQgeyBFc2J1aWxkQnVuZGxlciwgQnVuZGxlclByb3BzLCBFbnRyeVBvaW50cyB9IGZyb20gJy4vYnVuZGxlcic7XG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQXNzZXRCYXNlUHJvcHMgZXh0ZW5kcyBCdW5kbGVyUHJvcHMge1xuICAvKipcbiAgICogQSBoYXNoIG9mIHRoaXMgYXNzZXQsIHdoaWNoIGlzIGF2YWlsYWJsZSBhdCBjb25zdHJ1Y3Rpb24gdGltZS5cbiAgICpcbiAgICogQXMgdGhpcyBpcyBhIHBsYWluIHN0cmluZywgaXQgY2FuIGJlIHVzZWQgaW4gY29uc3RydWN0IElEcyBpbiBvcmRlciB0byBlbmZvcmNlIGNyZWF0aW9uIG9mIGEgbmV3IHJlc291cmNlIHdoZW4gdGhlIGNvbnRlbnQgaGFzaCBoYXMgY2hhbmdlZC5cbiAgICpcbiAgICogRGVmYXVsdHMgdG8gYSBoYXNoIG9mIGFsbCBmaWxlcyBpbiB0aGUgcmVzdWx0aW5nIGJ1bmRsZS5cbiAgICpcbiAgICogQHN0YWJpbGl0eSBzdGFibGVcbiAgICovXG4gIHJlYWRvbmx5IGFzc2V0SGFzaD86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBc3NldFByb3BzIGV4dGVuZHMgQXNzZXRCYXNlUHJvcHMge1xuICAvKipcbiAgICogQSBwYXRoIG9yIGxpc3Qgb3IgbWFwIG9mIHBhdGhzIHRvIHRoZSBlbnRyeSBwb2ludHMgb2YgeW91ciBjb2RlLlxuICAgKlxuICAgKiBSZWxhdGl2ZSBwYXRocyBhcmUgYnkgZGVmYXVsdCByZXNvbHZlZCBmcm9tIHRoZSBjdXJyZW50IHdvcmtpbmcgZGlyZWN0b3J5LlxuICAgKiBUbyBjaGFuZ2UgdGhlIHdvcmtpbmcgZGlyZWN0b3J5LCBzZWUgYGJ1aWxkT3B0aW9ucy5hYnNXb3JraW5nRGlyYC5cbiAgICpcbiAgICogQWJzb2x1dGUgcGF0aHMgY2FuIGJlIHVzZWQgaWYgZmlsZXMgYXJlIHBhcnQgb2YgdGhlIHdvcmtpbmcgZGlyZWN0b3J5LlxuICAgKlxuICAgKiBFeGFtcGxlczpcbiAgICogIC0gYCdzcmMvaW5kZXgudHMnYFxuICAgKiAgLSBgcmVxdWlyZS5yZXNvbHZlKCcuL2xhbWJkYScpYFxuICAgKiAgLSBgWydzcmMvaW5kZXgudHMnLCAnc3JjL3V0aWwudHMnXWBcbiAgICogIC0gYHtvbmU6ICdzcmMvdHdvLnRzJywgdHdvOiAnc3JjL29uZS50cyd9YFxuICAgKlxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgZW50cnlQb2ludHM6IEVudHJ5UG9pbnRzO1xufVxuXG50eXBlIEphdmFTY3JpcHRBc3NldFByb3BzID0gQXNzZXRQcm9wcztcbnR5cGUgVHlwZVNjcmlwdEFzc2V0UHJvcHMgPSBBc3NldFByb3BzO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgYSBnZW5lcmljIGVzYnVpbGQgYXNzZXQuXG4gKlxuICogWW91IHNob3VsZCBhbHdheXMgdXNlIGBUeXBlU2NyaXB0QXNzZXRgIG9yIGBKYXZhU2NyaXB0QXNzZXRgLlxuICpcbiAqIEBzdGFiaWxpdHkgZXhwZXJpbWVudGFsXG4gKi9cbmV4cG9ydCBjbGFzcyBFc2J1aWxkQXNzZXQ8UHJvcHMgZXh0ZW5kcyBBc3NldFByb3BzPiBleHRlbmRzIFMzQXNzZXQge1xuICAvKipcbiAgICogQHN0YWJpbGl0eSBzdGFibGVcbiAgICovXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcihcbiAgICBzY29wZTogQ29uc3RydWN0LFxuICAgIGlkOiBzdHJpbmcsXG4gICAgcHJvcHM6IFByb3BzLFxuICApIHtcbiAgICBjb25zdCB7XG4gICAgICBhc3NldEhhc2gsXG4gICAgICBidWlsZE9wdGlvbnM6IG9wdGlvbnMgPSB7fSxcbiAgICB9ID0gcHJvcHM7XG4gICAgY29uc3QgZW50cnlQb2ludHM6IHN0cmluZ1tdIHwgUmVjb3JkPHN0cmluZywgc3RyaW5nPiA9XG4gICAgICB0eXBlb2YgcHJvcHMuZW50cnlQb2ludHMgPT09ICdzdHJpbmcnID8gW3Byb3BzLmVudHJ5UG9pbnRzXSA6IHByb3BzLmVudHJ5UG9pbnRzO1xuXG4gICAgY29uc3QgbmFtZSA9IHNjb3BlLm5vZGUucGF0aCArIE5vZGUuUEFUSF9TRVAgKyBpZDtcblxuICAgIGNvbnN0IGFic1dvcmtpbmdEaXIgPSBvcHRpb25zLmFic1dvcmtpbmdEaXIgPz8gcHJvY2Vzcy5jd2QoKTtcblxuICAgIGNvbnN0IGZvcmNlUmVsYXRpdmVFbnRyeXBvaW50UGF0aCA9IChlbnRyeVBvaW50OiBzdHJpbmcpOiBzdHJpbmcgPT4ge1xuICAgICAgaWYgKCFpc0Fic29sdXRlKGVudHJ5UG9pbnQpKSB7XG4gICAgICAgIHJldHVybiBlbnRyeVBvaW50O1xuICAgICAgfVxuXG4gICAgICBjb25zdCByZWxhdGl2ZUVudHJ5UG9pbnQgPSByZWxhdGl2ZShhYnNXb3JraW5nRGlyLCBlbnRyeVBvaW50KTtcbiAgICAgIGlmIChyZWxhdGl2ZUVudHJ5UG9pbnQuc3RhcnRzV2l0aCgnLi4nKSB8fCBpc0Fic29sdXRlKHJlbGF0aXZlRW50cnlQb2ludCkpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICAgIGAke25hbWV9OiBFbnRyeSBwb2ludHMgbXVzdCBiZSBwYXJ0IG9mIHRoZSB3b3JraW5nIGRpcmVjdG9yeS4gU2VlIFxcYGJ1aWxkT3B0aW9ucy5hYnNXb3JraW5nRGlyXFxgIHRvIHNldCBhIHdvcmtpbmcgZGlyZWN0b3J5IGRpZmZlcmVudCB0byB0aGUgY3VycmVudCBvbmUuYCxcbiAgICAgICAgKTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHJlbGF0aXZlRW50cnlQb2ludDtcbiAgICB9O1xuXG4gICAgY29uc3QgcmVsYXRpdmVFbnRyeVBvaW50cyA9XG4gICAgICBBcnJheS5pc0FycmF5KGVudHJ5UG9pbnRzKSA/XG4gICAgICAgIGVudHJ5UG9pbnRzLm1hcChmb3JjZVJlbGF0aXZlRW50cnlwb2ludFBhdGgpIDpcbiAgICAgICAgT2JqZWN0LmZyb21FbnRyaWVzKFxuICAgICAgICAgIE9iamVjdC5lbnRyaWVzKGVudHJ5UG9pbnRzKVxuICAgICAgICAgICAgLm1hcCgoW291dCwgZW50cnlQb2ludF0pID0+IChbb3V0LCBmb3JjZVJlbGF0aXZlRW50cnlwb2ludFBhdGgoZW50cnlQb2ludCldKSxcbiAgICAgICAgICAgICksXG4gICAgICAgICk7XG5cblxuICAgIGNvbnN0IGJ1aWxkT3B0aW9ucyA9IHtcbiAgICAgIGJ1bmRsZTogdHJ1ZSxcbiAgICAgIC4uLm9wdGlvbnMsXG4gICAgICBhYnNXb3JraW5nRGlyLFxuICAgIH07XG5cbiAgICBzdXBlcihzY29wZSwgaWQsIHtcbiAgICAgIHBhdGg6IGFic1dvcmtpbmdEaXIsXG4gICAgICBhc3NldEhhc2gsXG4gICAgICBhc3NldEhhc2hUeXBlOiBhc3NldEhhc2ggPyBBc3NldEhhc2hUeXBlLkNVU1RPTSA6IEFzc2V0SGFzaFR5cGUuT1VUUFVULFxuICAgICAgYnVuZGxpbmc6IG5ldyBFc2J1aWxkQnVuZGxlcihcbiAgICAgICAgcmVsYXRpdmVFbnRyeVBvaW50cyxcbiAgICAgICAge1xuICAgICAgICAgIC4uLnByb3BzLFxuICAgICAgICAgIGJ1aWxkT3B0aW9ucyxcbiAgICAgICAgfSxcbiAgICAgICksXG4gICAgfSk7XG4gIH1cbn1cblxuLyoqXG4gKiBCdW5kbGVzIHRoZSBlbnRyeSBwb2ludHMgYW5kIGNyZWF0ZXMgYSBDREsgYXNzZXQgd2hpY2ggaXMgdXBsb2FkZWQgdG8gdGhlIGJvb3RzdHJhcHBlZCBDREsgUzMgYnVja2V0IGR1cmluZyBkZXBsb3ltZW50LlxuICpcbiAqIFRoZSBhc3NldCBjYW4gYmUgdXNlZCBieSBvdGhlciBjb25zdHJ1Y3RzLlxuICpcbiAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gKi9cbmV4cG9ydCBjbGFzcyBKYXZhU2NyaXB0QXNzZXQgZXh0ZW5kcyBFc2J1aWxkQXNzZXQ8SmF2YVNjcmlwdEFzc2V0UHJvcHM+IHt9XG5cbi8qKlxuICogQnVuZGxlcyB0aGUgZW50cnkgcG9pbnRzIGFuZCBjcmVhdGVzIGEgQ0RLIGFzc2V0IHdoaWNoIGlzIHVwbG9hZGVkIHRvIHRoZSBib290c3RyYXBwZWQgQ0RLIFMzIGJ1Y2tldCBkdXJpbmcgZGVwbG95bWVudC5cbiAqXG4gKiBUaGUgYXNzZXQgY2FuIGJlIHVzZWQgYnkgb3RoZXIgY29uc3RydWN0cy5cbiAqXG4gKiBAc3RhYmlsaXR5IHN0YWJsZVxuICovXG5leHBvcnQgY2xhc3MgVHlwZVNjcmlwdEFzc2V0IGV4dGVuZHMgRXNidWlsZEFzc2V0PFR5cGVTY3JpcHRBc3NldFByb3BzPiB7fVxuIl19
58
+ _a = JSII_RTTI_SYMBOL_1;
59
+ TypeScriptAsset[_a] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptAsset", version: "5.0.0" };
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvYXNzZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSwrQkFBNEM7QUFDNUMsNkNBQTRDO0FBQzVDLDZEQUE2RDtBQUM3RCwyQ0FBNkM7QUFDN0MsdUNBQXdEO0FBeUJ4RDs7Ozs7O0dBTUc7QUFDSCxNQUFhLGVBQWdCLFNBQVEscUJBQU87SUFDMUM7O09BRUc7SUFDSCxZQUNFLEtBQWdCLEVBQ2hCLEVBQVUsRUFDVixLQUEyQjtRQUUzQixNQUFNLEVBQ0osU0FBUyxFQUNULFlBQVksRUFBRSxPQUFPLEdBQUcsRUFBRSxHQUMzQixHQUFHLEtBQUssQ0FBQztRQUNWLE1BQU0sV0FBVyxHQUNmLE9BQU8sS0FBSyxDQUFDLFdBQVcsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDO1FBRWxGLE1BQU0sSUFBSSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxHQUFHLGlCQUFJLENBQUMsUUFBUSxHQUFHLEVBQUUsQ0FBQztRQUVsRCxNQUFNLGFBQWEsR0FBRyxPQUFPLENBQUMsYUFBYSxJQUFJLE9BQU8sQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUU3RCxNQUFNLDJCQUEyQixHQUFHLENBQUMsVUFBa0IsRUFBVSxFQUFFO1lBQ2pFLElBQUksQ0FBQyxJQUFBLGlCQUFVLEVBQUMsVUFBVSxDQUFDLEVBQUU7Z0JBQzNCLE9BQU8sVUFBVSxDQUFDO2FBQ25CO1lBRUQsTUFBTSxrQkFBa0IsR0FBRyxJQUFBLGVBQVEsRUFBQyxhQUFhLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDL0QsSUFBSSxrQkFBa0IsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLElBQUksSUFBQSxpQkFBVSxFQUFDLGtCQUFrQixDQUFDLEVBQUU7Z0JBQ3pFLE1BQU0sSUFBSSxLQUFLLENBQ2IsR0FBRyxJQUFJLG1KQUFtSixDQUMzSixDQUFDO2FBQ0g7WUFFRCxPQUFPLGtCQUFrQixDQUFDO1FBQzVCLENBQUMsQ0FBQztRQUVGLE1BQU0sbUJBQW1CLEdBQ3ZCLEtBQUssQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQztZQUMxQixXQUFXLENBQUMsR0FBRyxDQUFDLDJCQUEyQixDQUFDLENBQUMsQ0FBQztZQUM5QyxNQUFNLENBQUMsV0FBVyxDQUNoQixNQUFNLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQztpQkFDeEIsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLEVBQUUsVUFBVSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLEVBQUUsMkJBQTJCLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUMzRSxDQUNKLENBQUM7UUFHTixNQUFNLFlBQVksR0FBRztZQUNuQixNQUFNLEVBQUUsSUFBSTtZQUNaLEdBQUcsT0FBTztZQUNWLGFBQWE7U0FDZCxDQUFDO1FBRUYsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUU7WUFDZixJQUFJLEVBQUUsYUFBYTtZQUNuQixTQUFTO1lBQ1QsYUFBYSxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUMsMkJBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLDJCQUFhLENBQUMsTUFBTTtZQUN0RSxRQUFRLEVBQUUsSUFBSSx3QkFBYyxDQUMxQixtQkFBbUIsRUFDbkI7Z0JBQ0UsR0FBRyxLQUFLO2dCQUNSLFlBQVk7YUFDYixDQUNGO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7QUEvREgsMENBZ0VDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaXNBYnNvbHV0ZSwgcmVsYXRpdmUgfSBmcm9tICdwYXRoJztcbmltcG9ydCB7IEFzc2V0SGFzaFR5cGUgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBBc3NldCBhcyBTM0Fzc2V0IH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLXMzLWFzc2V0cyc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QsIE5vZGUgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IEVzYnVpbGRCdW5kbGVyLCBFbnRyeVBvaW50cyB9IGZyb20gJy4vYnVuZGxlcic7XG5pbXBvcnQgeyBUeXBlU2NyaXB0Q29kZVByb3BzIH0gZnJvbSAnLi9jb2RlJztcblxuXG5leHBvcnQgaW50ZXJmYWNlIFR5cGVTY3JpcHRBc3NldFByb3BzIGV4dGVuZHMgVHlwZVNjcmlwdENvZGVQcm9wcyB7XG4gIC8qKlxuICAgKiBBIHBhdGggb3IgbGlzdCBvciBtYXAgb2YgcGF0aHMgdG8gdGhlIGVudHJ5IHBvaW50cyBvZiB5b3VyIGNvZGUuXG4gICAqXG4gICAqIFJlbGF0aXZlIHBhdGhzIGFyZSBieSBkZWZhdWx0IHJlc29sdmVkIGZyb20gdGhlIGN1cnJlbnQgd29ya2luZyBkaXJlY3RvcnkuXG4gICAqIFRvIGNoYW5nZSB0aGUgd29ya2luZyBkaXJlY3RvcnksIHNlZSBgYnVpbGRPcHRpb25zLmFic1dvcmtpbmdEaXJgLlxuICAgKlxuICAgKiBBYnNvbHV0ZSBwYXRocyBjYW4gYmUgdXNlZCBpZiBmaWxlcyBhcmUgcGFydCBvZiB0aGUgd29ya2luZyBkaXJlY3RvcnkuXG4gICAqXG4gICAqIEV4YW1wbGVzOlxuICAgKiAgLSBgJ3NyYy9pbmRleC50cydgXG4gICAqICAtIGByZXF1aXJlLnJlc29sdmUoJy4vbGFtYmRhJylgXG4gICAqICAtIGBbJ3NyYy9pbmRleC50cycsICdzcmMvdXRpbC50cyddYFxuICAgKiAgLSBge29uZTogJ3NyYy90d28udHMnLCB0d286ICdzcmMvb25lLnRzJ31gXG4gICAqXG4gICAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gICAqL1xuICByZWFkb25seSBlbnRyeVBvaW50czogRW50cnlQb2ludHM7XG59XG5cblxuLyoqXG4gKiBCdW5kbGVzIHRoZSBlbnRyeSBwb2ludHMgYW5kIGNyZWF0ZXMgYSBDREsgYXNzZXQgd2hpY2ggaXMgdXBsb2FkZWQgdG8gdGhlIGJvb3RzdHJhcHBlZCBDREsgUzMgYnVja2V0IGR1cmluZyBkZXBsb3ltZW50LlxuICpcbiAqIFRoZSBhc3NldCBjYW4gYmUgdXNlZCBieSBvdGhlciBjb25zdHJ1Y3RzLlxuICpcbiAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gKi9cbmV4cG9ydCBjbGFzcyBUeXBlU2NyaXB0QXNzZXQgZXh0ZW5kcyBTM0Fzc2V0IHtcbiAgLyoqXG4gICAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gICAqL1xuICBwdWJsaWMgY29uc3RydWN0b3IoXG4gICAgc2NvcGU6IENvbnN0cnVjdCxcbiAgICBpZDogc3RyaW5nLFxuICAgIHByb3BzOiBUeXBlU2NyaXB0QXNzZXRQcm9wcyxcbiAgKSB7XG4gICAgY29uc3Qge1xuICAgICAgYXNzZXRIYXNoLFxuICAgICAgYnVpbGRPcHRpb25zOiBvcHRpb25zID0ge30sXG4gICAgfSA9IHByb3BzO1xuICAgIGNvbnN0IGVudHJ5UG9pbnRzOiBzdHJpbmdbXSB8IFJlY29yZDxzdHJpbmcsIHN0cmluZz4gPVxuICAgICAgdHlwZW9mIHByb3BzLmVudHJ5UG9pbnRzID09PSAnc3RyaW5nJyA/IFtwcm9wcy5lbnRyeVBvaW50c10gOiBwcm9wcy5lbnRyeVBvaW50cztcblxuICAgIGNvbnN0IG5hbWUgPSBzY29wZS5ub2RlLnBhdGggKyBOb2RlLlBBVEhfU0VQICsgaWQ7XG5cbiAgICBjb25zdCBhYnNXb3JraW5nRGlyID0gb3B0aW9ucy5hYnNXb3JraW5nRGlyID8/IHByb2Nlc3MuY3dkKCk7XG5cbiAgICBjb25zdCBmb3JjZVJlbGF0aXZlRW50cnlwb2ludFBhdGggPSAoZW50cnlQb2ludDogc3RyaW5nKTogc3RyaW5nID0+IHtcbiAgICAgIGlmICghaXNBYnNvbHV0ZShlbnRyeVBvaW50KSkge1xuICAgICAgICByZXR1cm4gZW50cnlQb2ludDtcbiAgICAgIH1cblxuICAgICAgY29uc3QgcmVsYXRpdmVFbnRyeVBvaW50ID0gcmVsYXRpdmUoYWJzV29ya2luZ0RpciwgZW50cnlQb2ludCk7XG4gICAgICBpZiAocmVsYXRpdmVFbnRyeVBvaW50LnN0YXJ0c1dpdGgoJy4uJykgfHwgaXNBYnNvbHV0ZShyZWxhdGl2ZUVudHJ5UG9pbnQpKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgICBgJHtuYW1lfTogRW50cnkgcG9pbnRzIG11c3QgYmUgcGFydCBvZiB0aGUgd29ya2luZyBkaXJlY3RvcnkuIFNlZSBcXGBidWlsZE9wdGlvbnMuYWJzV29ya2luZ0RpclxcYCB0byBzZXQgYSB3b3JraW5nIGRpcmVjdG9yeSBkaWZmZXJlbnQgdG8gdGhlIGN1cnJlbnQgb25lLmAsXG4gICAgICAgICk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiByZWxhdGl2ZUVudHJ5UG9pbnQ7XG4gICAgfTtcblxuICAgIGNvbnN0IHJlbGF0aXZlRW50cnlQb2ludHMgPVxuICAgICAgQXJyYXkuaXNBcnJheShlbnRyeVBvaW50cykgP1xuICAgICAgICBlbnRyeVBvaW50cy5tYXAoZm9yY2VSZWxhdGl2ZUVudHJ5cG9pbnRQYXRoKSA6XG4gICAgICAgIE9iamVjdC5mcm9tRW50cmllcyhcbiAgICAgICAgICBPYmplY3QuZW50cmllcyhlbnRyeVBvaW50cylcbiAgICAgICAgICAgIC5tYXAoKFtvdXQsIGVudHJ5UG9pbnRdKSA9PiAoW291dCwgZm9yY2VSZWxhdGl2ZUVudHJ5cG9pbnRQYXRoKGVudHJ5UG9pbnQpXSksXG4gICAgICAgICAgICApLFxuICAgICAgICApO1xuXG5cbiAgICBjb25zdCBidWlsZE9wdGlvbnMgPSB7XG4gICAgICBidW5kbGU6IHRydWUsXG4gICAgICAuLi5vcHRpb25zLFxuICAgICAgYWJzV29ya2luZ0RpcixcbiAgICB9O1xuXG4gICAgc3VwZXIoc2NvcGUsIGlkLCB7XG4gICAgICBwYXRoOiBhYnNXb3JraW5nRGlyLFxuICAgICAgYXNzZXRIYXNoLFxuICAgICAgYXNzZXRIYXNoVHlwZTogYXNzZXRIYXNoID8gQXNzZXRIYXNoVHlwZS5DVVNUT00gOiBBc3NldEhhc2hUeXBlLk9VVFBVVCxcbiAgICAgIGJ1bmRsaW5nOiBuZXcgRXNidWlsZEJ1bmRsZXIoXG4gICAgICAgIHJlbGF0aXZlRW50cnlQb2ludHMsXG4gICAgICAgIHtcbiAgICAgICAgICAuLi5wcm9wcyxcbiAgICAgICAgICBidWlsZE9wdGlvbnMsXG4gICAgICAgIH0sXG4gICAgICApLFxuICAgIH0pO1xuICB9XG59XG4iXX0=
package/lib/bundler.d.ts CHANGED
@@ -17,7 +17,7 @@ import { IBuildProvider } from './provider';
17
17
  *
18
18
  * @stability stable
19
19
  */
20
- export declare type EntryPoints = string | string[] | Record<string, string>;
20
+ export type EntryPoints = string | string[] | Record<string, string>;
21
21
  /**
22
22
  * @stability stable
23
23
  */
package/lib/bundler.js CHANGED
@@ -58,16 +58,16 @@ class EsbuildBundler {
58
58
  if (this.props.copyDir) {
59
59
  const copyDir = this.getCopyDirList(this.props.copyDir);
60
60
  copyDir.forEach(([dest, src]) => {
61
- const srcDir = path_1.resolve(this.props?.buildOptions?.absWorkingDir ?? process.cwd(), src);
62
- const destDir = path_1.resolve(outputDir, dest);
63
- const destToOutput = path_1.relative(outputDir, destDir);
64
- if (destToOutput.startsWith('..') || path_1.isAbsolute(destToOutput)) {
61
+ const srcDir = (0, path_1.resolve)(this.props?.buildOptions?.absWorkingDir ?? process.cwd(), src);
62
+ const destDir = (0, path_1.resolve)(outputDir, dest);
63
+ const destToOutput = (0, path_1.relative)(outputDir, destDir);
64
+ if (destToOutput.startsWith('..') || (0, path_1.isAbsolute)(destToOutput)) {
65
65
  throw new Error('Cannot copy files to outside of the asset staging directory. See docs for details.');
66
66
  }
67
- if (fs_1.existsSync(destDir)) {
68
- fs_1.rmSync(destDir, { recursive: true, force: true });
67
+ if ((0, fs_1.existsSync)(destDir)) {
68
+ (0, fs_1.rmSync)(destDir, { recursive: true, force: true });
69
69
  }
70
- fs_1.mkdirSync(destDir, { recursive: true });
70
+ (0, fs_1.mkdirSync)(destDir, { recursive: true });
71
71
  aws_cdk_lib_1.FileSystem.copyDirectory(srcDir, destDir);
72
72
  });
73
73
  }
@@ -81,7 +81,7 @@ class EsbuildBundler {
81
81
  });
82
82
  }
83
83
  catch (error) {
84
- if (utils_1.isEsbuildError(error)) {
84
+ if ((0, utils_1.isEsbuildError)(error)) {
85
85
  throw new Error(`Esbuild failed to bundle ${entryPoints}`);
86
86
  }
87
87
  throw error;
@@ -130,5 +130,5 @@ class EsbuildBundler {
130
130
  }
131
131
  exports.EsbuildBundler = EsbuildBundler;
132
132
  _a = JSII_RTTI_SYMBOL_1;
133
- EsbuildBundler[_a] = { fqn: "@mrgrain/cdk-esbuild.EsbuildBundler", version: "4.3.0" };
134
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundler.js","sourceRoot":"","sources":["../src/bundler.ts"],"names":[],"mappings":"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","sourcesContent":["import { existsSync, mkdirSync, rmSync } 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 { BuildOptions } from './esbuild-types';\nimport { isEsbuildError } from './private/utils';\nimport { EsbuildProvider, IBuildProvider } from './provider';\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   * The esbuild Build API implementation to be used.\n   *\n   * Configure the default `EsbuildProvider` for more options or\n   * provide a custom `IBuildProvider` as an escape hatch.\n   *\n   * @stability stable\n   *\n   * @default new EsbuildProvider()\n   */\n  readonly buildProvider?: IBuildProvider;\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   * ```\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 * 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 behavior 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    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            if (existsSync(destDir)) {\n              rmSync(destDir, { recursive: true, force: true });\n            }\n            mkdirSync(destDir, { recursive: true });\n            FileSystem.copyDirectory(srcDir, destDir);\n          });\n        }\n\n        try {\n          const provider = props.buildProvider ?? EsbuildProvider.defaultBuildProvider();\n\n          provider.buildSync({\n            entryPoints: typeof entryPoints === 'string' ? [entryPoints] : entryPoints,\n            color: process.env.NO_COLOR ? Boolean(process.env.NO_COLOR) : undefined,\n            ...(this.props?.buildOptions || {}),\n            ...this.getOutputOptions(outputDir, { normalize, join }),\n          });\n        } catch (error) {\n          if (isEsbuildError(error)) {\n            throw new Error(`Esbuild failed to bundle ${entryPoints}`);\n          }\n          throw error;\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"]}
133
+ EsbuildBundler[_a] = { fqn: "@mrgrain/cdk-esbuild.EsbuildBundler", version: "5.0.0" };
134
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundler.js","sourceRoot":"","sources":["../src/bundler.ts"],"names":[],"mappings":";;;;;AAAA,2BAAmD;AACnD,+BAA6E;AAC7E,6CAKqB;AAErB,2CAAiD;AACjD,yCAA6D;AAgF7D;;;;;GAKG;AACH,MAAa,cAAc;IAezB;;OAEG;IACH;IACE;;;;;;;;;;;;;;;OAeG;IACa,WAAwB;IAExC;;;;OAIG;IACa,KAAmB;QAPnB,gBAAW,GAAX,WAAW,CAAa;QAOxB,UAAK,GAAL,KAAK,CAAc;QAlCrC;;;;WAIG;QACa,UAAK,GAAG,yBAAW,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;QA+B1D,IAAI,KAAK,EAAE,YAAY,EAAE,OAAO,IAAI,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE;YAC/D,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;SAC3D;QACD,IAAI,CAAC,KAAK,GAAG;YACX,SAAS,EAAE,CAAC,SAAiB,EAAE,QAAyB,EAAW,EAAE;gBAEnE,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE;oBACtB,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;oBAExD,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,EAAE,GAAG,CAAC,EAAE,EAAE;wBAC9B,MAAM,MAAM,GAAG,IAAA,cAAO,EACpB,IAAI,CAAC,KAAK,EAAE,YAAY,EAAE,aAAa,IAAI,OAAO,CAAC,GAAG,EAAE,EACxD,GAAG,CACJ,CAAC;wBACF,MAAM,OAAO,GAAG,IAAA,cAAO,EAAC,SAAS,EAAE,IAAI,CAAC,CAAC;wBAEzC,MAAM,YAAY,GAAG,IAAA,eAAQ,EAAC,SAAS,EAAE,OAAO,CAAC,CAAC;wBAClD,IAAI,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,IAAA,iBAAU,EAAC,YAAY,CAAC,EAAE;4BAC7D,MAAM,IAAI,KAAK,CAAC,oFAAoF,CAAC,CAAC;yBACvG;wBAED,IAAI,IAAA,eAAU,EAAC,OAAO,CAAC,EAAE;4BACvB,IAAA,WAAM,EAAC,OAAO,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;yBACnD;wBACD,IAAA,cAAS,EAAC,OAAO,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;wBACxC,wBAAU,CAAC,aAAa,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;oBAC5C,CAAC,CAAC,CAAC;iBACJ;gBAED,IAAI;oBACF,MAAM,QAAQ,GAAG,KAAK,CAAC,aAAa,IAAI,0BAAe,CAAC,oBAAoB,EAAE,CAAC;oBAE/E,QAAQ,CAAC,SAAS,CAAC;wBACjB,WAAW,EAAE,OAAO,WAAW,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,WAAW;wBAC1E,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS;wBACvE,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,YAAY,IAAI,EAAE,CAAC;wBACnC,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,EAAE,SAAS,EAAT,gBAAS,EAAE,IAAI,EAAJ,WAAI,EAAE,CAAC;qBACzD,CAAC,CAAC;iBACJ;gBAAC,OAAO,KAAK,EAAE;oBACd,IAAI,IAAA,sBAAc,EAAC,KAAK,CAAC,EAAE;wBACzB,MAAM,IAAI,KAAK,CAAC,4BAA4B,WAAW,EAAE,CAAC,CAAC;qBAC5D;oBACD,MAAM,KAAK,CAAC;iBACb;gBAED,OAAO,IAAI,CAAC;YACd,CAAC;SACF,CAAC;IACJ,CAAC;IAEO,cAAc,CAAC,OAAgC;QACrD,kBAAkB;QAClB,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO,EAAE,CAAC;SACX;QAED,kBAAkB;QAClB,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;YAC1B,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,GAAW,EAAE,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;SACjD;QAED,QAAQ;QACR,IACE,OAAO,OAAO,KAAK,QAAQ;YAC3B,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC;YACvB,OAAO,KAAK,IAAI,EAChB;YACA,OAAO,MAAM;iBACV,OAAO,CAAC,OAAO,CAAC;iBAChB,OAAO,CAAC,CAAC,CAAC,IAAI,EAAE,OAAO,CAAC,EAAE,EAAE;gBAC3B,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;oBAC1B,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,GAAG,CAAC,CAA4B,CAAC;iBACrE;gBAED,OAAO,CAAC,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;YAC3B,CAAC,CAAC,CAAC;SACN;QAED,kBAAkB;QAClB,OAAO,CAAC,CAAC,GAAG,EAAE,OAAiB,CAAC,CAAC,CAAC;IACpC,CAAC;IAEO,gBAAgB,CACtB,YAAoB,EACpB,OAAiD,YAAK;QAEtD,IAAI,IAAI,CAAC,KAAK,EAAE,YAAY,EAAE,OAAO,EAAE;YACrC,OAAO;gBACL,MAAM,EAAE,SAAS;gBACjB,OAAO,EAAE,IAAI,CAAC,SAAS,CACrB,IAAI,CAAC,IAAI,CACP,GAAI,CAAC,YAAY,EAAE,IAAI,CAAC,KAAK,EAAE,YAAY,EAAE,OAAO,CAAC,CAAC,MAAM,CAC1D,OAAO,CACK,CACf,CACF;aACF,CAAC;SACH;QAED,OAAO;YACL,MAAM,EAAE,IAAI,CAAC,SAAS,CACpB,IAAI,CAAC,IAAI,CACP,GAAI,CAAC,YAAY,EAAE,IAAI,CAAC,KAAK,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC,MAAM,CACzD,OAAO,CACK,CACf,CACF;YACD,OAAO,EAAE,SAAS;SACnB,CAAC;IACJ,CAAC;;AAzJH,wCA0JC","sourcesContent":["import { existsSync, mkdirSync, rmSync } 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 { BuildOptions } from './esbuild-types';\nimport { isEsbuildError } from './private/utils';\nimport { EsbuildProvider, IBuildProvider } from './provider';\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   * The esbuild Build API implementation to be used.\n   *\n   * Configure the default `EsbuildProvider` for more options or\n   * provide a custom `IBuildProvider` as an escape hatch.\n   *\n   * @stability stable\n   *\n   * @default new EsbuildProvider()\n   */\n  readonly buildProvider?: IBuildProvider;\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   * ```\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 * 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 behavior 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    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            if (existsSync(destDir)) {\n              rmSync(destDir, { recursive: true, force: true });\n            }\n            mkdirSync(destDir, { recursive: true });\n            FileSystem.copyDirectory(srcDir, destDir);\n          });\n        }\n\n        try {\n          const provider = props.buildProvider ?? EsbuildProvider.defaultBuildProvider();\n\n          provider.buildSync({\n            entryPoints: typeof entryPoints === 'string' ? [entryPoints] : entryPoints,\n            color: process.env.NO_COLOR ? Boolean(process.env.NO_COLOR) : undefined,\n            ...(this.props?.buildOptions || {}),\n            ...this.getOutputOptions(outputDir, { normalize, join }),\n          });\n        } catch (error) {\n          if (isEsbuildError(error)) {\n            throw new Error(`Esbuild failed to bundle ${entryPoints}`);\n          }\n          throw error;\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,41 +1,28 @@
1
1
  import { CfnResource } from 'aws-cdk-lib';
2
2
  import { ResourceBindOptions, Code, CodeConfig } from 'aws-cdk-lib/aws-lambda';
3
3
  import { Construct } from 'constructs';
4
- import { EsbuildAsset, AssetBaseProps, AssetProps } from './asset';
5
- import { EntryPoints } from './bundler';
4
+ import { BundlerProps, EntryPoints } from './bundler';
6
5
  export { CodeConfig } from 'aws-cdk-lib/aws-lambda';
7
- export interface JavaScriptCodeProps extends AssetBaseProps {
8
- }
9
- export interface TypeScriptCodeProps extends AssetBaseProps {
10
- }
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 {
6
+ export interface TypeScriptCodeProps extends BundlerProps {
19
7
  /**
20
- * A path or list or map of paths to the entry points of your code.
8
+ * A hash of this asset, which is available at construction time.
21
9
  *
22
- * Relative paths are by default resolved from the current working directory.
23
- * To change the working directory, see `buildOptions.absWorkingDir`.
10
+ * As this is a plain string, it can be used in construct IDs in order to enforce creation of a new resource when the content hash has changed.
24
11
  *
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'}`
12
+ * Defaults to a hash of all files in the resulting bundle.
32
13
  *
33
14
  * @stability stable
34
15
  */
35
- readonly entryPoints: EntryPoints;
36
- protected getAsset(scope: Construct): EsbuildAsset<AssetProps>;
37
- protected props: AssetProps;
38
- protected asset: EsbuildAsset<AssetProps>;
16
+ readonly assetHash?: string;
17
+ }
18
+ /**
19
+ * Represents the deployed TypeScript Code.
20
+ *
21
+ * @stability stable
22
+ */
23
+ export declare class TypeScriptCode extends Code {
24
+ private props;
25
+ private asset?;
39
26
  /**
40
27
  * Determines whether this Code is inline code or not.
41
28
  *
@@ -70,7 +57,7 @@ export declare class EsbuildCode<Props extends JavaScriptCodeProps | TypeScriptC
70
57
  *
71
58
  * @stability stable
72
59
  */
73
- props: Props);
60
+ props?: TypeScriptCodeProps);
74
61
  bind(scope: Construct): CodeConfig;
75
62
  /**
76
63
  * Called after the CFN function resource has been created to allow the code class to bind to it.
@@ -82,77 +69,3 @@ export declare class EsbuildCode<Props extends JavaScriptCodeProps | TypeScriptC
82
69
  */
83
70
  bindToResource(resource: CfnResource, options?: ResourceBindOptions): void;
84
71
  }
85
- /**
86
- * Represents the deployed JavaScript Code.
87
- *
88
- * @stability stable
89
- */
90
- export declare class JavaScriptCode extends EsbuildCode<JavaScriptCodeProps> {
91
- protected getAsset(scope: Construct): EsbuildAsset<AssetProps>;
92
- constructor(
93
- /**
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'}`
106
- *
107
- * @stability stable
108
- */
109
- entryPoints: EntryPoints,
110
- /**
111
- * Props to change the behavior of the bundler.
112
- *
113
- * Default values for `props.buildOptions`:
114
- * - `bundle=true`
115
- * - `platform=node`
116
- * - `target=nodeX` with X being the major node version running locally
117
- *
118
- * @stability stable
119
- */
120
- props?: JavaScriptCodeProps);
121
- }
122
- /**
123
- * Represents the deployed TypeScript Code.
124
- *
125
- * @stability stable
126
- */
127
- export declare class TypeScriptCode extends EsbuildCode<TypeScriptCodeProps> {
128
- protected getAsset(scope: Construct): EsbuildAsset<AssetProps>;
129
- constructor(
130
- /**
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'}`
143
- *
144
- * @stability stable
145
- */
146
- entryPoints: EntryPoints,
147
- /**
148
- * Props to change the behavior of the bundler.
149
- *
150
- * Default values for `props.buildOptions`:
151
- * - `bundle=true`
152
- * - `platform=node`
153
- * - `target=nodeX` with X being the major node version running locally
154
- *
155
- * @stability stable
156
- */
157
- props?: TypeScriptCodeProps);
158
- }