@nikovirtala/projen-bundle-lambda-function-code 0.0.15 → 0.0.17

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/LICENSE CHANGED
@@ -1,4 +1,4 @@
1
- Copyright (c) 2023 Niko Virtala
1
+ Copyright (c) 2025 Niko Virtala
2
2
 
3
3
  Permission is hereby granted, free of charge, to any person obtaining a copy
4
4
  of this software and associated documentation files (the "Software"), to deal
package/README.md CHANGED
@@ -1 +1,198 @@
1
- # replace this
1
+ # @nikovirtala/projen-bundle-lambda-function-code
2
+
3
+ A Projen component for automatically bundling AWS Lambda function code using esbuild.
4
+
5
+ ## Features
6
+
7
+ - **Auto-discovery**: Automatically finds Lambda handler files with configurable extensions
8
+ - **ESBuild bundling**: Uses esbuild for fast, efficient bundling
9
+ - **CDK integration**: Generates CDK constructs with pre-bundled Lambda code
10
+ - **TypeScript support**: Full TypeScript support with configurable tsconfig
11
+ - **Flexible configuration**: Customizable bundling options per function
12
+
13
+ ## Installation
14
+
15
+ ```bash
16
+ npm install @nikovirtala/projen-bundle-lambda-function-code
17
+ ```
18
+
19
+ ## Usage
20
+
21
+ ### Basic Setup
22
+
23
+ Add the bundler to your Projen TypeScript project:
24
+
25
+ ```typescript
26
+ import { LambdaFunctionCodeBundler, Bundler } from '@nikovirtala/projen-bundle-lambda-function-code';
27
+
28
+ const project = new typescript.TypeScriptProject({
29
+ // ... your project config
30
+ });
31
+
32
+ // Add the bundler component
33
+ new Bundler(project);
34
+
35
+ // Auto-discover and bundle Lambda functions
36
+ new LambdaFunctionCodeBundler(project, {
37
+ extension: '.lambda.ts',
38
+ srcdir: 'src',
39
+ });
40
+ ```
41
+
42
+ ### Lambda Handler Files
43
+
44
+ Create Lambda handler files with the configured extension:
45
+
46
+ ```typescript
47
+ // src/hello-world.lambda.ts
48
+ export const handler = async (event: any) => {
49
+ return {
50
+ statusCode: 200,
51
+ body: JSON.stringify({ message: 'Hello World!' }),
52
+ };
53
+ };
54
+ ```
55
+
56
+ ### Generated CDK Constructs
57
+
58
+ The bundler automatically generates CDK constructs for each Lambda function:
59
+
60
+ ```typescript
61
+ // Generated: src/hello-world-code.ts
62
+ import * as path from 'path';
63
+ import { aws_lambda } from 'aws-cdk-lib';
64
+
65
+ export const HelloWorldFunctionCode = aws_lambda.Code.fromAsset(
66
+ path.join(__dirname, '../assets/hello-world'),
67
+ );
68
+ ```
69
+
70
+ Use in your CDK stack:
71
+
72
+ ```typescript
73
+ import { HelloWorldFunctionCode } from './hello-world-code';
74
+
75
+ new aws_lambda.Function(this, 'HelloWorldFunction', {
76
+ runtime: aws_lambda.Runtime.NODEJS_20_X,
77
+ handler: 'index.handler',
78
+ code: HelloWorldFunctionCode,
79
+ });
80
+ ```
81
+
82
+ ## API Reference
83
+
84
+ ### Bundler
85
+
86
+ Main component for esbuild bundling support.
87
+
88
+ ```typescript
89
+ new Bundler(project, {
90
+ esbuildVersion?: string; // esbuild version requirement
91
+ assetsDir?: string; // output directory (default: "assets")
92
+ addToPreCompile?: boolean; // add to pre-compile phase (default: true)
93
+ loaders?: Record<string, string>; // file extension loaders
94
+ });
95
+ ```
96
+
97
+ ### LambdaFunctionCodeBundler
98
+
99
+ Auto-discovers and bundles Lambda functions.
100
+
101
+ ```typescript
102
+ new LambdaFunctionCodeBundler(project, {
103
+ extension: string; // file extension to discover (e.g., ".lambda.ts")
104
+ srcdir: string; // source directory to scan
105
+ bundleOptions?: { // default bundling options
106
+ externals?: string[];
107
+ sourcemap?: boolean;
108
+ target?: string;
109
+ platform?: string;
110
+ // ... more options
111
+ };
112
+ });
113
+ ```
114
+
115
+ ### LambdaFunctionCodeBundle
116
+
117
+ Bundle individual Lambda functions.
118
+
119
+ ```typescript
120
+ new LambdaFunctionCodeBundle(project, {
121
+ entrypoint: string; // path to Lambda handler file
122
+ extension: string; // file extension
123
+ constructFile?: string; // generated construct file name
124
+ constructName?: string; // generated construct class name
125
+ bundlingOptions?: BundlingOptions;
126
+ });
127
+ ```
128
+
129
+ ## Bundling Options
130
+
131
+ Customize esbuild behavior:
132
+
133
+ ```typescript
134
+ interface BundlingOptions {
135
+ externals?: string[]; // external dependencies to exclude
136
+ sourcemap?: boolean; // include source maps (default: true)
137
+ target?: string; // esbuild target (default: "esnext")
138
+ platform?: string; // target platform (default: "node")
139
+ outfile?: string; // output filename (default: "index.mjs")
140
+ format?: string; // output format (esm, cjs, iife)
141
+ minify?: boolean; // minify output (default: true)
142
+ tsconfigPath?: string; // TypeScript config path
143
+ loaders?: Record<string, string>; // file loaders
144
+ }
145
+ ```
146
+
147
+ ## Examples
148
+
149
+ ### Custom Bundling Options
150
+
151
+ ```typescript
152
+ new LambdaFunctionCodeBundler(project, {
153
+ extension: '.lambda.ts',
154
+ srcdir: 'src/functions',
155
+ bundleOptions: {
156
+ externals: ['aws-sdk'],
157
+ minify: false,
158
+ sourcemap: true,
159
+ target: 'node18',
160
+ },
161
+ });
162
+ ```
163
+
164
+ ### Individual Function Bundle
165
+
166
+ ```typescript
167
+ new LambdaFunctionCodeBundle(project, {
168
+ entrypoint: 'src/special-function.lambda.ts',
169
+ extension: '.lambda.ts',
170
+ constructName: 'SpecialFunction',
171
+ bundlingOptions: {
172
+ externals: ['@aws-sdk/client-s3'],
173
+ format: 'cjs',
174
+ },
175
+ });
176
+ ```
177
+
178
+ ## Development
179
+
180
+ This project uses Projen for configuration management.
181
+
182
+ ```bash
183
+ # Install dependencies
184
+ pnpm install
185
+
186
+ # Build the project
187
+ pnpm build
188
+
189
+ # Run tests
190
+ pnpm test
191
+
192
+ # Update project configuration
193
+ npx projen
194
+ ```
195
+
196
+ ## License
197
+
198
+ MIT
package/lib/bundler.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import { Component, Project, Task } from "projen";
1
+ import { Component, type Project, type Task } from "projen";
2
2
  /**
3
3
  * Options for `Bundler`.
4
4
  */
package/lib/bundler.js CHANGED
@@ -15,16 +15,26 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
15
15
  }) : function(o, v) {
16
16
  o["default"] = v;
17
17
  });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
25
35
  Object.defineProperty(exports, "__esModule", { value: true });
26
36
  exports.Bundler = void 0;
27
- const path = __importStar(require("path"));
37
+ const path = __importStar(require("node:path"));
28
38
  const projen_1 = require("projen");
29
39
  const utils_1 = require("./utils");
30
40
  /**
@@ -46,11 +56,10 @@ class Bundler extends projen_1.Component {
46
56
  * Creates a `Bundler`.
47
57
  */
48
58
  constructor(project, options = {}) {
49
- var _a, _b;
50
59
  super(project);
51
60
  this.esbuildVersion = options.esbuildVersion;
52
- this.bundledir = (_a = options.assetsDir) !== null && _a !== void 0 ? _a : "assets";
53
- this.addToPreCompile = (_b = options.addToPreCompile) !== null && _b !== void 0 ? _b : true;
61
+ this.bundledir = options.assetsDir ?? "assets";
62
+ this.addToPreCompile = options.addToPreCompile ?? true;
54
63
  this.loaders = options.loaders;
55
64
  }
56
65
  /**
@@ -80,18 +89,18 @@ class Bundler extends projen_1.Component {
80
89
  * @param options Bundling options
81
90
  */
