@mrgrain/cdk-esbuild 3.6.0 → 3.7.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 +82 -60
- package/.projenrc.ts +16 -0
- package/API.md +121 -16
- package/CHANGELOG.md +12 -0
- package/README.md +6 -6
- package/lib/asset.d.ts +15 -2
- package/lib/asset.js +22 -11
- package/lib/bundler.d.ts +36 -5
- package/lib/bundler.js +14 -4
- package/lib/code.d.ts +51 -9
- package/lib/code.js +43 -11
- package/lib/inline-code.js +4 -4
- package/lib/source.d.ts +81 -5
- package/lib/source.js +84 -8
- package/package.json +2 -1
package/lib/code.d.ts
CHANGED
|
@@ -9,14 +9,26 @@ export interface JavaScriptCodeProps extends AssetBaseProps {
|
|
|
9
9
|
export interface TypeScriptCodeProps extends AssetBaseProps {
|
|
10
10
|
}
|
|
11
11
|
/**
|
|
12
|
-
* Represents
|
|
12
|
+
* Represents a generic esbuild code bundle.
|
|
13
|
+
*
|
|
14
|
+
* You should always use `TypeScriptCode` or `JavaScriptCode`.
|
|
13
15
|
*
|
|
14
16
|
* @stability experimental
|
|
15
17
|
*/
|
|
16
18
|
export declare class EsbuildCode<Props extends JavaScriptCodeProps | TypeScriptCodeProps> extends Code {
|
|
17
19
|
/**
|
|
18
|
-
* A
|
|
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'}`
|
|
20
32
|
*
|
|
21
33
|
* @stability stable
|
|
22
34
|
*/
|
|
@@ -32,8 +44,18 @@ export declare class EsbuildCode<Props extends JavaScriptCodeProps | TypeScriptC
|
|
|
32
44
|
isInline: boolean;
|
|
33
45
|
constructor(
|
|
34
46
|
/**
|
|
35
|
-
* A
|
|
36
|
-
*
|
|
47
|
+
* A path or list or map of paths to the entry points of your code.
|
|
48
|
+
*
|
|
49
|
+
* Relative paths are by default resolved from the current working directory.
|
|
50
|
+
* To change the working directory, see `buildOptions.absWorkingDir`.
|
|
51
|
+
*
|
|
52
|
+
* Absolute paths can be used if files are part of the working directory.
|
|
53
|
+
*
|
|
54
|
+
* Examples:
|
|
55
|
+
* - `'src/index.ts'`
|
|
56
|
+
* - `require.resolve('./lambda')`
|
|
57
|
+
* - `['src/index.ts', 'src/util.ts']`
|
|
58
|
+
* - `{one: 'src/two.ts', two: 'src/one.ts'}`
|
|
37
59
|
*
|
|
38
60
|
* @stability stable
|
|
39
61
|
*/
|
|
@@ -69,8 +91,18 @@ export declare class JavaScriptCode extends EsbuildCode<JavaScriptCodeProps> {
|
|
|
69
91
|
protected getAsset(scope: Construct): EsbuildAsset<AssetProps>;
|
|
70
92
|
constructor(
|
|
71
93
|
/**
|
|
72
|
-
* A
|
|
73
|
-
*
|
|
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'}`
|
|
74
106
|
*
|
|
75
107
|
* @stability stable
|
|
76
108
|
*/
|
|
@@ -96,8 +128,18 @@ export declare class TypeScriptCode extends EsbuildCode<TypeScriptCodeProps> {
|
|
|
96
128
|
protected getAsset(scope: Construct): EsbuildAsset<AssetProps>;
|
|
97
129
|
constructor(
|
|
98
130
|
/**
|
|
99
|
-
* A
|
|
100
|
-
*
|
|
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'}`
|
|
101
143
|
*
|
|
102
144
|
* @stability stable
|
|
103
145
|
*/
|
package/lib/code.js
CHANGED
|
@@ -12,15 +12,27 @@ function nodeMajorVersion() {
|
|
|
12
12
|
;
|
|
13
13
|
;
|
|
14
14
|
/**
|
|
15
|
-
* Represents
|
|
15
|
+
* Represents a generic esbuild code bundle.
|
|
16
|
+
*
|
|
17
|
+
* You should always use `TypeScriptCode` or `JavaScriptCode`.
|
|
16
18
|
*
|
|
17
19
|
* @stability experimental
|
|
18
20
|
*/
|
|
19
21
|
class EsbuildCode extends aws_lambda_1.Code {
|
|
20
22
|
constructor(
|
|
21
23
|
/**
|
|
22
|
-
* A
|
|
23
|
-
*
|
|
24
|
+
* A path or list or map of paths to the entry points of your code.
|
|
25
|
+
*
|
|
26
|
+
* Relative paths are by default resolved from the current working directory.
|
|
27
|
+
* To change the working directory, see `buildOptions.absWorkingDir`.
|
|
28
|
+
*
|
|
29
|
+
* Absolute paths can be used if files are part of the working directory.
|
|
30
|
+
*
|
|
31
|
+
* Examples:
|
|
32
|
+
* - `'src/index.ts'`
|
|
33
|
+
* - `require.resolve('./lambda')`
|
|
34
|
+
* - `['src/index.ts', 'src/util.ts']`
|
|
35
|
+
* - `{one: 'src/two.ts', two: 'src/one.ts'}`
|
|
24
36
|
*
|
|
25
37
|
* @stability stable
|
|
26
38
|
*/
|
|
@@ -96,7 +108,7 @@ class EsbuildCode extends aws_lambda_1.Code {
|
|
|
96
108
|
}
|
|
97
109
|
exports.EsbuildCode = EsbuildCode;
|
|
98
110
|
_a = JSII_RTTI_SYMBOL_1;
|
|
99
|
-
EsbuildCode[_a] = { fqn: "@mrgrain/cdk-esbuild.EsbuildCode", version: "3.
|
|
111
|
+
EsbuildCode[_a] = { fqn: "@mrgrain/cdk-esbuild.EsbuildCode", version: "3.7.0" };
|
|
100
112
|
/**
|
|
101
113
|
* Represents the deployed JavaScript Code.
|
|
102
114
|
*
|
|
@@ -105,8 +117,18 @@ EsbuildCode[_a] = { fqn: "@mrgrain/cdk-esbuild.EsbuildCode", version: "3.6.0" };
|
|
|
105
117
|
class JavaScriptCode extends EsbuildCode {
|
|
106
118
|
constructor(
|
|
107
119
|
/**
|
|
108
|
-
* A
|
|
109
|
-
*
|
|
120
|
+
* A path or list or map of paths to the entry points of your code.
|
|
121
|
+
*
|
|
122
|
+
* Relative paths are by default resolved from the current working directory.
|
|
123
|
+
* To change the working directory, see `buildOptions.absWorkingDir`.
|
|
124
|
+
*
|
|
125
|
+
* Absolute paths can be used if files are part of the working directory.
|
|
126
|
+
*
|
|
127
|
+
* Examples:
|
|
128
|
+
* - `'src/index.ts'`
|
|
129
|
+
* - `require.resolve('./lambda')`
|
|
130
|
+
* - `['src/index.ts', 'src/util.ts']`
|
|
131
|
+
* - `{one: 'src/two.ts', two: 'src/one.ts'}`
|
|
110
132
|
*
|
|
111
133
|
* @stability stable
|
|
112
134
|
*/
|
|
@@ -130,7 +152,7 @@ class JavaScriptCode extends EsbuildCode {
|
|
|
130
152
|
}
|
|
131
153
|
exports.JavaScriptCode = JavaScriptCode;
|
|
132
154
|
_b = JSII_RTTI_SYMBOL_1;
|
|
133
|
-
JavaScriptCode[_b] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptCode", version: "3.
|
|
155
|
+
JavaScriptCode[_b] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptCode", version: "3.7.0" };
|
|
134
156
|
/**
|
|
135
157
|
* Represents the deployed TypeScript Code.
|
|
136
158
|
*
|
|
@@ -139,8 +161,18 @@ JavaScriptCode[_b] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptCode", version: "3.6
|
|
|
139
161
|
class TypeScriptCode extends EsbuildCode {
|
|
140
162
|
constructor(
|
|
141
163
|
/**
|
|
142
|
-
* A
|
|
143
|
-
*
|
|
164
|
+
* A path or list or map of paths to the entry points of your code.
|
|
165
|
+
*
|
|
166
|
+
* Relative paths are by default resolved from the current working directory.
|
|
167
|
+
* To change the working directory, see `buildOptions.absWorkingDir`.
|
|
168
|
+
*
|
|
169
|
+
* Absolute paths can be used if files are part of the working directory.
|
|
170
|
+
*
|
|
171
|
+
* Examples:
|
|
172
|
+
* - `'src/index.ts'`
|
|
173
|
+
* - `require.resolve('./lambda')`
|
|
174
|
+
* - `['src/index.ts', 'src/util.ts']`
|
|
175
|
+
* - `{one: 'src/two.ts', two: 'src/one.ts'}`
|
|
144
176
|
*
|
|
145
177
|
* @stability stable
|
|
146
178
|
*/
|
|
@@ -164,5 +196,5 @@ class TypeScriptCode extends EsbuildCode {
|
|
|
164
196
|
}
|
|
165
197
|
exports.TypeScriptCode = TypeScriptCode;
|
|
166
198
|
_c = JSII_RTTI_SYMBOL_1;
|
|
167
|
-
TypeScriptCode[_c] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptCode", version: "3.
|
|
168
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code.js","sourceRoot":"","sources":["../src/code.ts"],"names":[],"mappings":";;;;;AAAA,6CAAiD;AACjD,uDAA+E;AAE/E,mCAMiB;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;AAG6D,CAAC;AACD,CAAC;AAE/D;;;;GAIG;AACH,MAAa,WAEX,SAAQ,iBAAI;IAoBZ;IACE;;;;;OAKG;IACM,WAAwB;IAEjC;;;;;;;;;OASG;IACH,KAAY;QAEZ,KAAK,EAAE,CAAC;QAdC,gBAAW,GAAX,WAAW,CAAa;QAdnC;;;;WAIG;QACI,aAAQ,GAAY,KAAK,CAAC;QAyB/B,MAAM,cAAc,GAA0B;YAC5C,GAAG,CAAC,CAAC,KAAK,CAAC,YAAY,EAAE,QAAQ;gBACjC,KAAK,CAAC,YAAY,EAAE,QAAQ,KAAK,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;IAzDS,QAAQ,CAAC,KAAgB;QACjC,OAAO,IAAI,oBAAY,CACrB,KAAK,EACL,IAAI,CAAC,WAAW,CAAC,IAAI,EACrB,IAAI,CAAC,KAAK,CACX,CAAC;IACJ,CAAC;IAqDD,IAAI,CAAC,KAAgB;QACnB,qFAAqF;QACrF,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACf,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACnC;aAAM,IAAI,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,mBAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE;YACnD,MAAM,IAAI,KAAK,CACb,mDACE,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,SACvB,KAAK,GAAG,8CAA8C,CACvD,CAAC;SACH;QAED,OAAO;YACL,UAAU,EAAE;gBACV,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,YAAY;gBACnC,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW;aAClC;SACF,CAAC;IACJ,CAAC;IAED;;;;;;;OAOG;IACH,cAAc,CAAC,QAAqB,EAAE,OAA6B;QACjE,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACf,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;SACjE;QACD,MAAM,gBAAgB,GAAG,OAAO,EAAE,gBAAgB,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;QAC5E,6CAA6C;QAC7C,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,QAAQ,EAAE,gBAAgB,CAAC,CAAC;IAC7D,CAAC;;AAjGH,kCAkGC;;;AAED;;;;GAIG;AACH,MAAa,cAAe,SAAQ,WAAgC;IASlE;IACE;;;;;OAKG;IACH,WAAwB;IACxB;;;;;;;;;OASG;IACH,QAA6B,EAAE;QAE/B,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;IAC5B,CAAC;IA7BS,QAAQ,CAAC,KAAgB;QACjC,OAAO,IAAI,uBAAO,CAChB,KAAK,EACL,IAAI,CAAC,WAAW,CAAC,IAAI,EACrB,IAAI,CAAC,KAAK,CACX,CAAC;IACJ,CAAC;;AAPH,wCA+BC;;;AAED;;;;GAIG;AACH,MAAa,cAAe,SAAQ,WAAgC;IASlE;IACE;;;;;OAKG;IACH,WAAwB;IACxB;;;;;;;;;OASG;IACH,QAA6B,EAAE;QAE/B,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;IAC5B,CAAC;IA7BS,QAAQ,CAAC,KAAgB;QACjC,OAAO,IAAI,uBAAO,CAChB,KAAK,EACL,IAAI,CAAC,WAAW,CAAC,IAAI,EACrB,IAAI,CAAC,KAAK,CACX,CAAC;IACJ,CAAC;;AAPH,wCA+BC","sourcesContent":["import { CfnResource, Stack } from 'aws-cdk-lib';\nimport { ResourceBindOptions, Code, CodeConfig } from 'aws-cdk-lib/aws-lambda';\nimport { Construct } from 'constructs';\nimport {\n  EsbuildAsset,\n  AssetBaseProps,\n  AssetProps,\n  JavaScriptAsset as JSAsset,\n  TypeScriptAsset as TSAsset,\n} from './asset';\nimport { EntryPoints } from './bundler';\nimport { BuildOptions } from './esbuild-types';\n\nfunction nodeMajorVersion(): number {\n  return parseInt(process.versions.node.split('.')[0], 10);\n}\n\nexport { CodeConfig } from 'aws-cdk-lib/aws-lambda';\nexport interface JavaScriptCodeProps extends AssetBaseProps {};\nexport interface TypeScriptCodeProps extends AssetBaseProps {};\n\n/**\n * Represents the a generic Esbuild Code bundle.\n *\n * @stability experimental\n */\nexport class EsbuildCode<\n  Props extends JavaScriptCodeProps | TypeScriptCodeProps,\n> extends Code {\n  protected getAsset(scope: Construct): EsbuildAsset<AssetProps> {\n    return new EsbuildAsset(\n      scope,\n      this.constructor.name,\n      this.props,\n    );\n  }\n\n  protected props: AssetProps;\n\n  protected asset!: EsbuildAsset<AssetProps>;\n\n  /**\n   * Determines whether this Code is inline code or not.\n   *\n   * @deprecated this value is ignored since inline is now determined based on the the inlineCode field of CodeConfig returned from bind().\n   */\n  public isInline: boolean = false;\n\n  constructor(\n    /**\n     * A 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    readonly entryPoints: EntryPoints,\n\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=node`\n     * - `target=nodeX` with X being the major node version running locally\n     *\n     * @stability stable\n     */\n    props: Props,\n  ) {\n    super();\n\n    const defaultOptions: Partial<BuildOptions> = {\n      ...(!props.buildOptions?.platform ||\n      props.buildOptions?.platform === 'node'\n        ? { platform: 'node', target: 'node' + nodeMajorVersion() }\n        : {}),\n    };\n\n    this.props = {\n      ...props,\n      entryPoints,\n      buildOptions: {\n        ...defaultOptions,\n        ...props.buildOptions,\n      },\n    };\n  }\n\n  bind(scope: Construct): CodeConfig {\n    // If the same AssetCode is used multiple times, retain only the first instantiation.\n    if (!this.asset) {\n      this.asset = this.getAsset(scope);\n    } else if (Stack.of(this.asset) !== Stack.of(scope)) {\n      throw new Error(\n        `Asset is already associated with another stack '${\n          Stack.of(this.asset).stackName\n        }'. ` + 'Create a new Asset instance for every stack.',\n      );\n    }\n\n    return {\n      s3Location: {\n        bucketName: this.asset.s3BucketName,\n        objectKey: this.asset.s3ObjectKey,\n      },\n    };\n  }\n\n  /**\n   * Called after the CFN function resource has been created to allow the code class to bind to it.\n   *\n   * Specifically it's required to allow assets to add\n   * metadata for tooling like SAM CLI to be able to find their origins.\n   *\n   * @stability stable\n   */\n  bindToResource(resource: CfnResource, options?: ResourceBindOptions) {\n    if (!this.asset) {\n      throw new Error('bindToResource() must be called after bind()');\n    }\n    const resourceProperty = options?.resourceProperty || this.constructor.name;\n    // https://github.com/aws/aws-cdk/issues/1432\n    this.asset.addResourceMetadata(resource, resourceProperty);\n  }\n}\n\n/**\n * Represents the deployed JavaScript Code.\n *\n * @stability stable\n */\nexport class JavaScriptCode extends EsbuildCode<JavaScriptCodeProps> {\n  protected getAsset(scope: Construct): EsbuildAsset<AssetProps> {\n    return new JSAsset(\n      scope,\n      this.constructor.name,\n      this.props,\n    );\n  }\n\n  constructor(\n    /**\n     * A relative path or list or map of relative paths to the entry points of your code from the root of the project.\n     * E.g. `src/index.ts`.\n     *\n     * @stability stable\n     */\n    entryPoints: EntryPoints,\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=node`\n     * - `target=nodeX` with X being the major node version running locally\n     *\n     * @stability stable\n     */\n    props: JavaScriptCodeProps = {},\n  ) {\n    super(entryPoints, props);\n  }\n}\n\n/**\n * Represents the deployed TypeScript Code.\n *\n * @stability stable\n */\nexport class TypeScriptCode extends EsbuildCode<TypeScriptCodeProps> {\n  protected getAsset(scope: Construct): EsbuildAsset<AssetProps> {\n    return new TSAsset(\n      scope,\n      this.constructor.name,\n      this.props,\n    );\n  }\n\n  constructor(\n    /**\n     * A 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"]}
|
|
199
|
+
TypeScriptCode[_c] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptCode", version: "3.7.0" };
|
|
200
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code.js","sourceRoot":"","sources":["../src/code.ts"],"names":[],"mappings":"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","sourcesContent":["import { CfnResource, Stack } from 'aws-cdk-lib';\nimport { ResourceBindOptions, Code, CodeConfig } from 'aws-cdk-lib/aws-lambda';\nimport { Construct } from 'constructs';\nimport {\n  EsbuildAsset,\n  AssetBaseProps,\n  AssetProps,\n  JavaScriptAsset as JSAsset,\n  TypeScriptAsset as TSAsset,\n} from './asset';\nimport { EntryPoints } from './bundler';\nimport { BuildOptions } from './esbuild-types';\n\nfunction nodeMajorVersion(): number {\n  return parseInt(process.versions.node.split('.')[0], 10);\n}\n\nexport { CodeConfig } from 'aws-cdk-lib/aws-lambda';\nexport interface JavaScriptCodeProps extends AssetBaseProps {};\nexport interface TypeScriptCodeProps extends AssetBaseProps {};\n\n/**\n * Represents a generic esbuild code bundle.\n *\n * You should always use `TypeScriptCode` or `JavaScriptCode`.\n *\n * @stability experimental\n */\nexport class EsbuildCode<\n  Props extends JavaScriptCodeProps | TypeScriptCodeProps,\n> extends Code {\n  protected getAsset(scope: Construct): EsbuildAsset<AssetProps> {\n    return new EsbuildAsset(\n      scope,\n      this.constructor.name,\n      this.props,\n    );\n  }\n\n  protected props: AssetProps;\n\n  protected asset!: EsbuildAsset<AssetProps>;\n\n  /**\n   * Determines whether this Code is inline code or not.\n   *\n   * @deprecated this value is ignored since inline is now determined based on the the inlineCode field of CodeConfig returned from bind().\n   */\n  public isInline: boolean = false;\n\n  constructor(\n    /**\n     * A path or list or map of paths to the entry points of your code.\n     *\n     * Relative paths are by default resolved from the current working directory.\n     * To change the working directory, see `buildOptions.absWorkingDir`.\n     *\n     * Absolute paths can be used if files are part of the working directory.\n     *\n     * Examples:\n     *  - `'src/index.ts'`\n     *  - `require.resolve('./lambda')`\n     *  - `['src/index.ts', 'src/util.ts']`\n     *  - `{one: 'src/two.ts', two: 'src/one.ts'}`\n     *\n     * @stability stable\n     */\n    readonly entryPoints: EntryPoints,\n\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=node`\n     * - `target=nodeX` with X being the major node version running locally\n     *\n     * @stability stable\n     */\n    props: Props,\n  ) {\n    super();\n\n    const defaultOptions: Partial<BuildOptions> = {\n      ...(!props.buildOptions?.platform ||\n      props.buildOptions?.platform === 'node'\n        ? { platform: 'node', target: 'node' + nodeMajorVersion() }\n        : {}),\n    };\n\n    this.props = {\n      ...props,\n      entryPoints,\n      buildOptions: {\n        ...defaultOptions,\n        ...props.buildOptions,\n      },\n    };\n  }\n\n  bind(scope: Construct): CodeConfig {\n    // If the same AssetCode is used multiple times, retain only the first instantiation.\n    if (!this.asset) {\n      this.asset = this.getAsset(scope);\n    } else if (Stack.of(this.asset) !== Stack.of(scope)) {\n      throw new Error(\n        `Asset is already associated with another stack '${\n          Stack.of(this.asset).stackName\n        }'. ` + 'Create a new Asset instance for every stack.',\n      );\n    }\n\n    return {\n      s3Location: {\n        bucketName: this.asset.s3BucketName,\n        objectKey: this.asset.s3ObjectKey,\n      },\n    };\n  }\n\n  /**\n   * Called after the CFN function resource has been created to allow the code class to bind to it.\n   *\n   * Specifically it's required to allow assets to add\n   * metadata for tooling like SAM CLI to be able to find their origins.\n   *\n   * @stability stable\n   */\n  bindToResource(resource: CfnResource, options?: ResourceBindOptions) {\n    if (!this.asset) {\n      throw new Error('bindToResource() must be called after bind()');\n    }\n    const resourceProperty = options?.resourceProperty || this.constructor.name;\n    // https://github.com/aws/aws-cdk/issues/1432\n    this.asset.addResourceMetadata(resource, resourceProperty);\n  }\n}\n\n/**\n * Represents the deployed JavaScript Code.\n *\n * @stability stable\n */\nexport class JavaScriptCode extends EsbuildCode<JavaScriptCodeProps> {\n  protected getAsset(scope: Construct): EsbuildAsset<AssetProps> {\n    return new JSAsset(\n      scope,\n      this.constructor.name,\n      this.props,\n    );\n  }\n\n  constructor(\n    /**\n     * A path or list or map of paths to the entry points of your code.\n     *\n     * Relative paths are by default resolved from the current working directory.\n     * To change the working directory, see `buildOptions.absWorkingDir`.\n     *\n     * Absolute paths can be used if files are part of the working directory.\n     *\n     * Examples:\n     *  - `'src/index.ts'`\n     *  - `require.resolve('./lambda')`\n     *  - `['src/index.ts', 'src/util.ts']`\n     *  - `{one: 'src/two.ts', two: 'src/one.ts'}`\n     *\n     * @stability stable\n     */\n    entryPoints: EntryPoints,\n\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=node`\n     * - `target=nodeX` with X being the major node version running locally\n     *\n     * @stability stable\n     */\n    props: JavaScriptCodeProps = {},\n  ) {\n    super(entryPoints, props);\n  }\n}\n\n/**\n * Represents the deployed TypeScript Code.\n *\n * @stability stable\n */\nexport class TypeScriptCode extends EsbuildCode<TypeScriptCodeProps> {\n  protected getAsset(scope: Construct): EsbuildAsset<AssetProps> {\n    return new TSAsset(\n      scope,\n      this.constructor.name,\n      this.props,\n    );\n  }\n\n  constructor(\n    /**\n     * A path or list or map of paths to the entry points of your code.\n     *\n     * Relative paths are by default resolved from the current working directory.\n     * To change the working directory, see `buildOptions.absWorkingDir`.\n     *\n     * Absolute paths can be used if files are part of the working directory.\n     *\n     * Examples:\n     *  - `'src/index.ts'`\n     *  - `require.resolve('./lambda')`\n     *  - `['src/index.ts', 'src/util.ts']`\n     *  - `{one: 'src/two.ts', two: 'src/one.ts'}`\n     *\n     * @stability stable\n     */\n    entryPoints: EntryPoints,\n\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=node`\n     * - `target=nodeX` with X being the major node version running locally\n     *\n     * @stability stable\n     */\n    props: TypeScriptCodeProps = {},\n  ) {\n    super(entryPoints, props);\n  }\n}\n"]}
|
package/lib/inline-code.js
CHANGED
|
@@ -70,7 +70,7 @@ class InlineJavaScriptCode extends BaseInlineCode {
|
|
|
70
70
|
}
|
|
71
71
|
exports.InlineJavaScriptCode = InlineJavaScriptCode;
|
|
72
72
|
_a = JSII_RTTI_SYMBOL_1;
|
|
73
|
-
InlineJavaScriptCode[_a] = { fqn: "@mrgrain/cdk-esbuild.InlineJavaScriptCode", version: "3.
|
|
73
|
+
InlineJavaScriptCode[_a] = { fqn: "@mrgrain/cdk-esbuild.InlineJavaScriptCode", version: "3.7.0" };
|
|
74
74
|
/**
|
|
75
75
|
* An implementation of `lambda.InlineCode` using the esbuild Transform API. Inline function code is limited to 4 KiB after transformation.
|
|
76
76
|
*
|
|
@@ -101,7 +101,7 @@ class InlineJsxCode extends BaseInlineCode {
|
|
|
101
101
|
}
|
|
102
102
|
exports.InlineJsxCode = InlineJsxCode;
|
|
103
103
|
_b = JSII_RTTI_SYMBOL_1;
|
|
104
|
-
InlineJsxCode[_b] = { fqn: "@mrgrain/cdk-esbuild.InlineJsxCode", version: "3.
|
|
104
|
+
InlineJsxCode[_b] = { fqn: "@mrgrain/cdk-esbuild.InlineJsxCode", version: "3.7.0" };
|
|
105
105
|
/**
|
|
106
106
|
* An implementation of `lambda.InlineCode` using the esbuild Transform API. Inline function code is limited to 4 KiB after transformation.
|
|
107
107
|
*
|
|
@@ -132,7 +132,7 @@ class InlineTypeScriptCode extends BaseInlineCode {
|
|
|
132
132
|
}
|
|
133
133
|
exports.InlineTypeScriptCode = InlineTypeScriptCode;
|
|
134
134
|
_c = JSII_RTTI_SYMBOL_1;
|
|
135
|
-
InlineTypeScriptCode[_c] = { fqn: "@mrgrain/cdk-esbuild.InlineTypeScriptCode", version: "3.
|
|
135
|
+
InlineTypeScriptCode[_c] = { fqn: "@mrgrain/cdk-esbuild.InlineTypeScriptCode", version: "3.7.0" };
|
|
136
136
|
/**
|
|
137
137
|
* An implementation of `lambda.InlineCode` using the esbuild Transform API. Inline function code is limited to 4 KiB after transformation.
|
|
138
138
|
*
|
|
@@ -163,5 +163,5 @@ class InlineTsxCode extends BaseInlineCode {
|
|
|
163
163
|
}
|
|
164
164
|
exports.InlineTsxCode = InlineTsxCode;
|
|
165
165
|
_d = JSII_RTTI_SYMBOL_1;
|
|
166
|
-
InlineTsxCode[_d] = { fqn: "@mrgrain/cdk-esbuild.InlineTsxCode", version: "3.
|
|
166
|
+
InlineTsxCode[_d] = { fqn: "@mrgrain/cdk-esbuild.InlineTsxCode", version: "3.7.0" };
|
|
167
167
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inline-code.js","sourceRoot":"","sources":["../src/inline-code.ts"],"names":[],"mappings":";;;;;AAAA,uDAAoD;AAEpD,uDAAkD;AAClD,qDAAsD;AA4BtD,MAAe,cAAe,SAAQ,uBAAU;IAC9C,YACE,IAAY,EACZ,KAAuB;QAGvB,MAAM,EAAE,WAAW,GAAG,+BAAa,EAAE,gBAAgB,GAAG,EAAE,EAAE,GAAG,KAAK,CAAC;QAErE,IAAI;YACF,MAAM,eAAe,GAAG,WAAW,CAAC,IAAI,EAAE;gBACxC,GAAG,gBAAgB;aACpB,CAAC,CAAC;YACH,mCAAkB,CAAC,eAAe,EAAE,EAAE,MAAM,EAAE,YAAY,EAAE,CAAC,CAAC;YAE9D,KAAK,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;SAC7B;QAAC,OAAO,KAAK,EAAE;YACd,mCAAkB,CAAC,KAAyB,EAAE,EAAE,MAAM,EAAE,YAAY,EAAE,CAAC,CAAC;YAExE,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;SACnD;IACH,CAAC;CACF;AAED,SAAS,0BAA0B,CAAC,MAAW;IAC7C,OAAO,kBAAkB,IAAI,MAAM,IAAI,aAAa,IAAI,MAAM,CAAC;AACjE,CAAC;AAED,SAAS,gBAAgB,CAAC,MAAc,EAAE,KAA2C;IACnF,IAAI,CAAC,KAAK,EAAE;QACV,OAAO,EAAE,gBAAgB,EAAE,EAAE,MAAM,EAAE,EAAE,CAAC;KACzC;IAED,IAAI,CAAC,0BAA0B,CAAC,KAAK,CAAC,EAAG;QACvC,OAAO,EAAE,gBAAgB,EAAE,EAAE,MAAM,EAAE,GAAG,KAAK,EAAE,EAAE,CAAC;KACnD;IAED,OAAO;QACL,GAAG,KAAK;QACR,gBAAgB,EAAE;YAChB,MAAM;YACN,GAAG,KAAK,CAAC,gBAAgB;SAC1B;KACF,CAAC;AACJ,CAAC;AAGD;;;;GAIG;AACH,MAAa,oBAAqB,SAAQ,cAAc;IACtD;IACE;;;;OAIG;IACH,IAAY;IACZ;;;;;;;;;;OAUG;IACH,KAA2C;QAG3C,KAAK,CAAC,IAAI,EAAE,gBAAgB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC;IAC7C,CAAC;;AAvBH,oDAwBC;;;AAED;;;;GAIG;AACH,MAAa,aAAc,SAAQ,cAAc;IAC/C;IACE;;;;OAIG;IACH,IAAY;IACZ;;;;;;;;;;OAUG;IACH,KAA2C;QAE3C,KAAK,CAAC,IAAI,EAAE,gBAAgB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;IAC9C,CAAC;;AAtBH,sCAuBC;;;AAED;;;;GAIG;AACH,MAAa,oBAAqB,SAAQ,cAAc;IACtD;IACE;;;;OAIG;IACH,IAAY;IACZ;;;;;;;;;;OAUG;IACH,KAA2C;QAE3C,KAAK,CAAC,IAAI,EAAE,gBAAgB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC;IAC7C,CAAC;;AAtBH,oDAuBC;;;AAED;;;;GAIG;AACH,MAAa,aAAc,SAAQ,cAAc;IAC/C;IACE;;;;OAIG;IACH,IAAY;IACZ;;;;;;;;;;OAUG;IACH,KAA2C;QAE3C,KAAK,CAAC,IAAI,EAAE,gBAAgB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;IAC9C,CAAC;;AAtBH,sCAuBC","sourcesContent":["import { InlineCode } from 'aws-cdk-lib/aws-lambda';\nimport { TransformOptions, Loader, TransformFailure } from './esbuild-types';\nimport { transformSync } from './esbuild-wrapper';\nimport { printBuildMessages } from './formatMessages';\n\n/**\n * @stability experimental\n */\nexport interface TransformerProps {\n  /**\n   * Transform options passed on to esbuild. Please refer to the esbuild Transform API docs for details.\n   *\n   * @see https://esbuild.github.io/api/#transform-api\n   * @stability stable\n   */\n  readonly transformOptions?: TransformOptions;\n\n  /**\n   * Escape hatch to provide the bundler with a custom transform function.\n   * The function will receive the computed options from the bundler. It can use with these options as it wishes, however a TransformResult must be returned to integrate with CDK.\n   * Must throw a `TransformFailure` on failure to correctly inform the bundler.\n   *\n   * @stability experimental\n   * @type esbuild.transformSync\n   * @returns esbuild.TransformResult\n   * @throws esbuild.TransformFailure\n   * @default esbuild.transformSync\n   */\n  readonly transformFn?: any;\n}\n\nabstract class BaseInlineCode extends InlineCode {\n  public constructor(\n    code: string,\n    props: TransformerProps,\n  ) {\n\n    const { transformFn = transformSync, transformOptions = {} } = props;\n\n    try {\n      const transformedCode = transformFn(code, {\n        ...transformOptions,\n      });\n      printBuildMessages(transformedCode, { prefix: 'Transform ' });\n\n      super(transformedCode.code);\n    } catch (error) {\n      printBuildMessages(error as TransformFailure, { prefix: 'Transform ' });\n\n      throw new Error('Failed to transform InlineCode');\n    }\n  }\n}\n\nfunction instanceOfTransformerProps(object: any): object is TransformerProps {\n  return 'transformOptions' in object || 'transformFn' in object;\n}\n\nfunction transformerProps(loader: Loader, props?: TransformerProps | TransformOptions): TransformerProps {\n  if (!props) {\n    return { transformOptions: { loader } };\n  }\n\n  if (!instanceOfTransformerProps(props) ) {\n    return { transformOptions: { loader, ...props } };\n  }\n\n  return {\n    ...props,\n    transformOptions: {\n      loader,\n      ...props.transformOptions,\n    },\n  };\n}\n\n\n/**\n * An implementation of `lambda.InlineCode` using the esbuild Transform API. Inline function code is limited to 4 KiB after transformation.\n *\n * @stability experimental\n */\nexport class InlineJavaScriptCode extends BaseInlineCode {\n  public constructor(\n    /**\n     * The inline code to be transformed.\n     *\n     * @stability experimental\n     */\n    code: string,\n    /**\n     * Support for `TransformOptions` is deprecated. Please provide `TransformerProps`!\n     *\n     * Props to change the behaviour of the transformer.\n     *\n     * Default values for `props.transformOptions`:\n     * - `loader='js'`\n     *\n     * @see https://esbuild.github.io/api/#transform-api\n     * @stability experimental\n     */\n    props?: TransformerProps | TransformOptions,\n  ) {\n\n    super(code, transformerProps('js', props));\n  }\n}\n\n/**\n * An implementation of `lambda.InlineCode` using the esbuild Transform API. Inline function code is limited to 4 KiB after transformation.\n *\n * @stability experimental\n */\nexport class InlineJsxCode extends BaseInlineCode {\n  public constructor(\n    /**\n     * The inline code to be transformed.\n     *\n     * @stability experimental\n     */\n    code: string,\n    /**\n     * Support for `TransformOptions` is deprecated. Please provide `TransformerProps`!\n     *\n     * Props to change the behaviour of the transformer.\n     *\n     * Default values for `transformOptions`:\n     * - `loader='jsx'`\n     *\n     * @see https://esbuild.github.io/api/#transform-api\n     * @stability experimental\n     */\n    props?: TransformerProps | TransformOptions,\n  ) {\n    super(code, transformerProps('jsx', props));\n  }\n}\n\n/**\n * An implementation of `lambda.InlineCode` using the esbuild Transform API. Inline function code is limited to 4 KiB after transformation.\n *\n * @stability experimental\n */\nexport class InlineTypeScriptCode extends BaseInlineCode {\n  public constructor(\n    /**\n     * The inline code to be transformed.\n     *\n     * @stability experimental\n     */\n    code: string,\n    /**\n     * Support for `TransformOptions` is deprecated. Please provide `TransformerProps`!\n     *\n     * Props to change the behaviour of the transformer.\n     *\n     * Default values for `transformOptions`:\n     * - `loader='ts'`\n     *\n     * @see https://esbuild.github.io/api/#transform-api\n     * @stability experimental\n     */\n    props?: TransformerProps | TransformOptions,\n  ) {\n    super(code, transformerProps('ts', props));\n  }\n}\n\n/**\n * An implementation of `lambda.InlineCode` using the esbuild Transform API. Inline function code is limited to 4 KiB after transformation.\n *\n * @stability experimental\n */\nexport class InlineTsxCode extends BaseInlineCode {\n  public constructor(\n    /**\n     * The inline code to be transformed.\n     *\n     * @stability experimental\n     */\n    code: string,\n    /**\n     * Support for `TransformOptions` is deprecated. Please provide `TransformerProps`!\n     *\n     * Props to change the behaviour of the transformer.\n     *\n     * Default values for `transformOptions`:\n     * - `loader='tsx'`\n     *\n     * @see https://esbuild.github.io/api/#transform-api\n     * @stability experimental\n     */\n    props?: TransformerProps | TransformOptions,\n  ) {\n    super(code, transformerProps('tsx', props));\n  }\n}\n"]}
|
package/lib/source.d.ts
CHANGED
|
@@ -10,20 +10,96 @@ declare abstract class Source<Props extends JavaScriptSourceProps | TypeScriptSo
|
|
|
10
10
|
protected readonly abstract assetClass: new (scope: Construct, id: string, props: AssetProps) => Asset;
|
|
11
11
|
protected props: AssetProps;
|
|
12
12
|
protected asset: Asset;
|
|
13
|
+
constructor(
|
|
13
14
|
/**
|
|
15
|
+
* A path or list or map of paths to the entry points of your code.
|
|
14
16
|
*
|
|
15
|
-
*
|
|
16
|
-
*
|
|
17
|
+
* Relative paths are by default resolved from the current working directory.
|
|
18
|
+
* To change the working directory, see `buildOptions.absWorkingDir`.
|
|
19
|
+
*
|
|
20
|
+
* Absolute paths can be used if files are part of the working directory.
|
|
21
|
+
*
|
|
22
|
+
* Examples:
|
|
23
|
+
* - `'src/index.ts'`
|
|
24
|
+
* - `require.resolve('./lambda')`
|
|
25
|
+
* - `['src/index.ts', 'src/util.ts']`
|
|
26
|
+
* - `{one: 'src/two.ts', two: 'src/one.ts'}`
|
|
27
|
+
*
|
|
28
|
+
* @stability stable
|
|
29
|
+
*/
|
|
30
|
+
entryPoints: EntryPoints,
|
|
31
|
+
/**
|
|
32
|
+
* Props to change the behavior of the bundler.
|
|
33
|
+
*
|
|
34
|
+
* Default values for `props.buildOptions`:
|
|
35
|
+
* - `bundle=true`
|
|
36
|
+
* - `platform=browser`
|
|
37
|
+
*
|
|
38
|
+
* @stability stable
|
|
17
39
|
*/
|
|
18
|
-
|
|
40
|
+
props: Props);
|
|
19
41
|
bind(scope: Construct, context?: DeploymentSourceContext): SourceConfig;
|
|
20
42
|
}
|
|
21
43
|
export declare class JavaScriptSource extends Source<JavaScriptSourceProps, JavaScriptAsset> {
|
|
22
44
|
assetClass: typeof JavaScriptAsset;
|
|
23
|
-
constructor(
|
|
45
|
+
constructor(
|
|
46
|
+
/**
|
|
47
|
+
* A path or list or map of paths to the entry points of your code.
|
|
48
|
+
*
|
|
49
|
+
* Relative paths are by default resolved from the current working directory.
|
|
50
|
+
* To change the working directory, see `buildOptions.absWorkingDir`.
|
|
51
|
+
*
|
|
52
|
+
* Absolute paths can be used if files are part of the working directory.
|
|
53
|
+
*
|
|
54
|
+
* Examples:
|
|
55
|
+
* - `'src/index.ts'`
|
|
56
|
+
* - `require.resolve('./lambda')`
|
|
57
|
+
* - `['src/index.ts', 'src/util.ts']`
|
|
58
|
+
* - `{one: 'src/two.ts', two: 'src/one.ts'}`
|
|
59
|
+
*
|
|
60
|
+
* @stability stable
|
|
61
|
+
*/
|
|
62
|
+
entryPoints: EntryPoints,
|
|
63
|
+
/**
|
|
64
|
+
* Props to change the behavior of the bundler.
|
|
65
|
+
*
|
|
66
|
+
* Default values for `props.buildOptions`:
|
|
67
|
+
* - `bundle=true`
|
|
68
|
+
* - `platform=browser`
|
|
69
|
+
*
|
|
70
|
+
* @stability stable
|
|
71
|
+
*/
|
|
72
|
+
props?: JavaScriptSourceProps);
|
|
24
73
|
}
|
|
25
74
|
export declare class TypeScriptSource extends Source<TypeScriptSourceProps, TypeScriptAsset> {
|
|
26
75
|
assetClass: typeof TypeScriptAsset;
|
|
27
|
-
constructor(
|
|
76
|
+
constructor(
|
|
77
|
+
/**
|
|
78
|
+
* A path or list or map of paths to the entry points of your code.
|
|
79
|
+
*
|
|
80
|
+
* Relative paths are by default resolved from the current working directory.
|
|
81
|
+
* To change the working directory, see `buildOptions.absWorkingDir`.
|
|
82
|
+
*
|
|
83
|
+
* Absolute paths can be used if files are part of the working directory.
|
|
84
|
+
*
|
|
85
|
+
* Examples:
|
|
86
|
+
* - `'src/index.ts'`
|
|
87
|
+
* - `require.resolve('./lambda')`
|
|
88
|
+
* - `['src/index.ts', 'src/util.ts']`
|
|
89
|
+
* - `{one: 'src/two.ts', two: 'src/one.ts'}`
|
|
90
|
+
*
|
|
91
|
+
* @stability stable
|
|
92
|
+
*/
|
|
93
|
+
entryPoints: EntryPoints,
|
|
94
|
+
/**
|
|
95
|
+
* Props to change the behavior of the bundler.
|
|
96
|
+
*
|
|
97
|
+
* Default values for `props.buildOptions`:
|
|
98
|
+
* - `bundle=true`
|
|
99
|
+
* - `platform=browser`
|
|
100
|
+
*
|
|
101
|
+
* @stability stable
|
|
102
|
+
*/
|
|
103
|
+
props?: TypeScriptSourceProps);
|
|
28
104
|
}
|
|
29
105
|
export {};
|
package/lib/source.js
CHANGED
|
@@ -8,12 +8,34 @@ const asset_1 = require("./asset");
|
|
|
8
8
|
;
|
|
9
9
|
;
|
|
10
10
|
class Source {
|
|
11
|
+
constructor(
|
|
11
12
|
/**
|
|
13
|
+
* A path or list or map of paths to the entry points of your code.
|
|
12
14
|
*
|
|
13
|
-
*
|
|
14
|
-
*
|
|
15
|
+
* Relative paths are by default resolved from the current working directory.
|
|
16
|
+
* To change the working directory, see `buildOptions.absWorkingDir`.
|
|
17
|
+
*
|
|
18
|
+
* Absolute paths can be used if files are part of the working directory.
|
|
19
|
+
*
|
|
20
|
+
* Examples:
|
|
21
|
+
* - `'src/index.ts'`
|
|
22
|
+
* - `require.resolve('./lambda')`
|
|
23
|
+
* - `['src/index.ts', 'src/util.ts']`
|
|
24
|
+
* - `{one: 'src/two.ts', two: 'src/one.ts'}`
|
|
25
|
+
*
|
|
26
|
+
* @stability stable
|
|
27
|
+
*/
|
|
28
|
+
entryPoints,
|
|
29
|
+
/**
|
|
30
|
+
* Props to change the behavior of the bundler.
|
|
31
|
+
*
|
|
32
|
+
* Default values for `props.buildOptions`:
|
|
33
|
+
* - `bundle=true`
|
|
34
|
+
* - `platform=browser`
|
|
35
|
+
*
|
|
36
|
+
* @stability stable
|
|
15
37
|
*/
|
|
16
|
-
|
|
38
|
+
props) {
|
|
17
39
|
const defaultOptions = {
|
|
18
40
|
platform: 'browser',
|
|
19
41
|
};
|
|
@@ -48,21 +70,75 @@ class Source {
|
|
|
48
70
|
}
|
|
49
71
|
}
|
|
50
72
|
class JavaScriptSource extends Source {
|
|
51
|
-
constructor(
|
|
73
|
+
constructor(
|
|
74
|
+
/**
|
|
75
|
+
* A path or list or map of paths to the entry points of your code.
|
|
76
|
+
*
|
|
77
|
+
* Relative paths are by default resolved from the current working directory.
|
|
78
|
+
* To change the working directory, see `buildOptions.absWorkingDir`.
|
|
79
|
+
*
|
|
80
|
+
* Absolute paths can be used if files are part of the working directory.
|
|
81
|
+
*
|
|
82
|
+
* Examples:
|
|
83
|
+
* - `'src/index.ts'`
|
|
84
|
+
* - `require.resolve('./lambda')`
|
|
85
|
+
* - `['src/index.ts', 'src/util.ts']`
|
|
86
|
+
* - `{one: 'src/two.ts', two: 'src/one.ts'}`
|
|
87
|
+
*
|
|
88
|
+
* @stability stable
|
|
89
|
+
*/
|
|
90
|
+
entryPoints,
|
|
91
|
+
/**
|
|
92
|
+
* Props to change the behavior of the bundler.
|
|
93
|
+
*
|
|
94
|
+
* Default values for `props.buildOptions`:
|
|
95
|
+
* - `bundle=true`
|
|
96
|
+
* - `platform=browser`
|
|
97
|
+
*
|
|
98
|
+
* @stability stable
|
|
99
|
+
*/
|
|
100
|
+
props = {}) {
|
|
52
101
|
super(entryPoints, props);
|
|
53
102
|
this.assetClass = asset_1.JavaScriptAsset;
|
|
54
103
|
}
|
|
55
104
|
}
|
|
56
105
|
exports.JavaScriptSource = JavaScriptSource;
|
|
57
106
|
_a = JSII_RTTI_SYMBOL_1;
|
|
58
|
-
JavaScriptSource[_a] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptSource", version: "3.
|
|
107
|
+
JavaScriptSource[_a] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptSource", version: "3.7.0" };
|
|
59
108
|
class TypeScriptSource extends Source {
|
|
60
|
-
constructor(
|
|
109
|
+
constructor(
|
|
110
|
+
/**
|
|
111
|
+
* A path or list or map of paths to the entry points of your code.
|
|
112
|
+
*
|
|
113
|
+
* Relative paths are by default resolved from the current working directory.
|
|
114
|
+
* To change the working directory, see `buildOptions.absWorkingDir`.
|
|
115
|
+
*
|
|
116
|
+
* Absolute paths can be used if files are part of the working directory.
|
|
117
|
+
*
|
|
118
|
+
* Examples:
|
|
119
|
+
* - `'src/index.ts'`
|
|
120
|
+
* - `require.resolve('./lambda')`
|
|
121
|
+
* - `['src/index.ts', 'src/util.ts']`
|
|
122
|
+
* - `{one: 'src/two.ts', two: 'src/one.ts'}`
|
|
123
|
+
*
|
|
124
|
+
* @stability stable
|
|
125
|
+
*/
|
|
126
|
+
entryPoints,
|
|
127
|
+
/**
|
|
128
|
+
* Props to change the behavior of the bundler.
|
|
129
|
+
*
|
|
130
|
+
* Default values for `props.buildOptions`:
|
|
131
|
+
* - `bundle=true`
|
|
132
|
+
* - `platform=browser`
|
|
133
|
+
*
|
|
134
|
+
* @stability stable
|
|
135
|
+
*/
|
|
136
|
+
props = {}) {
|
|
61
137
|
super(entryPoints, props);
|
|
62
138
|
this.assetClass = asset_1.TypeScriptAsset;
|
|
63
139
|
}
|
|
64
140
|
}
|
|
65
141
|
exports.TypeScriptSource = TypeScriptSource;
|
|
66
142
|
_b = JSII_RTTI_SYMBOL_1;
|
|
67
|
-
TypeScriptSource[_b] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptSource", version: "3.
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
143
|
+
TypeScriptSource[_b] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptSource", version: "3.7.0" };
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source.js","sourceRoot":"","sources":["../src/source.ts"],"names":[],"mappings":";;;;;AAAA,6CAAoC;AAOpC,mCAAuF;AAIxB,CAAC;AACD,CAAC;AAEhE,MAAe,MAAM;IAcnB;IACE;;;;;;;;;;;;;;;OAeG;IACH,WAAwB;IAExB;;;;;;;;OAQG;IACH,KAAY;QAEZ,MAAM,cAAc,GAA0B;YAC5C,QAAQ,EAAE,SAAS;SACpB,CAAC;QAEF,IAAI,CAAC,KAAK,GAAG;YACX,WAAW;YACX,GAAG,KAAK;YACR,YAAY,EAAE;gBACZ,GAAG,cAAc;gBACjB,GAAG,KAAK,CAAC,YAAY;aACtB;SACF,CAAC;IACJ,CAAC;IAED,IAAI,CAAC,KAAgB,EAAE,OAAiC;QACtD,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,IAAI,CAAC,OAAO,EAAE;YACZ,MAAM,IAAI,KAAK,CACb,YAAY,IAAI,CAAC,WAAW,CAAC,IAAI,4BAA4B,CAC9D,CAAC;SACH;QAED,wEAAwE;QACxE,sEAAsE;QACtE,6DAA6D;QAC7D,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAEjD,OAAO;YACL,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM;YACzB,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW;SACrC,CAAC;IACJ,CAAC;CACF;AAED,MAAa,gBAAiB,SAAQ,MAGrC;IAGC;IAEE;;;;;;;;;;;;;;;OAeG;IACH,WAAwB;IAExB;;;;;;;;QAQI;IACJ,QAA+B,EAAE;QAEjC,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;QAjC5B,eAAU,GAAG,uBAAe,CAAC;IAkC7B,CAAC;;AAtCH,4CAuCC;;;AAED,MAAa,gBAAiB,SAAQ,MAGrC;IAGC;IACE;;;;;;;;;;;;;;;OAeG;IACH,WAAwB;IAExB;;;;;;;;OAQG;IACH,QAA+B,EAAE;QAEjC,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;QAhC5B,eAAU,GAAG,uBAAe,CAAC;IAiC7B,CAAC;;AArCH,4CAsCC","sourcesContent":["import { Stack } from 'aws-cdk-lib';\nimport {\n  DeploymentSourceContext,\n  ISource,\n  SourceConfig,\n} from 'aws-cdk-lib/aws-s3-deployment';\nimport { Construct } from 'constructs';\nimport { AssetBaseProps, AssetProps, JavaScriptAsset, TypeScriptAsset } from './asset';\nimport { EntryPoints } from './bundler';\nimport { BuildOptions } from './esbuild-types';\n\nexport interface JavaScriptSourceProps extends AssetBaseProps{};\nexport interface TypeScriptSourceProps extends AssetBaseProps{};\n\nabstract class Source<\n  Props extends JavaScriptSourceProps | TypeScriptSourceProps,\n  Asset extends JavaScriptAsset | TypeScriptAsset,\n> implements ISource {\n  protected readonly abstract 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  constructor(\n    /**\n     * A path or list or map of paths to the entry points of your code.\n     *\n     * Relative paths are by default resolved from the current working directory.\n     * To change the working directory, see `buildOptions.absWorkingDir`.\n     *\n     * Absolute paths can be used if files are part of the working directory.\n     *\n     * Examples:\n     *  - `'src/index.ts'`\n     *  - `require.resolve('./lambda')`\n     *  - `['src/index.ts', 'src/util.ts']`\n     *  - `{one: 'src/two.ts', two: 'src/one.ts'}`\n     *\n     * @stability stable\n     */\n    entryPoints: EntryPoints,\n\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=browser`\n     *\n     * @stability stable\n     */\n    props: Props,\n  ) {\n    const defaultOptions: Partial<BuildOptions> = {\n      platform: 'browser',\n    };\n\n    this.props = {\n      entryPoints,\n      ...props,\n      buildOptions: {\n        ...defaultOptions,\n        ...props.buildOptions,\n      },\n    };\n  }\n\n  bind(scope: Construct, context?: DeploymentSourceContext): SourceConfig {\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    if (!context) {\n      throw new Error(\n        `To use a ${this.constructor.name}, context must be provided`,\n      );\n    }\n\n    // we give permissions on all files in the bucket since we don't want to\n    // accidentally revoke permission on old versions when deploying a new\n    // version (for example, when using Lambda traffic shifting).\n    this.asset.bucket.grantRead(context.handlerRole);\n\n    return {\n      bucket: this.asset.bucket,\n      zipObjectKey: this.asset.s3ObjectKey,\n    };\n  }\n}\n\nexport class JavaScriptSource extends Source<\nJavaScriptSourceProps,\nJavaScriptAsset\n> {\n  assetClass = JavaScriptAsset;\n\n  constructor(\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     */\n    entryPoints: EntryPoints,\n\n    /**\n      * Props to change the behavior of the bundler.\n      *\n      * Default values for `props.buildOptions`:\n      * - `bundle=true`\n      * - `platform=browser`\n      *\n      * @stability stable\n      */\n    props: JavaScriptSourceProps = {},\n  ) {\n    super(entryPoints, props);\n  }\n}\n\nexport class TypeScriptSource extends Source<\nTypeScriptSourceProps,\nTypeScriptAsset\n> {\n  assetClass = TypeScriptAsset;\n\n  constructor(\n    /**\n     * A path or list or map of paths to the entry points of your code.\n     *\n     * Relative paths are by default resolved from the current working directory.\n     * To change the working directory, see `buildOptions.absWorkingDir`.\n     *\n     * Absolute paths can be used if files are part of the working directory.\n     *\n     * Examples:\n     *  - `'src/index.ts'`\n     *  - `require.resolve('./lambda')`\n     *  - `['src/index.ts', 'src/util.ts']`\n     *  - `{one: 'src/two.ts', two: 'src/one.ts'}`\n     *\n     * @stability stable\n     */\n    entryPoints: EntryPoints,\n\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=browser`\n     *\n     * @stability stable\n     */\n    props: TypeScriptSourceProps = {},\n  ) {\n    super(entryPoints, props);\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -21,6 +21,7 @@
|
|
|
21
21
|
"post-compile": "npx projen post-compile",
|
|
22
22
|
"post-upgrade": "npx projen post-upgrade",
|
|
23
23
|
"pre-compile": "npx projen pre-compile",
|
|
24
|
+
"publish:git": "npx projen publish:git",
|
|
24
25
|
"release": "npx projen release",
|
|
25
26
|
"test": "npx projen test",
|
|
26
27
|
"test:update": "npx projen test:update",
|
|
@@ -84,7 +85,7 @@
|
|
|
84
85
|
"main": "lib/index.js",
|
|
85
86
|
"license": "MIT",
|
|
86
87
|
"homepage": "https://github.com/mrgrain/cdk-esbuild",
|
|
87
|
-
"version": "3.
|
|
88
|
+
"version": "3.7.0",
|
|
88
89
|
"jest": {
|
|
89
90
|
"testPathIgnorePatterns": [
|
|
90
91
|
"/node_modules/",
|