wrangler 2.20.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 +149 -75
  15. package/wrangler-dist/cli.js +60062 -64338
  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 -4517
  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 -528
  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 -957
  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 -989
  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 -321
  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 -77
  125. package/src/api/pages/index.ts +0 -5
  126. package/src/api/pages/publish.tsx +0 -371
  127. package/src/bundle-reporter.ts +0 -68
  128. package/src/bundle.ts +0 -929
  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 -625
  136. package/src/config/index.ts +0 -403
  137. package/src/config/validation-helpers.ts +0 -597
  138. package/src/config/validation.ts +0 -2369
  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 -363
  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 -605
  177. package/src/dev/get-local-persistence-path.ts +0 -31
  178. package/src/dev/local.tsx +0 -952
  179. package/src/dev/remote.tsx +0 -635
  180. package/src/dev/start-server.ts +0 -545
  181. package/src/dev/use-esbuild.ts +0 -215
  182. package/src/dev/validate-dev-props.ts +0 -40
  183. package/src/dev-registry.ts +0 -202
  184. package/src/dev.tsx +0 -934
  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 -344
  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 -1037
  200. package/src/inspect.ts +0 -883
  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 -423
  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 -734
  230. package/src/pages/errors.ts +0 -67
  231. package/src/pages/functions/buildPlugin.ts +0 -114
  232. package/src/pages/functions/buildWorker.ts +0 -350
  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 -1065
  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 -377
  275. package/src/selfsigned.d.ts +0 -29
  276. package/src/sites.ts +0 -484
  277. package/src/tail/createTail.ts +0 -415
  278. package/src/tail/filters.ts +0 -277
  279. package/src/tail/index.ts +0 -211
  280. package/src/tail/printing.ts +0 -132
  281. package/src/traverse-module-graph.ts +0 -54
  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 -279
  296. package/src/yargs-types.ts +0 -37
  297. package/src/zones.ts +0 -191
