@mrgrain/cdk-esbuild 4.0.0-alpha.7 → 4.0.0-beta.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/.jsii +1573 -588
- package/CHANGELOG.md +104 -0
- package/LICENSE +1 -1
- package/README.md +223 -102
- package/lib/asset.d.ts +20 -5
- package/lib/asset.js +31 -19
- package/lib/bundler.d.ts +51 -28
- package/lib/bundler.js +28 -17
- package/lib/code.d.ts +82 -16
- package/lib/code.js +71 -25
- package/lib/esbuild-types.d.ts +49 -18
- package/lib/esbuild-types.js +1 -1
- package/lib/index.d.ts +5 -4
- package/lib/index.js +8 -7
- package/lib/inline-code.d.ts +29 -77
- package/lib/inline-code.js +53 -104
- package/lib/private/dynamic-package.d.ts +41 -0
- package/lib/private/dynamic-package.js +115 -0
- package/lib/private/esbuild-source.d.ts +33 -0
- package/lib/private/esbuild-source.js +59 -0
- package/lib/private/utils.d.ts +7 -0
- package/lib/private/utils.js +23 -0
- package/lib/provider.d.ts +129 -0
- package/lib/provider.js +115 -0
- package/lib/source.d.ts +81 -5
- package/lib/source.js +84 -8
- package/package.json +33 -25
- package/rosetta/default.ts-fixture +32 -0
- package/.gitattributes +0 -24
- package/.projenrc.ts +0 -208
- package/API.md +0 -2477
- package/SECURITY.md +0 -19
- package/lib/esbuild-polyfill.js +0 -2302
- package/lib/esbuild-wrapper.d.ts +0 -3
- package/lib/esbuild-wrapper.js +0 -31
- package/lib/formatMessages.d.ts +0 -18
- package/lib/formatMessages.js +0 -34
- package/node_modules/isexe/.npmignore +0 -2
- package/node_modules/isexe/LICENSE +0 -15
- package/node_modules/isexe/README.md +0 -51
- package/node_modules/isexe/index.js +0 -57
- package/node_modules/isexe/mode.js +0 -41
- package/node_modules/isexe/package.json +0 -35
- package/node_modules/isexe/test/basic.js +0 -221
- package/node_modules/isexe/windows.js +0 -42
- package/node_modules/which/CHANGELOG.md +0 -166
- package/node_modules/which/LICENSE +0 -15
- package/node_modules/which/README.md +0 -54
- package/node_modules/which/bin/node-which +0 -52
- package/node_modules/which/package.json +0 -47
- package/node_modules/which/which.js +0 -125
package/lib/asset.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var _a, _b, _c;
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
exports.TypeScriptAsset = exports.JavaScriptAsset = exports.
|
|
4
|
+
exports.TypeScriptAsset = exports.JavaScriptAsset = exports.EsbuildAsset = 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,22 +9,35 @@ 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
|
-
*
|
|
12
|
+
* Represents a generic esbuild asset.
|
|
13
|
+
*
|
|
14
|
+
* You should always use `TypeScriptAsset` or `JavaScriptAsset`.
|
|
15
|
+
*
|
|
16
|
+
* @stability experimental
|
|
13
17
|
*/
|
|
14
|
-
class
|
|
18
|
+
class EsbuildAsset extends aws_s3_assets_1.Asset {
|
|
15
19
|
/**
|
|
16
20
|
* @stability stable
|
|
17
21
|
*/
|
|
18
22
|
constructor(scope, id, props) {
|
|
19
|
-
const { assetHash,
|
|
23
|
+
const { assetHash, buildOptions: options = {}, } = props;
|
|
20
24
|
const entryPoints = typeof props.entryPoints === 'string' ? [props.entryPoints] : props.entryPoints;
|
|
21
25
|
const name = scope.node.path + constructs_1.Node.PATH_SEP + id;
|
|
22
|
-
Object.values(entryPoints).forEach((entryPoint) => {
|
|
23
|
-
if (path_1.isAbsolute(entryPoint)) {
|
|
24
|
-
throw new Error(`${name}: Entry points must be a relative path. If you need to define an absolute path, please use \`buildOptions.absWorkingDir\` accordingly.`);
|
|
25
|
-
}
|
|
26
|
-
});
|
|
27
26
|
const absWorkingDir = options.absWorkingDir ?? process.cwd();
|
|
27
|
+
const forceRelativeEntrypointPath = (entryPoint) => {
|
|
28
|
+
if (!path_1.isAbsolute(entryPoint)) {
|
|
29
|
+
return entryPoint;
|
|
30
|
+
}
|
|
31
|
+
const relativeEntryPoint = path_1.relative(absWorkingDir, entryPoint);
|
|
32
|
+
if (relativeEntryPoint.startsWith('..') || path_1.isAbsolute(relativeEntryPoint)) {
|
|
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
|
+
}
|
|
35
|
+
return relativeEntryPoint;
|
|
36
|
+
};
|
|
37
|
+
const relativeEntryPoints = Array.isArray(entryPoints) ?
|
|
38
|
+
entryPoints.map(forceRelativeEntrypointPath) :
|
|
39
|
+
Object.fromEntries(Object.entries(entryPoints)
|
|
40
|
+
.map(([out, entryPoint]) => ([out, forceRelativeEntrypointPath(entryPoint)])));
|
|
28
41
|
const buildOptions = {
|
|
29
42
|
bundle: true,
|
|
30
43
|
...options,
|
|
@@ -34,17 +47,16 @@ class Asset extends aws_s3_assets_1.Asset {
|
|
|
34
47
|
path: absWorkingDir,
|
|
35
48
|
assetHash,
|
|
36
49
|
assetHashType: assetHash ? aws_cdk_lib_1.AssetHashType.CUSTOM : aws_cdk_lib_1.AssetHashType.OUTPUT,
|
|
37
|
-
bundling: new bundler_1.EsbuildBundler(
|
|
50
|
+
bundling: new bundler_1.EsbuildBundler(relativeEntryPoints, {
|
|
51
|
+
...props,
|
|
38
52
|
buildOptions,
|
|
39
|
-
copyDir,
|
|
40
|
-
buildFn,
|
|
41
53
|
}),
|
|
42
54
|
});
|
|
43
55
|
}
|
|
44
56
|
}
|
|
45
|
-
exports.
|
|
57
|
+
exports.EsbuildAsset = EsbuildAsset;
|
|
46
58
|
_a = JSII_RTTI_SYMBOL_1;
|
|
47
|
-
|
|
59
|
+
EsbuildAsset[_a] = { fqn: "@mrgrain/cdk-esbuild.EsbuildAsset", version: "4.0.0-beta.0" };
|
|
48
60
|
/**
|
|
49
61
|
* Bundles the entry points and creates a CDK asset which is uploaded to the bootstrapped CDK S3 bucket during deployment.
|
|
50
62
|
*
|
|
@@ -52,11 +64,11 @@ Asset[_a] = { fqn: "@mrgrain/cdk-esbuild.Asset", version: "4.0.0-alpha.7" };
|
|
|
52
64
|
*
|
|
53
65
|
* @stability stable
|
|
54
66
|
*/
|
|
55
|
-
class JavaScriptAsset extends
|
|
67
|
+
class JavaScriptAsset extends EsbuildAsset {
|
|
56
68
|
}
|
|
57
69
|
exports.JavaScriptAsset = JavaScriptAsset;
|
|
58
70
|
_b = JSII_RTTI_SYMBOL_1;
|
|
59
|
-
JavaScriptAsset[_b] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptAsset", version: "4.0.0-
|
|
71
|
+
JavaScriptAsset[_b] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptAsset", version: "4.0.0-beta.0" };
|
|
60
72
|
/**
|
|
61
73
|
* Bundles the entry points and creates a CDK asset which is uploaded to the bootstrapped CDK S3 bucket during deployment.
|
|
62
74
|
*
|
|
@@ -64,9 +76,9 @@ JavaScriptAsset[_b] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptAsset", version: "4
|
|
|
64
76
|
*
|
|
65
77
|
* @stability stable
|
|
66
78
|
*/
|
|
67
|
-
class TypeScriptAsset extends
|
|
79
|
+
class TypeScriptAsset extends EsbuildAsset {
|
|
68
80
|
}
|
|
69
81
|
exports.TypeScriptAsset = TypeScriptAsset;
|
|
70
82
|
_c = JSII_RTTI_SYMBOL_1;
|
|
71
|
-
TypeScriptAsset[_c] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptAsset", version: "4.0.0-
|
|
72
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
83
|
+
TypeScriptAsset[_c] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptAsset", version: "4.0.0-beta.0" };
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvYXNzZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSwrQkFBNEM7QUFDNUMsNkNBQTRDO0FBQzVDLDZEQUE2RDtBQUM3RCwyQ0FBNkM7QUFDN0MsdUNBQXNFO0FBeUN0RTs7Ozs7O0dBTUc7QUFDSCxNQUFhLFlBQXVDLFNBQVEscUJBQU87SUFDakU7O09BRUc7SUFDSCxZQUNFLEtBQWdCLEVBQ2hCLEVBQVUsRUFDVixLQUFZO1FBRVosTUFBTSxFQUNKLFNBQVMsRUFDVCxZQUFZLEVBQUUsT0FBTyxHQUFHLEVBQUUsR0FDM0IsR0FBRyxLQUFLLENBQUM7UUFDVixNQUFNLFdBQVcsR0FDZixPQUFPLEtBQUssQ0FBQyxXQUFXLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQztRQUVsRixNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksR0FBRyxpQkFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7UUFFbEQsTUFBTSxhQUFhLEdBQUcsT0FBTyxDQUFDLGFBQWEsSUFBSSxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7UUFFN0QsTUFBTSwyQkFBMkIsR0FBRyxDQUFDLFVBQWtCLEVBQVUsRUFBRTtZQUNqRSxJQUFJLENBQUMsaUJBQVUsQ0FBQyxVQUFVLENBQUMsRUFBRTtnQkFDM0IsT0FBTyxVQUFVLENBQUM7YUFDbkI7WUFFRCxNQUFNLGtCQUFrQixHQUFHLGVBQVEsQ0FBQyxhQUFhLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDL0QsSUFBSSxrQkFBa0IsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLElBQUksaUJBQVUsQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFO2dCQUN6RSxNQUFNLElBQUksS0FBSyxDQUNiLEdBQUcsSUFBSSxtSkFBbUosQ0FDM0osQ0FBQzthQUNIO1lBRUQsT0FBTyxrQkFBa0IsQ0FBQztRQUM1QixDQUFDLENBQUM7UUFFRixNQUFNLG1CQUFtQixHQUN2QixLQUFLLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUM7WUFDMUIsV0FBVyxDQUFDLEdBQUcsQ0FBQywyQkFBMkIsQ0FBQyxDQUFDLENBQUM7WUFDOUMsTUFBTSxDQUFDLFdBQVcsQ0FDaEIsTUFBTSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUM7aUJBQ3hCLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxFQUFFLFVBQVUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxFQUFFLDJCQUEyQixDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FDM0UsQ0FDSixDQUFDO1FBR04sTUFBTSxZQUFZLEdBQUc7WUFDbkIsTUFBTSxFQUFFLElBQUk7WUFDWixHQUFHLE9BQU87WUFDVixhQUFhO1NBQ2QsQ0FBQztRQUVGLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFO1lBQ2YsSUFBSSxFQUFFLGFBQWE7WUFDbkIsU0FBUztZQUNULGFBQWEsRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDLDJCQUFhLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQywyQkFBYSxDQUFDLE1BQU07WUFDdEUsUUFBUSxFQUFFLElBQUksd0JBQWMsQ0FDMUIsbUJBQW1CLEVBQ25CO2dCQUNFLEdBQUcsS0FBSztnQkFDUixZQUFZO2FBQ2IsQ0FDRjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7O0FBL0RILG9DQWdFQzs7O0FBRUQ7Ozs7OztHQU1HO0FBQ0gsTUFBYSxlQUFnQixTQUFRLFlBQWtDOztBQUF2RSwwQ0FBMEU7OztBQUUxRTs7Ozs7O0dBTUc7QUFDSCxNQUFhLGVBQWdCLFNBQVEsWUFBa0M7O0FBQXZFLDBDQUEwRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzQWJzb2x1dGUsIHJlbGF0aXZlIH0gZnJvbSAncGF0aCc7XG5pbXBvcnQgeyBBc3NldEhhc2hUeXBlIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0IHsgQXNzZXQgYXMgUzNBc3NldCB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1zMy1hc3NldHMnO1xuaW1wb3J0IHsgQ29uc3RydWN0LCBOb2RlIH0gZnJvbSAnY29uc3RydWN0cyc7XG5pbXBvcnQgeyBFc2J1aWxkQnVuZGxlciwgQnVuZGxlclByb3BzLCBFbnRyeVBvaW50cyB9IGZyb20gJy4vYnVuZGxlcic7XG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQXNzZXRCYXNlUHJvcHMgZXh0ZW5kcyBCdW5kbGVyUHJvcHMge1xuICAvKipcbiAgICogQSBoYXNoIG9mIHRoaXMgYXNzZXQsIHdoaWNoIGlzIGF2YWlsYWJsZSBhdCBjb25zdHJ1Y3Rpb24gdGltZS5cbiAgICpcbiAgICogQXMgdGhpcyBpcyBhIHBsYWluIHN0cmluZywgaXQgY2FuIGJlIHVzZWQgaW4gY29uc3RydWN0IElEcyBpbiBvcmRlciB0byBlbmZvcmNlIGNyZWF0aW9uIG9mIGEgbmV3IHJlc291cmNlIHdoZW4gdGhlIGNvbnRlbnQgaGFzaCBoYXMgY2hhbmdlZC5cbiAgICpcbiAgICogRGVmYXVsdHMgdG8gYSBoYXNoIG9mIGFsbCBmaWxlcyBpbiB0aGUgcmVzdWx0aW5nIGJ1bmRsZS5cbiAgICpcbiAgICogQHN0YWJpbGl0eSBzdGFibGVcbiAgICovXG4gIHJlYWRvbmx5IGFzc2V0SGFzaD86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBc3NldFByb3BzIGV4dGVuZHMgQXNzZXRCYXNlUHJvcHMge1xuICAvKipcbiAgICogQSBwYXRoIG9yIGxpc3Qgb3IgbWFwIG9mIHBhdGhzIHRvIHRoZSBlbnRyeSBwb2ludHMgb2YgeW91ciBjb2RlLlxuICAgKlxuICAgKiBSZWxhdGl2ZSBwYXRocyBhcmUgYnkgZGVmYXVsdCByZXNvbHZlZCBmcm9tIHRoZSBjdXJyZW50IHdvcmtpbmcgZGlyZWN0b3J5LlxuICAgKiBUbyBjaGFuZ2UgdGhlIHdvcmtpbmcgZGlyZWN0b3J5LCBzZWUgYGJ1aWxkT3B0aW9ucy5hYnNXb3JraW5nRGlyYC5cbiAgICpcbiAgICogQWJzb2x1dGUgcGF0aHMgY2FuIGJlIHVzZWQgaWYgZmlsZXMgYXJlIHBhcnQgb2YgdGhlIHdvcmtpbmcgZGlyZWN0b3J5LlxuICAgKlxuICAgKiBFeGFtcGxlczpcbiAgICogIC0gYCdzcmMvaW5kZXgudHMnYFxuICAgKiAgLSBgcmVxdWlyZS5yZXNvbHZlKCcuL2xhbWJkYScpYFxuICAgKiAgLSBgWydzcmMvaW5kZXgudHMnLCAnc3JjL3V0aWwudHMnXWBcbiAgICogIC0gYHtvbmU6ICdzcmMvdHdvLnRzJywgdHdvOiAnc3JjL29uZS50cyd9YFxuICAgKlxuICAgKiBAc3RhYmlsaXR5IHN0YWJsZVxuICAgKi9cbiAgcmVhZG9ubHkgZW50cnlQb2ludHM6IEVudHJ5UG9pbnRzO1xufVxuXG50eXBlIEphdmFTY3JpcHRBc3NldFByb3BzID0gQXNzZXRQcm9wcztcbnR5cGUgVHlwZVNjcmlwdEFzc2V0UHJvcHMgPSBBc3NldFByb3BzO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgYSBnZW5lcmljIGVzYnVpbGQgYXNzZXQuXG4gKlxuICogWW91IHNob3VsZCBhbHdheXMgdXNlIGBUeXBlU2NyaXB0QXNzZXRgIG9yIGBKYXZhU2NyaXB0QXNzZXRgLlxuICpcbiAqIEBzdGFiaWxpdHkgZXhwZXJpbWVudGFsXG4gKi9cbmV4cG9ydCBjbGFzcyBFc2J1aWxkQXNzZXQ8UHJvcHMgZXh0ZW5kcyBBc3NldFByb3BzPiBleHRlbmRzIFMzQXNzZXQge1xuICAvKipcbiAgICogQHN0YWJpbGl0eSBzdGFibGVcbiAgICovXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcihcbiAgICBzY29wZTogQ29uc3RydWN0LFxuICAgIGlkOiBzdHJpbmcsXG4gICAgcHJvcHM6IFByb3BzLFxuICApIHtcbiAgICBjb25zdCB7XG4gICAgICBhc3NldEhhc2gsXG4gICAgICBidWlsZE9wdGlvbnM6IG9wdGlvbnMgPSB7fSxcbiAgICB9ID0gcHJvcHM7XG4gICAgY29uc3QgZW50cnlQb2ludHM6IHN0cmluZ1tdIHwgUmVjb3JkPHN0cmluZywgc3RyaW5nPiA9XG4gICAgICB0eXBlb2YgcHJvcHMuZW50cnlQb2ludHMgPT09ICdzdHJpbmcnID8gW3Byb3BzLmVudHJ5UG9pbnRzXSA6IHByb3BzLmVudHJ5UG9pbnRzO1xuXG4gICAgY29uc3QgbmFtZSA9IHNjb3BlLm5vZGUucGF0aCArIE5vZGUuUEFUSF9TRVAgKyBpZDtcblxuICAgIGNvbnN0IGFic1dvcmtpbmdEaXIgPSBvcHRpb25zLmFic1dvcmtpbmdEaXIgPz8gcHJvY2Vzcy5jd2QoKTtcblxuICAgIGNvbnN0IGZvcmNlUmVsYXRpdmVFbnRyeXBvaW50UGF0aCA9IChlbnRyeVBvaW50OiBzdHJpbmcpOiBzdHJpbmcgPT4ge1xuICAgICAgaWYgKCFpc0Fic29sdXRlKGVudHJ5UG9pbnQpKSB7XG4gICAgICAgIHJldHVybiBlbnRyeVBvaW50O1xuICAgICAgfVxuXG4gICAgICBjb25zdCByZWxhdGl2ZUVudHJ5UG9pbnQgPSByZWxhdGl2ZShhYnNXb3JraW5nRGlyLCBlbnRyeVBvaW50KTtcbiAgICAgIGlmIChyZWxhdGl2ZUVudHJ5UG9pbnQuc3RhcnRzV2l0aCgnLi4nKSB8fCBpc0Fic29sdXRlKHJlbGF0aXZlRW50cnlQb2ludCkpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICAgIGAke25hbWV9OiBFbnRyeSBwb2ludHMgbXVzdCBiZSBwYXJ0IG9mIHRoZSB3b3JraW5nIGRpcmVjdG9yeS4gU2VlIFxcYGJ1aWxkT3B0aW9ucy5hYnNXb3JraW5nRGlyXFxgIHRvIHNldCBhIHdvcmtpbmcgZGlyZWN0b3J5IGRpZmZlcmVudCB0byB0aGUgY3VycmVudCBvbmUuYCxcbiAgICAgICAgKTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHJlbGF0aXZlRW50cnlQb2ludDtcbiAgICB9O1xuXG4gICAgY29uc3QgcmVsYXRpdmVFbnRyeVBvaW50cyA9XG4gICAgICBBcnJheS5pc0FycmF5KGVudHJ5UG9pbnRzKSA/XG4gICAgICAgIGVudHJ5UG9pbnRzLm1hcChmb3JjZVJlbGF0aXZlRW50cnlwb2ludFBhdGgpIDpcbiAgICAgICAgT2JqZWN0LmZyb21FbnRyaWVzKFxuICAgICAgICAgIE9iamVjdC5lbnRyaWVzKGVudHJ5UG9pbnRzKVxuICAgICAgICAgICAgLm1hcCgoW291dCwgZW50cnlQb2ludF0pID0+IChbb3V0LCBmb3JjZVJlbGF0aXZlRW50cnlwb2ludFBhdGgoZW50cnlQb2ludCldKSxcbiAgICAgICAgICAgICksXG4gICAgICAgICk7XG5cblxuICAgIGNvbnN0IGJ1aWxkT3B0aW9ucyA9IHtcbiAgICAgIGJ1bmRsZTogdHJ1ZSxcbiAgICAgIC4uLm9wdGlvbnMsXG4gICAgICBhYnNXb3JraW5nRGlyLFxuICAgIH07XG5cbiAgICBzdXBlcihzY29wZSwgaWQsIHtcbiAgICAgIHBhdGg6IGFic1dvcmtpbmdEaXIsXG4gICAgICBhc3NldEhhc2gsXG4gICAgICBhc3NldEhhc2hUeXBlOiBhc3NldEhhc2ggPyBBc3NldEhhc2hUeXBlLkNVU1RPTSA6IEFzc2V0SGFzaFR5cGUuT1VUUFVULFxuICAgICAgYnVuZGxpbmc6IG5ldyBFc2J1aWxkQnVuZGxlcihcbiAgICAgICAgcmVsYXRpdmVFbnRyeVBvaW50cyxcbiAgICAgICAge1xuICAgICAgICAgIC4uLnByb3BzLFxuICAgICAgICAgIGJ1aWxkT3B0aW9ucyxcbiAgICAgICAgfSxcbiAgICAgICksXG4gICAgfSk7XG4gIH1cbn1cblxuLyoqXG4gKiBCdW5kbGVzIHRoZSBlbnRyeSBwb2ludHMgYW5kIGNyZWF0ZXMgYSBDREsgYXNzZXQgd2hpY2ggaXMgdXBsb2FkZWQgdG8gdGhlIGJvb3RzdHJhcHBlZCBDREsgUzMgYnVja2V0IGR1cmluZyBkZXBsb3ltZW50LlxuICpcbiAqIFRoZSBhc3NldCBjYW4gYmUgdXNlZCBieSBvdGhlciBjb25zdHJ1Y3RzLlxuICpcbiAqIEBzdGFiaWxpdHkgc3RhYmxlXG4gKi9cbmV4cG9ydCBjbGFzcyBKYXZhU2NyaXB0QXNzZXQgZXh0ZW5kcyBFc2J1aWxkQXNzZXQ8SmF2YVNjcmlwdEFzc2V0UHJvcHM+IHt9XG5cbi8qKlxuICogQnVuZGxlcyB0aGUgZW50cnkgcG9pbnRzIGFuZCBjcmVhdGVzIGEgQ0RLIGFzc2V0IHdoaWNoIGlzIHVwbG9hZGVkIHRvIHRoZSBib290c3RyYXBwZWQgQ0RLIFMzIGJ1Y2tldCBkdXJpbmcgZGVwbG95bWVudC5cbiAqXG4gKiBUaGUgYXNzZXQgY2FuIGJlIHVzZWQgYnkgb3RoZXIgY29uc3RydWN0cy5cbiAqXG4gKiBAc3RhYmlsaXR5IHN0YWJsZVxuICovXG5leHBvcnQgY2xhc3MgVHlwZVNjcmlwdEFzc2V0IGV4dGVuZHMgRXNidWlsZEFzc2V0PFR5cGVTY3JpcHRBc3NldFByb3BzPiB7fVxuIl19
|
package/lib/bundler.d.ts
CHANGED
|
@@ -1,7 +1,19 @@
|
|
|
1
1
|
import { DockerImage, ILocalBundling } from 'aws-cdk-lib';
|
|
2
2
|
import { BuildOptions } from './esbuild-types';
|
|
3
|
+
import { IBuildProvider } from './provider';
|
|
3
4
|
/**
|
|
4
|
-
* A
|
|
5
|
+
* A path or list or map of paths to the entry points of your code.
|
|
6
|
+
*
|
|
7
|
+
* Relative paths are by default resolved from the current working directory.
|
|
8
|
+
* To change the working directory, see `buildOptions.absWorkingDir`.
|
|
9
|
+
*
|
|
10
|
+
* Absolute paths can be used if files are part of the working directory.
|
|
11
|
+
*
|
|
12
|
+
* Examples:
|
|
13
|
+
* - `'src/index.ts'`
|
|
14
|
+
* - `require.resolve('./lambda')`
|
|
15
|
+
* - `['src/index.ts', 'src/util.ts']`
|
|
16
|
+
* - `{one: 'src/two.ts', two: 'src/one.ts'}`
|
|
5
17
|
*
|
|
6
18
|
* @stability stable
|
|
7
19
|
*/
|
|
@@ -29,6 +41,17 @@ export interface BundlerProps {
|
|
|
29
41
|
* @stability stable
|
|
30
42
|
*/
|
|
31
43
|
readonly buildOptions?: BuildOptions;
|
|
44
|
+
/**
|
|
45
|
+
* The esbuild Build API implementation to be used.
|
|
46
|
+
*
|
|
47
|
+
* Configure the default `EsbuildProvider` for more options or
|
|
48
|
+
* provide a custom `IBuildProvider` as an escape hatch.
|
|
49
|
+
*
|
|
50
|
+
* @stability stable
|
|
51
|
+
*
|
|
52
|
+
* @default new EsbuildProvider()
|
|
53
|
+
*/
|
|
54
|
+
readonly buildProvider?: IBuildProvider;
|
|
32
55
|
/**
|
|
33
56
|
* 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.
|
|
34
57
|
* Files copied like this will be overwritten by esbuild if they share the same name as any of the outputs.
|
|
@@ -37,7 +60,7 @@ export interface BundlerProps {
|
|
|
37
60
|
* * 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.
|
|
38
61
|
*
|
|
39
62
|
* Therefore the following values for `copyDir` are all equivalent:
|
|
40
|
-
* ```
|
|
63
|
+
* ```
|
|
41
64
|
* { copyDir: "path/to/source" }
|
|
42
65
|
* { copyDir: ["path/to/source"] }
|
|
43
66
|
* { copyDir: { ".": "path/to/source" } }
|
|
@@ -51,26 +74,6 @@ export interface BundlerProps {
|
|
|
51
74
|
* @stability stable
|
|
52
75
|
*/
|
|
53
76
|
readonly copyDir?: string | string[] | Record<string, string | string[]>;
|
|
54
|
-
/**
|
|
55
|
-
* Escape hatch to provide the bundler with a custom build function.
|
|
56
|
-
* 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.
|
|
57
|
-
* Must throw a `BuildFailure` on failure to correctly inform the bundler.
|
|
58
|
-
*
|
|
59
|
-
* @stability experimental
|
|
60
|
-
* @type esbuild.buildSync
|
|
61
|
-
* @returns esbuild.BuildResult
|
|
62
|
-
* @throws esbuild.BuildFailure
|
|
63
|
-
* @default esbuild.buildSync
|
|
64
|
-
*/
|
|
65
|
-
readonly buildFn?: any;
|
|
66
|
-
/**
|
|
67
|
-
* Path to the binary used by esbuild.
|
|
68
|
-
*
|
|
69
|
-
* This is the same as setting the ESBUILD_BINARY_PATH environment variable.
|
|
70
|
-
*
|
|
71
|
-
* @stability experimental
|
|
72
|
-
*/
|
|
73
|
-
readonly esbuildBinaryPath?: string;
|
|
74
77
|
}
|
|
75
78
|
/**
|
|
76
79
|
* Low-level construct that can be used where `BundlingOptions` are required.
|
|
@@ -80,14 +83,24 @@ export interface BundlerProps {
|
|
|
80
83
|
*/
|
|
81
84
|
export declare class EsbuildBundler {
|
|
82
85
|
/**
|
|
83
|
-
* A
|
|
84
|
-
*
|
|
86
|
+
* A path or list or map of paths to the entry points of your code.
|
|
87
|
+
*
|
|
88
|
+
* Relative paths are by default resolved from the current working directory.
|
|
89
|
+
* To change the working directory, see `buildOptions.absWorkingDir`.
|
|
90
|
+
*
|
|
91
|
+
* Absolute paths can be used if files are part of the working directory.
|
|
92
|
+
*
|
|
93
|
+
* Examples:
|
|
94
|
+
* - `'src/index.ts'`
|
|
95
|
+
* - `require.resolve('./lambda')`
|
|
96
|
+
* - `['src/index.ts', 'src/util.ts']`
|
|
97
|
+
* - `{one: 'src/two.ts', two: 'src/one.ts'}`
|
|
85
98
|
*
|
|
86
99
|
* @stability experimental
|
|
87
100
|
*/
|
|
88
101
|
readonly entryPoints: EntryPoints;
|
|
89
102
|
/**
|
|
90
|
-
* Props to change the
|
|
103
|
+
* Props to change the behavior of the bundler.
|
|
91
104
|
*
|
|
92
105
|
* @stability experimental
|
|
93
106
|
*/
|
|
@@ -109,14 +122,24 @@ export declare class EsbuildBundler {
|
|
|
109
122
|
*/
|
|
110
123
|
constructor(
|
|
111
124
|
/**
|
|
112
|
-
* A
|
|
113
|
-
*
|
|
125
|
+
* A path or list or map of paths to the entry points of your code.
|
|
126
|
+
*
|
|
127
|
+
* Relative paths are by default resolved from the current working directory.
|
|
128
|
+
* To change the working directory, see `buildOptions.absWorkingDir`.
|
|
129
|
+
*
|
|
130
|
+
* Absolute paths can be used if files are part of the working directory.
|
|
131
|
+
*
|
|
132
|
+
* Examples:
|
|
133
|
+
* - `'src/index.ts'`
|
|
134
|
+
* - `require.resolve('./lambda')`
|
|
135
|
+
* - `['src/index.ts', 'src/util.ts']`
|
|
136
|
+
* - `{one: 'src/two.ts', two: 'src/one.ts'}`
|
|
114
137
|
*
|
|
115
138
|
* @stability experimental
|
|
116
139
|
*/
|
|
117
140
|
entryPoints: EntryPoints,
|
|
118
141
|
/**
|
|
119
|
-
* Props to change the
|
|
142
|
+
* Props to change the behavior of the bundler.
|
|
120
143
|
*
|
|
121
144
|
* @stability experimental
|
|
122
145
|
*/
|
package/lib/bundler.js
CHANGED
|
@@ -6,8 +6,8 @@ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
|
6
6
|
const fs_1 = require("fs");
|
|
7
7
|
const path_1 = require("path");
|
|
8
8
|
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
9
|
-
const
|
|
10
|
-
const
|
|
9
|
+
const utils_1 = require("./private/utils");
|
|
10
|
+
const provider_1 = require("./provider");
|
|
11
11
|
/**
|
|
12
12
|
* Low-level construct that can be used where `BundlingOptions` are required.
|
|
13
13
|
* This class directly interfaces with esbuild and provides almost no configuration safeguards.
|
|
@@ -20,14 +20,24 @@ class EsbuildBundler {
|
|
|
20
20
|
*/
|
|
21
21
|
constructor(
|
|
22
22
|
/**
|
|
23
|
-
* A
|
|
24
|
-
*
|
|
23
|
+
* A path or list or map of paths to the entry points of your code.
|
|
24
|
+
*
|
|
25
|
+
* Relative paths are by default resolved from the current working directory.
|
|
26
|
+
* To change the working directory, see `buildOptions.absWorkingDir`.
|
|
27
|
+
*
|
|
28
|
+
* Absolute paths can be used if files are part of the working directory.
|
|
29
|
+
*
|
|
30
|
+
* Examples:
|
|
31
|
+
* - `'src/index.ts'`
|
|
32
|
+
* - `require.resolve('./lambda')`
|
|
33
|
+
* - `['src/index.ts', 'src/util.ts']`
|
|
34
|
+
* - `{one: 'src/two.ts', two: 'src/one.ts'}`
|
|
25
35
|
*
|
|
26
36
|
* @stability experimental
|
|
27
37
|
*/
|
|
28
38
|
entryPoints,
|
|
29
39
|
/**
|
|
30
|
-
* Props to change the
|
|
40
|
+
* Props to change the behavior of the bundler.
|
|
31
41
|
*
|
|
32
42
|
* @stability experimental
|
|
33
43
|
*/
|
|
@@ -43,7 +53,6 @@ class EsbuildBundler {
|
|
|
43
53
|
if (props?.buildOptions?.outfile && props?.buildOptions?.outdir) {
|
|
44
54
|
throw new Error('Cannot use both "outfile" and "outdir"');
|
|
45
55
|
}
|
|
46
|
-
const { buildFn = esbuild_wrapper_1.buildSync } = this.props;
|
|
47
56
|
this.local = {
|
|
48
57
|
tryBundle: (outputDir, _options) => {
|
|
49
58
|
if (this.props.copyDir) {
|
|
@@ -55,26 +64,28 @@ class EsbuildBundler {
|
|
|
55
64
|
if (destToOutput.startsWith('..') || path_1.isAbsolute(destToOutput)) {
|
|
56
65
|
throw new Error('Cannot copy files to outside of the asset staging directory. See docs for details.');
|
|
57
66
|
}
|
|
67
|
+
if (fs_1.existsSync(destDir)) {
|
|
68
|
+
fs_1.rmSync(destDir, { recursive: true, force: true });
|
|
69
|
+
}
|
|
58
70
|
fs_1.mkdirSync(destDir, { recursive: true });
|
|
59
71
|
aws_cdk_lib_1.FileSystem.copyDirectory(srcDir, destDir);
|
|
60
72
|
});
|
|
61
73
|
}
|
|
62
|
-
const originalEsbuildBinaryPath = process.env.ESBUILD_BINARY_PATH;
|
|
63
|
-
if (this.props.esbuildBinaryPath) {
|
|
64
|
-
process.env.ESBUILD_BINARY_PATH = this.props.esbuildBinaryPath;
|
|
65
|
-
}
|
|
66
74
|
try {
|
|
67
|
-
const
|
|
68
|
-
|
|
75
|
+
const provider = props.buildProvider ?? provider_1.EsbuildProvider.defaultBuildProvider();
|
|
76
|
+
provider.buildSync({
|
|
77
|
+
entryPoints: typeof entryPoints === 'string' ? [entryPoints] : entryPoints,
|
|
78
|
+
color: process.env.NO_COLOR ? Boolean(process.env.NO_COLOR) : undefined,
|
|
69
79
|
...(this.props?.buildOptions || {}),
|
|
70
80
|
...this.getOutputOptions(outputDir, { normalize: path_1.normalize, join: path_1.join }),
|
|
71
81
|
});
|
|
72
|
-
formatMessages_1.printBuildMessages(buildResult, { prefix: 'Build ' });
|
|
73
82
|
}
|
|
74
83
|
catch (error) {
|
|
75
|
-
|
|
84
|
+
if (utils_1.isEsbuildError(error)) {
|
|
85
|
+
throw new Error(`Esbuild failed to bundle ${entryPoints}`);
|
|
86
|
+
}
|
|
87
|
+
throw error;
|
|
76
88
|
}
|
|
77
|
-
process.env.ESBUILD_BINARY_PATH = originalEsbuildBinaryPath;
|
|
78
89
|
return true;
|
|
79
90
|
},
|
|
80
91
|
};
|
|
@@ -119,5 +130,5 @@ class EsbuildBundler {
|
|
|
119
130
|
}
|
|
120
131
|
exports.EsbuildBundler = EsbuildBundler;
|
|
121
132
|
_a = JSII_RTTI_SYMBOL_1;
|
|
122
|
-
EsbuildBundler[_a] = { fqn: "@mrgrain/cdk-esbuild.EsbuildBundler", version: "4.0.0-
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundler.js","sourceRoot":"","sources":["../src/bundler.ts"],"names":[],"mappings":"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","sourcesContent":["import { mkdirSync } from 'fs';\nimport { join, normalize, relative, resolve, posix, isAbsolute } from 'path';\nimport {\n  BundlingOptions,\n  DockerImage,\n  FileSystem,\n  ILocalBundling,\n} from 'aws-cdk-lib';\nimport { BuildFailure, BuildOptions, BuildResult } from './esbuild-types';\nimport { buildSync } from './esbuild-wrapper';\nimport { printBuildMessages } from './formatMessages';\n\n/**\n * A relative path or list or map of relative paths to the entry points of your code from the root of the project. E.g. `src/index.ts`.\n *\n * @stability stable\n */\nexport type EntryPoints = string | string[] | Record<string, string>;\n\n/**\n * @stability stable\n */\nexport interface BundlerProps {\n  /**\n   * Build options passed on to esbuild. Please refer to the esbuild Build API docs for details.\n   *\n   * * `buildOptions.outdir: string`\n   * The actual path for the output directory is defined by CDK. However setting this option allows to write files into a subdirectory. \\\n   * For example `{ outdir: 'js' }` will create an asset with a single directory called `js`, which contains all built files. This approach can be useful for static website deployments, where JavaScript code should be placed into a subdirectory. \\\n   * *Cannot be used together with `outfile`*.\n   * * `buildOptions.outfile: string`\n   * Relative path to a file inside the CDK asset output directory.\n   * For example `{ outfile: 'js/index.js' }` will create an asset with a single directory called `js`, which contains a single file `index.js`. This can be useful to rename the entry point. \\\n   * *Cannot be used with multiple entryPoints or together with `outdir`.*\n   * * `buildOptions.absWorkingDir: string`\n   * Absolute path to the [esbuild working directory](https://esbuild.github.io/api/#working-directory) and defaults to the [current working directory](https://en.wikipedia.org/wiki/Working_directory). \\\n   * If paths cannot be found, a good starting point is to look at the concatenation of `absWorkingDir + entryPoint`. It must always be a valid absolute path pointing to the entry point. When needed, the probably easiest way to set absWorkingDir is to use a combination of `resolve` and `__dirname` (see \"Library authors\" section in the documentation).\n   *\n   * @see https://esbuild.github.io/api/#build-api\n   * @stability stable\n   */\n  readonly buildOptions?: BuildOptions;\n\n  /**\n   * Copy additional files to the code [asset staging directory](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.AssetStaging.html#absolutestagedpath), before the build runs.\n   * Files copied like this will be overwritten by esbuild if they share the same name as any of the outputs.\n   *\n   * * When provided with a `string` or `array`, all files are copied to the root of asset staging directory.\n   * * When given a `map`, the key indicates the destination relative to the asset staging directory and the value is a list of all sources to be copied.\n   *\n   * Therefore the following values for `copyDir` are all equivalent:\n   * ```ts\n   * { copyDir: \"path/to/source\" }\n   * { copyDir: [\"path/to/source\"] }\n   * { copyDir: { \".\": \"path/to/source\" } }\n   * { copyDir: { \".\": [\"path/to/source\"] } }\n   * ```\n   * The destination cannot be outside of the asset staging directory.\n   * If you are receiving the error \"Cannot copy files to outside of the asset staging directory.\"\n   * you are likely using `..` or an absolute path as key on the `copyDir` map.\n   * Instead use only relative paths and avoid `..`.\n   *\n   * @stability stable\n   */\n  readonly copyDir?: string | string[] | Record<string, string | string []>;\n\n\n  /**\n   * Escape hatch to provide the bundler with a custom build function.\n   * The function will receive the computed options from the bundler. It can use with these options as it wishes, however `outdir`/`outfile` must be respected to integrate with CDK.\n   * Must throw a `BuildFailure` on failure to correctly inform the bundler.\n   *\n   * @stability experimental\n   * @type esbuild.buildSync\n   * @returns esbuild.BuildResult\n   * @throws esbuild.BuildFailure\n   * @default esbuild.buildSync\n   */\n  readonly buildFn?: any;\n\n  /**\n   * Path to the binary used by esbuild.\n   *\n   * This is the same as setting the ESBUILD_BINARY_PATH environment variable.\n   *\n   * @stability experimental\n   */\n  readonly esbuildBinaryPath?: string;\n}\n\n/**\n * Low-level construct that can be used where `BundlingOptions` are required.\n * This class directly interfaces with esbuild and provides almost no configuration safeguards.\n *\n * @stability experimental\n */\nexport class EsbuildBundler {\n  /**\n   * Implementation of `ILocalBundling` interface, responsible for calling esbuild functions.\n   *\n   * @stability experimental\n   */\n  public readonly local: ILocalBundling;\n\n  /**\n   * @deprecated This value is ignored since the bundler is always using a locally installed version of esbuild. However the property is required to comply with the `BundlingOptions` interface.\n   *\n   * @stability deprecated\n   */\n  public readonly image = DockerImage.fromRegistry('scratch');\n\n  /**\n   * @stability experimental\n   */\n  public constructor(\n    /**\n     * A relative path or list or map of relative paths to the entry points of your code from the root of the project.\n     * E.g. `src/index.ts`.\n     *\n     * @stability experimental\n     */\n    public readonly entryPoints: EntryPoints,\n\n    /**\n     * Props to change the behaviour of the bundler.\n     *\n     * @stability experimental\n     */\n    public readonly props: BundlerProps,\n  ) {\n    if (props?.buildOptions?.outfile && props?.buildOptions?.outdir) {\n      throw new Error('Cannot use both \"outfile\" and \"outdir\"');\n    }\n\n    const { buildFn = buildSync } = this.props;\n\n    this.local = {\n      tryBundle: (outputDir: string, _options: BundlingOptions): boolean => {\n\n        if (this.props.copyDir) {\n          const copyDir = this.getCopyDirList(this.props.copyDir);\n\n          copyDir.forEach(([dest, src]) => {\n            const srcDir = resolve(\n              this.props?.buildOptions?.absWorkingDir ?? process.cwd(),\n              src,\n            );\n            const destDir = resolve(outputDir, dest) ;\n\n            const destToOutput = relative(outputDir, destDir);\n            if (destToOutput.startsWith('..') || isAbsolute(destToOutput)) {\n              throw new Error('Cannot copy files to outside of the asset staging directory. See docs for details.');\n            }\n\n            mkdirSync(destDir, { recursive: true });\n            FileSystem.copyDirectory(srcDir, destDir);\n          });\n        }\n\n        const originalEsbuildBinaryPath = process.env.ESBUILD_BINARY_PATH;\n        if (this.props.esbuildBinaryPath) {\n          process.env.ESBUILD_BINARY_PATH = this.props.esbuildBinaryPath;\n        }\n\n        try {\n          const buildResult: BuildResult = buildFn({\n            entryPoints,\n            ...(this.props?.buildOptions || {}),\n            ...this.getOutputOptions(outputDir, { normalize, join }),\n          });\n\n          printBuildMessages(buildResult, { prefix: 'Build ' });\n        } catch (error) {\n          printBuildMessages(error as BuildFailure, { prefix: 'Build ' });\n        }\n\n        process.env.ESBUILD_BINARY_PATH = originalEsbuildBinaryPath;\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: "4.0.0-beta.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"]}
|
package/lib/code.d.ts
CHANGED
|
@@ -1,30 +1,76 @@
|
|
|
1
1
|
import { CfnResource } from 'aws-cdk-lib';
|
|
2
|
-
import { ResourceBindOptions, Code
|
|
2
|
+
import { ResourceBindOptions, Code, CodeConfig } from 'aws-cdk-lib/aws-lambda';
|
|
3
3
|
import { Construct } from 'constructs';
|
|
4
|
-
import {
|
|
4
|
+
import { EsbuildAsset, AssetBaseProps, AssetProps } from './asset';
|
|
5
5
|
import { EntryPoints } from './bundler';
|
|
6
6
|
export { CodeConfig } from 'aws-cdk-lib/aws-lambda';
|
|
7
7
|
export interface JavaScriptCodeProps extends AssetBaseProps {
|
|
8
8
|
}
|
|
9
9
|
export interface TypeScriptCodeProps extends AssetBaseProps {
|
|
10
10
|
}
|
|
11
|
-
|
|
11
|
+
/**
|
|
12
|
+
* Represents a generic esbuild code bundle.
|
|
13
|
+
*
|
|
14
|
+
* You should always use `TypeScriptCode` or `JavaScriptCode`.
|
|
15
|
+
*
|
|
16
|
+
* @stability experimental
|
|
17
|
+
*/
|
|
18
|
+
export declare class EsbuildCode<Props extends JavaScriptCodeProps | TypeScriptCodeProps> extends Code {
|
|
19
|
+
/**
|
|
20
|
+
* A path or list or map of paths to the entry points of your code.
|
|
21
|
+
*
|
|
22
|
+
* Relative paths are by default resolved from the current working directory.
|
|
23
|
+
* To change the working directory, see `buildOptions.absWorkingDir`.
|
|
24
|
+
*
|
|
25
|
+
* Absolute paths can be used if files are part of the working directory.
|
|
26
|
+
*
|
|
27
|
+
* Examples:
|
|
28
|
+
* - `'src/index.ts'`
|
|
29
|
+
* - `require.resolve('./lambda')`
|
|
30
|
+
* - `['src/index.ts', 'src/util.ts']`
|
|
31
|
+
* - `{one: 'src/two.ts', two: 'src/one.ts'}`
|
|
32
|
+
*
|
|
33
|
+
* @stability stable
|
|
34
|
+
*/
|
|
12
35
|
readonly entryPoints: EntryPoints;
|
|
13
|
-
protected
|
|
36
|
+
protected getAsset(scope: Construct): EsbuildAsset<AssetProps>;
|
|
14
37
|
protected props: AssetProps;
|
|
15
|
-
protected asset:
|
|
38
|
+
protected asset: EsbuildAsset<AssetProps>;
|
|
16
39
|
/**
|
|
17
40
|
* Determines whether this Code is inline code or not.
|
|
18
41
|
*
|
|
19
42
|
* @deprecated this value is ignored since inline is now determined based on the the inlineCode field of CodeConfig returned from bind().
|
|
20
43
|
*/
|
|
21
44
|
isInline: boolean;
|
|
45
|
+
constructor(
|
|
22
46
|
/**
|
|
47
|
+
* A path or list or map of paths to the entry points of your code.
|
|
48
|
+
*
|
|
49
|
+
* Relative paths are by default resolved from the current working directory.
|
|
50
|
+
* To change the working directory, see `buildOptions.absWorkingDir`.
|
|
23
51
|
*
|
|
24
|
-
*
|
|
25
|
-
*
|
|
52
|
+
* Absolute paths can be used if files are part of the working directory.
|
|
53
|
+
*
|
|
54
|
+
* Examples:
|
|
55
|
+
* - `'src/index.ts'`
|
|
56
|
+
* - `require.resolve('./lambda')`
|
|
57
|
+
* - `['src/index.ts', 'src/util.ts']`
|
|
58
|
+
* - `{one: 'src/two.ts', two: 'src/one.ts'}`
|
|
59
|
+
*
|
|
60
|
+
* @stability stable
|
|
26
61
|
*/
|
|
27
|
-
|
|
62
|
+
entryPoints: EntryPoints,
|
|
63
|
+
/**
|
|
64
|
+
* Props to change the behavior of the bundler.
|
|
65
|
+
*
|
|
66
|
+
* Default values for `props.buildOptions`:
|
|
67
|
+
* - `bundle=true`
|
|
68
|
+
* - `platform=node`
|
|
69
|
+
* - `target=nodeX` with X being the major node version running locally
|
|
70
|
+
*
|
|
71
|
+
* @stability stable
|
|
72
|
+
*/
|
|
73
|
+
props: Props);
|
|
28
74
|
bind(scope: Construct): CodeConfig;
|
|
29
75
|
/**
|
|
30
76
|
* Called after the CFN function resource has been created to allow the code class to bind to it.
|
|
@@ -41,12 +87,22 @@ export declare abstract class Code<Props extends JavaScriptCodeProps | TypeScrip
|
|
|
41
87
|
*
|
|
42
88
|
* @stability stable
|
|
43
89
|
*/
|
|
44
|
-
export declare class JavaScriptCode extends
|
|
45
|
-
protected getAsset(scope: Construct):
|
|
90
|
+
export declare class JavaScriptCode extends EsbuildCode<JavaScriptCodeProps> {
|
|
91
|
+
protected getAsset(scope: Construct): EsbuildAsset<AssetProps>;
|
|
46
92
|
constructor(
|
|
47
93
|
/**
|
|
48
|
-
* A
|
|
49
|
-
*
|
|
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'}`
|
|
50
106
|
*
|
|
51
107
|
* @stability stable
|
|
52
108
|
*/
|
|
@@ -68,12 +124,22 @@ export declare class JavaScriptCode extends Code<JavaScriptCodeProps> {
|
|
|
68
124
|
*
|
|
69
125
|
* @stability stable
|
|
70
126
|
*/
|
|
71
|
-
export declare class TypeScriptCode extends
|
|
72
|
-
protected getAsset(scope: Construct):
|
|
127
|
+
export declare class TypeScriptCode extends EsbuildCode<TypeScriptCodeProps> {
|
|
128
|
+
protected getAsset(scope: Construct): EsbuildAsset<AssetProps>;
|
|
73
129
|
constructor(
|
|
74
130
|
/**
|
|
75
|
-
* A
|
|
76
|
-
*
|
|
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'}`
|
|
77
143
|
*
|
|
78
144
|
* @stability stable
|
|
79
145
|
*/
|