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/dev.tsx DELETED
@@ -1,934 +0,0 @@
1
- import path from "node:path";
2
- import chalk from "chalk";
3
- import { watch } from "chokidar";
4
- import getPort from "get-port";
5
- import { render } from "ink";
6
- import React from "react";
7
- import { findWranglerToml, printBindings, readConfig } from "./config";
8
- import Dev from "./dev/dev";
9
- import { getVarsForDev } from "./dev/dev-vars";
10
- import { getLocalPersistencePath } from "./dev/get-local-persistence-path";
11
-
12
- import { startDevServer } from "./dev/start-server";
13
- import { getEntry } from "./entry";
14
- import { logger } from "./logger";
15
- import * as metrics from "./metrics";
16
- import { getAssetPaths, getSiteAssetPaths } from "./sites";
17
- import { getAccountFromCache, loginOrRefreshIfRequired } from "./user";
18
- import { collectKeyValues } from "./utils/collectKeyValues";
19
- import { identifyD1BindingsAsBeta } from "./worker";
20
- import { getHostFromRoute, getZoneForRoute, getZoneIdFromHost } from "./zones";
21
- import {
22
- DEFAULT_INSPECTOR_PORT,
23
- DEFAULT_LOCAL_PORT,
24
- getDevCompatibilityDate,
25
- getRules,
26
- getScriptName,
27
- isLegacyEnv,
28
- printWranglerBanner,
29
- } from "./index";
30
- import type { Config, Environment } from "./config";
31
- import type { Route, Rule } from "./config/environment";
32
- import type { LoggerLevel } from "./logger";
33
- import type { EnablePagesAssetsServiceBindingOptions } from "./miniflare-cli/types";
34
- import type { CfWorkerInit } from "./worker";
35
- import type {
36
- CommonYargsArgv,
37
- StrictYargsOptionsToInterface,
38
- } from "./yargs-types";
39
-
40
- export function devOptions(yargs: CommonYargsArgv) {
41
- return (
42
- yargs
43
- .positional("script", {
44
- describe: "The path to an entry point for your worker",
45
- type: "string",
46
- })
47
- .option("name", {
48
- describe: "Name of the worker",
49
- type: "string",
50
- requiresArg: true,
51
- })
52
- // We want to have a --no-bundle flag, but yargs requires that
53
- // we also have a --bundle flag (that it adds the --no to by itself)
54
- // So we make a --bundle flag, but hide it, and then add a --no-bundle flag
55
- // that's visible to the user but doesn't "do" anything.
56
- .option("bundle", {
57
- describe: "Run wrangler's compilation step before publishing",
58
- type: "boolean",
59
- hidden: true,
60
- })
61
- .option("no-bundle", {
62
- describe: "Skip internal build steps and directly publish script",
63
- type: "boolean",
64
- default: false,
65
- })
66
- .option("format", {
67
- choices: ["modules", "service-worker"] as const,
68
- describe: "Choose an entry type",
69
- hidden: true,
70
- deprecated: true,
71
- })
72
- .option("compatibility-date", {
73
- describe: "Date to use for compatibility checks",
74
- type: "string",
75
- requiresArg: true,
76
- })
77
- .option("compatibility-flags", {
78
- describe: "Flags to use for compatibility checks",
79
- alias: "compatibility-flag",
80
- type: "string",
81
- requiresArg: true,
82
- array: true,
83
- })
84
- .option("latest", {
85
- describe: "Use the latest version of the worker runtime",
86
- type: "boolean",
87
- default: true,
88
- })
89
- .option("ip", {
90
- describe: "IP address to listen on",
91
- type: "string",
92
- })
93
- .option("port", {
94
- describe: "Port to listen on",
95
- type: "number",
96
- })
97
- .option("inspector-port", {
98
- describe: "Port for devtools to connect to",
99
- type: "number",
100
- })
101
- .option("routes", {
102
- describe: "Routes to upload",
103
- alias: "route",
104
- type: "string",
105
- requiresArg: true,
106
- array: true,
107
- })
108
- .option("host", {
109
- type: "string",
110
- requiresArg: true,
111
- describe:
112
- "Host to forward requests to, defaults to the zone of project",
113
- })
114
- .option("local-protocol", {
115
- describe: "Protocol to listen to requests on, defaults to http.",
116
- choices: ["http", "https"] as const,
117
- })
118
- .options("local-upstream", {
119
- type: "string",
120
- describe:
121
- "Host to act as origin in local mode, defaults to dev.host or route",
122
- })
123
- .option("experimental-public", {
124
- describe: "Static assets to be served",
125
- type: "string",
126
- requiresArg: true,
127
- deprecated: true,
128
- hidden: true,
129
- })
130
- .option("assets", {
131
- describe: "Static assets to be served",
132
- type: "string",
133
- requiresArg: true,
134
- })
135
- .option("public", {
136
- describe: "(Deprecated) Static assets to be served",
137
- type: "string",
138
- requiresArg: true,
139
- deprecated: true,
140
- hidden: true,
141
- })
142
- .option("site", {
143
- describe: "Root folder of static assets for Workers Sites",
144
- type: "string",
145
- requiresArg: true,
146
- })
147
- .option("site-include", {
148
- describe:
149
- "Array of .gitignore-style patterns that match file or directory names from the sites directory. Only matched items will be uploaded.",
150
- type: "string",
151
- requiresArg: true,
152
- array: true,
153
- })
154
- .option("site-exclude", {
155
- describe:
156
- "Array of .gitignore-style patterns that match file or directory names from the sites directory. Matched items will not be uploaded.",
157
- type: "string",
158
- requiresArg: true,
159
- array: true,
160
- })
161
- .option("upstream-protocol", {
162
- describe: "Protocol to forward requests to host on, defaults to https.",
163
- choices: ["http", "https"] as const,
164
- })
165
- .option("var", {
166
- describe:
167
- "A key-value pair to be injected into the script as a variable",
168
- type: "string",
169
- requiresArg: true,
170
- array: true,
171
- })
172
- .option("define", {
173
- describe: "A key-value pair to be substituted in the script",
174
- type: "string",
175
- requiresArg: true,
176
- array: true,
177
- })
178
- .option("jsx-factory", {
179
- describe: "The function that is called for each JSX element",
180
- type: "string",
181
- requiresArg: true,
182
- })
183
- .option("jsx-fragment", {
184
- describe: "The function that is called for each JSX fragment",
185
- type: "string",
186
- requiresArg: true,
187
- })
188
- .option("tsconfig", {
189
- describe: "Path to a custom tsconfig.json file",
190
- type: "string",
191
- requiresArg: true,
192
- })
193
- .option("local", {
194
- alias: "l",
195
- describe: "Run on my machine",
196
- type: "boolean",
197
- default: false, // I bet this will a point of contention. We'll revisit it.
198
- })
199
- .option("experimental-local", {
200
- describe: "Run on my machine using the Cloudflare Workers runtime",
201
- type: "boolean",
202
- default: false,
203
- })
204
- .option("experimental-local-remote-kv", {
205
- describe:
206
- "Read/write KV data from/to real namespaces on the Cloudflare network",
207
- type: "boolean",
208
- default: false,
209
- })
210
- .check((argv) => {
211
- if (argv.local && argv["experimental-local"]) {
212
- throw new Error(
213
- "--local and --experimental-local are mutually exclusive. " +
214
- "Please enable one or the other."
215
- );
216
- }
217
- if (
218
- argv["experimental-local-remote-kv"] &&
219
- !argv["experimental-local"]
220
- ) {
221
- throw new Error(
222
- "--experimental-local-remote-kv requires --experimental-local to be enabled."
223
- );
224
- }
225
- return true;
226
- })
227
- .option("minify", {
228
- describe: "Minify the script",
229
- type: "boolean",
230
- })
231
- .option("node-compat", {
232
- describe: "Enable Node.js compatibility",
233
- type: "boolean",
234
- })
235
- .option("experimental-enable-local-persistence", {
236
- describe:
237
- "Enable persistence for local mode (deprecated, use --persist)",
238
- type: "boolean",
239
- deprecated: true,
240
- hidden: true,
241
- })
242
- .option("persist", {
243
- describe:
244
- "Enable persistence for local mode, using default path: .wrangler/state",
245
- type: "boolean",
246
- })
247
- .option("persist-to", {
248
- describe:
249
- "Specify directory to use for local persistence (implies --persist)",
250
- type: "string",
251
- requiresArg: true,
252
- })
253
- .option("live-reload", {
254
- describe:
255
- "Auto reload HTML pages when change is detected in local mode",
256
- type: "boolean",
257
- })
258
- .check((argv) => {
259
- const local = argv["local"] || argv["experimental-local"];
260
- if (argv["live-reload"] && !local) {
261
- throw new Error(
262
- "--live-reload is only supported in local mode. " +
263
- "Please enable either --local or --experimental-local."
264
- );
265
- }
266
- return true;
267
- })
268
- .option("inspect", {
269
- describe: "Enable dev tools",
270
- type: "boolean",
271
- deprecated: true,
272
- hidden: true,
273
- })
274
- .option("legacy-env", {
275
- type: "boolean",
276
- describe: "Use legacy environments",
277
- hidden: true,
278
- })
279
- .option("test-scheduled", {
280
- describe: "Test scheduled events by visiting /__scheduled in browser",
281
- type: "boolean",
282
- default: false,
283
- })
284
- .option("log-level", {
285
- choices: ["debug", "info", "log", "warn", "error", "none"] as const,
286
- describe: "Specify logging level",
287
- // Yargs requires this to type log-level properly
288
- default: "log" as LoggerLevel,
289
- })
290
- );
291
- }
292
-
293
- type DevArguments = StrictYargsOptionsToInterface<typeof devOptions>;
294
-
295
- export async function devHandler(args: DevArguments) {
296
- if (!(args.local || args.experimentalLocal)) {
297
- const isLoggedIn = await loginOrRefreshIfRequired();
298
- if (!isLoggedIn) {
299
- throw new Error(
300
- "You must be logged in to use wrangler dev in remote mode. Try logging in, or run wrangler dev --local."
301
- );
302
- }
303
- }
304
-
305
- let watcher;
306
- try {
307
- const devInstance = await startDev(args);
308
- watcher = devInstance.watcher;
309
- const { waitUntilExit } = devInstance.devReactElement;
310
- await waitUntilExit();
311
- } finally {
312
- await watcher?.close();
313
- }
314
- }
315
-
316
- export type AdditionalDevProps = {
317
- vars?: {
318
- [key: string]: unknown;
319
- };
320
- kv?: {
321
- binding: string;
322
- id: string;
323
- preview_id?: string;
324
- }[];
325
- durableObjects?: {
326
- name: string;
327
- class_name: string;
328
- script_name?: string | undefined;
329
- environment?: string | undefined;
330
- }[];
331
- r2?: {
332
- binding: string;
333
- bucket_name: string;
334
- preview_bucket_name?: string;
335
- }[];
336
- d1Databases?: Environment["d1_databases"];
337
- processEntrypoint?: boolean;
338
- moduleRoot?: string;
339
- rules?: Rule[];
340
- };
341
-
342
- type StartDevOptions = DevArguments &
343
- // These options can be passed in directly when called with the `wrangler.dev()` API.
344
- // They aren't exposed as CLI arguments.
345
- AdditionalDevProps & {
346
- forceLocal?: boolean;
347
- disableDevRegistry?: boolean;
348
- enablePagesAssetsServiceBinding?: EnablePagesAssetsServiceBindingOptions;
349
- onReady?: (ip: string, port: number) => void;
350
- showInteractiveDevSession?: boolean;
351
- };
352
-
353
- export async function startDev(args: StartDevOptions) {
354
- let watcher: ReturnType<typeof watch> | undefined;
355
- let rerender: (node: React.ReactNode) => void | undefined;
356
- try {
357
- if (args.logLevel) {
358
- logger.loggerLevel = args.logLevel;
359
- }
360
- await printWranglerBanner();
361
-
362
- if (args.local && process.platform !== "win32") {
363
- logger.info(
364
- chalk.magenta(
365
- `Want to try out the next version of local mode using the open-source Workers runtime?\nSwitch out --local for ${chalk.bold(
366
- "--experimental-local"
367
- )} and let us know what you think at https://discord.gg/cloudflaredev !`
368
- )
369
- );
370
- }
371
-
372
- const configPath =
373
- args.config ||
374
- (args.script && findWranglerToml(path.dirname(args.script)));
375
- let config = readConfig(configPath, args);
376
-
377
- if (config.configPath) {
378
- watcher = watch(config.configPath, {
379
- persistent: true,
380
- }).on("change", async (_event) => {
381
- // TODO: Do we need to handle different `_event` types differently?
382
- // e.g. what if the file is deleted, or added?
383
- config = readConfig(configPath, args);
384
- if (config.configPath) {
385
- logger.log(`${path.basename(config.configPath)} changed...`);
386
- rerender(await getDevReactElement(config));
387
- }
388
- });
389
- }
390
-
391
- const {
392
- entry,
393
- legacyNodeCompat,
394
- nodejsCompat,
395
- upstreamProtocol,
396
- zoneId,
397
- host,
398
- routes,
399
- getLocalPort,
400
- getInspectorPort,
401
- cliDefines,
402
- localPersistencePath,
403
- } = await validateDevServerSettings(args, config);
404
-
405
- await metrics.sendMetricsEvent(
406
- "run dev",
407
- {
408
- local: args.local,
409
- usesTypeScript: /\.tsx?$/.test(entry.file),
410
- },
411
- { sendMetrics: config.send_metrics, offline: args.local }
412
- );
413
-
414
- // eslint-disable-next-line no-inner-declarations
415
- async function getDevReactElement(configParam: Config) {
416
- const { assetPaths, bindings } = getBindingsAndAssetPaths(
417
- args,
418
- configParam
419
- );
420
-
421
- return (
422
- <Dev
423
- name={getScriptName({ name: args.name, env: args.env }, configParam)}
424
- noBundle={!(args.bundle ?? !configParam.no_bundle)}
425
- entry={entry}
426
- env={args.env}
427
- zone={zoneId}
428
- host={host}
429
- routes={routes}
430
- processEntrypoint={!!args.processEntrypoint}
431
- rules={args.rules ?? getRules(configParam)}
432
- legacyEnv={isLegacyEnv(configParam)}
433
- minify={args.minify ?? configParam.minify}
434
- legacyNodeCompat={legacyNodeCompat}
435
- nodejsCompat={nodejsCompat}
436
- build={configParam.build || {}}
437
- define={{ ...configParam.define, ...cliDefines }}
438
- initialMode={
439
- args.local || args.experimentalLocal ? "local" : "remote"
440
- }
441
- jsxFactory={args.jsxFactory || configParam.jsx_factory}
442
- jsxFragment={args.jsxFragment || configParam.jsx_fragment}
443
- tsconfig={args.tsconfig ?? configParam.tsconfig}
444
- upstreamProtocol={upstreamProtocol}
445
- localProtocol={args.localProtocol || configParam.dev.local_protocol}
446
- localUpstream={args.localUpstream ?? host}
447
- localPersistencePath={localPersistencePath}
448
- liveReload={args.liveReload || false}
449
- accountId={configParam.account_id || getAccountFromCache()?.id}
450
- assetPaths={assetPaths}
451
- assetsConfig={configParam.assets}
452
- initialPort={
453
- args.port ?? configParam.dev.port ?? (await getLocalPort())
454
- }
455
- initialIp={args.ip || configParam.dev.ip}
456
- inspectorPort={
457
- args.inspectorPort ??
458
- configParam.dev.inspector_port ??
459
- (await getInspectorPort())
460
- }
461
- isWorkersSite={Boolean(args.site || configParam.site)}
462
- compatibilityDate={getDevCompatibilityDate(
463
- configParam,
464
- args.compatibilityDate
465
- )}
466
- compatibilityFlags={
467
- args.compatibilityFlags || configParam.compatibility_flags
468
- }
469
- usageModel={configParam.usage_model}
470
- bindings={bindings}
471
- crons={configParam.triggers.crons}
472
- queueConsumers={configParam.queues.consumers}
473
- onReady={args.onReady}
474
- inspect={args.inspect ?? true}
475
- showInteractiveDevSession={args.showInteractiveDevSession}
476
- forceLocal={args.forceLocal}
477
- enablePagesAssetsServiceBinding={args.enablePagesAssetsServiceBinding}
478
- firstPartyWorker={configParam.first_party_worker}
479
- sendMetrics={configParam.send_metrics}
480
- testScheduled={args.testScheduled}
481
- experimentalLocal={args.experimentalLocal}
482
- experimentalLocalRemoteKv={args.experimentalLocalRemoteKv}
483
- />
484
- );
485
- }
486
- const devReactElement = render(await getDevReactElement(config));
487
-
488
- // In the bootstrapper script `bin/wrangler.js`, we open an IPC channel, so
489
- // IPC messages from this process are propagated through the bootstrapper.
490
- // Normally, Node's SIGINT handler would close this for us, but interactive
491
- // mode enables raw mode on stdin which disables the built-in handler. The
492
- // following line disconnects from the IPC channel when we press `x` or
493
- // CTRL-C in interactive mode, ensuring no open handles, and allowing for a
494
- // clean exit. Note, if we called `stop()` using the dev API, we don't want
495
- // to disconnect here, as the user may still need IPC. We also don't want
496
- // to disconnect if this file was imported in Jest (not the case with E2E
497
- // tests), as that would stop communication with the test runner.
498
- let apiStopped = false;
499
- void devReactElement.waitUntilExit().then(() => {
500
- if (!apiStopped && typeof jest === "undefined") process.disconnect?.();
501
- });
502
-
503
- rerender = devReactElement.rerender;
504
- return {
505
- devReactElement,
506
- watcher,
507
- stop: async () => {
508
- apiStopped = true;
509
- devReactElement.unmount();
510
- await watcher?.close();
511
- },
512
- };
513
- } finally {
514
- await watcher?.close();
515
- }
516
- }
517
-
518
- export async function startApiDev(args: StartDevOptions) {
519
- if (args.logLevel) {
520
- logger.loggerLevel = args.logLevel;
521
- }
522
- await printWranglerBanner();
523
-
524
- const configPath =
525
- args.config || (args.script && findWranglerToml(path.dirname(args.script)));
526
- const config = readConfig(configPath, args);
527
-
528
- const {
529
- entry,
530
- legacyNodeCompat,
531
- nodejsCompat,
532
- upstreamProtocol,
533
- zoneId,
534
- host,
535
- routes,
536
- getLocalPort,
537
- getInspectorPort,
538
- cliDefines,
539
- localPersistencePath,
540
- } = await validateDevServerSettings(args, config);
541
-
542
- await metrics.sendMetricsEvent(
543
- "run dev (api)",
544
- { local: args.local },
545
- { sendMetrics: config.send_metrics, offline: args.local }
546
- );
547
-
548
- // eslint-disable-next-line no-inner-declarations
549
- async function getDevServer(configParam: Config) {
550
- const { assetPaths, bindings } = getBindingsAndAssetPaths(
551
- args,
552
- configParam
553
- );
554
-
555
- //if args.bundle is on, don't disable bundling
556
- //if there's no args.bundle, and configParam.no_bundle is on, disable bundling
557
- //otherwise, enable bundling
558
- const enableBundling = args.bundle ?? !configParam.no_bundle;
559
- return await startDevServer({
560
- name: getScriptName({ name: args.name, env: args.env }, configParam),
561
- noBundle: !enableBundling,
562
- entry: entry,
563
- env: args.env,
564
- zone: zoneId,
565
- host: host,
566
- routes: routes,
567
- processEntrypoint: !!args.processEntrypoint,
568
- rules: args.rules ?? getRules(configParam),
569
- legacyEnv: isLegacyEnv(configParam),
570
- minify: args.minify ?? configParam.minify,
571
- legacyNodeCompat,
572
- nodejsCompat,
573
- build: configParam.build || {},
574
- define: { ...config.define, ...cliDefines },
575
- initialMode: args.local ? "local" : "remote",
576
- jsxFactory: args.jsxFactory ?? configParam.jsx_factory,
577
- jsxFragment: args.jsxFragment ?? configParam.jsx_fragment,
578
- tsconfig: args.tsconfig ?? configParam.tsconfig,
579
- upstreamProtocol: upstreamProtocol,
580
- localProtocol: args.localProtocol ?? configParam.dev.local_protocol,
581
- localUpstream: args.localUpstream ?? host,
582
- localPersistencePath,
583
- liveReload: args.liveReload ?? false,
584
- accountId: configParam.account_id ?? getAccountFromCache()?.id,
585
- assetPaths: assetPaths,
586
- assetsConfig: configParam.assets,
587
- //port can be 0, which means to use a random port
588
- initialPort: args.port ?? configParam.dev.port ?? (await getLocalPort()),
589
- initialIp: args.ip ?? configParam.dev.ip,
590
- inspectorPort:
591
- args.inspectorPort ??
592
- configParam.dev.inspector_port ??
593
- (await getInspectorPort()),
594
- isWorkersSite: Boolean(args.site || configParam.site),
595
- compatibilityDate: getDevCompatibilityDate(
596
- config,
597
- // Only `compatibilityDate` will be set when using `unstable_dev`
598
- args.compatibilityDate
599
- ),
600
- compatibilityFlags:
601
- args.compatibilityFlags ?? configParam.compatibility_flags,
602
- usageModel: configParam.usage_model,
603
- bindings: bindings,
604
- crons: configParam.triggers.crons,
605
- queueConsumers: configParam.queues.consumers,
606
- onReady: args.onReady,
607
- inspect: args.inspect ?? true,
608
- showInteractiveDevSession: args.showInteractiveDevSession,
609
- forceLocal: args.forceLocal,
610
- enablePagesAssetsServiceBinding: args.enablePagesAssetsServiceBinding,
611
- local: args.local ?? true,
612
- firstPartyWorker: configParam.first_party_worker,
613
- sendMetrics: configParam.send_metrics,
614
- testScheduled: args.testScheduled,
615
- experimentalLocal: args.experimentalLocal,
616
- experimentalLocalRemoteKv: args.experimentalLocalRemoteKv,
617
- disableDevRegistry: args.disableDevRegistry ?? false,
618
- });
619
- }
620
-
621
- const devServer = await getDevServer(config);
622
- if (!devServer) {
623
- throw logger.error("Failed to start dev server.");
624
- }
625
-
626
- return {
627
- stop: async () => {
628
- await devServer.stop();
629
- },
630
- };
631
- }
632
- /**
633
- * Avoiding calling `getPort()` multiple times by memoizing the first result.
634
- */
635
- function memoizeGetPort(defaultPort: number) {
636
- let portValue: number;
637
- return async () => {
638
- return portValue || (portValue = await getPort({ port: defaultPort }));
639
- };
640
- }
641
- /**
642
- * mask anything that was overridden in .dev.vars
643
- * so that we don't log potential secrets into the terminal
644
- */
645
- function maskVars(bindings: CfWorkerInit["bindings"], configParam: Config) {
646
- const maskedVars = { ...bindings.vars };
647
- for (const key of Object.keys(maskedVars)) {
648
- if (maskedVars[key] !== configParam.vars[key]) {
649
- // This means it was overridden in .dev.vars
650
- // so let's mask it
651
- maskedVars[key] = "(hidden)";
652
- }
653
- }
654
- return maskedVars;
655
- }
656
-
657
- async function getZoneIdHostAndRoutes(args: StartDevOptions, config: Config) {
658
- // TODO: if worker_dev = false and no routes, then error (only for dev)
659
- // Compute zone info from the `host` and `route` args and config;
660
- let host = args.host || config.dev.host;
661
- let zoneId: string | undefined;
662
- const routes: Route[] | undefined =
663
- args.routes || (config.route && [config.route]) || config.routes;
664
-
665
- if (args.forceLocal) {
666
- args.local = true;
667
- }
668
-
669
- if (!args.local && !args.experimentalLocal) {
670
- if (host) {
671
- zoneId = await getZoneIdFromHost(host);
672
- }
673
- if (!zoneId && routes) {
674
- const firstRoute = routes[0];
675
- const zone = await getZoneForRoute(firstRoute);
676
- if (zone) {
677
- zoneId = zone.id;
678
- host = zone.host;
679
- }
680
- }
681
- } else if (!host) {
682
- if (routes) {
683
- const firstRoute = routes[0];
684
- host = getHostFromRoute(firstRoute);
685
- }
686
- }
687
- return { host, routes, zoneId };
688
- }
689
-
690
- async function validateDevServerSettings(
691
- args: StartDevOptions,
692
- config: Config
693
- ) {
694
- const entry = await getEntry(
695
- { assets: args.assets, script: args.script, moduleRoot: args.moduleRoot },
696
- config,
697
- "dev"
698
- );
699
-
700
- const { zoneId, host, routes } = await getZoneIdHostAndRoutes(args, config);
701
- const getLocalPort = memoizeGetPort(DEFAULT_LOCAL_PORT);
702
- const getInspectorPort = memoizeGetPort(DEFAULT_INSPECTOR_PORT);
703
-
704
- if (config.services && config.services.length > 0) {
705
- logger.warn(
706
- `This worker is bound to live services: ${config.services
707
- .map(
708
- (service) =>
709
- `${service.binding} (${service.service}${
710
- service.environment ? `@${service.environment}` : ""
711
- })`
712
- )
713
- .join(", ")}`
714
- );
715
- }
716
-
717
- if (args.inspect) {
718
- //devtools are enabled by default, but we still need to disable them if the caller doesn't want them
719
- logger.warn(
720
- "Passing --inspect is unnecessary, now you can always connect to devtools."
721
- );
722
- }
723
- if (args.experimentalPublic) {
724
- throw new Error(
725
- "The --experimental-public field has been renamed to --assets"
726
- );
727
- }
728
-
729
- if (args.public) {
730
- throw new Error("The --public field has been renamed to --assets");
731
- }
732
-
733
- if ((args.assets ?? config.assets) && (args.site ?? config.site)) {
734
- throw new Error("Cannot use Assets and Workers Sites in the same Worker.");
735
- }
736
-
737
- if (args.assets) {
738
- logger.warn(
739
- "The --assets argument is experimental and may change or break at any time"
740
- );
741
- }
742
- const upstreamProtocol =
743
- args.upstreamProtocol ?? config.dev.upstream_protocol;
744
- if (upstreamProtocol === "http") {
745
- logger.warn(
746
- "Setting upstream-protocol to http is not currently implemented.\n" +
747
- "If this is required in your project, please add your use case to the following issue:\n" +
748
- "https://github.com/cloudflare/workers-sdk/issues/583."
749
- );
750
- }
751
- const legacyNodeCompat = args.nodeCompat ?? config.node_compat;
752
- if (legacyNodeCompat) {
753
- logger.warn(
754
- "Enabling Node.js compatibility mode for built-ins and globals. This is experimental and has serious tradeoffs. Please see https://github.com/ionic-team/rollup-plugin-node-polyfills/ for more details."
755
- );
756
- }
757
-
758
- const compatibilityFlags =
759
- args.compatibilityFlags ?? config.compatibility_flags;
760
- const nodejsCompat = compatibilityFlags?.includes("nodejs_compat");
761
- if (legacyNodeCompat && nodejsCompat) {
762
- throw new Error(
763
- "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."
764
- );
765
- }
766
-
767
- if (args.experimentalEnableLocalPersistence) {
768
- logger.warn(
769
- `--experimental-enable-local-persistence is deprecated.\n` +
770
- `Move any existing data to .wrangler/state and use --persist, or\n` +
771
- `use --persist-to=./wrangler-local-state to keep using the old path.`
772
- );
773
- }
774
-
775
- const localPersistencePath = getLocalPersistencePath(
776
- args.persistTo,
777
- Boolean(args.persist),
778
- config.configPath
779
- );
780
-
781
- const cliDefines = collectKeyValues(args.define);
782
-
783
- return {
784
- entry,
785
- upstreamProtocol,
786
- legacyNodeCompat,
787
- nodejsCompat,
788
- getLocalPort,
789
- getInspectorPort,
790
- zoneId,
791
- host,
792
- routes,
793
- cliDefines,
794
- localPersistencePath,
795
- };
796
- }
797
-
798
- function getBindingsAndAssetPaths(args: StartDevOptions, configParam: Config) {
799
- const cliVars = collectKeyValues(args.var);
800
-
801
- // now log all available bindings into the terminal
802
- const bindings = getBindings(configParam, args.env, args.local ?? false, {
803
- kv: args.kv,
804
- vars: { ...args.vars, ...cliVars },
805
- durableObjects: args.durableObjects,
806
- r2: args.r2,
807
- d1Databases: args.d1Databases,
808
- });
809
-
810
- const maskedVars = maskVars(bindings, configParam);
811
-
812
- printBindings({
813
- ...bindings,
814
- vars: maskedVars,
815
- });
816
-
817
- const assetPaths =
818
- args.assets || configParam.assets
819
- ? getAssetPaths(configParam, args.assets)
820
- : getSiteAssetPaths(
821
- configParam,
822
- args.site,
823
- args.siteInclude,
824
- args.siteExclude
825
- );
826
- return { assetPaths, bindings };
827
- }
828
-
829
- function getBindings(
830
- configParam: Config,
831
- env: string | undefined,
832
- local: boolean,
833
- args: AdditionalDevProps
834
- ): CfWorkerInit["bindings"] {
835
- const bindings = {
836
- kv_namespaces: [
837
- ...(configParam.kv_namespaces || []).map(
838
- ({ binding, preview_id, id: _id }) => {
839
- // In `dev`, we make folks use a separate kv namespace called
840
- // `preview_id` instead of `id` so that they don't
841
- // break production data. So here we check that a `preview_id`
842
- // has actually been configured.
843
- // This whole block of code will be obsoleted in the future
844
- // when we have copy-on-write for previews on edge workers.
845
- if (!preview_id) {
846
- // TODO: This error has to be a _lot_ better, ideally just asking
847
- // to create a preview namespace for the user automatically
848
- throw new Error(
849
- `In development, you should use a separate kv namespace than the one you'd use in production. Please create a new kv namespace with "wrangler kv:namespace create <name> --preview" and add its id as preview_id to the kv_namespace "${binding}" in your wrangler.toml`
850
- ); // Ugh, I really don't like this message very much
851
- }
852
- return {
853
- binding,
854
- id: preview_id,
855
- };
856
- }
857
- ),
858
- ...(args.kv || []),
859
- ],
860
- send_email: configParam.send_email,
861
- // Use a copy of combinedVars since we're modifying it later
862
- vars: {
863
- ...getVarsForDev(configParam, env),
864
- ...args.vars,
865
- },
866
- wasm_modules: configParam.wasm_modules,
867
- text_blobs: configParam.text_blobs,
868
- data_blobs: configParam.data_blobs,
869
- durable_objects: {
870
- bindings: [
871
- ...(configParam.durable_objects || { bindings: [] }).bindings,
872
- ...(args.durableObjects || []),
873
- ],
874
- },
875
- queues: [
876
- ...(configParam.queues.producers || []).map((queue) => {
877
- return { binding: queue.binding, queue_name: queue.queue };
878
- }),
879
- ],
880
- r2_buckets: [
881
- ...(configParam.r2_buckets?.map(
882
- ({ binding, preview_bucket_name, bucket_name: _bucket_name }) => {
883
- // same idea as kv namespace preview id,
884
- // same copy-on-write TODO
885
- if (!preview_bucket_name) {
886
- throw new Error(
887
- `In development, you should use a separate r2 bucket than the one you'd use in production. Please create a new r2 bucket with "wrangler r2 bucket create <name>" and add its name as preview_bucket_name to the r2_buckets "${binding}" in your wrangler.toml`
888
- );
889
- }
890
- return {
891
- binding,
892
- bucket_name: preview_bucket_name,
893
- };
894
- }
895
- ) || []),
896
- ...(args.r2 || []),
897
- ],
898
- dispatch_namespaces: configParam.dispatch_namespaces,
899
- mtls_certificates: configParam.mtls_certificates,
900
- services: configParam.services,
901
- analytics_engine_datasets: configParam.analytics_engine_datasets,
902
- unsafe: {
903
- bindings: configParam.unsafe.bindings,
904
- metadata: configParam.unsafe.metadata,
905
- },
906
- logfwdr: configParam.logfwdr,
907
- d1_databases: identifyD1BindingsAsBeta([
908
- ...(configParam.d1_databases ?? []).map((d1Db) => {
909
- //in local dev, bindings don't matter
910
- if (local) {
911
- return {
912
- ...d1Db,
913
- database_id: "local",
914
- };
915
- }
916
- // if you have a preview_database_id, we'll use it, but we shouldn't force people to use it.
917
- if (!d1Db.preview_database_id && !process.env.NO_D1_WARNING) {
918
- logger.log(
919
- `--------------------\nšŸ’” Recommendation: for development, use a preview D1 database rather than the one you'd use in production.\nšŸ’” Create a new D1 database with "wrangler d1 create <name>" and add its id as preview_database_id to the d1_database "${d1Db.binding}" in your wrangler.toml\n--------------------\n`
920
- );
921
- }
922
- return {
923
- ...d1Db,
924
- database_id: d1Db.preview_database_id
925
- ? d1Db.preview_database_id
926
- : d1Db.database_id,
927
- };
928
- }),
929
- ...(args.d1Databases || []),
930
- ]),
931
- };
932
-
933
- return bindings;
934
- }