82
91
  addBundle(entrypoint, options) {
83
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
84
92
  const name = (0, utils_1.renderBundleName)(entrypoint);
85
93
  const outdir = path.posix.join(this.bundledir, name);
86
- const outfile = path.posix.join(outdir, (_a = options.outfile) !== null && _a !== void 0 ? _a : "index.mjs");
87
- const target = (_b = options.target) !== null && _b !== void 0 ? _b : "esnext";
88
- const platform = (_c = options.platform) !== null && _c !== void 0 ? _c : "node";
89
- const format = (_d = options.format) !== null && _d !== void 0 ? _d : "esm";
90
- const sourcemap = (_e = options.sourcemap) !== null && _e !== void 0 ? _e : true;
91
- const sourcesContent = (_f = options.sourcesContent) !== null && _f !== void 0 ? _f : false;
92
- const minify = (_g = options.minify) !== null && _g !== void 0 ? _g : true;
93
- const mainFields = (_h = options.mainFields) !== null && _h !== void 0 ? _h : "module,main";
94
- const banner = (_j = options.banner) !== null && _j !== void 0 ? _j : ":js=import { createRequire as topLevelCreateRequire } from 'module';const require = topLevelCreateRequire(import.meta.url)";
94
+ const outfile = path.posix.join(outdir, options.outfile ?? "index.mjs");
95
+ const target = options.target ?? "esnext";
96
+ const platform = options.platform ?? "node";
97
+ const format = options.format ?? "esm";
98
+ const sourcemap = options.sourcemap ?? true;
99
+ const sourcesContent = options.sourcesContent ?? false;
100
+ const minify = options.minify ?? true;
101
+ const mainFields = options.mainFields ?? "module,main";
102
+ const banner = options.banner ??
103
+ ":js=import { createRequire as topLevelCreateRequire } from 'module';const require = topLevelCreateRequire(import.meta.url)";
95
104
  const args = [
96
105
  "esbuild",
97
106
  "--bundle",
@@ -100,11 +109,11 @@ class Bundler extends projen_1.Component {
100
109
  `--platform="${platform}"`,
101
110
  `--outfile="${outfile}"`,
102
111
  ];
103
- const tsconfig = (_k = options.tsconfigPath) !== null && _k !== void 0 ? _k : false;
112
+ const tsconfig = options.tsconfigPath ?? false;
104
113
  if (tsconfig) {
105
114
  args.push(`--tsconfig="${tsconfig}"`);
106
115
  }
107
- for (const x of (_l = options.externals) !== null && _l !== void 0 ? _l : []) {
116
+ for (const x of options.externals ?? []) {
108
117
  args.push(`--external:${x}`);
109
118
  }
110
119
  if (sourcemap) {
@@ -125,9 +134,9 @@ class Bundler extends projen_1.Component {
125
134
  if (banner) {
126
135
  args.push(`--banner${banner}`);
127
136
  }
128
- const loaders = ((_m = options.loaders) !== null && _m !== void 0 ? _m : false) ? options.loaders : (_o = this.loaders) !== null && _o !== void 0 ? _o : false;
137
+ const loaders = (options.loaders ?? false) ? options.loaders : (this.loaders ?? false);
129
138
  if (loaders) {
130
- for (let [extension, loader] of Object.entries(loaders)) {
139
+ for (const [extension, loader] of Object.entries(loaders)) {
131
140
  args.push(`--loader:.${extension}=${loader}`);
132
141
  }
133
142
  }
@@ -152,11 +161,9 @@ class Bundler extends projen_1.Component {
152
161
  const ignoreEntry = `/${this.bundledir}/`;
153
162
  this.project.addGitIgnore(ignoreEntry);
154
163
  this.project.addPackageIgnore(`!${ignoreEntry}`); // include in tarball
155
- const dep = this.esbuildVersion
156
- ? `esbuild@${this.esbuildVersion}`
157
- : "esbuild";
164
+ const dep = this.esbuildVersion ? `esbuild@${this.esbuildVersion}` : "esbuild";
158
165
  this.project.deps.addDependency(dep, projen_1.DependencyType.BUILD);
159
166
  }
160
167
  }
161
168
  exports.Bundler = Bundler;
162
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundler.js","sourceRoot":"","sources":["../src/bundler.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from \"path\";\nimport { Component, DependencyType, Project, Task } from \"projen\";\nimport { renderBundleName } from \"./utils\";\n\n/**\n * Options for `Bundler`.\n */\nexport interface BundlerOptions {\n  /**\n   * The semantic version requirement for `esbuild`.\n   *\n   * @default - no specific version (implies latest)\n   */\n  readonly esbuildVersion?: string;\n\n  /**\n   * Output directory for all bundles.\n   * @default \"assets\"\n   */\n  readonly assetsDir?: string;\n\n  /**\n   * Install the `bundle` command as a pre-compile phase.\n   *\n   * @default true\n   */\n  readonly addToPreCompile?: boolean;\n\n  /**\n   * Map of file extensions (without dot) and loaders to use for this file type.\n   * Loaders are appended to the esbuild command by `--loader:.extension=loader`\n   */\n  readonly loaders?: { [key: string]: string };\n}\n\n/**\n * Adds support for bundling JavaScript applications and dependencies into a\n * single file. In the future, this will also supports bundling websites.\n */\nexport class Bundler extends Component {\n  /**\n   * Returns the `Bundler` instance associated with a project or `undefined` if\n   * there is no Bundler.\n   * @param project The project\n   * @returns A bundler\n   */\n  public static of(project: Project): Bundler | undefined {\n    const isBundler = (o: Component): o is Bundler => o instanceof Bundler;\n    return project.components.find(isBundler);\n  }\n\n  /**\n   * The semantic version requirement for `esbuild` (if defined).\n   */\n  public readonly esbuildVersion: string | undefined;\n\n  /**\n   * Root bundle directory.\n   */\n  public readonly bundledir: string;\n\n  private _task: Task | undefined;\n  private readonly addToPreCompile: boolean;\n  private readonly loaders?: { [key: string]: string };\n\n  /**\n   * Creates a `Bundler`.\n   */\n  constructor(project: Project, options: BundlerOptions = {}) {\n    super(project);\n\n    this.esbuildVersion = options.esbuildVersion;\n    this.bundledir = options.assetsDir ?? \"assets\";\n    this.addToPreCompile = options.addToPreCompile ?? true;\n    this.loaders = options.loaders;\n  }\n\n  /**\n   * Gets or creates the singleton \"bundle\" task of the project.\n   *\n   * If the project doesn't have a \"bundle\" task, it will be created and spawned\n   * during the pre-compile phase.\n   */\n  public get bundleTask(): Task {\n    if (!this._task) {\n      this.addBundlingSupport();\n      this._task = this.project.tasks.addTask(\"bundle\", {\n        description: \"Prepare assets\",\n      });\n\n      // install the bundle task into the pre-compile phase.\n      if (this.addToPreCompile) {\n        this.project.preCompileTask.spawn(this._task);\n      }\n    }\n\n    return this._task;\n  }\n\n  /**\n   * Adds a task to the project which bundles a specific entrypoint and all of\n   * its dependencies into a single javascript output file.\n   *\n   * @param entrypoint The relative path of the artifact within the project\n   * @param options Bundling options\n   */\n  public addBundle(entrypoint: string, options: BundlingOptions): Bundle {\n    const name = renderBundleName(entrypoint);\n\n    const outdir = path.posix.join(this.bundledir, name);\n    const outfile = path.posix.join(outdir, options.outfile ?? \"index.mjs\");\n    const target = options.target ?? \"esnext\";\n    const platform = options.platform ?? \"node\";\n    const format = options.format ?? \"esm\";\n    const sourcemap = options.sourcemap ?? true;\n    const sourcesContent = options.sourcesContent ?? false;\n    const minify = options.minify ?? true;\n    const mainFields = options.mainFields ?? \"module,main\";\n    const banner =\n      options.banner ??\n      \":js=import { createRequire as topLevelCreateRequire } from 'module';const require = topLevelCreateRequire(import.meta.url)\";\n\n    const args = [\n      \"esbuild\",\n      \"--bundle\",\n      entrypoint,\n      `--target=\"${target}\"`,\n      `--platform=\"${platform}\"`,\n      `--outfile=\"${outfile}\"`,\n    ];\n\n    const tsconfig = options.tsconfigPath ?? false;\n    if (tsconfig) {\n      args.push(`--tsconfig=\"${tsconfig}\"`);\n    }\n\n    for (const x of options.externals ?? []) {\n      args.push(`--external:${x}`);\n    }\n\n    if (sourcemap) {\n      args.push(\"--sourcemap\");\n    }\n\n    if (sourcesContent) {\n      args.push(`--sources-content=${sourcesContent}`);\n    }\n\n    if (minify) {\n      args.push(\"--minify\");\n    }\n\n    if (format) {\n      args.push(`--format=${format}`);\n    }\n\n    if (mainFields) {\n      args.push(`--main-fields=${mainFields}`);\n    }\n\n    if (banner) {\n      args.push(`--banner${banner}`);\n    }\n\n    const loaders =\n      options.loaders ?? false ? options.loaders : this.loaders ?? false;\n    if (loaders) {\n      for (let [extension, loader] of Object.entries(loaders)) {\n        args.push(`--loader:.${extension}=${loader}`);\n      }\n    }\n\n    console.log({ args: args });\n\n    const bundleTask = this.project.addTask(`bundle:${name}`, {\n      description: `Create a JavaScript bundle from ${entrypoint}`,\n      exec: args.join(\" \"),\n    });\n\n    this.bundleTask.spawn(bundleTask);\n\n    return {\n      bundleTask: bundleTask,\n      outdir: outdir,\n      outfile: outfile,\n    };\n  }\n\n  /**\n   * Add bundling support to a project. This is called implicitly when\n   * `bundleTask` is referenced first. It adds the dependency on `esbuild`,\n   * gitignore/npmignore, etc.\n   */\n  private addBundlingSupport() {\n    const ignoreEntry = `/${this.bundledir}/`;\n    this.project.addGitIgnore(ignoreEntry);\n    this.project.addPackageIgnore(`!${ignoreEntry}`); // include in tarball\n    const dep = this.esbuildVersion\n      ? `esbuild@${this.esbuildVersion}`\n      : \"esbuild\";\n    this.project.deps.addDependency(dep, DependencyType.BUILD);\n  }\n}\n\nexport interface Bundle {\n  /**\n   * The task that produces this bundle.\n   */\n  readonly bundleTask: Task;\n\n  /**\n   * Location of the output file (relative to project root).\n   */\n  readonly outfile: string;\n\n  /**\n   * Base directory containing the output file (relative to project root).\n   */\n  readonly outdir: string;\n}\n\n/**\n * Options for bundling.\n */\nexport interface BundlingOptions {\n  /**\n   * You can mark a file or a package as external to exclude it from your build.\n   * Instead of being bundled, the import will be preserved (using require for\n   * the iife and cjs formats and using import for the esm format) and will be\n   * evaluated at run time instead.\n   *\n   * This has several uses. First of all, it can be used to trim unnecessary\n   * code from your bundle for a code path that you know will never be executed.\n   * For example, a package may contain code that only runs in node but you will\n   * only be using that package in the browser. It can also be used to import\n   * code in node at run time from a package that cannot be bundled. For\n   * example, the fsevents package contains a native extension, which esbuild\n   * doesn't support.\n   *\n   * @default []\n   */\n  readonly externals?: string[];\n\n  /**\n   * Include a source map in the bundle.\n   *\n   * @default true\n   */\n  readonly sourcemap?: boolean;\n\n  /**\n   * esbuild target.\n   *\n   * @default \"esnext\"\n   */\n  readonly target?: string;\n\n  /**\n   * esbuild platform.\n   *\n   * @default \"node\"\n   */\n  readonly platform?: string;\n\n  /**\n   * Bundler output path relative to the asset's output directory.\n   * @default \"index.mjs\"\n   */\n  readonly outfile?: string;\n\n  /**\n   * The path of the tsconfig.json file to use for bundling\n   * @default \"tsconfig.json\"\n   */\n  readonly tsconfigPath?: string;\n\n  /**\n   * Map of file extensions (without dot) and loaders to use for this file type.\n   * Loaders are appended to the esbuild command by `--loader:.extension=loader`\n   */\n  readonly loaders?: { [key: string]: string };\n\n  /**\n   * Output format for the generated JavaScript files. There are currently three possible values that can be configured: `\"iife\"`, `\"cjs\"`, and `\"esm\"`.\n   *\n   * If not set (`undefined`), esbuild picks an output format for you based on `platform`:\n   * - `\"cjs\"` if `platform` is `\"node\"`\n   * - `\"iife\"` if `platform` is `\"browser\"`\n   * - `\"esm\"` if `platform` is `\"neutral\"`\n   *\n   * Note: If making a bundle to run under node with ESM, set `format` to `\"esm\"` instead of setting `platform` to `\"neutral\"`.\n   *\n   * @default undefined\n   *\n   * @see https://esbuild.github.io/api/#format\n   */\n  readonly format?: string;\n\n  /**\n   *\n   *\n   * @default true\n   */\n  readonly minify?: boolean;\n\n  /**\n   *\n   *\n   * @default false\n   */\n  readonly sourcesContent?: boolean;\n\n  /**\n   *\n   *\n   * @default \"module,main\"\n   */\n  readonly mainFields?: string;\n\n  /**\n   *\n   *\n   * @default \":js='import { createRequire as topLevelCreateRequire } from 'module';const require = topLevelCreateRequire(import.meta.url)'\"\n   */\n  readonly banner?: string;\n}\n"]}
169
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundler.js","sourceRoot":"","sources":["../src/bundler.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from \"node:path\";\nimport { Component, DependencyType, type Project, type Task } from \"projen\";\nimport { renderBundleName } from \"./utils\";\n\n/**\n * Options for `Bundler`.\n */\nexport interface BundlerOptions {\n    /**\n     * The semantic version requirement for `esbuild`.\n     *\n     * @default - no specific version (implies latest)\n     */\n    readonly esbuildVersion?: string;\n\n    /**\n     * Output directory for all bundles.\n     * @default \"assets\"\n     */\n    readonly assetsDir?: string;\n\n    /**\n     * Install the `bundle` command as a pre-compile phase.\n     *\n     * @default true\n     */\n    readonly addToPreCompile?: boolean;\n\n    /**\n     * Map of file extensions (without dot) and loaders to use for this file type.\n     * Loaders are appended to the esbuild command by `--loader:.extension=loader`\n     */\n    readonly loaders?: { [key: string]: string };\n}\n\n/**\n * Adds support for bundling JavaScript applications and dependencies into a\n * single file. In the future, this will also supports bundling websites.\n */\nexport class Bundler extends Component {\n    /**\n     * Returns the `Bundler` instance associated with a project or `undefined` if\n     * there is no Bundler.\n     * @param project The project\n     * @returns A bundler\n     */\n    public static of(project: Project): Bundler | undefined {\n        const isBundler = (o: Component): o is Bundler => o instanceof Bundler;\n        return project.components.find(isBundler);\n    }\n\n    /**\n     * The semantic version requirement for `esbuild` (if defined).\n     */\n    public readonly esbuildVersion: string | undefined;\n\n    /**\n     * Root bundle directory.\n     */\n    public readonly bundledir: string;\n\n    private _task: Task | undefined;\n    private readonly addToPreCompile: boolean;\n    private readonly loaders?: { [key: string]: string };\n\n    /**\n     * Creates a `Bundler`.\n     */\n    constructor(project: Project, options: BundlerOptions = {}) {\n        super(project);\n\n        this.esbuildVersion = options.esbuildVersion;\n        this.bundledir = options.assetsDir ?? \"assets\";\n        this.addToPreCompile = options.addToPreCompile ?? true;\n        this.loaders = options.loaders;\n    }\n\n    /**\n     * Gets or creates the singleton \"bundle\" task of the project.\n     *\n     * If the project doesn't have a \"bundle\" task, it will be created and spawned\n     * during the pre-compile phase.\n     */\n    public get bundleTask(): Task {\n        if (!this._task) {\n            this.addBundlingSupport();\n            this._task = this.project.tasks.addTask(\"bundle\", {\n                description: \"Prepare assets\",\n            });\n\n            // install the bundle task into the pre-compile phase.\n            if (this.addToPreCompile) {\n                this.project.preCompileTask.spawn(this._task);\n            }\n        }\n\n        return this._task;\n    }\n\n    /**\n     * Adds a task to the project which bundles a specific entrypoint and all of\n     * its dependencies into a single javascript output file.\n     *\n     * @param entrypoint The relative path of the artifact within the project\n     * @param options Bundling options\n     */\n    public addBundle(entrypoint: string, options: BundlingOptions): Bundle {\n        const name = renderBundleName(entrypoint);\n\n        const outdir = path.posix.join(this.bundledir, name);\n        const outfile = path.posix.join(outdir, options.outfile ?? \"index.mjs\");\n        const target = options.target ?? \"esnext\";\n        const platform = options.platform ?? \"node\";\n        const format = options.format ?? \"esm\";\n        const sourcemap = options.sourcemap ?? true;\n        const sourcesContent = options.sourcesContent ?? false;\n        const minify = options.minify ?? true;\n        const mainFields = options.mainFields ?? \"module,main\";\n        const banner =\n            options.banner ??\n            \":js=import { createRequire as topLevelCreateRequire } from 'module';const require = topLevelCreateRequire(import.meta.url)\";\n\n        const args = [\n            \"esbuild\",\n            \"--bundle\",\n            entrypoint,\n            `--target=\"${target}\"`,\n            `--platform=\"${platform}\"`,\n            `--outfile=\"${outfile}\"`,\n        ];\n\n        const tsconfig = options.tsconfigPath ?? false;\n        if (tsconfig) {\n            args.push(`--tsconfig=\"${tsconfig}\"`);\n        }\n\n        for (const x of options.externals ?? []) {\n            args.push(`--external:${x}`);\n        }\n\n        if (sourcemap) {\n            args.push(\"--sourcemap\");\n        }\n\n        if (sourcesContent) {\n            args.push(`--sources-content=${sourcesContent}`);\n        }\n\n        if (minify) {\n            args.push(\"--minify\");\n        }\n\n        if (format) {\n            args.push(`--format=${format}`);\n        }\n\n        if (mainFields) {\n            args.push(`--main-fields=${mainFields}`);\n        }\n\n        if (banner) {\n            args.push(`--banner${banner}`);\n        }\n\n        const loaders = (options.loaders ?? false) ? options.loaders : (this.loaders ?? false);\n        if (loaders) {\n            for (const [extension, loader] of Object.entries(loaders)) {\n                args.push(`--loader:.${extension}=${loader}`);\n            }\n        }\n\n        console.log({ args: args });\n\n        const bundleTask = this.project.addTask(`bundle:${name}`, {\n            description: `Create a JavaScript bundle from ${entrypoint}`,\n            exec: args.join(\" \"),\n        });\n\n        this.bundleTask.spawn(bundleTask);\n\n        return {\n            bundleTask: bundleTask,\n            outdir: outdir,\n            outfile: outfile,\n        };\n    }\n\n    /**\n     * Add bundling support to a project. This is called implicitly when\n     * `bundleTask` is referenced first. It adds the dependency on `esbuild`,\n     * gitignore/npmignore, etc.\n     */\n    private addBundlingSupport() {\n        const ignoreEntry = `/${this.bundledir}/`;\n        this.project.addGitIgnore(ignoreEntry);\n        this.project.addPackageIgnore(`!${ignoreEntry}`); // include in tarball\n        const dep = this.esbuildVersion ? `esbuild@${this.esbuildVersion}` : \"esbuild\";\n        this.project.deps.addDependency(dep, DependencyType.BUILD);\n    }\n}\n\nexport interface Bundle {\n    /**\n     * The task that produces this bundle.\n     */\n    readonly bundleTask: Task;\n\n    /**\n     * Location of the output file (relative to project root).\n     */\n    readonly outfile: string;\n\n    /**\n     * Base directory containing the output file (relative to project root).\n     */\n    readonly outdir: string;\n}\n\n/**\n * Options for bundling.\n */\nexport interface BundlingOptions {\n    /**\n     * You can mark a file or a package as external to exclude it from your build.\n     * Instead of being bundled, the import will be preserved (using require for\n     * the iife and cjs formats and using import for the esm format) and will be\n     * evaluated at run time instead.\n     *\n     * This has several uses. First of all, it can be used to trim unnecessary\n     * code from your bundle for a code path that you know will never be executed.\n     * For example, a package may contain code that only runs in node but you will\n     * only be using that package in the browser. It can also be used to import\n     * code in node at run time from a package that cannot be bundled. For\n     * example, the fsevents package contains a native extension, which esbuild\n     * doesn't support.\n     *\n     * @default []\n     */\n    readonly externals?: string[];\n\n    /**\n     * Include a source map in the bundle.\n     *\n     * @default true\n     */\n    readonly sourcemap?: boolean;\n\n    /**\n     * esbuild target.\n     *\n     * @default \"esnext\"\n     */\n    readonly target?: string;\n\n    /**\n     * esbuild platform.\n     *\n     * @default \"node\"\n     */\n    readonly platform?: string;\n\n    /**\n     * Bundler output path relative to the asset's output directory.\n     * @default \"index.mjs\"\n     */\n    readonly outfile?: string;\n\n    /**\n     * The path of the tsconfig.json file to use for bundling\n     * @default \"tsconfig.json\"\n     */\n    readonly tsconfigPath?: string;\n\n    /**\n     * Map of file extensions (without dot) and loaders to use for this file type.\n     * Loaders are appended to the esbuild command by `--loader:.extension=loader`\n     */\n    readonly loaders?: { [key: string]: string };\n\n    /**\n     * Output format for the generated JavaScript files. There are currently three possible values that can be configured: `\"iife\"`, `\"cjs\"`, and `\"esm\"`.\n     *\n     * If not set (`undefined`), esbuild picks an output format for you based on `platform`:\n     * - `\"cjs\"` if `platform` is `\"node\"`\n     * - `\"iife\"` if `platform` is `\"browser\"`\n     * - `\"esm\"` if `platform` is `\"neutral\"`\n     *\n     * Note: If making a bundle to run under node with ESM, set `format` to `\"esm\"` instead of setting `platform` to `\"neutral\"`.\n     *\n     * @default undefined\n     *\n     * @see https://esbuild.github.io/api/#format\n     */\n    readonly format?: string;\n\n    /**\n     *\n     *\n     * @default true\n     */\n    readonly minify?: boolean;\n\n    /**\n     *\n     *\n     * @default false\n     */\n    readonly sourcesContent?: boolean;\n\n    /**\n     *\n     *\n     * @default \"module,main\"\n     */\n    readonly mainFields?: string;\n\n    /**\n     *\n     *\n     * @default \":js='import { createRequire as topLevelCreateRequire } from 'module';const require = topLevelCreateRequire(import.meta.url)'\"\n     */\n    readonly banner?: string;\n}\n"]}
package/lib/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
- import { Project, cdk } from "projen";
2
- import { LambdaFunctionCodeBundleOptions } from "./lambda-function-code";
1
+ import { cdk, type Project } from "projen";
2
+ import { type LambdaFunctionCodeBundleOptions } from "./lambda-function-code";
3
3
  /**
4
4
  * Options for `LambdaFunctionCodeBundler`
5
5
  */
package/lib/index.js CHANGED
@@ -22,4 +22,4 @@ class LambdaFunctionCodeBundler extends projen_1.cdk.AutoDiscoverBase {
22
22
  }
23
23
  }
