@mrgrain/cdk-esbuild 2.0.0 → 3.0.0-rc.1
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/.gitattributes +21 -21
- package/.jsii +2847 -897
- package/.projenrc.ts +33 -22
- package/API.md +180 -38
- package/CHANGELOG.md +76 -14
- package/README.md +74 -22
- package/SECURITY.md +6 -5
- package/lib/asset.d.ts +2 -2
- package/lib/asset.js +10 -8
- package/lib/bundler.d.ts +14 -1
- package/lib/bundler.js +7 -6
- package/lib/code.d.ts +4 -3
- package/lib/code.js +6 -6
- package/lib/index.d.ts +1 -1
- package/lib/index.js +1 -1
- package/lib/inline-code.d.ts +51 -20
- package/lib/inline-code.js +52 -30
- package/lib/source.d.ts +2 -2
- package/lib/source.js +6 -6
- package/package.json +41 -54
package/README.md
CHANGED
|
@@ -2,7 +2,9 @@
|
|
|
2
2
|
|
|
3
3
|
_CDK constructs for [esbuild](https://github.com/evanw/esbuild), an extremely fast JavaScript bundler_
|
|
4
4
|
|
|
5
|
-
|
|
5
|
+
> ⚠️ This is the documentation for the version compatible with AWS CDK v2. For the previous, AWS CDK v1 compatible release, see [cdk-esbuild@v2](https://github.com/mrgrain/cdk-esbuild/tree/v2)
|
|
6
|
+
|
|
7
|
+
[Getting started](#getting-started) | [Migrating to v3](#migrating-to-v3) |
|
|
6
8
|
[Documentation](#documentation) | [API Reference](#api-reference) | [Versioning](#versioning)
|
|
7
9
|
|
|
8
10
|
## Why?
|
|
@@ -14,24 +16,24 @@ AWS CDK [supports _esbuild_ with Lambda Functions](https://docs.aws.amazon.com/c
|
|
|
14
16
|
|
|
15
17
|
This package is running _esbuild_ directly in Node.js and bypasses Docker which the AWS CDK implementation uses. The approach is quicker and easier to use for Node.js users, but incompatible with other languages.
|
|
16
18
|
|
|
17
|
-
|
|
19
|
+
**Production readiness**
|
|
18
20
|
|
|
19
|
-
This package is generally stable and ready to be used in production as many do. However _esbuild_
|
|
21
|
+
This package is generally stable and ready to be used in production, as many do. However _esbuild_ not yet released a version 1.0.0 yet and its API is still in active development. Please check their guide on [production readiness](https://esbuild.github.io/faq/#production-readiness).
|
|
20
22
|
|
|
21
|
-
Notably upgrades of the _esbuild_ version requirement will be introduced in **minor versions** of this package and will inherit breaking changes from _esbuild_.
|
|
23
|
+
Notably upgrades of the _esbuild_ minimum version requirement will be introduced in **minor versions** of this package and will inherit breaking changes from _esbuild_.
|
|
22
24
|
|
|
23
25
|
## Getting started
|
|
24
26
|
|
|
25
27
|
Install `cdk-esbuild`:
|
|
26
28
|
|
|
27
29
|
```
|
|
28
|
-
npm install @mrgrain/cdk-esbuild
|
|
30
|
+
npm install @mrgrain/cdk-esbuild@^3.0.0
|
|
29
31
|
```
|
|
30
32
|
|
|
31
33
|
If _peer_ and _optional dependencies_ are not installed automatically (e.g. when using npm v4-6), please use this command to install all of them:
|
|
32
34
|
|
|
33
35
|
```
|
|
34
|
-
npm install @mrgrain/cdk-esbuild esbuild
|
|
36
|
+
npm install @mrgrain/cdk-esbuild@^3.0.0 esbuild
|
|
35
37
|
```
|
|
36
38
|
|
|
37
39
|
### AWS Lambda: Serverless function
|
|
@@ -135,28 +137,82 @@ Underlying classes power the other features. You normally won't have to use them
|
|
|
135
137
|
|
|
136
138
|
Auto-generated reference for classes and structs. This information is also available within the code completion of your IDE.
|
|
137
139
|
|
|
138
|
-
##
|
|
140
|
+
## Escape hatches
|
|
141
|
+
|
|
142
|
+
It's possible that you want to use a implementation of esbuild that's different to the default one. Common reasons are:
|
|
143
|
+
|
|
144
|
+
- The current version constraints for esbuild are not suitable
|
|
145
|
+
- To use version of esbuild that is installed by any other means than `npm`, including Docker
|
|
146
|
+
- Plugin support is needed for the building
|
|
147
|
+
|
|
148
|
+
For these situations, this package offers an escape hatch to bypass regular the implementation and provide a custom build and transform function.
|
|
149
|
+
|
|
150
|
+
### Custom build function
|
|
151
|
+
|
|
152
|
+
> 💡 See [Using esbuild with plugins](examples/esbuild-with-plugins) for a complete working example of a custom build function using this escape hatch.
|
|
153
|
+
|
|
154
|
+
Constructs that result in starting a build, take a `buildFn` as optional prop. While the defined type for this function is `any`, it must implement the same signature as esbuild's `buildSync` function.
|
|
155
|
+
|
|
156
|
+
```ts
|
|
157
|
+
new TypeScriptCode("fixtures/handlers/ts-handler.ts", {
|
|
158
|
+
buildFn: (options: BuildOptions): BuildResult => {
|
|
159
|
+
try {
|
|
160
|
+
// custom implementation returning BuildResult
|
|
161
|
+
} catch (error) {
|
|
162
|
+
// throw BuildFailure exception here
|
|
163
|
+
}
|
|
164
|
+
},
|
|
165
|
+
});
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
Instead of esbuild, the provided function will be invoked with the calculated build options. The custom build function can amend, change or discard any of these. However integration with CDK relies heavily on the values `outdir`/`outfile` are set to and it's usually required to use them unchanged.
|
|
169
|
+
|
|
170
|
+
Failures have to cause a `BuildFailure` exception in order to be fully handled.
|
|
139
171
|
|
|
140
|
-
|
|
172
|
+
### Custom transform function
|
|
141
173
|
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
174
|
+
Constructs that result in starting a transformation, take a `transformFn` as optional prop. While the defined type for this function is `any`, it must implement the same signature as esbuild's `transformSync` function.
|
|
175
|
+
|
|
176
|
+
```ts
|
|
177
|
+
new InlineTypeScriptCode("let x: number = 1", {
|
|
178
|
+
transformFn: (options: TransformOptions): TransformResult => {
|
|
179
|
+
try {
|
|
180
|
+
// custom implementation returning TransformResult
|
|
181
|
+
} catch (error) {
|
|
182
|
+
// throw TransformFailure exception here
|
|
183
|
+
}
|
|
184
|
+
},,
|
|
185
|
+
});
|
|
186
|
+
```
|
|
187
|
+
|
|
188
|
+
Instead of esbuild, the provided function will be invoked with the calculated transform options. The custom transform function can amend, change or discard any of these.
|
|
189
|
+
|
|
190
|
+
Failures have to cause a `TransformFailure` exception in order to be fully handled.
|
|
191
|
+
|
|
192
|
+
## Migrating to v3
|
|
193
|
+
|
|
194
|
+
The release of cdk-esbuild v3 brings compatibility with AWS CDK v2. Furthermore all deprecated properties and classes have been removed. In particular `InlineCode` classes now take `TransformerProps` as second parameter instead of transform options.
|
|
146
195
|
|
|
147
196
|
### Upgrading
|
|
148
197
|
|
|
149
|
-
-
|
|
150
|
-
-
|
|
151
|
-
-
|
|
152
|
-
-
|
|
198
|
+
- This version requires AWS CDK v2. Follow the [official migration guide](https://docs.aws.amazon.com/cdk/latest/guide/work-with-cdk-v2.html) to upgrade.
|
|
199
|
+
- Update the package dependency to v3: `npm install --save @mrgrain/cdk-esbuild@^3.0.0`
|
|
200
|
+
- `esbuild` is installed as an optional dependency. If your setup does not automatically install optional dependencies, make sure to add it as an explicit dependency.
|
|
201
|
+
- Any use of `InlineCode` variations has to be updated. Previously the second parameter was either of type `TransformerProps` or `TransformOptions`. Now it must be `TransformerProps`.\
|
|
202
|
+
If the passed value is of type `TransformOptions`, turn it into the correct type like this:
|
|
203
|
+
|
|
204
|
+
```ts
|
|
205
|
+
const oldOptions: TransformOptions = {...}
|
|
206
|
+
|
|
207
|
+
new InlineTypeScriptCode('// inline code', {
|
|
208
|
+
transformOptions: oldOptions
|
|
209
|
+
});
|
|
210
|
+
```
|
|
153
211
|
|
|
154
212
|
## Versioning
|
|
155
213
|
|
|
156
214
|
This package _mostly_ follows [Semantic Versioning](https://semver.org/), with the exception of upgrades to `esbuild`. These will be released as **minor versions** and often include breaking changes from `esbuild`.
|
|
157
215
|
|
|
158
|
-
Although great care is taken to avoid this, all features marked as `@unstable` may change with minor versions. Please note that the unstable flag is applied to all new or experimental features and internal classes.
|
|
159
|
-
|
|
160
216
|
### Npm Tags
|
|
161
217
|
|
|
162
218
|
Some users prefer to use tags over version ranges. The following stable tags are available for use:
|
|
@@ -173,10 +229,6 @@ These tags also exist, but usage is strongly not recommended:
|
|
|
173
229
|
|
|
174
230
|
## Future releases
|
|
175
231
|
|
|
176
|
-
### AWS CDK v2
|
|
177
|
-
|
|
178
|
-
The monolithic version 2 of CDK (aka Mono-CDK) is on the horizon. A new major release of this package will be marked alongside CDK. Support for AWS CDK v1.x.x will be continued, however no new features will be added.
|
|
179
|
-
|
|
180
232
|
### Stable esbuild
|
|
181
233
|
|
|
182
234
|
Once `esbuild` has reached a stable version 1.0, a new major version will be released for _all_ breaking changes, including updates to minimum (peer) dependencies.
|
package/SECURITY.md
CHANGED
|
@@ -4,10 +4,11 @@
|
|
|
4
4
|
|
|
5
5
|
Only the latest release of each major version is supported.
|
|
6
6
|
|
|
7
|
-
| Plugin Version | CDK Version | Supported
|
|
8
|
-
| -------------- | ----------- |
|
|
9
|
-
| v1 | ^1.99.0 |
|
|
10
|
-
| v2 | ^1.99.0 |
|
|
7
|
+
| Plugin Version | CDK Version | Supported |
|
|
8
|
+
| -------------- | ----------- | ---------------------------------------------------------- |
|
|
9
|
+
| v1 | ^1.99.0 | :x: |
|
|
10
|
+
| v2 | ^1.99.0 | Security updates and critical bug fixes until June 1, 2023 |
|
|
11
|
+
| v3 | ^2.00.0 | :white_check_mark: |
|
|
11
12
|
|
|
12
13
|
## Reporting a Vulnerability
|
|
13
14
|
|
|
@@ -15,4 +16,4 @@ Please raise an [issue](https://github.com/mrgrain/cdk-esbuild/issues) and add t
|
|
|
15
16
|
|
|
16
17
|
I strive to respond to security issues within 48h. However this is an open source project with a single maintainer and life can get in the way.
|
|
17
18
|
|
|
18
|
-
Contributions of
|
|
19
|
+
Contributions of security fixes are most welcome!
|
package/lib/asset.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Asset as S3Asset } from '
|
|
2
|
-
import { Construct } from '
|
|
1
|
+
import { Asset as S3Asset } from 'aws-cdk-lib/aws-s3-assets';
|
|
2
|
+
import { Construct } from 'constructs';
|
|
3
3
|
import { BundlerProps, EntryPoints } from './bundler';
|
|
4
4
|
/**
|
|
5
5
|
* @internal
|
package/lib/asset.js
CHANGED
|
@@ -4,8 +4,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
4
4
|
exports.TypeScriptAsset = exports.JavaScriptAsset = void 0;
|
|
5
5
|
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
6
|
const path_1 = require("path");
|
|
7
|
-
const
|
|
8
|
-
const
|
|
7
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
8
|
+
const aws_s3_assets_1 = require("aws-cdk-lib/aws-s3-assets");
|
|
9
|
+
const constructs_1 = require("constructs");
|
|
9
10
|
const bundler_1 = require("./bundler");
|
|
10
11
|
/**
|
|
11
12
|
* @stability stable
|
|
@@ -16,9 +17,9 @@ class Asset extends aws_s3_assets_1.Asset {
|
|
|
16
17
|
*/
|
|
17
18
|
constructor(scope, id, props) {
|
|
18
19
|
var _c;
|
|
19
|
-
const { assetHash, copyDir, buildOptions: options = {}, } = props;
|
|
20
|
+
const { assetHash, copyDir, buildOptions: options = {}, buildFn, } = props;
|
|
20
21
|
const entryPoints = typeof props.entryPoints === 'string' ? [props.entryPoints] : props.entryPoints;
|
|
21
|
-
const name = scope.node.path +
|
|
22
|
+
const name = scope.node.path + constructs_1.Node.PATH_SEP + id;
|
|
22
23
|
Object.values(entryPoints).forEach((entryPoint) => {
|
|
23
24
|
if (path_1.isAbsolute(entryPoint)) {
|
|
24
25
|
throw new Error(`${name}: Entry points must be a relative path. If you need to define an absolute path, please use \`buildOptions.absWorkingDir\` accordingly.`);
|
|
@@ -33,10 +34,11 @@ class Asset extends aws_s3_assets_1.Asset {
|
|
|
33
34
|
super(scope, id, {
|
|
34
35
|
path: absWorkingDir,
|
|
35
36
|
assetHash,
|
|
36
|
-
assetHashType: assetHash ?
|
|
37
|
+
assetHashType: assetHash ? aws_cdk_lib_1.AssetHashType.CUSTOM : aws_cdk_lib_1.AssetHashType.OUTPUT,
|
|
37
38
|
bundling: new bundler_1.EsbuildBundler(entryPoints, {
|
|
38
39
|
buildOptions,
|
|
39
40
|
copyDir,
|
|
41
|
+
buildFn,
|
|
40
42
|
}),
|
|
41
43
|
});
|
|
42
44
|
}
|
|
@@ -52,7 +54,7 @@ class JavaScriptAsset extends Asset {
|
|
|
52
54
|
}
|
|
53
55
|
exports.JavaScriptAsset = JavaScriptAsset;
|
|
54
56
|
_a = JSII_RTTI_SYMBOL_1;
|
|
55
|
-
JavaScriptAsset[_a] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptAsset", version: "
|
|
57
|
+
JavaScriptAsset[_a] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptAsset", version: "3.0.0-rc.1" };
|
|
56
58
|
/**
|
|
57
59
|
* Bundles the entry points and creates a CDK asset which is uploaded to the bootstrapped CDK S3 bucket during deployment.
|
|
58
60
|
*
|
|
@@ -64,5 +66,5 @@ class TypeScriptAsset extends Asset {
|
|
|
64
66
|
}
|
|
65
67
|
exports.TypeScriptAsset = TypeScriptAsset;
|
|
66
68
|
_b = JSII_RTTI_SYMBOL_1;
|
|
67
|
-
TypeScriptAsset[_b] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptAsset", version: "
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
TypeScriptAsset[_b] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptAsset", version: "3.0.0-rc.1" };
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvYXNzZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSwrQkFBa0M7QUFDbEMsNkNBQTRDO0FBQzVDLDZEQUE2RDtBQUM3RCwyQ0FBNkM7QUFDN0MsdUNBQXNFO0FBa0J0RTs7R0FFRztBQUNILE1BQWUsS0FBZ0MsU0FBUSxxQkFBTzs7OztJQUU1RCxZQUNFLEtBQWdCLEVBQ2hCLEVBQVUsRUFDVixLQUFZOztRQUVaLE1BQU0sRUFDSixTQUFTLEVBQ1QsT0FBTyxFQUNQLFlBQVksRUFBRSxPQUFPLEdBQUcsRUFBRSxFQUMxQixPQUFPLEdBQ1IsR0FBRyxLQUFLLENBQUM7UUFDVixNQUFNLFdBQVcsR0FDZixPQUFPLEtBQUssQ0FBQyxXQUFXLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQztRQUVsRixNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksR0FBRyxpQkFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7UUFFbEQsTUFBTSxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxVQUFrQixFQUFFLEVBQUU7WUFDeEQsSUFBSSxpQkFBVSxDQUFDLFVBQVUsQ0FBQyxFQUFFO2dCQUMxQixNQUFNLElBQUksS0FBSyxDQUNiLEdBQUcsSUFBSSx3SUFBd0ksQ0FDaEosQ0FBQzthQUNIO1FBQ0gsQ0FBQyxDQUFDLENBQUM7UUFFSCxNQUFNLGFBQWEsU0FBRyxPQUFPLENBQUMsYUFBYSxtQ0FBSSxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7UUFFN0QsTUFBTSxZQUFZLEdBQUc7WUFDbkIsTUFBTSxFQUFFLElBQUk7WUFDWixHQUFHLE9BQU87WUFDVixhQUFhO1NBQ2QsQ0FBQztRQUVGLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFO1lBQ2YsSUFBSSxFQUFFLGFBQWE7WUFDbkIsU0FBUztZQUNULGFBQWEsRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDLDJCQUFhLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQywyQkFBYSxDQUFDLE1BQU07WUFDdEUsUUFBUSxFQUFFLElBQUksd0JBQWMsQ0FDMUIsV0FBVyxFQUNYO2dCQUNFLFlBQVk7Z0JBQ1osT0FBTztnQkFDUCxPQUFPO2FBQ1IsQ0FDRjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRjs7Ozs7Ozs7QUFHRCxNQUFhLGVBQWdCLFNBQVEsS0FBMkI7O0FBQWhFLDBDQUFtRTs7Ozs7Ozs7OztBQUduRSxNQUFhLGVBQWdCLFNBQVEsS0FBMkI7O0FBQWhFLDBDQUFtRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzQWJzb2x1dGUgfSBmcm9tICdwYXRoJztcbmltcG9ydCB7IEFzc2V0SGFzaFR5cGUgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBBc3NldCBhcyBTM0Fzc2V0IH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLXMzLWFzc2V0cyc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QsIE5vZGUgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IEVzYnVpbGRCdW5kbGVyLCBCdW5kbGVyUHJvcHMsIEVudHJ5UG9pbnRzIH0gZnJvbSAnLi9idW5kbGVyJztcblxuLyoqXG4gKiBAaW50ZXJuYWxcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBBc3NldEJhc2VQcm9wcyBleHRlbmRzIEJ1bmRsZXJQcm9wcyB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IGFzc2V0SGFzaD86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBc3NldFByb3BzIGV4dGVuZHMgQXNzZXRCYXNlUHJvcHMge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHJlYWRvbmx5IGVudHJ5UG9pbnRzOiBFbnRyeVBvaW50cztcbn1cblxudHlwZSBKYXZhU2NyaXB0QXNzZXRQcm9wcyA9IEFzc2V0UHJvcHM7XG50eXBlIFR5cGVTY3JpcHRBc3NldFByb3BzID0gQXNzZXRQcm9wcztcblxuLyoqXG4gKiBAc3RhYmlsaXR5IHN0YWJsZVxuICovXG5hYnN0cmFjdCBjbGFzcyBBc3NldDxQcm9wcyBleHRlbmRzIEFzc2V0UHJvcHM+IGV4dGVuZHMgUzNBc3NldCB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcihcbiAgICBzY29wZTogQ29uc3RydWN0LFxuICAgIGlkOiBzdHJpbmcsXG4gICAgcHJvcHM6IFByb3BzLFxuICApIHtcbiAgICBjb25zdCB7XG4gICAgICBhc3NldEhhc2gsXG4gICAgICBjb3B5RGlyLFxuICAgICAgYnVpbGRPcHRpb25zOiBvcHRpb25zID0ge30sXG4gICAgICBidWlsZEZuLFxuICAgIH0gPSBwcm9wcztcbiAgICBjb25zdCBlbnRyeVBvaW50czogc3RyaW5nW10gfCBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+ID1cbiAgICAgIHR5cGVvZiBwcm9wcy5lbnRyeVBvaW50cyA9PT0gJ3N0cmluZycgPyBbcHJvcHMuZW50cnlQb2ludHNdIDogcHJvcHMuZW50cnlQb2ludHM7XG5cbiAgICBjb25zdCBuYW1lID0gc2NvcGUubm9kZS5wYXRoICsgTm9kZS5QQVRIX1NFUCArIGlkO1xuXG4gICAgT2JqZWN0LnZhbHVlcyhlbnRyeVBvaW50cykuZm9yRWFjaCgoZW50cnlQb2ludDogc3RyaW5nKSA9PiB7XG4gICAgICBpZiAoaXNBYnNvbHV0ZShlbnRyeVBvaW50KSkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgICAgYCR7bmFtZX06IEVudHJ5IHBvaW50cyBtdXN0IGJlIGEgcmVsYXRpdmUgcGF0aC4gSWYgeW91IG5lZWQgdG8gZGVmaW5lIGFuIGFic29sdXRlIHBhdGgsIHBsZWFzZSB1c2UgXFxgYnVpbGRPcHRpb25zLmFic1dvcmtpbmdEaXJcXGAgYWNjb3JkaW5nbHkuYCxcbiAgICAgICAgKTtcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIGNvbnN0IGFic1dvcmtpbmdEaXIgPSBvcHRpb25zLmFic1dvcmtpbmdEaXIgPz8gcHJvY2Vzcy5jd2QoKTtcblxuICAgIGNvbnN0IGJ1aWxkT3B0aW9ucyA9IHtcbiAgICAgIGJ1bmRsZTogdHJ1ZSxcbiAgICAgIC4uLm9wdGlvbnMsXG4gICAgICBhYnNXb3JraW5nRGlyLFxuICAgIH07XG5cbiAgICBzdXBlcihzY29wZSwgaWQsIHtcbiAgICAgIHBhdGg6IGFic1dvcmtpbmdEaXIsXG4gICAgICBhc3NldEhhc2gsXG4gICAgICBhc3NldEhhc2hUeXBlOiBhc3NldEhhc2ggPyBBc3NldEhhc2hUeXBlLkNVU1RPTSA6IEFzc2V0SGFzaFR5cGUuT1VUUFVULFxuICAgICAgYnVuZGxpbmc6IG5ldyBFc2J1aWxkQnVuZGxlcihcbiAgICAgICAgZW50cnlQb2ludHMsXG4gICAgICAgIHtcbiAgICAgICAgICBidWlsZE9wdGlvbnMsXG4gICAgICAgICAgY29weURpcixcbiAgICAgICAgICBidWlsZEZuLFxuICAgICAgICB9LFxuICAgICAgKSxcbiAgICB9KTtcbiAgfVxufVxuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuZXhwb3J0IGNsYXNzIEphdmFTY3JpcHRBc3NldCBleHRlbmRzIEFzc2V0PEphdmFTY3JpcHRBc3NldFByb3BzPiB7fVxuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuZXhwb3J0IGNsYXNzIFR5cGVTY3JpcHRBc3NldCBleHRlbmRzIEFzc2V0PFR5cGVTY3JpcHRBc3NldFByb3BzPiB7fVxuIl19
|
package/lib/bundler.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { DockerImage, ILocalBundling } from '
|
|
1
|
+
import { DockerImage, ILocalBundling } from 'aws-cdk-lib';
|
|
2
2
|
import { BuildOptions } from './esbuild-types';
|
|
3
3
|
/**
|
|
4
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`.
|
|
@@ -37,6 +37,19 @@ export interface BundlerProps {
|
|
|
37
37
|
* @stability stable
|
|
38
38
|
*/
|
|
39
39
|
readonly copyDir?: string;
|
|
40
|
+
/**
|
|
41
|
+
* (experimental) Escape hatch to provide the bundler with a custom build function.
|
|
42
|
+
*
|
|
43
|
+
* 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.
|
|
44
|
+
* Must throw a `BuildFailure` on failure to correctly inform the bundler.
|
|
45
|
+
*
|
|
46
|
+
* @returns esbuild.BuildResult
|
|
47
|
+
* @default esbuild.buildSync
|
|
48
|
+
* @experimental
|
|
49
|
+
* @type esbuild.buildSync
|
|
50
|
+
* @throws esbuild.BuildFailure
|
|
51
|
+
*/
|
|
52
|
+
readonly buildFn?: any;
|
|
40
53
|
}
|
|
41
54
|
/**
|
|
42
55
|
* (experimental) Low-level construct that can be used where `BundlingOptions` are required.
|
package/lib/bundler.js
CHANGED
|
@@ -4,7 +4,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
4
4
|
exports.EsbuildBundler = void 0;
|
|
5
5
|
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
6
|
const path_1 = require("path");
|
|
7
|
-
const
|
|
7
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
8
8
|
const esbuild_wrapper_1 = require("./esbuild-wrapper");
|
|
9
9
|
const formatMessages_1 = require("./formatMessages");
|
|
10
10
|
/**
|
|
@@ -40,18 +40,19 @@ class EsbuildBundler {
|
|
|
40
40
|
/**
|
|
41
41
|
* @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.
|
|
42
42
|
*/
|
|
43
|
-
this.image =
|
|
43
|
+
this.image = aws_cdk_lib_1.DockerImage.fromRegistry('scratch');
|
|
44
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)) {
|
|
45
45
|
throw new Error('Cannot use both "outfile" and "outdir"');
|
|
46
46
|
}
|
|
47
|
+
const { buildFn = esbuild_wrapper_1.buildSync } = this.props;
|
|
47
48
|
this.local = {
|
|
48
49
|
tryBundle: (outputDir, _options) => {
|
|
49
50
|
var _b, _c, _d, _e;
|
|
50
51
|
try {
|
|
51
52
|
if (this.props.copyDir) {
|
|
52
|
-
|
|
53
|
+
aws_cdk_lib_1.FileSystem.copyDirectory(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(), this.props.copyDir), outputDir);
|
|
53
54
|
}
|
|
54
|
-
const buildResult =
|
|
55
|
+
const buildResult = buildFn({
|
|
55
56
|
entryPoints,
|
|
56
57
|
...(((_e = this.props) === null || _e === void 0 ? void 0 : _e.buildOptions) || {}),
|
|
57
58
|
...this.getOutputOptions(outputDir, { normalize: path_1.normalize, join: path_1.join }),
|
|
@@ -81,5 +82,5 @@ class EsbuildBundler {
|
|
|
81
82
|
}
|
|
82
83
|
exports.EsbuildBundler = EsbuildBundler;
|
|
83
84
|
_a = JSII_RTTI_SYMBOL_1;
|
|
84
|
-
EsbuildBundler[_a] = { fqn: "@mrgrain/cdk-esbuild.EsbuildBundler", version: "
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundler.js","sourceRoot":"","sources":["../src/bundler.ts"],"names":[],"mappings":";;;;;AAAA,+BAAqE;AACrE,wCAKuB;AAEvB,uDAA8C;AAC9C,qDAAsD;;;;;;;;AAmBtD,MAAa,cAAc;;;;;;IAQzB;IACE;;;;;OAKG;IACa,WAAwB;IAExC;;;;OAIG;IACa,KAAmB;;QAPnB,gBAAW,GAAX,WAAW,CAAa;QAOxB,UAAK,GAAL,KAAK,CAAc;;;;QAjBrB,UAAK,GAAG,kBAAW,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;QAmB1D,IAAI,OAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,YAAY,0CAAE,OAAO,YAAI,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,YAAY,0CAAE,MAAM,CAAA,EAAE;YAC/D,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;SAC3D;QAED,IAAI,CAAC,KAAK,GAAG;YACX,SAAS,EAAE,CAAC,SAAiB,EAAE,QAAyB,EAAW,EAAE;;gBACnE,IAAI;oBACF,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE;wBACtB,iBAAU,CAAC,aAAa,CACtB,cAAO,mBACL,IAAI,CAAC,KAAK,0CAAE,YAAY,0CAAE,aAAa,mCAAI,OAAO,CAAC,GAAG,EAAE,EACxD,IAAI,CAAC,KAAK,CAAC,OAAO,CACnB,EACD,SAAS,CACV,CAAC;qBACH;oBAED,MAAM,WAAW,GAAgB,2BAAS,CAAC;wBACzC,WAAW;wBACX,GAAG,CAAC,OAAA,IAAI,CAAC,KAAK,0CAAE,YAAY,KAAI,EAAE,CAAC;wBACnC,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,EAAE,SAAS,EAAT,gBAAS,EAAE,IAAI,EAAJ,WAAI,EAAE,CAAC;qBACzD,CAAC,CAAC;oBAEH,mCAAkB,CAAC,WAAW,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;iBACvD;gBAAC,OAAO,KAAK,EAAE;oBACd,mCAAkB,CAAC,KAAqB,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;iBACjE;gBAED,OAAO,IAAI,CAAC;YACd,CAAC;SACF,CAAC;IACJ,CAAC;IAEO,gBAAgB,CACtB,YAAoB,EACpB,OAAiD,YAAK;;QAEtD,gBAAI,IAAI,CAAC,KAAK,0CAAE,YAAY,0CAAE,OAAO,EAAE;YACrC,OAAO;gBACL,MAAM,EAAE,SAAS;gBACjB,OAAO,EAAE,IAAI,CAAC,SAAS,CACrB,IAAI,CAAC,IAAI,CACP,GAAI,CAAC,YAAY,cAAE,IAAI,CAAC,KAAK,0CAAE,YAAY,0CAAE,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,cAAE,IAAI,CAAC,KAAK,0CAAE,YAAY,0CAAE,MAAM,CAAC,CAAC,MAAM,CACzD,OAAO,CACK,CACf,CACF;YACD,OAAO,EAAE,SAAS;SACnB,CAAC;IACJ,CAAC;;AApFH,wCAqFC","sourcesContent":["import { join, normalize, resolve, posix, PlatformPath } from 'path';\nimport {\n  BundlingOptions,\n  DockerImage,\n  FileSystem,\n  ILocalBundling,\n} from '@aws-cdk/core';\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                            \nexport interface BundlerProps {\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     \n  readonly buildOptions?: BuildOptions;\n\n                                                                                                                                                                                                                                \n  readonly copyDir?: string;\n}\n\n                                                                                                                                                                                                                   \nexport class EsbuildBundler {\n                                                                                                                                           \n  public readonly local: ILocalBundling;\n\n                                                                                                                                                                                                                                             \n  public readonly image = DockerImage.fromRegistry('scratch');\n\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    this.local = {\n      tryBundle: (outputDir: string, _options: BundlingOptions): boolean => {\n        try {\n          if (this.props.copyDir) {\n            FileSystem.copyDirectory(\n              resolve(\n                this.props?.buildOptions?.absWorkingDir ?? process.cwd(),\n                this.props.copyDir,\n              ),\n              outputDir,\n            );\n          }\n\n          const buildResult: BuildResult = buildSync({\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 getOutputOptions(\n    cdkOutputDir: string,\n    path: Pick<PlatformPath, '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"]}
|
|
85
|
+
EsbuildBundler[_a] = { fqn: "@mrgrain/cdk-esbuild.EsbuildBundler", version: "3.0.0-rc.1" };
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundler.js","sourceRoot":"","sources":["../src/bundler.ts"],"names":[],"mappings":";;;;;AAAA,+BAAqE;AACrE,6CAKqB;AAErB,uDAA8C;AAC9C,qDAAsD;;;;;;;;AAuBtD,MAAa,cAAc;;;;;;IAQzB;IACE;;;;;OAKG;IACa,WAAwB;IAExC;;;;OAIG;IACa,KAAmB;;QAPnB,gBAAW,GAAX,WAAW,CAAa;QAOxB,UAAK,GAAL,KAAK,CAAc;;;;QAjBrB,UAAK,GAAG,yBAAW,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;QAmB1D,IAAI,OAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,YAAY,0CAAE,OAAO,YAAI,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,YAAY,0CAAE,MAAM,CAAA,EAAE;YAC/D,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;SAC3D;QAED,MAAM,EAAE,OAAO,GAAG,2BAAS,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC;QAE3C,IAAI,CAAC,KAAK,GAAG;YACX,SAAS,EAAE,CAAC,SAAiB,EAAE,QAAyB,EAAW,EAAE;;gBACnE,IAAI;oBACF,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE;wBACtB,wBAAU,CAAC,aAAa,CACtB,cAAO,mBACL,IAAI,CAAC,KAAK,0CAAE,YAAY,0CAAE,aAAa,mCAAI,OAAO,CAAC,GAAG,EAAE,EACxD,IAAI,CAAC,KAAK,CAAC,OAAO,CACnB,EACD,SAAS,CACV,CAAC;qBACH;oBAED,MAAM,WAAW,GAAgB,OAAO,CAAC;wBACvC,WAAW;wBACX,GAAG,CAAC,OAAA,IAAI,CAAC,KAAK,0CAAE,YAAY,KAAI,EAAE,CAAC;wBACnC,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,EAAE,SAAS,EAAT,gBAAS,EAAE,IAAI,EAAJ,WAAI,EAAE,CAAC;qBACzD,CAAC,CAAC;oBAEH,mCAAkB,CAAC,WAAW,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;iBACvD;gBAAC,OAAO,KAAK,EAAE;oBACd,mCAAkB,CAAC,KAAqB,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;iBACjE;gBAED,OAAO,IAAI,CAAC;YACd,CAAC;SACF,CAAC;IACJ,CAAC;IAEO,gBAAgB,CACtB,YAAoB,EACpB,OAAiD,YAAK;;QAEtD,gBAAI,IAAI,CAAC,KAAK,0CAAE,YAAY,0CAAE,OAAO,EAAE;YACrC,OAAO;gBACL,MAAM,EAAE,SAAS;gBACjB,OAAO,EAAE,IAAI,CAAC,SAAS,CACrB,IAAI,CAAC,IAAI,CACP,GAAI,CAAC,YAAY,cAAE,IAAI,CAAC,KAAK,0CAAE,YAAY,0CAAE,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,cAAE,IAAI,CAAC,KAAK,0CAAE,YAAY,0CAAE,MAAM,CAAC,CAAC,MAAM,CACzD,OAAO,CACK,CACf,CACF;YACD,OAAO,EAAE,SAAS;SACnB,CAAC;IACJ,CAAC;;AAtFH,wCAuFC","sourcesContent":["import { join, normalize, resolve, posix, PlatformPath } 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                            \nexport interface BundlerProps {\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     \n  readonly buildOptions?: BuildOptions;\n\n                                                                                                                                                                                                                                \n  readonly copyDir?: string;\n\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        \n  readonly buildFn?: any;\n}\n\n                                                                                                                                                                                                                   \nexport class EsbuildBundler {\n                                                                                                                                           \n  public readonly local: ILocalBundling;\n\n                                                                                                                                                                                                                                             \n  public readonly image = DockerImage.fromRegistry('scratch');\n\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        try {\n          if (this.props.copyDir) {\n            FileSystem.copyDirectory(\n              resolve(\n                this.props?.buildOptions?.absWorkingDir ?? process.cwd(),\n                this.props.copyDir,\n              ),\n              outputDir,\n            );\n          }\n\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 getOutputOptions(\n    cdkOutputDir: string,\n    path: Pick<PlatformPath, '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,6 +1,7 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
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';
|
|
4
|
+
import { Construct } from 'constructs';
|
|
4
5
|
import { AssetBaseProps, AssetProps, JavaScriptAsset as JSAsset, TypeScriptAsset as TSAsset } from './asset';
|
|
5
6
|
import { EntryPoints } from './bundler';
|
|
6
7
|
/**
|
package/lib/code.js
CHANGED
|
@@ -3,7 +3,7 @@ var _a, _b;
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
4
|
exports.TypeScriptCode = exports.JavaScriptCode = void 0;
|
|
5
5
|
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
-
const
|
|
6
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
7
7
|
const asset_1 = require("./asset");
|
|
8
8
|
function nodeMajorVersion() {
|
|
9
9
|
return parseInt(process.versions.node.split('.')[0], 10);
|
|
@@ -48,8 +48,8 @@ class Code {
|
|
|
48
48
|
if (!this.asset) {
|
|
49
49
|
this.asset = new this.assetClass(scope, this.constructor.name, this.props);
|
|
50
50
|
}
|
|
51
|
-
else if (
|
|
52
|
-
throw new Error(`Asset is already associated with another stack '${
|
|
51
|
+
else if (aws_cdk_lib_1.Stack.of(this.asset) !== aws_cdk_lib_1.Stack.of(scope)) {
|
|
52
|
+
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.');
|
|
53
53
|
}
|
|
54
54
|
return {
|
|
55
55
|
s3Location: {
|
|
@@ -114,7 +114,7 @@ class JavaScriptCode extends Code {
|
|
|
114
114
|
}
|
|
115
115
|
exports.JavaScriptCode = JavaScriptCode;
|
|
116
116
|
_a = JSII_RTTI_SYMBOL_1;
|
|
117
|
-
JavaScriptCode[_a] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptCode", version: "
|
|
117
|
+
JavaScriptCode[_a] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptCode", version: "3.0.0-rc.1" };
|
|
118
118
|
/**
|
|
119
119
|
* Represents the deployed TypeScript Code.
|
|
120
120
|
*
|
|
@@ -154,5 +154,5 @@ class TypeScriptCode extends Code {
|
|
|
154
154
|
}
|
|
155
155
|
exports.TypeScriptCode = TypeScriptCode;
|
|
156
156
|
_b = JSII_RTTI_SYMBOL_1;
|
|
157
|
-
TypeScriptCode[_b] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptCode", version: "
|
|
158
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
157
|
+
TypeScriptCode[_b] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptCode", version: "3.0.0-rc.1" };
|
|
158
|
+
//# 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;AAO6D,CAAC;AACD,CAAC;AAE/D,MAAe,IAAI;IAiBjB;;;;OAIG;IACH,YAA4B,WAAwB,EAAE,KAAY;;QAAtC,gBAAW,GAAX,WAAW,CAAa;;;;;;QAP7C,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;;;;;;;;;IAGD,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;;;;;;AAGD,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;;;;;;;;AAGD,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  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  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  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                                                                           \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                                                                           \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"]}
|
package/lib/index.d.ts
CHANGED
|
@@ -2,5 +2,5 @@ export { BuildOptions, TransformOptions } from './esbuild-types';
|
|
|
2
2
|
export { EsbuildBundler, BundlerProps } from './bundler';
|
|
3
3
|
export { JavaScriptAsset, TypeScriptAsset, AssetBaseProps, AssetProps } from './asset';
|
|
4
4
|
export { JavaScriptCode, JavaScriptCodeProps, TypeScriptCode, TypeScriptCodeProps, CodeConfig, } from './code';
|
|
5
|
-
export { InlineJavaScriptCode, InlineJsxCode, InlineTsxCode, InlineTypeScriptCode, } from './inline-code';
|
|
5
|
+
export { TransformerProps, InlineJavaScriptCode, InlineJsxCode, InlineTsxCode, InlineTypeScriptCode, } from './inline-code';
|
|
6
6
|
export { JavaScriptSource, JavaScriptSourceProps, TypeScriptSource, TypeScriptSourceProps, } from './source';
|
package/lib/index.js
CHANGED
|
@@ -16,4 +16,4 @@ Object.defineProperty(exports, "InlineTypeScriptCode", { enumerable: true, get:
|
|
|
16
16
|
var source_1 = require("./source");
|
|
17
17
|
Object.defineProperty(exports, "JavaScriptSource", { enumerable: true, get: function () { return source_1.JavaScriptSource; } });
|
|
18
18
|
Object.defineProperty(exports, "TypeScriptSource", { enumerable: true, get: function () { return source_1.TypeScriptSource; } });
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFHQSxxQ0FBeUQ7QUFBaEQseUdBQUEsY0FBYyxPQUFBO0FBRXZCLGlDQUF1RjtBQUE5RSx3R0FBQSxlQUFlLE9BQUE7QUFBRSx3R0FBQSxlQUFlLE9BQUE7QUFFekMsK0JBTWdCO0FBTGQsc0dBQUEsY0FBYyxPQUFBO0FBRWQsc0dBQUEsY0FBYyxPQUFBO0FBS2hCLDZDQU11QjtBQUpyQixtSEFBQSxvQkFBb0IsT0FBQTtBQUNwQiw0R0FBQSxhQUFhLE9BQUE7QUFDYiw0R0FBQSxhQUFhLE9BQUE7QUFDYixtSEFBQSxvQkFBb0IsT0FBQTtBQUd0QixtQ0FLa0I7QUFKaEIsMEdBQUEsZ0JBQWdCLE9BQUE7QUFFaEIsMEdBQUEsZ0JBQWdCLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyJcbmV4cG9ydCB7IEJ1aWxkT3B0aW9ucywgVHJhbnNmb3JtT3B0aW9ucyB9IGZyb20gJy4vZXNidWlsZC10eXBlcyc7XG5cbmV4cG9ydCB7IEVzYnVpbGRCdW5kbGVyLCBCdW5kbGVyUHJvcHMgfSBmcm9tICcuL2J1bmRsZXInO1xuXG5leHBvcnQgeyBKYXZhU2NyaXB0QXNzZXQsIFR5cGVTY3JpcHRBc3NldCwgQXNzZXRCYXNlUHJvcHMsIEFzc2V0UHJvcHMgfSBmcm9tICcuL2Fzc2V0JztcblxuZXhwb3J0IHtcbiAgSmF2YVNjcmlwdENvZGUsXG4gIEphdmFTY3JpcHRDb2RlUHJvcHMsXG4gIFR5cGVTY3JpcHRDb2RlLFxuICBUeXBlU2NyaXB0Q29kZVByb3BzLFxuICBDb2RlQ29uZmlnLFxufSBmcm9tICcuL2NvZGUnO1xuXG5leHBvcnQge1xuICBUcmFuc2Zvcm1lclByb3BzLFxuICBJbmxpbmVKYXZhU2NyaXB0Q29kZSxcbiAgSW5saW5lSnN4Q29kZSxcbiAgSW5saW5lVHN4Q29kZSxcbiAgSW5saW5lVHlwZVNjcmlwdENvZGUsXG59IGZyb20gJy4vaW5saW5lLWNvZGUnO1xuXG5leHBvcnQge1xuICBKYXZhU2NyaXB0U291cmNlLFxuICBKYXZhU2NyaXB0U291cmNlUHJvcHMsXG4gIFR5cGVTY3JpcHRTb3VyY2UsXG4gIFR5cGVTY3JpcHRTb3VyY2VQcm9wcyxcbn0gZnJvbSAnLi9zb3VyY2UnOyJdfQ==
|