package/src/pages/dev.ts DELETED
@@ -1,734 +0,0 @@
1
- import { execSync, spawn } from "node:child_process";
2
- import { existsSync, lstatSync, readFileSync } from "node:fs";
3
- import { homedir, tmpdir } from "node:os";
4
- import { join, resolve } from "node:path";
5
- import { watch } from "chokidar";
6
- import * as esbuild from "esbuild";
7
- import { unstable_dev } from "../api";
8
- import { esbuildAliasExternalPlugin } from "../bundle";
9
- import { FatalError } from "../errors";
10
- import { logger } from "../logger";
11
- import * as metrics from "../metrics";
12
- import { getBasePath } from "../paths";
13
- import { buildFunctions } from "./buildFunctions";
14
- import { ROUTES_SPEC_VERSION, SECONDS_TO_WAIT_FOR_PROXY } from "./constants";
15
- import { FunctionsNoRoutesError, getFunctionsNoRoutesWarning } from "./errors";
16
- import { buildRawWorker, checkRawWorker } from "./functions/buildWorker";
17
- import { validateRoutes } from "./functions/routes-validation";
18
- import { CLEANUP, CLEANUP_CALLBACKS, pagesBetaWarning } from "./utils";
19
- import type { AdditionalDevProps } from "../dev";
20
- import type {
21
- CommonYargsArgv,
22
- StrictYargsOptionsToInterface,
23
- } from "../yargs-types";
24
- import type { RoutesJSONSpec } from "./functions/routes-transformation";
25
-
26
- const DURABLE_OBJECTS_BINDING_REGEXP = new RegExp(
27
- /^(?<binding>[^=]+)=(?<className>[^@\s]+)(@(?<scriptName>.*)$)?$/
28
- );
29
-
30
- export function Options(yargs: CommonYargsArgv) {
31
- return yargs
32
- .positional("directory", {
33
- type: "string",
34
- demandOption: undefined,
35
- description: "The directory of static assets to serve",
36
- })
37
- .positional("command", {
38
- type: "string",
39
- demandOption: undefined,
40
- description: "The proxy command to run",
41
- })
42
- .options({
43
- local: {
44
- type: "boolean",
45
- default: true,
46
- description: "Run on my machine",
47
- },
48
- "compatibility-date": {
49
- describe: "Date to use for compatibility checks",
50
- type: "string",
51
- },
52
- "compatibility-flags": {
53
- describe: "Flags to use for compatibility checks",
54
- alias: "compatibility-flag",
55
- type: "string",
56
- array: true,
57
- },
58
- ip: {
59
- type: "string",
60
- default: "0.0.0.0",
61
- description: "The IP address to listen on",
62
- },
63
- port: {
64
- type: "number",
65
- default: 8788,
66
- description: "The port to listen on (serve from)",
67
- },
68
- "inspector-port": {
69
- type: "number",
70
- describe: "Port for devtools to connect to",
71
- },
72
- proxy: {
73
- type: "number",
74
- description: "The port to proxy (where the static assets are served)",
75
- },
76
- "script-path": {
77
- type: "string",
78
- default: "_worker.js",
79
- description:
80
- "The location of the single Worker script if not using functions",
81
- },
82
- bundle: {
83
- type: "boolean",
84
- default: undefined,
85
- hidden: true,
86
- },
87
- "no-bundle": {
88
- type: "boolean",
89
- default: false,
90
- description: "Whether to run bundling on `_worker.js`",
91
- },
92
- binding: {
93
- type: "array",
94
- description: "Bind variable/secret (KEY=VALUE)",
95
- alias: "b",
96
- },
97
- kv: {
98
- type: "array",
99
- description: "KV namespace to bind (--kv KV_BINDING)",
100
- alias: "k",
101
- },
102
- d1: {
103
- type: "array",
104
- description: "D1 database to bind",
105
- },
106
- do: {
107
- type: "array",
108
- description: "Durable Object to bind (--do NAME=CLASS)",
109
- alias: "o",
110
- },
111
- r2: {
112
- type: "array",
113
- description: "R2 bucket to bind (--r2 R2_BINDING)",
114
- },
115
- "live-reload": {
116
- type: "boolean",
117
- default: false,
118
- description: "Auto reload HTML pages when change is detected",
119
- },
120
- "local-protocol": {
121
- describe: "Protocol to listen to requests on, defaults to http.",
122
- choices: ["http", "https"] as const,
123
- },
124
- "experimental-enable-local-persistence": {
125
- describe:
126
- "Enable persistence for local mode (deprecated, use --persist)",
127
- type: "boolean",
128
- deprecated: true,
129
- hidden: true,
130
- },
131
- persist: {
132
- describe:
133
- "Enable persistence for local mode, using default path: .wrangler/state",
134
- type: "boolean",
135
- },
136
- "persist-to": {
137
- describe:
138
- "Specify directory to use for local persistence (implies --persist)",
139
- type: "string",
140
- requiresArg: true,
141
- },
142
- "node-compat": {
143
- describe: "Enable Node.js compatibility",
144
- default: false,
145
- type: "boolean",
146
- hidden: true,
147
- },
148
- "experimental-local": {
149
- describe: "Run on my machine using the Cloudflare Workers runtime",
150
- type: "boolean",
151
- default: false,
152
- },
153
- config: {
154
- describe: "Pages does not support wrangler.toml",
155
- type: "string",
156
- hidden: true,
157
- },
158
- "log-level": {
159
- choices: ["debug", "info", "log", "warn", "error", "none"] as const,
160
- describe: "Specify logging level",
161
- },
162
- })
163
- .epilogue(pagesBetaWarning);
164
- }
165
-
166
- export const Handler = async ({
167
- local,
168
- directory,
169
- compatibilityDate,
170
- compatibilityFlags,
171
- ip,
172
- port,
173
- inspectorPort,
174
- proxy: requestedProxyPort,
175
- bundle,
176
- noBundle,
177
- scriptPath: singleWorkerScriptPath,
178
- binding: bindings = [],
179
- kv: kvs = [],
180
- do: durableObjects = [],
181
- d1: d1s = [],
182
- r2: r2s = [],
183
- liveReload,
184
- localProtocol,
185
- experimentalEnableLocalPersistence,
186
- persist,
187
- persistTo,
188
- nodeCompat: legacyNodeCompat,
189
- experimentalLocal,
190
- config: config,
191
- _: [_pages, _dev, ...remaining],
192
- logLevel,
193
- }: StrictYargsOptionsToInterface<typeof Options>) => {
194
- // Beta message for `wrangler pages <commands>` usage
195
- logger.log(pagesBetaWarning);
196
-
197
- if (logLevel) {
198
- logger.loggerLevel = logLevel;
199
- }
200
-
201
- if (!local) {
202
- throw new FatalError("Only local mode is supported at the moment.", 1);
203
- }
204
-
205
- if (config) {
206
- throw new FatalError("Pages does not support wrangler.toml", 1);
207
- }
208
-
209
- const command = remaining;
210
-
211
- let proxyPort: number | undefined;
212
-
213
- if (directory !== undefined && command.length > 0) {
214
- throw new FatalError(
215
- "Specify either a directory OR a proxy command, not both.",
216
- 1
217
- );
218
- } else if (directory === undefined) {
219
- proxyPort = await spawnProxyProcess({
220
- port: requestedProxyPort,
221
- command,
222
- });
223
- if (proxyPort === undefined) return undefined;
224
- } else {
225
- directory = resolve(directory);
226
- }
227
-
228
- if (!compatibilityDate) {
229
- const currentDate = new Date().toISOString().substring(0, 10);
230
- logger.warn(
231
- `No compatibility_date was specified. Using today's date: ${currentDate}.\n` +
232
- "Pass it in your terminal:\n" +
233
- "```\n" +
234
- `--compatibility-date=${currentDate}\n` +
235
- "```\n" +
236
- "See https://developers.cloudflare.com/workers/platform/compatibility-dates/ for more information."
237
- );
238
- compatibilityDate = currentDate;
239
- }
240
-
241
- if (experimentalEnableLocalPersistence) {
242
- logger.warn(
243
- `--experimental-enable-local-persistence is deprecated.\n` +
244
- `Move any existing data to .wrangler/state and use --persist, or\n` +
245
- `use --persist-to=./wrangler-local-state to keep using the old path.`
246
- );
247
- }
248
-
249
- let scriptReadyResolve: () => void;
250
- const scriptReadyPromise = new Promise<void>(
251
- (promiseResolve) => (scriptReadyResolve = promiseResolve)
252
- );
253
-
254
- const workerScriptPath =
255
- directory !== undefined
256
- ? join(directory, singleWorkerScriptPath)
257
- : singleWorkerScriptPath;
258
- const usingWorkerDirectory =
259
- existsSync(workerScriptPath) && lstatSync(workerScriptPath).isDirectory();
260
- const usingWorkerScript = existsSync(workerScriptPath);
261
- // TODO: Here lies a known bug. If you specify both `--bundle` and `--no-bundle`, this behavior is undefined and you will get unexpected results.
262
- // There is no sane way to get the true value out of yargs, so here we are.
263
- const enableBundling = bundle ?? !noBundle;
264
-
265
- const functionsDirectory = "./functions";
266
- let usingFunctions = !usingWorkerScript && existsSync(functionsDirectory);
267
-
268
- let scriptPath = "";
269
-
270
- const nodejsCompat = compatibilityFlags?.includes("nodejs_compat");
271
-
272
- if (usingWorkerScript) {
273
- scriptPath = workerScriptPath;
274
- let runBuild = async () => {
275
- await checkRawWorker(workerScriptPath, () => scriptReadyResolve());
276
- };
277
-
278
- if (enableBundling) {
279
- // We want to actually run the `_worker.js` script through the bundler
280
- // So update the final path to the script that will be uploaded and
281
- // change the `runBuild()` function to bundle the `_worker.js`.
282
- scriptPath = join(tmpdir(), `./bundledWorker-${Math.random()}.mjs`);
283
- runBuild = async () => {
284
- try {
285
- await buildRawWorker({
286
- workerScriptPath: usingWorkerDirectory
287
- ? join(workerScriptPath, "index.js")
288
- : workerScriptPath,
289
- outfile: scriptPath,
290
- directory: directory ?? ".",
291
- nodejsCompat,
292
- local: true,
293
- sourcemap: true,
294
- watch: true,
295
- onEnd: () => scriptReadyResolve(),
296
- });
297
- } catch (e: unknown) {
298
- logger.warn("Failed to bundle _worker.js.", e);
299
- }
300
- };
301
- }
302
-
303
- await runBuild();
304
- watch([workerScriptPath], {
305
- persistent: true,
306
- ignoreInitial: true,
307
- }).on("all", async () => {
308
- await runBuild();
309
- });
310
- } else if (usingFunctions) {
311
- // Try to use Functions
312
- scriptPath = join(tmpdir(), `./functionsWorker-${Math.random()}.mjs`);
313
-
314
- if (legacyNodeCompat) {
315
- console.warn(
316
- "Enabling Node.js compatibility mode for builtins and globals. This is experimental and has serious tradeoffs. Please see https://github.com/ionic-team/rollup-plugin-node-polyfills/ for more details."
317
- );
318
- }
319
-
320
- if (legacyNodeCompat && nodejsCompat) {
321
- throw new FatalError(
322
- "The `nodejs_compat` compatibility flag cannot be used in conjunction with the legacy `--node-compat` flag. If you want to use the Workers runtime Node.js compatibility features, please remove the `--node-compat` argument from your CLI command or `node_compat = true` from your config file.",
323
- 1
324
- );
325
- }
326
-
327
- logger.log(`Compiling worker to "${scriptPath}"...`);
328
- const onEnd = () => scriptReadyResolve();
329
- try {
330
- const buildFn = async () => {
331
- await buildFunctions({
332
- outfile: scriptPath,
333
- functionsDirectory,
334
- sourcemap: true,
335
- watch: true,
336
- onEnd,
337
- buildOutputDirectory: directory,
338
- legacyNodeCompat,
339
- nodejsCompat,
340
- local: true,
341
- });
342
- await metrics.sendMetricsEvent("build pages functions");
343
- };
344
-
345
- await buildFn();
346
- // If Functions found routes, continue using Functions
347
- watch([functionsDirectory], {
348
- persistent: true,
349
- ignoreInitial: true,
350
- }).on("all", async () => {
351
- try {
352
- await buildFn();
353
- } catch (e) {
354
- if (e instanceof FunctionsNoRoutesError) {
355
- logger.warn(
356
- getFunctionsNoRoutesWarning(functionsDirectory, "skipping")
357
- );
358
- } else {
359
- throw e;
360
- }
361
- }
362
- });
363
- } catch (e) {
364
- // If there are no Functions, then Pages will only serve assets.
365
- if (e instanceof FunctionsNoRoutesError) {
366
- logger.warn(
367
- getFunctionsNoRoutesWarning(functionsDirectory, "skipping")
368
- );
369
- // Resolve anyway and run without Functions
370
- onEnd();
371
- // Turn off Functions
372
- usingFunctions = false;
373
- } else {
374
- throw e;
375
- }
376
- }
377
- }
378
-
379
- // Depending on the result of building Functions, we may not actually be using
380
- // Functions even if the directory exists.
381
- if (!usingFunctions && !usingWorkerScript) {
382
- // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
383
- scriptReadyResolve!();
384
-
385
- logger.log("No functions. Shimming...");
386
- scriptPath = resolve(getBasePath(), "templates/pages-shim.ts");
387
- }
388
-
389
- await scriptReadyPromise;
390
-
391
- if (scriptPath === "") {
392
- // Failed to get a script with or without Functions,
393
- // something really bad must have happened.
394
- throw new FatalError(
395
- "Failed to start wrangler pages dev due to an unknown error",
396
- 1
397
- );
398
- }
399
-
400
- let entrypoint = scriptPath;
401
-
402
- // custom _routes.json apply only to Functions or Advanced Mode Pages projects
403
- if (
404
- directory &&
405
- (usingFunctions || usingWorkerScript || usingWorkerDirectory)
406
- ) {
407
- const routesJSONPath = join(directory, "_routes.json");
408
-
409
- if (existsSync(routesJSONPath)) {
410
- let routesJSONContents: string;
411
- const runBuild = async (
412
- entrypointFile: string,
413
- outfile: string,
414
- routes: string
415
- ) => {
416
- await esbuild.build({
417
- entryPoints: [
418
- resolve(getBasePath(), "templates/pages-dev-pipeline.ts"),
419
- ],
420
- bundle: true,
421
- sourcemap: true,
422
- format: "esm",
423
- plugins: [
424
- esbuildAliasExternalPlugin({
425
- __ENTRY_POINT__: entrypointFile,
426
- "./pages-dev-util": resolve(
427
- getBasePath(),
428
- "templates/pages-dev-util.ts"
429
- ),
430
- }),
431
- ],
432
- outfile,
433
- define: {
434
- __ROUTES__: routes,
435
- },
436
- });
437
- };
438
-
439
- try {
440
- // always run the routes validation first. If _routes.json is invalid we
441
- // want to throw accordingly and exit.
442
- routesJSONContents = readFileSync(routesJSONPath, "utf-8");
443
- validateRoutes(JSON.parse(routesJSONContents), directory);
444
-
445
- entrypoint = join(
446
- tmpdir(),
447
- `${Math.random().toString(36).slice(2)}.js`
448
- );
449
- await runBuild(scriptPath, entrypoint, routesJSONContents);
450
- } catch (err) {
451
- if (err instanceof FatalError) {
452
- throw err;
453
- } else {
454
- throw new FatalError(
455
- `Could not validate _routes.json at ${directory}: ${err}`,
456
- 1
457
- );
458
- }
459
- }
460
-
461
- watch([routesJSONPath], {
462
- persistent: true,
463
- ignoreInitial: true,
464
- }).on("all", async () => {
465
- try {
466
- /**
467
- * Watch for _routes.json file changes and validate file each time.
468
- * If file is valid proceed to running the build.
469
- */
470
- routesJSONContents = readFileSync(routesJSONPath, "utf-8");
471
- validateRoutes(JSON.parse(routesJSONContents), directory as string);
472
- await runBuild(scriptPath, entrypoint, routesJSONContents);
473
- } catch (err) {
474
- /**
475
- * If _routes.json is invalid, don't exit but instead fallback to a sensible default
476
- * and continue to serve the assets. At the same time make sure we warn users that we
477
- * we detected an invalid file and that we'll be using a default.
478
- * This basically equates to serving a Functions or _worker.js project as is,
479
- * without applying any additional routing rules on top.
480
- */
481
- const error =
482
- err instanceof FatalError
483
- ? err
484
- : `Could not validate _routes.json at ${directory}: ${err}`;
485
- const defaultRoutesJSONSpec: RoutesJSONSpec = {
486
- version: ROUTES_SPEC_VERSION,
487
- include: ["/*"],
488
- exclude: [],
489
- };
490
-
491
- logger.error(error);
492
- logger.warn(
493
- `Falling back to the following _routes.json default: ${JSON.stringify(
494
- defaultRoutesJSONSpec,
495
- null,
496
- 2
497
- )}`
498
- );
499
-
500
- routesJSONContents = JSON.stringify(defaultRoutesJSONSpec);
501
- await runBuild(scriptPath, entrypoint, routesJSONContents);
502
- }
503
- });
504
- }
505
- }
506
-
507
- const { stop, waitUntilExit } = await unstable_dev(entrypoint, {
508
- ip,
509
- port,
510
- inspectorPort,
511
- localProtocol,
512
- compatibilityDate,
513
- compatibilityFlags,
514
- nodeCompat: legacyNodeCompat,
515
- vars: Object.fromEntries(
516
- bindings
517
- .map((binding) => binding.toString().split("="))
518
- .map(([key, ...values]) => [key, values.join("=")])
519
- ),
520
- kv: kvs.map((binding) => ({
521
- binding: binding.toString(),
522
- id: "",
523
- })),
524
- durableObjects: durableObjects
525
- .map((durableObject) => {
526
- const { binding, className, scriptName } =
527
- DURABLE_OBJECTS_BINDING_REGEXP.exec(durableObject.toString())
528
- ?.groups || {};
529
-
530
- if (!binding || !className) {
531
- logger.warn(
532
- "Could not parse Durable Object binding:",
533
- durableObject.toString()
534
- );
535
- return;
536
- }
537
-
538
- return {
539
- name: binding,
540
- class_name: className,
541
- script_name: scriptName,
542
- };
543
- })
544
- .filter(Boolean) as AdditionalDevProps["durableObjects"],
545
- r2: r2s.map((binding) => {
546
- return { binding: binding.toString(), bucket_name: "" };
547
- }),
548
- processEntrypoint: true,
549
- moduleRoot: workerScriptPath,
550
- rules: usingWorkerDirectory
551
- ? [
552
- {
553
- type: "ESModule",
554
- globs: ["**/*.js"],
555
- },
556
- ]
557
- : undefined,
558
- bundle: enableBundling,
559
- persist,
560
- persistTo,
561
- inspect: undefined,
562
- logLevel,
563
- experimental: {
564
- d1Databases: d1s.map((binding) => ({
565
- binding: binding.toString(),
566
- database_id: "", // Required for types, but unused by dev
567
- database_name: `local-${binding}`,
568
- })),
569
- disableExperimentalWarning: true,
570
- enablePagesAssetsServiceBinding: {
571
- proxyPort,
572
- directory,
573
- },
574
- experimentalLocal,
575
- liveReload,
576
- forceLocal: true,
577
- showInteractiveDevSession: undefined,
578
- testMode: false,
579
- watch: true,
580
- },
581
- });
582
- await metrics.sendMetricsEvent("run pages dev");
583
-
584
- CLEANUP_CALLBACKS.push(stop);
585
-
586
- void waitUntilExit().then(() => {
587
- CLEANUP();
588
- process.exit(0);
589
- });
590
-
591
- process.on("exit", CLEANUP);
592
- process.on("SIGINT", CLEANUP);
593
- process.on("SIGTERM", CLEANUP);
594
- };
595
-
596
- function isWindows() {
597
- return process.platform === "win32";
598
- }
599
-
600
- async function sleep(ms: number) {
601
- await new Promise((promiseResolve) => setTimeout(promiseResolve, ms));
602
- }
603
-
604
- function getPids(pid: number) {
605
- const pids: number[] = [pid];
606
- let command: string, regExp: RegExp;
607
-
608
- if (isWindows()) {
609
- command = `wmic process where (ParentProcessId=${pid}) get ProcessId`;
610
- regExp = new RegExp(/(\d+)/);
611
- } else {
612
- command = `pgrep -P ${pid}`;
613
- regExp = new RegExp(/(\d+)/);
614
- }
615
-
616
- try {
617
- const newPids = (
618
- execSync(command)
619
- .toString()
620
- .split("\n")
621
- .map((line) => line.match(regExp))
622
- .filter((line) => line !== null) as RegExpExecArray[]
623
- ).map((match) => parseInt(match[1]));
624
-
625
- pids.push(...newPids.map(getPids).flat());
626
- } catch {}
627
-
628
- return pids;
629
- }
630
-
631
- function getPort(pid: number) {
632
- let command: string, regExp: RegExp;
633
-
634
- if (isWindows()) {
635
- const drive = homedir().split(":\\")[0];
636
- command = drive + ":\\windows\\system32\\netstat.exe -nao";
637
- regExp = new RegExp(`TCP\\s+.*:(\\d+)\\s+.*:\\d+\\s+LISTENING\\s+${pid}`);
638
- } else {
639
- command = "lsof -nPi";
640
- regExp = new RegExp(`${pid}\\s+.*TCP\\s+.*:(\\d+)\\s+\\(LISTEN\\)`);
641
- }
642
-
643
- try {
644
- const matches = execSync(command)
645
- .toString()
646
- .split("\n")
647
- .map((line) => line.match(regExp))
648
- .filter((line) => line !== null) as RegExpExecArray[];
649
-
650
- const match = matches[0];
651
- if (match) return parseInt(match[1]);
652
- } catch (thrown) {
653
- logger.error(
654
- `Error scanning for ports of process with PID ${pid}: ${thrown}`
655
- );
656
- }
657
- }
658
-
659
- async function spawnProxyProcess({
660
- port,
661
- command,
662
- }: {
663
- port?: number;
664
- command: (string | number)[];
665
- }): Promise<undefined | number> {
666
- if (command.length === 0) {
667
- if (port !== undefined) {
668
- return port;
669
- }
670
-
671
- CLEANUP();
672
- throw new FatalError(
673
- "Must specify a directory of static assets to serve or a command to run or a proxy port.",
674
- 1
675
- );
676
- }
677
-
678
- logger.log(`Running ${command.join(" ")}...`);
679
- const proxy = spawn(
680
- command[0].toString(),
681
- command.slice(1).map((value) => value.toString()),
682
- {
683
- shell: isWindows(),
684
- env: {
685
- BROWSER: "none",
686
- ...process.env,
687
- },
688
- }
689
- );
690
- CLEANUP_CALLBACKS.push(() => {
691
- proxy.kill();
692
- });
693
-
694
- proxy.stdout.on("data", (data) => {
695
- logger.log(`[proxy]: ${data}`);
696
- });
697
-
698
- proxy.stderr.on("data", (data) => {
699
- logger.error(`[proxy]: ${data}`);
700
- });
701
-
702
- proxy.on("close", (code) => {
703
- logger.error(`Proxy exited with status ${code}.`);
704
- CLEANUP();
705
- process.exitCode = code ?? 0;
706
- });
707
-
708
- // Wait for proxy process to start...
709
- while (!proxy.pid) {}
710
-
711
- if (port === undefined) {
712
- logger.log(
713
- `Sleeping ${SECONDS_TO_WAIT_FOR_PROXY} seconds to allow proxy process to start before attempting to automatically determine port...`
714
- );
715
- logger.log("To skip, specify the proxy port with --proxy.");
716
- await sleep(SECONDS_TO_WAIT_FOR_PROXY * 1000);
717
-
718
- port = getPids(proxy.pid)
719
- .map(getPort)
720
- .filter((nr) => nr !== undefined)[0];
721
-
722
- if (port === undefined) {
723
- CLEANUP();
724
- throw new FatalError(
725
- "Could not automatically determine proxy port. Please specify the proxy port with --proxy.",
726
- 1
727
- );
728
- } else {
729
- logger.log(`Automatically determined the proxy port to be ${port}.`);
730
- }
731
- }
732
-
733
- return port;
734
- }