24
24
  exports.LambdaFunctionCodeBundler = LambdaFunctionCodeBundler;
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsbUNBQXNDO0FBQ3RDLGlFQUdnQztBQXdCaEM7O0dBRUc7QUFDSCxNQUFhLHlCQUEwQixTQUFRLFlBQUcsQ0FBQyxnQkFBZ0I7SUFDakUsWUFBWSxPQUFnQixFQUFFLE9BQXlDO1FBQ3JFLEtBQUssQ0FBQyxPQUFPLEVBQUU7WUFDYixVQUFVLEVBQUUsT0FBTyxDQUFDLE1BQU07WUFDMUIsU0FBUyxFQUFFLE9BQU8sQ0FBQyxTQUFTO1NBQzdCLENBQUMsQ0FBQztRQUVILEtBQUssTUFBTSxVQUFVLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQzFDLElBQUksK0NBQXdCLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtnQkFDekMsVUFBVSxFQUFFLFVBQVU7Z0JBQ3RCLFNBQVMsRUFBRSxPQUFPLENBQUMsU0FBUztnQkFDNUIsR0FBRyxPQUFPLENBQUMsYUFBYTthQUN6QixDQUFDLENBQUM7UUFDTCxDQUFDO0lBQ0gsQ0FBQztDQUNGO0FBZkQsOERBZUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQcm9qZWN0LCBjZGsgfSBmcm9tIFwicHJvamVuXCI7XG5pbXBvcnQge1xuICBMYW1iZGFGdW5jdGlvbkNvZGVCdW5kbGUsXG4gIExhbWJkYUZ1bmN0aW9uQ29kZUJ1bmRsZU9wdGlvbnMsXG59IGZyb20gXCIuL2xhbWJkYS1mdW5jdGlvbi1jb2RlXCI7XG5cbi8qKlxuICogT3B0aW9ucyBmb3IgYExhbWJkYUZ1bmN0aW9uQ29kZUJ1bmRsZXJgXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTGFtYmRhRnVuY3Rpb25Db2RlQnVuZGxlck9wdGlvbnMge1xuICAvKipcbiAgICogTG9jYXRlIGZpbGVzIHdpdGggdGhlIGdpdmVuIGV4dGVuc2lvbi5cbiAgICpcbiAgICogQGV4YW1wbGUgXCIubGFtYmRhLnRzXCJcbiAgICovXG4gIHJlYWRvbmx5IGV4dGVuc2lvbjogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBQcm9qZWN0IHNvdXJjZSB0cmVlIChyZWxhdGl2ZSB0byBwcm9qZWN0IG91dHB1dCBkaXJlY3RvcnkpLlxuICAgKi9cbiAgcmVhZG9ubHkgc3JjZGlyOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIE9wdGlvbnMgZm9yIEFXUyBMYW1iZGEgRnVuY3Rpb24gYnVuZGxpbmcuXG4gICAqL1xuICByZWFkb25seSBidW5kbGVPcHRpb25zPzogTGFtYmRhRnVuY3Rpb25Db2RlQnVuZGxlT3B0aW9ucztcbn1cblxuLyoqXG4gKiBDcmVhdGVzIExhbWJkYSBGdW5jdGlvbiBjb2RlIGJ1bmRsZXMgZnJvbSBlbnRyeXBvaW50cyBkaXNjb3ZlcmVkIGluIHRoZSBwcm9qZWN0J3Mgc291cmNlIHRyZWUuXG4gKi9cbmV4cG9ydCBjbGFzcyBMYW1iZGFGdW5jdGlvbkNvZGVCdW5kbGVyIGV4dGVuZHMgY2RrLkF1dG9EaXNjb3ZlckJhc2Uge1xuICBjb25zdHJ1Y3Rvcihwcm9qZWN0OiBQcm9qZWN0LCBvcHRpb25zOiBMYW1iZGFGdW5jdGlvbkNvZGVCdW5kbGVyT3B0aW9ucykge1xuICAgIHN1cGVyKHByb2plY3QsIHtcbiAgICAgIHByb2plY3RkaXI6IG9wdGlvbnMuc3JjZGlyLFxuICAgICAgZXh0ZW5zaW9uOiBvcHRpb25zLmV4dGVuc2lvbixcbiAgICB9KTtcblxuICAgIGZvciAoY29uc3QgZW50cnlwb2ludCBvZiB0aGlzLmVudHJ5cG9pbnRzKSB7XG4gICAgICBuZXcgTGFtYmRhRnVuY3Rpb25Db2RlQnVuZGxlKHRoaXMucHJvamVjdCwge1xuICAgICAgICBlbnRyeXBvaW50OiBlbnRyeXBvaW50LFxuICAgICAgICBleHRlbnNpb246IG9wdGlvbnMuZXh0ZW5zaW9uLFxuICAgICAgICAuLi5vcHRpb25zLmJ1bmRsZU9wdGlvbnMsXG4gICAgICB9KTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsbUNBQTJDO0FBQzNDLGlFQUF3RztBQXdCeEc7O0dBRUc7QUFDSCxNQUFhLHlCQUEwQixTQUFRLFlBQUcsQ0FBQyxnQkFBZ0I7SUFDL0QsWUFBWSxPQUFnQixFQUFFLE9BQXlDO1FBQ25FLEtBQUssQ0FBQyxPQUFPLEVBQUU7WUFDWCxVQUFVLEVBQUUsT0FBTyxDQUFDLE1BQU07WUFDMUIsU0FBUyxFQUFFLE9BQU8sQ0FBQyxTQUFTO1NBQy9CLENBQUMsQ0FBQztRQUVILEtBQUssTUFBTSxVQUFVLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ3hDLElBQUksK0NBQXdCLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtnQkFDdkMsVUFBVSxFQUFFLFVBQVU7Z0JBQ3RCLFNBQVMsRUFBRSxPQUFPLENBQUMsU0FBUztnQkFDNUIsR0FBRyxPQUFPLENBQUMsYUFBYTthQUMzQixDQUFDLENBQUM7UUFDUCxDQUFDO0lBQ0wsQ0FBQztDQUNKO0FBZkQsOERBZUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjZGssIHR5cGUgUHJvamVjdCB9IGZyb20gXCJwcm9qZW5cIjtcbmltcG9ydCB7IExhbWJkYUZ1bmN0aW9uQ29kZUJ1bmRsZSwgdHlwZSBMYW1iZGFGdW5jdGlvbkNvZGVCdW5kbGVPcHRpb25zIH0gZnJvbSBcIi4vbGFtYmRhLWZ1bmN0aW9uLWNvZGVcIjtcblxuLyoqXG4gKiBPcHRpb25zIGZvciBgTGFtYmRhRnVuY3Rpb25Db2RlQnVuZGxlcmBcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBMYW1iZGFGdW5jdGlvbkNvZGVCdW5kbGVyT3B0aW9ucyB7XG4gICAgLyoqXG4gICAgICogTG9jYXRlIGZpbGVzIHdpdGggdGhlIGdpdmVuIGV4dGVuc2lvbi5cbiAgICAgKlxuICAgICAqIEBleGFtcGxlIFwiLmxhbWJkYS50c1wiXG4gICAgICovXG4gICAgcmVhZG9ubHkgZXh0ZW5zaW9uOiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBQcm9qZWN0IHNvdXJjZSB0cmVlIChyZWxhdGl2ZSB0byBwcm9qZWN0IG91dHB1dCBkaXJlY3RvcnkpLlxuICAgICAqL1xuICAgIHJlYWRvbmx5IHNyY2Rpcjogc3RyaW5nO1xuXG4gICAgLyoqXG4gICAgICogT3B0aW9ucyBmb3IgQVdTIExhbWJkYSBGdW5jdGlvbiBidW5kbGluZy5cbiAgICAgKi9cbiAgICByZWFkb25seSBidW5kbGVPcHRpb25zPzogTGFtYmRhRnVuY3Rpb25Db2RlQnVuZGxlT3B0aW9ucztcbn1cblxuLyoqXG4gKiBDcmVhdGVzIExhbWJkYSBGdW5jdGlvbiBjb2RlIGJ1bmRsZXMgZnJvbSBlbnRyeXBvaW50cyBkaXNjb3ZlcmVkIGluIHRoZSBwcm9qZWN0J3Mgc291cmNlIHRyZWUuXG4gKi9cbmV4cG9ydCBjbGFzcyBMYW1iZGFGdW5jdGlvbkNvZGVCdW5kbGVyIGV4dGVuZHMgY2RrLkF1dG9EaXNjb3ZlckJhc2Uge1xuICAgIGNvbnN0cnVjdG9yKHByb2plY3Q6IFByb2plY3QsIG9wdGlvbnM6IExhbWJkYUZ1bmN0aW9uQ29kZUJ1bmRsZXJPcHRpb25zKSB7XG4gICAgICAgIHN1cGVyKHByb2plY3QsIHtcbiAgICAgICAgICAgIHByb2plY3RkaXI6IG9wdGlvbnMuc3JjZGlyLFxuICAgICAgICAgICAgZXh0ZW5zaW9uOiBvcHRpb25zLmV4dGVuc2lvbixcbiAgICAgICAgfSk7XG5cbiAgICAgICAgZm9yIChjb25zdCBlbnRyeXBvaW50IG9mIHRoaXMuZW50cnlwb2ludHMpIHtcbiAgICAgICAgICAgIG5ldyBMYW1iZGFGdW5jdGlvbkNvZGVCdW5kbGUodGhpcy5wcm9qZWN0LCB7XG4gICAgICAgICAgICAgICAgZW50cnlwb2ludDogZW50cnlwb2ludCxcbiAgICAgICAgICAgICAgICBleHRlbnNpb246IG9wdGlvbnMuZXh0ZW5zaW9uLFxuICAgICAgICAgICAgICAgIC4uLm9wdGlvbnMuYnVuZGxlT3B0aW9ucyxcbiAgICAgICAgICAgIH0pO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
@@ -1,5 +1,5 @@
1
- import { Component, Project } from "projen";
2
- import { BundlingOptions } from "./bundler";
1
+ import { Component, type Project } from "projen";
2
+ import { type BundlingOptions } from "./bundler";
3
3
  /**
4
4
  * Options for `LambdaFunctionCodeBundle`.
5
5
  */
