wrangler 2.19.0 → 3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (297) hide show
  1. package/README.md +4 -4
  2. package/bin/wrangler.js +9 -75
  3. package/package.json +5 -13
  4. package/templates/__tests__/tsconfig.tsbuildinfo +1 -1
  5. package/templates/checked-fetch.js +1 -1
  6. package/templates/first-party-worker-module-facade.ts +2 -2
  7. package/templates/middleware/common.ts +9 -4
  8. package/templates/middleware/loader-sw.ts +2 -7
  9. package/templates/new-worker-scheduled.ts +1 -1
  10. package/templates/new-worker.ts +1 -1
  11. package/templates/pages-dev-util.ts +4 -1
  12. package/templates/pages-shim.ts +0 -3
  13. package/templates/tsconfig.tsbuildinfo +1 -1
  14. package/wrangler-dist/cli.d.ts +160 -75
  15. package/wrangler-dist/cli.js +61843 -65907
  16. package/import_meta_url.js +0 -3
  17. package/miniflare-config-stubs/.env.empty +0 -0
  18. package/miniflare-config-stubs/package.empty.json +0 -1
  19. package/miniflare-config-stubs/wrangler.empty.toml +0 -0
  20. package/miniflare-dist/index.mjs +0 -6442
  21. package/src/__tests__/access.test.ts +0 -25
  22. package/src/__tests__/api-dev.test.ts +0 -238
  23. package/src/__tests__/api-devregistry.test.ts +0 -121
  24. package/src/__tests__/api.test.ts +0 -102
  25. package/src/__tests__/config-cache-without-cache-dir.test.ts +0 -38
  26. package/src/__tests__/config-cache.test.ts +0 -42
  27. package/src/__tests__/configuration.test.ts +0 -4509
  28. package/src/__tests__/constellation.test.ts +0 -371
  29. package/src/__tests__/d1/d1.test.ts +0 -82
  30. package/src/__tests__/d1/execute.test.ts +0 -66
  31. package/src/__tests__/d1/migrate.test.ts +0 -257
  32. package/src/__tests__/d1/splitter.test.ts +0 -255
  33. package/src/__tests__/delete.test.ts +0 -272
  34. package/src/__tests__/deployments.test.ts +0 -369
  35. package/src/__tests__/dev.test.tsx +0 -1617
  36. package/src/__tests__/generate.test.ts +0 -237
  37. package/src/__tests__/get-host-from-url.test.ts +0 -16
  38. package/src/__tests__/guess-worker-format.test.ts +0 -120
  39. package/src/__tests__/helpers/clipboardy-mock.js +0 -4
  40. package/src/__tests__/helpers/cmd-shim.d.ts +0 -11
  41. package/src/__tests__/helpers/end-event-loop.ts +0 -6
  42. package/src/__tests__/helpers/mock-account-id.ts +0 -48
  43. package/src/__tests__/helpers/mock-auth-domain.ts +0 -20
  44. package/src/__tests__/helpers/mock-bin.ts +0 -36
  45. package/src/__tests__/helpers/mock-console.ts +0 -112
  46. package/src/__tests__/helpers/mock-dialogs.ts +0 -139
  47. package/src/__tests__/helpers/mock-get-pages-upload-token.ts +0 -25
  48. package/src/__tests__/helpers/mock-get-zone-from-host.ts +0 -11
  49. package/src/__tests__/helpers/mock-http-server.ts +0 -46
  50. package/src/__tests__/helpers/mock-istty.ts +0 -74
  51. package/src/__tests__/helpers/mock-known-routes.ts +0 -12
  52. package/src/__tests__/helpers/mock-kv.ts +0 -46
  53. package/src/__tests__/helpers/mock-oauth-flow.ts +0 -263
  54. package/src/__tests__/helpers/mock-process.ts +0 -34
  55. package/src/__tests__/helpers/mock-set-timeout.ts +0 -16
  56. package/src/__tests__/helpers/mock-stdin.ts +0 -108
  57. package/src/__tests__/helpers/mock-web-socket.ts +0 -29
  58. package/src/__tests__/helpers/msw/blob-worker.cjs +0 -19
  59. package/src/__tests__/helpers/msw/handlers/access.ts +0 -13
  60. package/src/__tests__/helpers/msw/handlers/deployments.ts +0 -160
  61. package/src/__tests__/helpers/msw/handlers/namespaces.ts +0 -81
  62. package/src/__tests__/helpers/msw/handlers/oauth.ts +0 -31
  63. package/src/__tests__/helpers/msw/handlers/r2.ts +0 -60
  64. package/src/__tests__/helpers/msw/handlers/script.ts +0 -56
  65. package/src/__tests__/helpers/msw/handlers/user.ts +0 -52
  66. package/src/__tests__/helpers/msw/handlers/zones.ts +0 -20
  67. package/src/__tests__/helpers/msw/index.ts +0 -52
  68. package/src/__tests__/helpers/msw/read-file-sync.js +0 -61
  69. package/src/__tests__/helpers/run-in-tmp.ts +0 -38
  70. package/src/__tests__/helpers/run-wrangler.ts +0 -16
  71. package/src/__tests__/helpers/string-dynamic-values-matcher.ts +0 -28
  72. package/src/__tests__/helpers/worker-scripts/child-wrangler.toml +0 -1
  73. package/src/__tests__/helpers/worker-scripts/hello-world-worker.js +0 -5
  74. package/src/__tests__/helpers/worker-scripts/hello-world-wrangler.toml +0 -1
  75. package/src/__tests__/helpers/worker-scripts/parent-worker.js +0 -11
  76. package/src/__tests__/helpers/worker-scripts/parent-wrangler.toml +0 -5
  77. package/src/__tests__/helpers/write-worker-source.ts +0 -31
  78. package/src/__tests__/helpers/write-wrangler-toml.ts +0 -17
  79. package/src/__tests__/https-options.test.ts +0 -163
  80. package/src/__tests__/index.test.ts +0 -282
  81. package/src/__tests__/init.test.ts +0 -3196
  82. package/src/__tests__/jest.setup.ts +0 -179
  83. package/src/__tests__/kv.test.ts +0 -1799
  84. package/src/__tests__/logger.test.ts +0 -207
  85. package/src/__tests__/logout.test.ts +0 -47
  86. package/src/__tests__/metrics.test.ts +0 -493
  87. package/src/__tests__/middleware.scheduled.test.ts +0 -145
  88. package/src/__tests__/middleware.test.ts +0 -816
  89. package/src/__tests__/mtls-certificates.test.ts +0 -589
  90. package/src/__tests__/package-manager.test.ts +0 -353
  91. package/src/__tests__/pages/deployment-list.test.ts +0 -80
  92. package/src/__tests__/pages/functions-build.test.ts +0 -452
  93. package/src/__tests__/pages/pages.test.ts +0 -81
  94. package/src/__tests__/pages/project-create.test.ts +0 -63
  95. package/src/__tests__/pages/project-list.test.ts +0 -110
  96. package/src/__tests__/pages/project-upload.test.ts +0 -500
  97. package/src/__tests__/pages/publish.test.ts +0 -2864
  98. package/src/__tests__/pages-deployment-tail.test.ts +0 -955
  99. package/src/__tests__/parse.test.ts +0 -436
  100. package/src/__tests__/paths.test.ts +0 -39
  101. package/src/__tests__/publish.test.ts +0 -8849
  102. package/src/__tests__/pubsub.test.ts +0 -496
  103. package/src/__tests__/queues.test.ts +0 -532
  104. package/src/__tests__/r2.test.ts +0 -374
  105. package/src/__tests__/route.test.ts +0 -45
  106. package/src/__tests__/secret.test.ts +0 -693
  107. package/src/__tests__/tail.test.ts +0 -958
  108. package/src/__tests__/test-old-node-version.js +0 -31
  109. package/src/__tests__/traverse-module-graph.test.ts +0 -220
  110. package/src/__tests__/tsconfig-sanity.ts +0 -12
  111. package/src/__tests__/tsconfig.json +0 -8
  112. package/src/__tests__/tsconfig.tsbuildinfo +0 -1
  113. package/src/__tests__/type-generation.test.ts +0 -234
  114. package/src/__tests__/user.test.ts +0 -118
  115. package/src/__tests__/utils-collectKeyValues.test.ts +0 -47
  116. package/src/__tests__/validate-dev-props.test.ts +0 -56
  117. package/src/__tests__/version.test.ts +0 -35
  118. package/src/__tests__/whoami.test.tsx +0 -172
  119. package/src/__tests__/worker-namespace.test.ts +0 -340
  120. package/src/abort.d.ts +0 -3
  121. package/src/api/dev.ts +0 -316
  122. package/src/api/index.ts +0 -11
  123. package/src/api/mtls-certificate.ts +0 -148
  124. package/src/api/pages/create-worker-bundle-contents.ts +0 -76
  125. package/src/api/pages/index.ts +0 -5
  126. package/src/api/pages/publish.tsx +0 -355
  127. package/src/bundle-reporter.ts +0 -68
  128. package/src/bundle.ts +0 -908
  129. package/src/cfetch/index.ts +0 -158
  130. package/src/cfetch/internal.ts +0 -258
  131. package/src/cli.ts +0 -28
  132. package/src/config/README.md +0 -107
  133. package/src/config/config.ts +0 -282
  134. package/src/config/diagnostics.ts +0 -80
  135. package/src/config/environment.ts +0 -618
  136. package/src/config/index.ts +0 -403
  137. package/src/config/validation-helpers.ts +0 -597
  138. package/src/config/validation.ts +0 -2342
  139. package/src/config-cache.ts +0 -85
  140. package/src/constellation/createProject.tsx +0 -51
  141. package/src/constellation/deleteProject.ts +0 -51
  142. package/src/constellation/deleteProjectModel.ts +0 -68
  143. package/src/constellation/index.ts +0 -75
  144. package/src/constellation/listCatalog.tsx +0 -35
  145. package/src/constellation/listModel.tsx +0 -41
  146. package/src/constellation/listProject.tsx +0 -28
  147. package/src/constellation/listRuntime.tsx +0 -28
  148. package/src/constellation/options.ts +0 -17
  149. package/src/constellation/types.ts +0 -17
  150. package/src/constellation/uploadModel.tsx +0 -64
  151. package/src/constellation/utils.ts +0 -90
  152. package/src/create-worker-preview.ts +0 -293
  153. package/src/create-worker-upload-form.ts +0 -359
  154. package/src/d1/backups.tsx +0 -219
  155. package/src/d1/constants.ts +0 -2
  156. package/src/d1/create.tsx +0 -70
  157. package/src/d1/delete.ts +0 -53
  158. package/src/d1/execute.tsx +0 -357
  159. package/src/d1/formatTimeAgo.ts +0 -14
  160. package/src/d1/index.ts +0 -100
  161. package/src/d1/list.tsx +0 -62
  162. package/src/d1/migrations/apply.tsx +0 -212
  163. package/src/d1/migrations/create.tsx +0 -79
  164. package/src/d1/migrations/helpers.ts +0 -169
  165. package/src/d1/migrations/index.ts +0 -3
  166. package/src/d1/migrations/list.tsx +0 -95
  167. package/src/d1/migrations/options.ts +0 -23
  168. package/src/d1/options.ts +0 -22
  169. package/src/d1/splitter.ts +0 -161
  170. package/src/d1/types.ts +0 -25
  171. package/src/d1/utils.ts +0 -49
  172. package/src/delete.ts +0 -100
  173. package/src/deployments.ts +0 -368
  174. package/src/deprecated/index.ts +0 -144
  175. package/src/dev/dev-vars.ts +0 -39
  176. package/src/dev/dev.tsx +0 -600
  177. package/src/dev/get-local-persistence-path.ts +0 -31
  178. package/src/dev/local.tsx +0 -948
  179. package/src/dev/remote.tsx +0 -632
  180. package/src/dev/start-server.ts +0 -534
  181. package/src/dev/use-esbuild.ts +0 -203
  182. package/src/dev/validate-dev-props.ts +0 -40
  183. package/src/dev-registry.ts +0 -202
  184. package/src/dev.tsx +0 -929
  185. package/src/dialogs.ts +0 -136
  186. package/src/dispatch-namespace.ts +0 -211
  187. package/src/docs/helpers.ts +0 -50
  188. package/src/docs/index.ts +0 -54
  189. package/src/durable.ts +0 -102
  190. package/src/entry.ts +0 -337
  191. package/src/environment-variables/factory.ts +0 -89
  192. package/src/environment-variables/misc-variables.ts +0 -30
  193. package/src/errors.ts +0 -11
  194. package/src/generate/index.ts +0 -298
  195. package/src/git-client.ts +0 -135
  196. package/src/global-wrangler-config-path.ts +0 -26
  197. package/src/https-options.ts +0 -127
  198. package/src/index.ts +0 -768
  199. package/src/init.ts +0 -1032
  200. package/src/inspect.ts +0 -782
  201. package/src/intl-polyfill.d.ts +0 -139
  202. package/src/is-ci.ts +0 -14
  203. package/src/is-interactive.ts +0 -16
  204. package/src/jest.d.ts +0 -4
  205. package/src/kv/helpers.ts +0 -433
  206. package/src/kv/index.ts +0 -594
  207. package/src/logger.ts +0 -123
  208. package/src/metrics/index.ts +0 -5
  209. package/src/metrics/metrics-config.ts +0 -239
  210. package/src/metrics/metrics-dispatcher.ts +0 -96
  211. package/src/metrics/metrics-usage-headers.ts +0 -24
  212. package/src/metrics/send-event.ts +0 -99
  213. package/src/miniflare-cli/README.md +0 -30
  214. package/src/miniflare-cli/assets.ts +0 -251
  215. package/src/miniflare-cli/index.ts +0 -210
  216. package/src/miniflare-cli/request-context.ts +0 -40
  217. package/src/miniflare-cli/tsconfig.json +0 -9
  218. package/src/miniflare-cli/tsconfig.tsbuildinfo +0 -1
  219. package/src/miniflare-cli/types.ts +0 -11
  220. package/src/module-collection.ts +0 -333
  221. package/src/mtls-certificate/cli.ts +0 -155
  222. package/src/open-in-browser.ts +0 -17
  223. package/src/package-manager.ts +0 -219
  224. package/src/pages/build.ts +0 -410
  225. package/src/pages/buildFunctions.ts +0 -140
  226. package/src/pages/constants.ts +0 -18
  227. package/src/pages/deployment-tails.ts +0 -281
  228. package/src/pages/deployments.tsx +0 -84
  229. package/src/pages/dev.ts +0 -716
  230. package/src/pages/errors.ts +0 -67
  231. package/src/pages/functions/buildPlugin.ts +0 -113
  232. package/src/pages/functions/buildWorker.ts +0 -291
  233. package/src/pages/functions/filepath-routing.test.ts +0 -234
  234. package/src/pages/functions/filepath-routing.ts +0 -189
  235. package/src/pages/functions/identifiers.ts +0 -78
  236. package/src/pages/functions/routes-consolidation.test.ts +0 -250
  237. package/src/pages/functions/routes-consolidation.ts +0 -73
  238. package/src/pages/functions/routes-transformation.test.ts +0 -282
  239. package/src/pages/functions/routes-transformation.ts +0 -115
  240. package/src/pages/functions/routes-validation.test.ts +0 -403
  241. package/src/pages/functions/routes-validation.ts +0 -202
  242. package/src/pages/functions/routes.ts +0 -151
  243. package/src/pages/functions/tsconfig.json +0 -8
  244. package/src/pages/functions/tsconfig.tsbuildinfo +0 -1
  245. package/src/pages/functions.ts +0 -86
  246. package/src/pages/hash.ts +0 -13
  247. package/src/pages/index.ts +0 -102
  248. package/src/pages/projects.tsx +0 -159
  249. package/src/pages/prompt-select-project.tsx +0 -31
  250. package/src/pages/publish.tsx +0 -267
  251. package/src/pages/types.ts +0 -46
  252. package/src/pages/upload.tsx +0 -469
  253. package/src/pages/utils.ts +0 -23
  254. package/src/parse.ts +0 -308
  255. package/src/paths.ts +0 -71
  256. package/src/proxy.ts +0 -694
  257. package/src/publish/index.ts +0 -274
  258. package/src/publish/publish.ts +0 -1060
  259. package/src/pubsub/index.ts +0 -286
  260. package/src/pubsub/pubsub-commands.ts +0 -623
  261. package/src/queues/cli/commands/consumer/add.ts +0 -71
  262. package/src/queues/cli/commands/consumer/index.ts +0 -19
  263. package/src/queues/cli/commands/consumer/remove.ts +0 -31
  264. package/src/queues/cli/commands/create.ts +0 -25
  265. package/src/queues/cli/commands/delete.ts +0 -26
  266. package/src/queues/cli/commands/index.ts +0 -35
  267. package/src/queues/cli/commands/list.ts +0 -25
  268. package/src/queues/client.ts +0 -136
  269. package/src/queues/utils.ts +0 -18
  270. package/src/r2/constants.ts +0 -4
  271. package/src/r2/helpers.ts +0 -132
  272. package/src/r2/index.ts +0 -289
  273. package/src/routes.ts +0 -140
  274. package/src/secret/index.ts +0 -376
  275. package/src/selfsigned.d.ts +0 -29
  276. package/src/sites.ts +0 -484
  277. package/src/tail/createTail.ts +0 -406
  278. package/src/tail/filters.ts +0 -277
  279. package/src/tail/index.ts +0 -211
  280. package/src/tail/printing.ts +0 -122
  281. package/src/traverse-module-graph.ts +0 -53
  282. package/src/tsconfig-sanity.ts +0 -16
  283. package/src/type-generation.ts +0 -181
  284. package/src/update-check.ts +0 -19
  285. package/src/user/access.ts +0 -68
  286. package/src/user/auth-variables.ts +0 -113
  287. package/src/user/choose-account.tsx +0 -39
  288. package/src/user/generate-auth-url.ts +0 -33
  289. package/src/user/generate-random-state.ts +0 -16
  290. package/src/user/index.ts +0 -2
  291. package/src/user/user.ts +0 -1234
  292. package/src/utils/collectKeyValues.ts +0 -14
  293. package/src/utils/render.ts +0 -93
  294. package/src/whoami.ts +0 -135
  295. package/src/worker.ts +0 -274
  296. package/src/yargs-types.ts +0 -37
  297. package/src/zones.ts +0 -191