@@ -15,16 +15,26 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
15
15
  }) : function(o, v) {
16
16
  o["default"] = v;
17
17
  });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
25
35
  Object.defineProperty(exports, "__esModule", { value: true });
26
36
  exports.LambdaFunctionCodeBundle = void 0;
27
- const path = __importStar(require("path"));
37
+ const path = __importStar(require("node:path"));
28
38
  const case_1 = require("case");
29
39
  const projen_1 = require("projen");
30
40
  const bundler_1 = require("./bundler");
@@ -57,7 +67,6 @@ class LambdaFunctionCodeBundle extends projen_1.Component {
57
67
  * @param options Options
58
68
  */
59
69
  constructor(project, options) {
60
- var _a, _b, _c, _d;
61
70
  super(project);
62
71
  const bundler = bundler_1.Bundler.of(project);
63
72
  if (!bundler) {
@@ -66,22 +75,22 @@ class LambdaFunctionCodeBundle extends projen_1.Component {
66
75
  // allow Lambda handler code to import dev-deps since they are only needed
67
76
  // during bundling
68
77
  const eslint = projen_1.javascript.Eslint.of(project);
69
- eslint === null || eslint === void 0 ? void 0 : eslint.allowDevDeps(options.entrypoint);
78
+ eslint?.allowDevDeps(options.entrypoint);
70
79
  const entrypoint = options.entrypoint;
71
- const extension = (_a = options.extension) !== null && _a !== void 0 ? _a : ".lambda.ts";
80
+ const extension = options.extension ?? ".lambda.ts";
72
81
  if (!entrypoint.endsWith(extension)) {
73
82
  throw new Error(`${entrypoint} must have a ${extension} extension`);
74
83
  }
75
84
  const basePath = path.posix.join(path.dirname(entrypoint), path.basename(entrypoint, extension));
76
- const constructFile = (_b = options.constructFile) !== null && _b !== void 0 ? _b : `${basePath}-code.ts`;
85
+ const constructFile = options.constructFile ?? `${basePath}-code.ts`;
77
86
  if (path.extname(constructFile) !== ".ts") {
78
87
  throw new Error(`Construct file name "${constructFile}" must have a .ts extension`);
79
88
  }
80
89
  // type names
81
- const constructName = (_c = options.constructName) !== null && _c !== void 0 ? _c : (0, case_1.pascal)(path.basename(basePath)) + "FunctionCode";
90
+ const constructName = options.constructName ?? `${(0, case_1.pascal)(path.basename(basePath))}FunctionCode`;
82
91
  const bundle = bundler.addBundle(entrypoint, {
83
92
  ...options.bundlingOptions,
84
- tsconfigPath: (_d = project === null || project === void 0 ? void 0 : project.tsconfigDev) === null || _d === void 0 ? void 0 : _d.fileName,
93
+ tsconfigPath: project?.tsconfigDev?.fileName,
85
94
  });
86
95
  // calculate the relative path between the directory containing the
87
96
  // generated construct source file to the directory containing the bundle
@@ -107,4 +116,4 @@ class LambdaFunctionCodeBundle extends projen_1.Component {
107
116
  }
108
117
  }
109
118
  exports.LambdaFunctionCodeBundle = LambdaFunctionCodeBundle;
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda-function-code.js","sourceRoot":"","sources":["../src/lambda-function-code.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from \"path\";\nimport { pascal } from \"case\";\nimport { Component, Project, SourceCode, javascript, typescript } from \"projen\";\nimport { Bundler, BundlingOptions } from \"./bundler\";\nimport { convertToPosixPath } from \"./utils\";\n\n/**\n * Options for `LambdaFunctionCodeBundle`.\n */\nexport interface LambdaFunctionCodeBundleOptions {\n  /**\n   * A path from the project root directory to a TypeScript file which contains\n   * the AWS Lambda handler entrypoint (exports a `handler` function).\n   *\n   * This is relative to the root directory of the project.\n   *\n   * @example \"src/subdir/foo.lambda.ts\"\n   */\n  readonly entrypoint: string;\n\n  /**\n   * Suffix for AWS Lambda handlers.\n   *\n   * @example \".lambda.ts\"\n   */\n  readonly extension: string;\n\n  /**\n   * The name of the generated TypeScript source file. This file should also be\n   * under the source tree.\n   *\n   * @default - The name of the entrypoint file, with the `-function.ts` suffix\n   * instead of `.lambda.ts`.\n   */\n  readonly constructFile?: string;\n\n  /**\n   * The name of the generated `lambda.Function` subclass.\n   *\n   * @default - A pascal cased version of the name of the entrypoint file, with\n   * the extension `Function` (e.g. `ResizeImageFunction`).\n   */\n  readonly constructName?: string;\n\n  /**\n   * Bundling options for this AWS Lambda Function.\n   *\n   * If not specified the default bundling options specified for the project\n   * `Bundler` instance will be used.\n   *\n   * @default - defaults\n   */\n  readonly bundlingOptions?: BundlingOptions;\n}\n\n/**\n * Generates a pre-bundled AWS Lambda Function code bundle construct from handler code.\n *\n * To use this, create an AWS Lambda handler file under your source tree with\n * the `.lambda.ts` extension and add a `LambdaFunctionCodeBundle` component to your\n * typescript project pointing to this entrypoint.\n *\n * This will add a task to your \"compile\" step which will use `esbuild` to\n * bundle the handler code into the build directory. It will also generate a\n * file `src/foo-function.ts` with a custom AWS construct called `FooFunction`\n * which extends `@aws-cdk/aws-lambda.Function` which is bound to the bundled\n * handle through an asset.\n *\n * @example\n *\n * new LambdaFunctionCodeBundle(myProject, {\n *   srcdir: myProject.srcdir,\n *   entrypoint: 'src/foo.lambda.ts',\n * });\n */\nexport class LambdaFunctionCodeBundle extends Component {\n  /**\n   * Defines a pre-bundled AWS Lambda Function construct from handler code.\n   *\n   * @param project The project to use\n   * @param options Options\n   */\n  constructor(project: Project, options: LambdaFunctionCodeBundleOptions) {\n    super(project);\n\n    const bundler = Bundler.of(project);\n    if (!bundler) {\n      throw new Error(\n        \"No bundler found. Please add a Bundler component to your project.\",\n      );\n    }\n\n    // allow Lambda handler code to import dev-deps since they are only needed\n    // during bundling\n    const eslint = javascript.Eslint.of(project);\n    eslint?.allowDevDeps(options.entrypoint);\n\n    const entrypoint = options.entrypoint;\n\n    const extension = options.extension ?? \".lambda.ts\";\n\n    if (!entrypoint.endsWith(extension)) {\n      throw new Error(`${entrypoint} must have a ${extension} extension`);\n    }\n\n    const basePath = path.posix.join(\n      path.dirname(entrypoint),\n      path.basename(entrypoint, extension),\n    );\n    const constructFile = options.constructFile ?? `${basePath}-code.ts`;\n\n    if (path.extname(constructFile) !== \".ts\") {\n      throw new Error(\n        `Construct file name \"${constructFile}\" must have a .ts extension`,\n      );\n    }\n\n    // type names\n    const constructName =\n      options.constructName ?? pascal(path.basename(basePath)) + \"FunctionCode\";\n\n    const bundle = bundler.addBundle(entrypoint, {\n      ...options.bundlingOptions,\n      tsconfigPath: (project as typescript.TypeScriptProject)?.tsconfigDev\n        ?.fileName,\n    });\n\n    // calculate the relative path between the directory containing the\n    // generated construct source file to the directory containing the bundle\n    // index.js by resolving them as absolute paths first.\n    // e.g:\n    //  - outfileAbs => `/project-outdir/assets/foo/bar/baz/foo-function/index.js`\n    //  - constructAbs => `/project-outdir/src/foo/bar/baz/foo-function.ts`\n    const outfileAbs = path.join(project.outdir, bundle.outfile);\n    const constructAbs = path.join(project.outdir, constructFile);\n    const relativeOutfile = path.relative(\n      path.dirname(constructAbs),\n      path.dirname(outfileAbs),\n    );\n\n    const src = new SourceCode(project, constructFile);\n    if (src.marker) {\n      src.line(`// ${src.marker}`);\n    }\n    src.line(\"import * as path from 'path';\");\n    src.line(\"import { aws_lambda } from 'aws-cdk-lib';\");\n    src.line();\n    src.open(`export const ${constructName} = aws_lambda.Code.fromAsset(`);\n    src.line(`path.join(__dirname, '${convertToPosixPath(relativeOutfile)}'),`);\n    src.close(\");\");\n\n    this.project.logger.verbose(\n      `${basePath}: construct \"${constructName}\" generated under \"${constructFile}\"`,\n    );\n    this.project.logger.verbose(\n      `${basePath}: bundle task \"${bundle.bundleTask.name}\"`,\n    );\n  }\n}\n"]}
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda-function-code.js","sourceRoot":"","sources":["../src/lambda-function-code.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from \"node:path\";\nimport { pascal } from \"case\";\nimport { Component, javascript, type Project, SourceCode, type typescript } from \"projen\";\nimport { Bundler, type BundlingOptions } from \"./bundler\";\nimport { convertToPosixPath } from \"./utils\";\n\n/**\n * Options for `LambdaFunctionCodeBundle`.\n */\nexport interface LambdaFunctionCodeBundleOptions {\n    /**\n     * A path from the project root directory to a TypeScript file which contains\n     * the AWS Lambda handler entrypoint (exports a `handler` function).\n     *\n     * This is relative to the root directory of the project.\n     *\n     * @example \"src/subdir/foo.lambda.ts\"\n     */\n    readonly entrypoint: string;\n\n    /**\n     * Suffix for AWS Lambda handlers.\n     *\n     * @example \".lambda.ts\"\n     */\n    readonly extension: string;\n\n    /**\n     * The name of the generated TypeScript source file. This file should also be\n     * under the source tree.\n     *\n     * @default - The name of the entrypoint file, with the `-function.ts` suffix\n     * instead of `.lambda.ts`.\n     */\n    readonly constructFile?: string;\n\n    /**\n     * The name of the generated `lambda.Function` subclass.\n     *\n     * @default - A pascal cased version of the name of the entrypoint file, with\n     * the extension `Function` (e.g. `ResizeImageFunction`).\n     */\n    readonly constructName?: string;\n\n    /**\n     * Bundling options for this AWS Lambda Function.\n     *\n     * If not specified the default bundling options specified for the project\n     * `Bundler` instance will be used.\n     *\n     * @default - defaults\n     */\n    readonly bundlingOptions?: BundlingOptions;\n}\n\n/**\n * Generates a pre-bundled AWS Lambda Function code bundle construct from handler code.\n *\n * To use this, create an AWS Lambda handler file under your source tree with\n * the `.lambda.ts` extension and add a `LambdaFunctionCodeBundle` component to your\n * typescript project pointing to this entrypoint.\n *\n * This will add a task to your \"compile\" step which will use `esbuild` to\n * bundle the handler code into the build directory. It will also generate a\n * file `src/foo-function.ts` with a custom AWS construct called `FooFunction`\n * which extends `@aws-cdk/aws-lambda.Function` which is bound to the bundled\n * handle through an asset.\n *\n * @example\n *\n * new LambdaFunctionCodeBundle(myProject, {\n *   srcdir: myProject.srcdir,\n *   entrypoint: 'src/foo.lambda.ts',\n * });\n */\nexport class LambdaFunctionCodeBundle extends Component {\n    /**\n     * Defines a pre-bundled AWS Lambda Function construct from handler code.\n     *\n     * @param project The project to use\n     * @param options Options\n     */\n    constructor(project: Project, options: LambdaFunctionCodeBundleOptions) {\n        super(project);\n\n        const bundler = Bundler.of(project);\n        if (!bundler) {\n            throw new Error(\"No bundler found. Please add a Bundler component to your project.\");\n        }\n\n        // allow Lambda handler code to import dev-deps since they are only needed\n        // during bundling\n        const eslint = javascript.Eslint.of(project);\n        eslint?.allowDevDeps(options.entrypoint);\n\n        const entrypoint = options.entrypoint;\n\n        const extension = options.extension ?? \".lambda.ts\";\n\n        if (!entrypoint.endsWith(extension)) {\n            throw new Error(`${entrypoint} must have a ${extension} extension`);\n        }\n\n        const basePath = path.posix.join(path.dirname(entrypoint), path.basename(entrypoint, extension));\n        const constructFile = options.constructFile ?? `${basePath}-code.ts`;\n\n        if (path.extname(constructFile) !== \".ts\") {\n            throw new Error(`Construct file name \"${constructFile}\" must have a .ts extension`);\n        }\n\n        // type names\n        const constructName = options.constructName ?? `${pascal(path.basename(basePath))}FunctionCode`;\n\n        const bundle = bundler.addBundle(entrypoint, {\n            ...options.bundlingOptions,\n            tsconfigPath: (project as typescript.TypeScriptProject)?.tsconfigDev?.fileName,\n        });\n\n        // calculate the relative path between the directory containing the\n        // generated construct source file to the directory containing the bundle\n        // index.js by resolving them as absolute paths first.\n        // e.g:\n        //  - outfileAbs => `/project-outdir/assets/foo/bar/baz/foo-function/index.js`\n        //  - constructAbs => `/project-outdir/src/foo/bar/baz/foo-function.ts`\n        const outfileAbs = path.join(project.outdir, bundle.outfile);\n        const constructAbs = path.join(project.outdir, constructFile);\n        const relativeOutfile = path.relative(path.dirname(constructAbs), path.dirname(outfileAbs));\n\n        const src = new SourceCode(project, constructFile);\n        if (src.marker) {\n            src.line(`// ${src.marker}`);\n        }\n        src.line(\"import * as path from 'path';\");\n        src.line(\"import { aws_lambda } from 'aws-cdk-lib';\");\n        src.line();\n        src.open(`export const ${constructName} = aws_lambda.Code.fromAsset(`);\n        src.line(`path.join(__dirname, '${convertToPosixPath(relativeOutfile)}'),`);\n        src.close(\");\");\n\n        this.project.logger.verbose(`${basePath}: construct \"${constructName}\" generated under \"${constructFile}\"`);\n        this.project.logger.verbose(`${basePath}: bundle task \"${bundle.bundleTask.name}\"`);\n    }\n}\n"]}
package/lib/utils.js CHANGED
@@ -1,23 +1,22 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.convertToPosixPath = exports.renderBundleName = void 0;
4
- const path_1 = require("path");
3
+ exports.renderBundleName = renderBundleName;
4
+ exports.convertToPosixPath = convertToPosixPath;
5
+ const node_path_1 = require("node:path");
5
6
  function renderBundleName(entrypoint) {
6
- const parts = (0, path_1.join)(entrypoint).split(path_1.sep);
7
+ const parts = (0, node_path_1.join)(entrypoint).split(node_path_1.sep);
7
8
  if (parts[0] === "src") {
8
9
  parts.shift(); // just remove 'src' if its the first element for ergonomics
9
10
  }
10
- const p = parts.join(path_1.sep);
11
- const dir = (0, path_1.dirname)(p);
12
- const base = (0, path_1.basename)(p, (0, path_1.extname)(p));
13
- return (0, path_1.join)(dir, base);
11
+ const p = parts.join(node_path_1.sep);
12
+ const dir = (0, node_path_1.dirname)(p);
13
+ const base = (0, node_path_1.basename)(p, (0, node_path_1.extname)(p));
14
+ return (0, node_path_1.join)(dir, base);
14
15
  }
15
- exports.renderBundleName = renderBundleName;
16
16
  /**
17
17
  * Converts the given path string to posix if it wasn't already.
18
18
  */
19
19
  function convertToPosixPath(p) {
20
- return p.split(path_1.sep).join(path_1.posix.sep);
20
+ return p.split(node_path_1.sep).join(node_path_1.posix.sep);
21
21
  }
22
- exports.convertToPosixPath = convertToPosixPath;
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsK0JBQW9FO0FBRXBFLFNBQWdCLGdCQUFnQixDQUFDLFVBQWtCO0lBQ2pELE1BQU0sS0FBSyxHQUFHLElBQUEsV0FBSSxFQUFDLFVBQVUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxVQUFHLENBQUMsQ0FBQztJQUMxQyxJQUFJLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxLQUFLLEVBQUUsQ0FBQztRQUN2QixLQUFLLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyw0REFBNEQ7SUFDN0UsQ0FBQztJQUVELE1BQU0sQ0FBQyxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsVUFBRyxDQUFDLENBQUM7SUFDMUIsTUFBTSxHQUFHLEdBQUcsSUFBQSxjQUFPLEVBQUMsQ0FBQyxDQUFDLENBQUM7SUFDdkIsTUFBTSxJQUFJLEdBQUcsSUFBQSxlQUFRLEVBQUMsQ0FBQyxFQUFFLElBQUEsY0FBTyxFQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDckMsT0FBTyxJQUFBLFdBQUksRUFBQyxHQUFHLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDekIsQ0FBQztBQVZELDRDQVVDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixrQkFBa0IsQ0FBQyxDQUFTO0lBQzFDLE9BQU8sQ0FBQyxDQUFDLEtBQUssQ0FBQyxVQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsWUFBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0FBQ3RDLENBQUM7QUFGRCxnREFFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGJhc2VuYW1lLCBkaXJuYW1lLCBleHRuYW1lLCBqb2luLCBwb3NpeCwgc2VwIH0gZnJvbSBcInBhdGhcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIHJlbmRlckJ1bmRsZU5hbWUoZW50cnlwb2ludDogc3RyaW5nKSB7XG4gIGNvbnN0IHBhcnRzID0gam9pbihlbnRyeXBvaW50KS5zcGxpdChzZXApO1xuICBpZiAocGFydHNbMF0gPT09IFwic3JjXCIpIHtcbiAgICBwYXJ0cy5zaGlmdCgpOyAvLyBqdXN0IHJlbW92ZSAnc3JjJyBpZiBpdHMgdGhlIGZpcnN0IGVsZW1lbnQgZm9yIGVyZ29ub21pY3NcbiAgfVxuXG4gIGNvbnN0IHAgPSBwYXJ0cy5qb2luKHNlcCk7XG4gIGNvbnN0IGRpciA9IGRpcm5hbWUocCk7XG4gIGNvbnN0IGJhc2UgPSBiYXNlbmFtZShwLCBleHRuYW1lKHApKTtcbiAgcmV0dXJuIGpvaW4oZGlyLCBiYXNlKTtcbn1cblxuLyoqXG4gKiBDb252ZXJ0cyB0aGUgZ2l2ZW4gcGF0aCBzdHJpbmcgdG8gcG9zaXggaWYgaXQgd2Fzbid0IGFscmVhZHkuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjb252ZXJ0VG9Qb3NpeFBhdGgocDogc3RyaW5nKSB7XG4gIHJldHVybiBwLnNwbGl0KHNlcCkuam9pbihwb3NpeC5zZXApO1xufVxuIl19
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQSw0Q0FVQztBQUtELGdEQUVDO0FBbkJELHlDQUF5RTtBQUV6RSxTQUFnQixnQkFBZ0IsQ0FBQyxVQUFrQjtJQUMvQyxNQUFNLEtBQUssR0FBRyxJQUFBLGdCQUFJLEVBQUMsVUFBVSxDQUFDLENBQUMsS0FBSyxDQUFDLGVBQUcsQ0FBQyxDQUFDO0lBQzFDLElBQUksS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLEtBQUssRUFBRSxDQUFDO1FBQ3JCLEtBQUssQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLDREQUE0RDtJQUMvRSxDQUFDO0lBRUQsTUFBTSxDQUFDLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxlQUFHLENBQUMsQ0FBQztJQUMxQixNQUFNLEdBQUcsR0FBRyxJQUFBLG1CQUFPLEVBQUMsQ0FBQyxDQUFDLENBQUM7SUFDdkIsTUFBTSxJQUFJLEdBQUcsSUFBQSxvQkFBUSxFQUFDLENBQUMsRUFBRSxJQUFBLG1CQUFPLEVBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNyQyxPQUFPLElBQUEsZ0JBQUksRUFBQyxHQUFHLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDM0IsQ0FBQztBQUVEOztHQUVHO0FBQ0gsU0FBZ0Isa0JBQWtCLENBQUMsQ0FBUztJQUN4QyxPQUFPLENBQUMsQ0FBQyxLQUFLLENBQUMsZUFBRyxDQUFDLENBQUMsSUFBSSxDQUFDLGlCQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7QUFDeEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGJhc2VuYW1lLCBkaXJuYW1lLCBleHRuYW1lLCBqb2luLCBwb3NpeCwgc2VwIH0gZnJvbSBcIm5vZGU6cGF0aFwiO1xuXG5leHBvcnQgZnVuY3Rpb24gcmVuZGVyQnVuZGxlTmFtZShlbnRyeXBvaW50OiBzdHJpbmcpIHtcbiAgICBjb25zdCBwYXJ0cyA9IGpvaW4oZW50cnlwb2ludCkuc3BsaXQoc2VwKTtcbiAgICBpZiAocGFydHNbMF0gPT09IFwic3JjXCIpIHtcbiAgICAgICAgcGFydHMuc2hpZnQoKTsgLy8ganVzdCByZW1vdmUgJ3NyYycgaWYgaXRzIHRoZSBmaXJzdCBlbGVtZW50IGZvciBlcmdvbm9taWNzXG4gICAgfVxuXG4gICAgY29uc3QgcCA9IHBhcnRzLmpvaW4oc2VwKTtcbiAgICBjb25zdCBkaXIgPSBkaXJuYW1lKHApO1xuICAgIGNvbnN0IGJhc2UgPSBiYXNlbmFtZShwLCBleHRuYW1lKHApKTtcbiAgICByZXR1cm4gam9pbihkaXIsIGJhc2UpO1xufVxuXG4vKipcbiAqIENvbnZlcnRzIHRoZSBnaXZlbiBwYXRoIHN0cmluZyB0byBwb3NpeCBpZiBpdCB3YXNuJ3QgYWxyZWFkeS5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNvbnZlcnRUb1Bvc2l4UGF0aChwOiBzdHJpbmcpIHtcbiAgICByZXR1cm4gcC5zcGxpdChzZXApLmpvaW4ocG9zaXguc2VwKTtcbn1cbiJdfQ==
package/package.json CHANGED
@@ -1,13 +1,38 @@
1
1
  {
2
2
  "name": "@nikovirtala/projen-bundle-lambda-function-code",
3
+ "repository": {
4
+ "type": "git",
5
+ "url": "https://github.com/nikovirtala/projen-bundle-lambda-function-code.git"
6
+ },
7
+ "devDependencies": {
8
+ "@biomejs/biome": "^2",
9
+ "@types/node": "^18.19.130",
10
+ "commit-and-tag-version": "^12",
11
+ "constructs": "^10.0.0",
12
+ "projen": "^0.98.10",
13
+ "ts-node": "^10.9.2",
14
+ "typescript": "^5.9.3"
15
+ },
16
+ "dependencies": {
17
+ "case": "^1.6.3",
18
+ "projen": "^0.98.10"
19
+ },
20
+ "main": "lib/index.js",
21
+ "license": "MIT",
22
+ "publishConfig": {
23
+ "access": "public"
24
+ },
25
+ "version": "0.0.17",
26
+ "types": "lib/index.d.ts",
27
+ "//": "~~ Generated by projen. To modify, edit .projenrc.ts and run \"npx projen\".",
3
28
  "scripts": {
29
+ "biome": "npx projen biome",
4
30
  "build": "npx projen build",
5
31
  "bump": "npx projen bump",
6
32
  "clobber": "npx projen clobber",
7
33
  "compile": "npx projen compile",
8
34
  "default": "npx projen default",
9
35
  "eject": "npx projen eject",
10
- "eslint": "npx projen eslint",
11
36
  "package": "npx projen package",
12
37
  "post-compile": "npx projen post-compile",
13
38
  "post-upgrade": "npx projen post-upgrade",
@@ -18,34 +43,5 @@
18
43
  "upgrade": "npx projen upgrade",
19
44
  "watch": "npx projen watch",
20
45
  "projen": "npx projen"
21
- },
22
- "devDependencies": {
23
- "@types/node": "^18",
24
- "@typescript-eslint/eslint-plugin": "^6",
25
- "@typescript-eslint/parser": "^6",
26
- "constructs": "^10.0.0",
27
- "eslint": "^8",
28
- "eslint-config-prettier": "^9.0.0",
29
- "eslint-import-resolver-typescript": "^3.6.1",
30
- "eslint-plugin-import": "^2.29.0",
31
- "eslint-plugin-prettier": "^5.0.1",
32
- "npm-check-updates": "^16",
33
- "prettier": "^3.1.0",
34
- "projen": "^0.77.1",
35
- "standard-version": "^9",
36
- "ts-node": "^10.9.1",
37
- "typescript": "^5.3.2"
38
- },
39
- "dependencies": {
40
- "case": "^1.6.3",
41
- "projen": "^0.77.1"
42
- },
43
- "main": "lib/index.js",
44
- "license": "MIT",
45
- "publishConfig": {
46
- "access": "public"
47
- },
48
- "version": "0.0.15",
49
- "types": "lib/index.d.ts",
50
- "//": "~~ Generated by projen. To modify, edit .projenrc.ts and run \"npx projen\"."
51
- }
46
+ }
47
+ }
package/.gitattributes DELETED
@@ -1,23 +0,0 @@
1
- # ~~ Generated by projen. To modify, edit .projenrc.ts and run "npx projen".
2
-
3
- /.eslintrc.json linguist-generated
4
- /.gitattributes linguist-generated
5
- /.github/pull_request_template.md linguist-generated
6
- /.github/workflows/build.yml linguist-generated
7
- /.github/workflows/pull-request-lint.yml linguist-generated
8
- /.github/workflows/release.yml linguist-generated
9
- /.github/workflows/upgrade-main.yml linguist-generated
10
- /.gitignore linguist-generated
11
- /.mergify.yml linguist-generated
12
- /.npmignore linguist-generated
13
- /.prettierignore linguist-generated
14
- /.prettierrc.json linguist-generated
15
- /.projen/** linguist-generated
16
- /.projen/deps.json linguist-generated
17
- /.projen/files.json linguist-generated
18
- /.projen/tasks.json linguist-generated
19
- /LICENSE linguist-generated
20
- /package.json linguist-generated
21
- /tsconfig.dev.json linguist-generated
22
- /tsconfig.json linguist-generated
23
- /yarn.lock linguist-generated
package/.prettierignore DELETED
@@ -1 +0,0 @@
1
- # ~~ Generated by projen. To modify, edit .projenrc.ts and run "npx projen".
package/.prettierrc.json DELETED
@@ -1,3 +0,0 @@
1
- {
2
- "overrides": []
3
- }
package/.projenrc.ts DELETED
@@ -1,14 +0,0 @@
1
- import { typescript, javascript } from "projen";
2
- const project = new typescript.TypeScriptProject({
3
- copyrightOwner: "Niko Virtala",
4
- defaultReleaseBranch: "main",
5
- deps: ["case", "projen"],
6
- jest: false,
7
- license: "MIT",
8
- name: "@nikovirtala/projen-bundle-lambda-function-code",
9
- npmAccess: javascript.NpmAccess.PUBLIC,
10
- prettier: true,
11
- projenrcTs: true,
12
- releaseToNpm: true,
13
- });
14
- project.synth();
@@ -1,3 +0,0 @@
1
- <?xml version="1.0" encoding="UTF-8"?>
2
- <testsuites name="jest tests" tests="0" failures="0" errors="0" time="0.001">
3
- </testsuites>