package/src/bundle.ts DELETED
@@ -1,908 +0,0 @@
1
- import assert from "node:assert";
2
- import * as fs from "node:fs";
3
- import { builtinModules } from "node:module";
4
- import * as path from "node:path";
5
- import NodeGlobalsPolyfills from "@esbuild-plugins/node-globals-polyfill";
6
- import NodeModulesPolyfills from "@esbuild-plugins/node-modules-polyfill";
7
- import * as esbuild from "esbuild";
8
- import tmp from "tmp-promise";
9
- import createModuleCollector from "./module-collection";
10
- import { getBasePath } from "./paths";
11
- import type { Config } from "./config";
12
- import type { DurableObjectBindings } from "./config/environment";
13
- import type { WorkerRegistry } from "./dev-registry";
14
- import type { Entry } from "./entry";
15
- import type { CfModule } from "./worker";
16
-
17
- export const COMMON_ESBUILD_OPTIONS = {
18
- // Our workerd runtime uses the same V8 version as recent Chrome, which is highly ES2022 compliant: https://kangax.github.io/compat-table/es2016plus/
19
- target: "es2022",
20
- loader: { ".js": "jsx", ".mjs": "jsx", ".cjs": "jsx" },
21
- } as const;
22
-
23
- export type BundleResult = {
24
- modules: CfModule[];
25
- dependencies: esbuild.Metafile["outputs"][string]["inputs"];
26
- resolvedEntryPointPath: string;
27
- bundleType: "esm" | "commonjs";
28
- stop: (() => void) | undefined;
29
- sourceMapPath?: string | undefined;
30
- };
31
-
32
- type StaticAssetsConfig =
33
- | (Config["assets"] & {
34
- bypassCache: boolean | undefined;
35
- })
36
- | undefined;
37
-
38
- /**
39
- * When applying the middleware facade for service workers, we need to inject
40
- * some code at the top of the final output bundle. Applying an inject too early
41
- * will allow esbuild to reorder the code. Additionally, we need to make sure
42
- * user code is bundled in the final esbuild step with `watch` correctly
43
- * configured, so code changes are detected.
44
- *
45
- * This type is used as the return type for the `MiddlewareFn` type representing
46
- * a facade-applying function. Returned injects should be injected with the
47
- * final esbuild step.
48
- */
49
- type EntryWithInject = Entry & { inject?: string[] };
50
-
51
- /**
52
- * RegExp matching against esbuild's error text when it is unable to resolve
53
- * a Node built-in module. If we detect this when node_compat is disabled,
54
- * we'll rewrite the error to suggest enabling it.
55
- */
56
- const nodeBuiltinResolveErrorText = new RegExp(
57
- '^Could not resolve "(' +
58
- builtinModules.join("|") +
59
- "|" +
60
- builtinModules.map((module) => "node:" + module).join("|") +
61
- ')"$'
62
- );
63
-
64
- /**
65
- * Returns true if the passed value looks like an esbuild BuildFailure object
66
- */
67
- export function isBuildFailure(err: unknown): err is esbuild.BuildFailure {
68
- return (
69
- typeof err === "object" &&
70
- err !== null &&
71
- "errors" in err &&
72
- "warnings" in err
73
- );
74
- }
75
-
76
- /**
77
- * Rewrites esbuild BuildFailures for failing to resolve Node built-in modules
78
- * to suggest enabling Node compat as opposed to `platform: "node"`.
79
- */
80
- export function rewriteNodeCompatBuildFailure(err: esbuild.BuildFailure) {
81
- for (const error of err.errors) {
82
- const match = nodeBuiltinResolveErrorText.exec(error.text);
83
- if (match !== null) {
84
- error.notes = [
85
- {
86
- location: null,
87
- text: `The package "${match[1]}" wasn't found on the file system but is built into node.
88
- Add "node_compat = true" to your wrangler.toml file to enable Node compatibility.`,
89
- },
90
- ];
91
- }
92
- }
93
- }
94
-
95
- const nodejsCompatPlugin: esbuild.Plugin = {
96
- name: "nodejs_compat Plugin",
97
- setup(pluginBuild) {
98
- pluginBuild.onResolve({ filter: /node:.*/ }, () => {
99
- return { external: true };
100
- });
101
- },
102
- };
103
-
104
- const cloudflareJsPlugin: esbuild.Plugin = {
105
- name: "cloudflare javascript Plugin",
106
- setup(pluginBuild) {
107
- pluginBuild.onResolve({ filter: /^cloudflare:.*/ }, () => {
108
- return { external: true };
109
- });
110
- },
111
- };
112
-
113
- /**
114
- * Generate a bundle for the worker identified by the arguments passed in.
115
- */
116
- export async function bundleWorker(
117
- entry: Entry,
118
- destination: string,
119
- options: {
120
- serveAssetsFromWorker: boolean;
121
- assets?: StaticAssetsConfig;
122
- betaD1Shims?: string[];
123
- doBindings: DurableObjectBindings;
124
- jsxFactory?: string;
125
- jsxFragment?: string;
126
- entryName?: string;
127
- rules: Config["rules"];
128
- watch?: esbuild.WatchMode | boolean;
129
- tsconfig?: string;
130
- minify?: boolean;
131
- legacyNodeCompat?: boolean;
132
- nodejsCompat?: boolean;
133
- define: Config["define"];
134
- checkFetch: boolean;
135
- services?: Config["services"];
136
- workerDefinitions?: WorkerRegistry;
137
- firstPartyWorkerDevFacade?: boolean;
138
- targetConsumer: "dev" | "publish";
139
- local: boolean;
140
- testScheduled?: boolean;
141
- experimentalLocal?: boolean;
142
- inject?: string[];
143
- loader?: Record<string, string>;
144
- sourcemap?: esbuild.CommonOptions["sourcemap"];
145
- plugins?: esbuild.Plugin[];
146
- // TODO: Rip these out https://github.com/cloudflare/workers-sdk/issues/2153
147
- disableModuleCollection?: boolean;
148
- isOutfile?: boolean;
149
- }
150
- ): Promise<BundleResult> {
151
- const {
152
- serveAssetsFromWorker,
153
- betaD1Shims,
154
- doBindings,
155
- jsxFactory,
156
- jsxFragment,
157
- entryName,
158
- rules,
159
- watch,
160
- tsconfig,
161
- minify,
162
- legacyNodeCompat,
163
- nodejsCompat,
164
- checkFetch,
165
- local,
166
- assets,
167
- workerDefinitions,
168
- services,
169
- firstPartyWorkerDevFacade,
170
- targetConsumer,
171
- testScheduled,
172
- experimentalLocal,
173
- inject: injectOption,
174
- loader,
175
- sourcemap,
176
- plugins,
177
- disableModuleCollection,
178
- isOutfile,
179
- } = options;
180
-
181
- // We create a temporary directory for any oneoff files we
182
- // need to create. This is separate from the main build
183
- // directory (`destination`).
184
- const tmpDir = await tmp.dir({ unsafeCleanup: true });
185
-
186
- const entryDirectory = path.dirname(entry.file);
187
- let moduleCollector = createModuleCollector({
188
- wrangler1xlegacyModuleReferences: {
189
- rootDirectory: entryDirectory,
190
- fileNames: new Set(
191
- fs
192
- .readdirSync(entryDirectory, { withFileTypes: true })
193
- .filter(
194
- (dirEntry) =>
195
- dirEntry.isFile() && dirEntry.name !== path.basename(entry.file)
196
- )
197
- .map((dirEnt) => dirEnt.name)
198
- ),
199
- },
200
- format: entry.format,
201
- rules,
202
- });
203
- if (disableModuleCollection) {
204
- moduleCollector = {
205
- modules: [],
206
- plugin: {
207
- name: moduleCollector.plugin.name,
208
- setup: () => {},
209
- },
210
- };
211
- }
212
-
213
- // In dev, we want to patch `fetch()` with a special version that looks
214
- // for bad usages and can warn the user about them; so we inject
215
- // `checked-fetch.js` to do so. However, with yarn 3 style pnp,
216
- // we need to extract that file to an accessible place before injecting
217
- // it in, hence this code here.
218
-
219
- const checkedFetchFileToInject = path.join(tmpDir.path, "checked-fetch.js");
220
-
221
- if (checkFetch && !fs.existsSync(checkedFetchFileToInject)) {
222
- fs.mkdirSync(tmpDir.path, {
223
- recursive: true,
224
- });
225
- fs.writeFileSync(
226
- checkedFetchFileToInject,
227
- fs.readFileSync(path.resolve(getBasePath(), "templates/checked-fetch.js"))
228
- );
229
- }
230
-
231
- // At this point, we take the opportunity to "wrap" any input workers
232
- // with any extra functionality we may want to add. This is done by
233
- // passing the entry point through a pipeline of functions that return
234
- // a new entry point, that we call "middleware" or "facades".
235
- // Look at implementations of these functions to learn more.
236
-
237
- // We also have middleware that uses a more "traditional" middleware stack,
238
- // which is all loaded as one in a stack.
239
- const middlewareToLoad: MiddlewareLoader[] = [];
240
-
241
- if (testScheduled) {
242
- middlewareToLoad.push({
243
- path: "templates/middleware/middleware-scheduled.ts",
244
- });
245
- }
246
- if (experimentalLocal) {
247
- // In Miniflare 3, we bind the user's worker as a service binding in a
248
- // special entry worker that handles things like injecting `Request.cf`,
249
- // live-reload, and the pretty-error page.
250
- //
251
- // Unfortunately, due to a bug in `workerd`, errors thrown asynchronously by
252
- // native APIs don't have `stack`s. This means Miniflare can't extract the
253
- // `stack` trace from dispatching to the user worker service binding by
254
- // `try/catch`.
255
- //
256
- // As a stop-gap solution, if the `MF-Experimental-Error-Stack` header is
257
- // truthy on responses, the body will be interpreted as a JSON-error of the
258
- // form `{ message?: string, name?: string, stack?: string }`.
259
- //
260
- // This middleware wraps the user's worker in a `try/catch`, and rewrites
261
- // errors in this format so a pretty-error page can be shown.
262
- middlewareToLoad.push({
263
- path: "templates/middleware/middleware-miniflare3-json-error.ts",
264
- dev: true,
265
- });
266
- }
267
-
268
- type MiddlewareFn = (currentEntry: Entry) => Promise<EntryWithInject>;
269
- const middleware: (false | undefined | MiddlewareFn)[] = [
270
- // serve static assets
271
- serveAssetsFromWorker &&
272
- ((currentEntry: Entry) => {
273
- return applyStaticAssetFacade(currentEntry, tmpDir.path, assets);
274
- }),
275
- // format errors nicely
276
- // We use an env var here because we don't actually
277
- // want to expose this to the user. It's only used internally to
278
- // experiment with middleware as a teaching exercise.
279
- process.env.FORMAT_WRANGLER_ERRORS === "true" &&
280
- ((currentEntry: Entry) => {
281
- return applyFormatDevErrorsFacade(currentEntry, tmpDir.path);
282
- }),
283
- // bind to other dev instances/service bindings
284
- workerDefinitions &&
285
- Object.keys(workerDefinitions).length > 0 &&
286
- services &&
287
- services.length > 0 &&
288
- ((currentEntry: Entry) => {
289
- return applyMultiWorkerDevFacade(
290
- currentEntry,
291
- tmpDir.path,
292
- services,
293
- workerDefinitions
294
- );
295
- }),
296
- // Simulate internal environment when using first party workers in dev
297
- firstPartyWorkerDevFacade === true &&
298
- ((currentEntry: Entry) => {
299
- return applyFirstPartyWorkerDevFacade(currentEntry, tmpDir.path);
300
- }),
301
-
302
- Array.isArray(betaD1Shims) &&
303
- betaD1Shims.length > 0 &&
304
- ((currentEntry: Entry) => {
305
- return applyD1BetaFacade(
306
- currentEntry,
307
- tmpDir.path,
308
- betaD1Shims,
309
- local && !experimentalLocal,
310
- doBindings
311
- );
312
- }),
313
-
314
- // Middleware loader: to add middleware, we add the path to the middleware
315
- // Currently for demonstration purposes we have two example middlewares
316
- // Middlewares are togglable by changing the `publish` (default=false) and `dev` (default=true) options
317
- // As we are not yet supporting user created middlewares yet, if no wrangler applied middleware
318
- // are found, we will not load any middleware. We also need to check if there are middlewares compatible with
319
- // the target consumer (dev / publish).
320
- (middlewareToLoad.filter(
321
- (m) =>
322
- (m.publish && targetConsumer === "publish") ||
323
- (m.dev !== false && targetConsumer === "dev")
324
- ).length > 0 ||
325
- process.env.EXPERIMENTAL_MIDDLEWARE === "true") &&
326
- ((currentEntry: Entry) => {
327
- return applyMiddlewareLoaderFacade(
328
- currentEntry,
329
- tmpDir.path,
330
- middlewareToLoad.filter(
331
- // We dynamically filter the middleware depending on where we are bundling for
332
- (m) =>
333
- (targetConsumer === "dev" && m.dev !== false) ||
334
- (m.publish && targetConsumer === "publish")
335
- )
336
- );
337
- }),
338
- ].filter(Boolean);
339
-
340
- const inject: string[] = injectOption ?? [];
341
- if (checkFetch) inject.push(checkedFetchFileToInject);
342
-
343
- let inputEntry: EntryWithInject = entry;
344
- for (const middlewareFn of middleware as MiddlewareFn[]) {
345
- inputEntry = await middlewareFn(inputEntry);
346
- if (inputEntry.inject !== undefined) inject.push(...inputEntry.inject);
347
- }
348
-
349
- // At this point, inputEntry points to the entry point we want to build.
350
-
351
- const buildOptions: esbuild.BuildOptions & { metafile: true } = {
352
- entryPoints: [inputEntry.file],
353
- bundle: true,
354
- absWorkingDir: entry.directory,
355
- outdir: destination,
356
- entryNames: entryName || path.parse(entry.file).name,
357
- ...(isOutfile
358
- ? {
359
- outdir: undefined,
360
- outfile: destination,
361
- entryNames: undefined,
362
- }
363
- : {}),
364
- inject,
365
- external: ["__STATIC_CONTENT_MANIFEST"],
366
- format: entry.format === "modules" ? "esm" : "iife",
367
- target: COMMON_ESBUILD_OPTIONS.target,
368
- sourcemap: sourcemap ?? true, // this needs to use ?? to accept false
369
- // Include a reference to the output folder in the sourcemap.
370
- // This is omitted by default, but we need it to properly resolve source paths in error output.
371
- sourceRoot: destination,
372
- minify,
373
- metafile: true,
374
- conditions: ["workerd", "worker", "browser"],
375
- ...(process.env.NODE_ENV && {
376
- define: {
377
- // use process.env["NODE_ENV" + ""] so that esbuild doesn't replace it
378
- // when we do a build of wrangler. (re: https://github.com/cloudflare/workers-sdk/issues/1477)
379
- "process.env.NODE_ENV": `"${process.env["NODE_ENV" + ""]}"`,
380
- ...(legacyNodeCompat ? { global: "globalThis" } : {}),
381
- ...(checkFetch ? { fetch: "checkedFetch" } : {}),
382
- ...options.define,
383
- },
384
- }),
385
- loader: {
386
- ...COMMON_ESBUILD_OPTIONS.loader,
387
- ...(loader || {}),
388
- },
389
- plugins: [
390
- moduleCollector.plugin,
391
- ...(legacyNodeCompat
392
- ? [NodeGlobalsPolyfills({ buffer: true }), NodeModulesPolyfills()]
393
- : []),
394
- ...(nodejsCompat ? [nodejsCompatPlugin] : []),
395
- ...[cloudflareJsPlugin],
396
- ...(plugins || []),
397
- ],
398
- ...(jsxFactory && { jsxFactory }),
399
- ...(jsxFragment && { jsxFragment }),
400
- ...(tsconfig && { tsconfig }),
401
- watch,
402
- // The default logLevel is "warning". So that we can rewrite errors before
403
- // logging, we disable esbuild's default logging, and log build failures
404
- // ourselves.
405
- logLevel: "silent",
406
- };
407
- let result;
408
- try {
409
- result = await esbuild.build(buildOptions);
410
- } catch (e) {
411
- if (!legacyNodeCompat && isBuildFailure(e))
412
- rewriteNodeCompatBuildFailure(e);
413
- throw e;
414
- }
415
-
416
- const entryPointOutputs = Object.entries(result.metafile.outputs).filter(
417
- ([_path, output]) => output.entryPoint !== undefined
418
- );
419
- assert(
420
- entryPointOutputs.length > 0,
421
- `Cannot find entry-point "${entry.file}" in generated bundle.` +
422
- listEntryPoints(entryPointOutputs)
423
- );
424
- assert(
425
- entryPointOutputs.length < 2,
426
- "More than one entry-point found for generated bundle." +
427
- listEntryPoints(entryPointOutputs)
428
- );
429
-
430
- const { exports: entryPointExports, inputs: dependencies } =
431
- entryPointOutputs[0][1];
432
- const bundleType = entryPointExports.length > 0 ? "esm" : "commonjs";
433
-
434
- const sourceMapPath = Object.keys(result.metafile.outputs).filter((_path) =>
435
- _path.includes(".map")
436
- )[0];
437
-
438
- const resolvedEntryPointPath = path.resolve(
439
- entry.directory,
440
- entryPointOutputs[0][0]
441
- );
442
-
443
- // copy all referenced modules into the output bundle directory
444
- for (const module of moduleCollector.modules) {
445
- fs.writeFileSync(
446
- path.join(path.dirname(resolvedEntryPointPath), module.name),
447
- module.content
448
- );
449
- }
450
-
451
- return {
452
- modules: moduleCollector.modules,
453
- dependencies,
454
- resolvedEntryPointPath,
455
- bundleType,
456
- stop: result.stop,
457
- sourceMapPath,
458
- };
459
- }
460
-
461
- /**
462
- * A simple plugin to alias modules and mark them as external
463
- */
464
- export function esbuildAliasExternalPlugin(
465
- aliases: Record<string, string>
466
- ): esbuild.Plugin {
467
- return {
468
- name: "alias",
469
- setup(build) {
470
- build.onResolve({ filter: /.*/g }, (args) => {
471
- // If it's the entrypoint, let it be as is
472
- if (args.kind === "entry-point") {
473
- return {
474
- path: args.path,
475
- };
476
- }
477
- // If it's not a recognised alias, then throw an error
478
- if (!Object.keys(aliases).includes(args.path)) {
479
- throw new Error("unrecognized module: " + args.path);
480
- }
481
-
482
- // Otherwise, return the alias
483
- return {
484
- path: aliases[args.path as keyof typeof aliases],
485
- external: true,
486
- };
487
- });
488
- },
489
- };
490
- }
491
-
492
- /**
493
- * A middleware that catches any thrown errors, and instead formats
494
- * them to be rendered in a browser. This middleware is for demonstration
495
- * purposes only, and is not intended to be used in production (or even dev!)
496
- */
497
- async function applyFormatDevErrorsFacade(
498
- entry: Entry,
499
- tmpDirPath: string
500
- ): Promise<Entry> {
501
- const targetPath = path.join(tmpDirPath, "format-dev-errors.entry.js");
502
- await esbuild.build({
503
- entryPoints: [
504
- path.resolve(getBasePath(), "templates/format-dev-errors.ts"),
505
- ],
506
- bundle: true,
507
- sourcemap: true,
508
- format: "esm",
509
- plugins: [
510
- esbuildAliasExternalPlugin({
511
- __ENTRY_POINT__: entry.file,
512
- }),
513
- ],
514
- outfile: targetPath,
515
- });
516
-
517
- return {
518
- ...entry,
519
- file: targetPath,
520
- };
521
- }
522
-
523
- /**
524
- * A facade that acts as a "middleware loader".
525
- * Instead of needing to apply a facade for each individual middleware, this allows
526
- * middleware to be written in a more traditional manner and then be applied all
527
- * at once, requiring just two esbuild steps, rather than 1 per middleware.
528
- */
529
-
530
- interface MiddlewareLoader {
531
- path: string;
532
- // By default all middleware will run on dev, but will not be run when published
533
- publish?: boolean;
534
- dev?: boolean;
535
- }
536
-
537
- async function applyMiddlewareLoaderFacade(
538
- entry: Entry,
539
- tmpDirPath: string,
540
- middleware: MiddlewareLoader[] // a list of paths to middleware files
541
- ): Promise<EntryWithInject> {
542
- // Firstly we need to insert the middleware array into the project,
543
- // and then we load the middleware - this insertion and loading is
544
- // different for each format.
545
-
546
- // Make sure we resolve all files relative to the actual temporary directory,
547
- // otherwise we'll have issues with source maps
548
- tmpDirPath = fs.realpathSync(tmpDirPath);
549
-
550
- const targetPathInsertion = path.join(
551
- tmpDirPath,
552
- "middleware-insertion.entry.js"
553
- );
554
-
555
- // We need to import each of the middlewares, so we need to generate a
556
- // random, unique identifier that we can use for the import.
557
- // Middlewares are required to be default exports so we can import to any name.
558
- const middlewareIdentifiers = middleware.map(
559
- (_, index) => `__MIDDLEWARE_${index}__`
560
- );
561
-
562
- const dynamicFacadePath = path.join(
563
- tmpDirPath,
564
- "middleware-insertion-facade.js"
565
- );
566
-
567
- if (entry.format === "modules") {
568
- // We use a facade to expose the required middleware alongside any user defined
569
- // middleware on the worker object
570
-
571
- const imports = middlewareIdentifiers
572
- .map((m) => `import ${m} from "${m}";`)
573
- .join("\n");
574
-
575
- // write a file with all of the imports required
576
- fs.writeFileSync(
577
- dynamicFacadePath,
578
- `import worker from "__ENTRY_POINT__";
579
- ${imports}
580
- const facade = {
581
- ...worker,
582
- middleware: [
583
- ${middlewareIdentifiers.join(",")}${middlewareIdentifiers.length > 0 ? "," : ""}
584
- ...(worker.middleware ? worker.middleware : []),
585
- ]
586
- }
587
- export * from "__ENTRY_POINT__";
588
- export default facade;`
589
- );
590
-
591
- await esbuild.build({
592
- entryPoints: [dynamicFacadePath],
593
- bundle: true,
594
- sourcemap: true,
595
- format: "esm",
596
- plugins: [
597
- esbuildAliasExternalPlugin({
598
- __ENTRY_POINT__: entry.file,
599
- ...Object.fromEntries(
600
- middleware.map((val, index) => [
601
- middlewareIdentifiers[index],
602
- path.resolve(getBasePath(), val.path),
603
- ])
604
- ),
605
- }),
606
- ],
607
- outfile: targetPathInsertion,
608
- });
609
- const targetPathLoader = path.join(
610
- tmpDirPath,
611
- "middleware-loader.entry.js"
612
- );
613
- const loaderPath = path.resolve(
614
- getBasePath(),
615
- "templates/middleware/loader-modules.ts"
616
- );
617
- await esbuild.build({
618
- entryPoints: [loaderPath],
619
- bundle: true,
620
- sourcemap: true,
621
- format: "esm",
622
- plugins: [
623
- esbuildAliasExternalPlugin({
624
- __ENTRY_POINT__: targetPathInsertion,
625
- "./common": path.resolve(
626
- getBasePath(),
627
- "templates/middleware/common.ts"
628
- ),
629
- }),
630
- ],
631
- outfile: targetPathLoader,
632
- });
633
- return {
634
- ...entry,
635
- file: targetPathLoader,
636
- };
637
- } else {
638
- const imports = middlewareIdentifiers
639
- .map((m) => `import ${m} from "${m}";`)
640
- .join("\n");
641
- const contents = `import { __facade_registerInternal__ } from "__LOADER__";
642
- ${imports}
643
- __facade_registerInternal__([${middlewareIdentifiers.join(",")}]);`;
644
- fs.writeFileSync(dynamicFacadePath, contents);
645
-
646
- await esbuild.build({
647
- entryPoints: [dynamicFacadePath],
648
- bundle: true,
649
- sourcemap: true,
650
- format: "iife",
651
- plugins: [
652
- {
653
- name: "dynamic-facade-imports",
654
- setup(build) {
655
- build.onResolve({ filter: /^__LOADER__$/ }, () => {
656
- const loaderPath = path.resolve(
657
- getBasePath(),
658
- "templates/middleware/loader-sw.ts"
659
- );
660
- return { path: loaderPath };
661
- });
662
- const middlewareFilter = /^__MIDDLEWARE_(\d+)__$/;
663
- build.onResolve({ filter: middlewareFilter }, (args) => {
664
- const match = middlewareFilter.exec(args.path);
665
- assert(match !== null);
666
- const middlewareIndex = parseInt(match[1]);
667
- return {
668
- path: path.resolve(
669
- getBasePath(),
670
- middleware[middlewareIndex].path
671
- ),
672
- };
673
- });
674
- },
675
- },
676
- ],
677
- outfile: targetPathInsertion,
678
- });
679
- return {
680
- ...entry,
681
- inject: [targetPathInsertion],
682
- };
683
- }
684
- }
685
-
686
- /**
687
- * A middleware that serves static assets from a worker.
688
- * This powers --assets / config.assets
689
- */
690
-
691
- async function applyStaticAssetFacade(
692
- entry: Entry,
693
- tmpDirPath: string,
694
- assets: StaticAssetsConfig
695
- ): Promise<Entry> {
696
- const targetPath = path.join(tmpDirPath, "serve-static-assets.entry.js");
697
-
698
- await esbuild.build({
699
- entryPoints: [
700
- path.resolve(getBasePath(), "templates/serve-static-assets.ts"),
701
- ],
702
- bundle: true,
703
- format: "esm",
704
- sourcemap: true,
705
- plugins: [
706
- esbuildAliasExternalPlugin({
707
- __ENTRY_POINT__: entry.file,
708
- __KV_ASSET_HANDLER__: path.join(getBasePath(), "kv-asset-handler.js"),
709
- __STATIC_CONTENT_MANIFEST: "__STATIC_CONTENT_MANIFEST",
710
- }),
711
- ],
712
- define: {
713
- __CACHE_CONTROL_OPTIONS__: JSON.stringify(
714
- typeof assets === "object"
715
- ? {
716
- browserTTL:
717
- assets.browser_TTL || 172800 /* 2 days: 2* 60 * 60 * 24 */,
718
- bypassCache: assets.bypassCache,
719
- }
720
- : {}
721
- ),
722
- __SERVE_SINGLE_PAGE_APP__: JSON.stringify(
723
- typeof assets === "object" ? assets.serve_single_page_app : false
724
- ),
725
- },
726
- outfile: targetPath,
727
- });
728
-
729
- return {
730
- ...entry,
731
- file: targetPath,
732
- };
733
- }
734
-
735
- /**
736
- * A middleware that enables service bindings to be used in dev,
737
- * binding to other love wrangler dev instances
738
- */
739
-
740
- async function applyMultiWorkerDevFacade(
741
- entry: Entry,
742
- tmpDirPath: string,
743
- services: Config["services"],
744
- workerDefinitions: WorkerRegistry
745
- ) {
746
- const targetPath = path.join(tmpDirPath, "multiworker-dev-facade.entry.js");
747
- const serviceMap = Object.fromEntries(
748
- (services || []).map((serviceBinding) => [
749
- serviceBinding.binding,
750
- workerDefinitions[serviceBinding.service] || null,
751
- ])
752
- );
753
-
754
- await esbuild.build({
755
- entryPoints: [
756
- path.join(
757
- getBasePath(),
758
- entry.format === "modules"
759
- ? "templates/service-bindings-module-facade.js"
760
- : "templates/service-bindings-sw-facade.js"
761
- ),
762
- ],
763
- bundle: true,
764
- sourcemap: true,
765
- format: "esm",
766
- plugins: [
767
- esbuildAliasExternalPlugin({
768
- __ENTRY_POINT__: entry.file,
769
- }),
770
- ],
771
- define: {
772
- __WORKERS__: JSON.stringify(serviceMap),
773
- },
774
- outfile: targetPath,
775
- });
776
-
777
- return {
778
- ...entry,
779
- file: targetPath,
780
- };
781
- }
782
-
783
- /**
784
- * A middleware that makes first party workers "work" in
785
- * our dev environments. Is applied during wrangler dev
786
- * when config.first_party_worker is true
787
- */
788
- async function applyFirstPartyWorkerDevFacade(
789
- entry: Entry,
790
- tmpDirPath: string
791
- ) {
792
- if (entry.format !== "modules") {
793
- throw new Error(
794
- "First party workers must be in the modules format. See https://developers.cloudflare.com/workers/learning/migrating-to-module-workers/"
795
- );
796
- }
797
-
798
- const targetPath = path.join(
799
- tmpDirPath,
800
- "first-party-worker-module-facade.entry.js"
801
- );
802
-
803
- await esbuild.build({
804
- entryPoints: [
805
- path.resolve(
806
- getBasePath(),
807
- "templates/first-party-worker-module-facade.ts"
808
- ),
809
- ],
810
- bundle: true,
811
- format: "esm",
812
- sourcemap: true,
813
- plugins: [
814
- esbuildAliasExternalPlugin({
815
- __ENTRY_POINT__: entry.file,
816
- }),
817
- ],
818
- outfile: targetPath,
819
- });
820
-
821
- return {
822
- ...entry,
823
- file: targetPath,
824
- };
825
- }
826
-
827
- /**
828
- * A middleware that injects the beta D1 API in JS.
829
- *
830
- * This code be removed from here when the API is in Workers core,
831
- * but moved inside Miniflare for simulating D1.
832
- */
833
- async function applyD1BetaFacade(
834
- entry: Entry,
835
- tmpDirPath: string,
836
- betaD1Shims: string[],
837
- miniflare2: boolean,
838
- doBindings: DurableObjectBindings
839
- ): Promise<Entry> {
840
- let entrypointPath = path.resolve(
841
- getBasePath(),
842
- "templates/d1-beta-facade.js"
843
- );
844
- if (Array.isArray(doBindings) && doBindings.length > 0) {
845
- //we have DO bindings, so we need to shim them
846
- const maskedDoBindings = doBindings
847
- // Don't shim anything not local to this worker
848
- .filter((b) => !b.script_name)
849
- // Reexport the DO classnames
850
- .map(
851
- (b) =>
852
- `export const ${b.class_name} = maskDurableObjectDefinition(OTHER_EXPORTS.${b.class_name});`
853
- )
854
- .join("\n");
855
- const baseFile = fs.readFileSync(
856
- path.resolve(getBasePath(), "templates/d1-beta-facade.js"),
857
- "utf8"
858
- );
859
- //getMaskedEnv is already used to shim regular Workers
860
- const contents = `
861
- ${baseFile}
862
-
863
- var maskDurableObjectDefinition = (cls) =>
864
- class extends cls {
865
- constructor(state, env) {
866
- super(state, getMaskedEnv(env));
867
- }
868
- };
869
- ${maskedDoBindings}`;
870
- const doD1FacadePath = path.join(tmpDirPath, "d1-do-facade.js");
871
- //write our shim so we can build it
872
- fs.writeFileSync(doD1FacadePath, contents);
873
- entrypointPath = doD1FacadePath;
874
- }
875
- const targetPath = path.join(tmpDirPath, "d1-beta-facade.entry.js");
876
- await esbuild.build({
877
- entryPoints: [entrypointPath],
878
- bundle: true,
879
- format: "esm",
880
- sourcemap: true,
881
- plugins: [
882
- esbuildAliasExternalPlugin({
883
- __ENTRY_POINT__: entry.file,
884
- }),
885
- ],
886
- define: {
887
- __D1_IMPORTS__: JSON.stringify(betaD1Shims),
888
- __LOCAL_MODE__: JSON.stringify(miniflare2),
889
- },
890
- outfile: targetPath,
891
- });
892
-
893
- return {
894
- ...entry,
895
- file: targetPath,
896
- };
897
- }
898
-
899
- /**
900
- * Generate a string that describes the entry-points that were identified by esbuild.
901
- */
902
- function listEntryPoints(
903
- outputs: [string, ValueOf<esbuild.Metafile["outputs"]>][]
904
- ): string {
905
- return outputs.map(([_input, output]) => output.entryPoint).join("\n");
906
- }
907
-
908
- type ValueOf<T> = T[keyof T];