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
@@ -1,632 +0,0 @@
1
- import { readFile } from "node:fs/promises";
2
- import path from "node:path";
3
- import { Text } from "ink";
4
- import SelectInput from "ink-select-input";
5
- import React, { useState, useEffect, useRef } from "react";
6
- import { useErrorHandler } from "react-error-boundary";
7
- import { printBundleSize } from "../bundle-reporter";
8
- import {
9
- createPreviewSession,
10
- createWorkerPreview,
11
- } from "../create-worker-preview";
12
- import useInspector from "../inspect";
13
- import { logger } from "../logger";
14
- import { startPreviewServer, usePreviewServer } from "../proxy";
15
- import { helpIfErrorIsSizeOrScriptStartup } from "../publish/publish";
16
- import { syncAssets } from "../sites";
17
- import {
18
- getAccountChoices,
19
- requireApiToken,
20
- saveAccountToCache,
21
- } from "../user";
22
- import type { Route } from "../config/environment";
23
- import type {
24
- CfPreviewToken,
25
- CfPreviewSession,
26
- } from "../create-worker-preview";
27
- import type { AssetPaths } from "../sites";
28
- import type { ChooseAccountItem } from "../user";
29
- import type {
30
- CfModule,
31
- CfWorkerInit,
32
- CfScriptFormat,
33
- CfAccount,
34
- CfWorkerContext,
35
- } from "../worker";
36
- import type { EsbuildBundle } from "./use-esbuild";
37
-
38
- interface RemoteProps {
39
- name: string | undefined;
40
- bundle: EsbuildBundle | undefined;
41
- format: CfScriptFormat | undefined;
42
- isWorkersSite: boolean;
43
- assetPaths: AssetPaths | undefined;
44
- port: number;
45
- ip: string;
46
- localProtocol: "https" | "http";
47
- inspect: boolean;
48
- inspectorPort: number;
49
- accountId: string | undefined;
50
- bindings: CfWorkerInit["bindings"];
51
- compatibilityDate: string;
52
- compatibilityFlags: string[] | undefined;
53
- usageModel: "bundled" | "unbound" | undefined;
54
- env: string | undefined;
55
- legacyEnv: boolean | undefined;
56
- zone: string | undefined;
57
- host: string | undefined;
58
- routes: Route[] | undefined;
59
- onReady?: ((ip: string, port: number) => void) | undefined;
60
- sourceMapPath: string | undefined;
61
- sendMetrics: boolean | undefined;
62
- }
63
-
64
- export function Remote(props: RemoteProps) {
65
- const [accountId, setAccountId] = useState(props.accountId);
66
- const accountChoicesRef = useRef<Promise<ChooseAccountItem[]>>();
67
- const [accountChoices, setAccountChoices] = useState<ChooseAccountItem[]>();
68
-
69
- const previewToken = useWorker({
70
- name: props.name,
71
- bundle: props.bundle,
72
- format: props.format,
73
- modules: props.bundle ? props.bundle.modules : [],
74
- accountId,
75
- bindings: props.bindings,
76
- assetPaths: props.assetPaths,
77
- isWorkersSite: props.isWorkersSite,
78
- compatibilityDate: props.compatibilityDate,
79
- compatibilityFlags: props.compatibilityFlags,
80
- usageModel: props.usageModel,
81
- env: props.env,
82
- legacyEnv: props.legacyEnv,
83
- zone: props.zone,
84
- host: props.host,
85
- routes: props.routes,
86
- onReady: props.onReady,
87
- sendMetrics: props.sendMetrics,
88
- port: props.port,
89
- });
90
-
91
- usePreviewServer({
92
- previewToken,
93
- assetDirectory: props.isWorkersSite
94
- ? undefined
95
- : props.assetPaths?.assetDirectory,
96
- localProtocol: props.localProtocol,
97
- localPort: props.port,
98
- ip: props.ip,
99
- });
100
-
101
- useInspector({
102
- inspectorUrl:
103
- props.inspect && previewToken
104
- ? previewToken.inspectorUrl.href
105
- : undefined,
106
- port: props.inspectorPort,
107
- logToTerminal: true,
108
- sourceMapPath: props.sourceMapPath,
109
- host: previewToken?.host,
110
- });
111
-
112
- const errorHandler = useErrorHandler();
113
-
114
- // This effect handles the async step of fetching the available accounts for the current user.
115
- // If only one account is available then it is just used by calling `setAccountId()`.
116
- useEffect(() => {
117
- if (
118
- accountChoicesRef.current !== undefined ||
119
- props.accountId !== undefined
120
- ) {
121
- return;
122
- }
123
- accountChoicesRef.current = getAccountChoices();
124
- accountChoicesRef.current.then(
125
- (accounts) => {
126
- if (accounts.length === 1) {
127
- saveAccountToCache({
128
- id: accounts[0].id,
129
- name: accounts[0].name,
130
- });
131
- setAccountId(accounts[0].id);
132
- } else {
133
- setAccountChoices(accounts);
134
- }
135
- },
136
- (err) => {
137
- errorHandler(err);
138
- }
139
- );
140
- });
141
-
142
- // If we have not already chosen an account and there are multiple accounts available
143
- // allow the users to select one.
144
- return accountId === undefined && accountChoices !== undefined ? (
145
- <ChooseAccount
146
- accounts={accountChoices}
147
- onSelect={(selectedAccount) => {
148
- saveAccountToCache(selectedAccount);
149
- setAccountId(selectedAccount.id);
150
- }}
151
- onError={(err) => errorHandler(err)}
152
- ></ChooseAccount>
153
- ) : null;
154
- }
155
-
156
- interface RemoteWorkerProps {
157
- name: string | undefined;
158
- bundle: EsbuildBundle | undefined;
159
- format: CfScriptFormat | undefined;
160
- modules: CfModule[];
161
- accountId: string | undefined;
162
- bindings: CfWorkerInit["bindings"];
163
- assetPaths: AssetPaths | undefined;
164
- isWorkersSite: boolean;
165
- compatibilityDate: string | undefined;
166
- compatibilityFlags: string[] | undefined;
167
- usageModel: "bundled" | "unbound" | undefined;
168
- env: string | undefined;
169
- legacyEnv: boolean | undefined;
170
- zone: string | undefined;
171
- host: string | undefined;
172
- routes: Route[] | undefined;
173
- onReady: ((ip: string, port: number) => void) | undefined;
174
- sendMetrics: boolean | undefined;
175
- port: number;
176
- }
177
-
178
- export function useWorker(
179
- props: RemoteWorkerProps
180
- ): CfPreviewToken | undefined {
181
- const [session, setSession] = useState<CfPreviewSession | undefined>();
182
- const [token, setToken] = useState<CfPreviewToken | undefined>();
183
- const [restartCounter, setRestartCounter] = useState<number>(0);
184
- // This is the most reliable way to detect whether
185
- // something's "happened" in our system; We make a ref and
186
- // mark it once we log our initial message. Refs are vars!
187
- const startedRef = useRef(false);
188
- // functions must be destructured before use inside a useEffect, otherwise the entire props object has to be added to the dependency array
189
- const { onReady } = props;
190
- // This effect sets up the preview session
191
- useEffect(() => {
192
- const abortController = new AbortController();
193
- async function start() {
194
- if (props.accountId === undefined) {
195
- return;
196
- }
197
- const { workerAccount, workerContext } = getWorkerAccountAndContext({
198
- accountId: props.accountId,
199
- env: props.env,
200
- legacyEnv: props.legacyEnv,
201
- zone: props.zone,
202
- host: props.host,
203
- routes: props.routes,
204
- sendMetrics: props.sendMetrics,
205
- });
206
-
207
- setSession(
208
- await createPreviewSession(
209
- workerAccount,
210
- workerContext,
211
- abortController.signal
212
- )
213
- );
214
- }
215
- start().catch((err) => {
216
- // instead of logging the raw API error to the user,
217
- // give them friendly instructions
218
- // for error 10063 (workers.dev subdomain required)
219
- if (err.code === 10063) {
220
- const errorMessage =
221
- "Error: You need to register a workers.dev subdomain before running the dev command in remote mode";
222
- const solutionMessage =
223
- "You can either enable local mode by pressing l, or register a workers.dev subdomain here:";
224
- const onboardingLink = `https://dash.cloudflare.com/${props.accountId}/workers/onboarding`;
225
- logger.error(`${errorMessage}\n${solutionMessage}\n${onboardingLink}`);
226
- }
227
- // we want to log the error, but not end the process
228
- // since it could recover after the developer fixes whatever's wrong
229
- else if ((err as { code: string }).code !== "ABORT_ERR") {
230
- logger.error("Error while creating remote dev session:", err);
231
- }
232
- });
233
-
234
- return () => {
235
- abortController.abort();
236
- };
237
- }, [
238
- props.accountId,
239
- props.env,
240
- props.host,
241
- props.legacyEnv,
242
- props.routes,
243
- props.zone,
244
- props.sendMetrics,
245
- restartCounter,
246
- ]);
247
-
248
- // This effect uses the session to upload the worker and create a preview
249
- useEffect(() => {
250
- const abortController = new AbortController();
251
- async function start() {
252
- if (props.accountId === undefined) {
253
- return;
254
- }
255
- if (session === undefined) {
256
- return;
257
- }
258
- setToken(undefined); // reset token in case we're re-running
259
-
260
- if (!props.bundle || !props.format) return;
261
-
262
- if (!startedRef.current) {
263
- startedRef.current = true;
264
- } else {
265
- logger.log("⎔ Detected changes, restarted server.");
266
- }
267
-
268
- const init = await createRemoteWorkerInit({
269
- bundle: props.bundle,
270
- modules: props.modules,
271
- accountId: props.accountId,
272
- name: props.name,
273
- legacyEnv: props.legacyEnv,
274
- env: props.env,
275
- isWorkersSite: props.isWorkersSite,
276
- assetPaths: props.assetPaths,
277
- format: props.format,
278
- bindings: props.bindings,
279
- compatibilityDate: props.compatibilityDate,
280
- compatibilityFlags: props.compatibilityFlags,
281
- usageModel: props.usageModel,
282
- });
283
-
284
- const { workerAccount, workerContext } = getWorkerAccountAndContext({
285
- accountId: props.accountId,
286
- env: props.env,
287
- legacyEnv: props.legacyEnv,
288
- zone: props.zone,
289
- host: props.host,
290
- routes: props.routes,
291
- sendMetrics: props.sendMetrics,
292
- });
293
-
294
- const workerPreviewToken = await createWorkerPreview(
295
- init,
296
- workerAccount,
297
- workerContext,
298
- session,
299
- abortController.signal
300
- );
301
-
302
- setToken(workerPreviewToken);
303
-
304
- // TODO: Once we get service bindings working in the
305
- // edge preview server, we can define remote dev service bindings
306
- // and you can uncomment this code.
307
- // https://github.com/cloudflare/workers-sdk/issues/1182
308
-
309
- /*
310
- if (name) {
311
- await registerWorker(name, {
312
- mode: "remote",
313
- // upstream protocol is always https (https://github.com/cloudflare/workers-sdk/issues/583)
314
- protocol: "https",
315
- port: undefined,
316
- host: workerPreviewToken.host,
317
- headers: {
318
- "cf-workers-preview-token": workerPreviewToken.value,
319
- host: workerPreviewToken.host,
320
- },
321
- });
322
- }
323
- */
324
- onReady?.(props.host || "localhost", props.port);
325
- }
326
- start().catch((err) => {
327
- // we want to log the error, but not end the process
328
- // since it could recover after the developer fixes whatever's wrong
329
- if ((err as { code: string }).code !== "ABORT_ERR") {
330
- // instead of logging the raw API error to the user,
331
- // give them friendly instructions
332
- // for error 10063 (workers.dev subdomain required)
333
- if (err.code === 10063) {
334
- const errorMessage =
335
- "Error: You need to register a workers.dev subdomain before running the dev command in remote mode";
336
- const solutionMessage =
337
- "You can either enable local mode by pressing l, or register a workers.dev subdomain here:";
338
- const onboardingLink = `https://dash.cloudflare.com/${props.accountId}/workers/onboarding`;
339
- logger.error(
340
- `${errorMessage}\n${solutionMessage}\n${onboardingLink}`
341
- );
342
- } else if (err.code === 10049) {
343
- logger.log("Preview token expired, fetching a new one");
344
- // code 10049 happens when the preview token expires
345
- // since we want a new preview token when this happens,
346
- // lets increment the counter, and trigger a rerun of
347
- // the useEffect above
348
- setRestartCounter((prevCount) => prevCount + 1);
349
- } else {
350
- logger.error("Error on remote worker:", err);
351
- }
352
- }
353
- });
354
-
355
- return () => {
356
- abortController.abort();
357
- };
358
- }, [
359
- props.name,
360
- props.bundle,
361
- props.format,
362
- props.accountId,
363
- props.assetPaths,
364
- props.isWorkersSite,
365
- props.compatibilityDate,
366
- props.compatibilityFlags,
367
- props.usageModel,
368
- props.bindings,
369
- props.modules,
370
- props.env,
371
- props.legacyEnv,
372
- props.zone,
373
- props.host,
374
- props.routes,
375
- session,
376
- onReady,
377
- props.sendMetrics,
378
- props.port,
379
- ]);
380
-
381
- return token;
382
- }
383
-
384
- export async function startRemoteServer(props: RemoteProps) {
385
- let accountId = props.accountId;
386
- if (accountId === undefined) {
387
- const accountChoices = await getAccountChoices();
388
- if (accountChoices.length === 1) {
389
- saveAccountToCache({
390
- id: accountChoices[0].id,
391
- name: accountChoices[0].name,
392
- });
393
- accountId = accountChoices[0].id;
394
- } else {
395
- throw logger.error(
396
- "In a non-interactive environment, it is mandatory to specify an account ID, either by assigning its value to CLOUDFLARE_ACCOUNT_ID, or as `account_id` in your `wrangler.toml` file."
397
- );
398
- }
399
- }
400
-
401
- const previewToken = await getRemotePreviewToken({
402
- ...props,
403
- accountId: accountId,
404
- });
405
-
406
- if (previewToken === undefined) {
407
- throw logger.error("Failed to get a previewToken");
408
- }
409
- // start our proxy server
410
- const previewServer = await startPreviewServer({
411
- previewToken,
412
- assetDirectory: props.isWorkersSite
413
- ? undefined
414
- : props.assetPaths?.assetDirectory,
415
- localProtocol: props.localProtocol,
416
- localPort: props.port,
417
- ip: props.ip,
418
- onReady: props.onReady,
419
- });
420
- if (!previewServer) {
421
- throw logger.error("Failed to start remote server");
422
- }
423
- return { stop: previewServer.stop };
424
- }
425
-
426
- /**
427
- * getRemotePreviewToken is a react-free version of `useWorker`.
428
- * It returns a preview token, which we then use in our proxy server
429
- */
430
- export async function getRemotePreviewToken(props: RemoteProps) {
431
- //setup the preview session
432
- async function start() {
433
- if (props.accountId === undefined) {
434
- throw logger.error("no accountId provided");
435
- }
436
- const abortController = new AbortController();
437
- const { workerAccount, workerContext } = getWorkerAccountAndContext({
438
- accountId: props.accountId,
439
- env: props.env,
440
- legacyEnv: props.legacyEnv,
441
- zone: props.zone,
442
- host: props.host,
443
- routes: props.routes,
444
- sendMetrics: props.sendMetrics,
445
- });
446
- const session = await createPreviewSession(
447
- workerAccount,
448
- workerContext,
449
- abortController.signal
450
- );
451
- //use the session to upload the worker, and create a preview
452
-
453
- if (session === undefined) {
454
- throw logger.error("Failed to start a session");
455
- }
456
- if (!props.bundle || !props.format) return;
457
-
458
- const init = await createRemoteWorkerInit({
459
- bundle: props.bundle,
460
- modules: props.bundle ? props.bundle.modules : [],
461
- accountId: props.accountId,
462
- name: props.name,
463
- legacyEnv: props.legacyEnv,
464
- env: props.env,
465
- isWorkersSite: props.isWorkersSite,
466
- assetPaths: props.assetPaths,
467
- format: props.format,
468
- bindings: props.bindings,
469
- compatibilityDate: props.compatibilityDate,
470
- compatibilityFlags: props.compatibilityFlags,
471
- usageModel: props.usageModel,
472
- });
473
- const workerPreviewToken = await createWorkerPreview(
474
- init,
475
- workerAccount,
476
- workerContext,
477
- session,
478
- abortController.signal
479
- );
480
- return workerPreviewToken;
481
- }
482
- return start().catch((err) => {
483
- if ((err as { code?: string })?.code !== "ABORT_ERR") {
484
- // instead of logging the raw API error to the user,
485
- // give them friendly instructions
486
- // for error 10063 (workers.dev subdomain required)
487
- if (err?.code === 10063) {
488
- const errorMessage =
489
- "Error: You need to register a workers.dev subdomain before running the dev command in remote mode";
490
- const solutionMessage =
491
- "You can either enable local mode by pressing l, or register a workers.dev subdomain here:";
492
- const onboardingLink = `https://dash.cloudflare.com/${props.accountId}/workers/onboarding`;
493
- logger.error(`${errorMessage}\n${solutionMessage}\n${onboardingLink}`);
494
- } else if (err?.code === 10049) {
495
- // code 10049 happens when the preview token expires
496
- logger.log("Preview token expired, restart server to fetch a new one");
497
- } else {
498
- helpIfErrorIsSizeOrScriptStartup(err, props.bundle?.dependencies || {});
499
- logger.error("Error on remote worker:", err);
500
- }
501
- }
502
- });
503
- }
504
-
505
- async function createRemoteWorkerInit(props: {
506
- bundle: EsbuildBundle;
507
- modules: CfModule[];
508
- accountId: string;
509
- name: string | undefined;
510
- legacyEnv: boolean | undefined;
511
- env: string | undefined;
512
- isWorkersSite: boolean;
513
- assetPaths: AssetPaths | undefined;
514
- format: CfScriptFormat;
515
- bindings: CfWorkerInit["bindings"];
516
- compatibilityDate: string | undefined;
517
- compatibilityFlags: string[] | undefined;
518
- usageModel: "bundled" | "unbound" | undefined;
519
- }) {
520
- const content = await readFile(props.bundle.path, "utf-8");
521
-
522
- // TODO: For Dev we could show the reporter message in the interactive box.
523
- void printBundleSize(
524
- { name: path.basename(props.bundle.path), content: content },
525
- props.modules
526
- );
527
-
528
- const assets = await syncAssets(
529
- props.accountId,
530
- // When we're using the newer service environments, we wouldn't
531
- // have added the env name on to the script name. However, we must
532
- // include it in the kv namespace name regardless (since there's no
533
- // concept of service environments for kv namespaces yet).
534
- props.name + (!props.legacyEnv && props.env ? `-${props.env}` : ""),
535
- props.isWorkersSite ? props.assetPaths : undefined,
536
- true,
537
- false
538
- ); // TODO: cancellable?
539
-
540
- const init: CfWorkerInit = {
541
- name: props.name,
542
- main: {
543
- name: path.basename(props.bundle.path),
544
- type: props.format === "modules" ? "esm" : "commonjs",
545
- content,
546
- },
547
- modules: props.modules.concat(
548
- assets.manifest
549
- ? {
550
- name: "__STATIC_CONTENT_MANIFEST",
551
- content: JSON.stringify(assets.manifest),
552
- type: "text",
553
- }
554
- : []
555
- ),
556
- bindings: {
557
- ...props.bindings,
558
- kv_namespaces: (props.bindings.kv_namespaces || []).concat(
559
- assets.namespace
560
- ? { binding: "__STATIC_CONTENT", id: assets.namespace }
561
- : []
562
- ),
563
- text_blobs: {
564
- ...props.bindings.text_blobs,
565
- ...(assets.manifest &&
566
- props.format === "service-worker" && {
567
- __STATIC_CONTENT_MANIFEST: "__STATIC_CONTENT_MANIFEST",
568
- }),
569
- },
570
- },
571
- migrations: undefined, // no migrations in dev
572
- compatibility_date: props.compatibilityDate,
573
- compatibility_flags: props.compatibilityFlags,
574
- usage_model: props.usageModel,
575
- keepVars: true,
576
- logpush: false,
577
- };
578
-
579
- return init;
580
- }
581
-
582
- function getWorkerAccountAndContext(props: {
583
- accountId: string;
584
- env?: string;
585
- legacyEnv?: boolean;
586
- zone?: string;
587
- host?: string;
588
- routes: Route[] | undefined;
589
- sendMetrics?: boolean;
590
- }): { workerAccount: CfAccount; workerContext: CfWorkerContext } {
591
- const workerAccount: CfAccount = {
592
- accountId: props.accountId,
593
- apiToken: requireApiToken(),
594
- };
595
-
596
- const workerContext: CfWorkerContext = {
597
- env: props.env,
598
- legacyEnv: props.legacyEnv,
599
- zone: props.zone,
600
- host: props.host,
601
- routes: props.routes,
602
- sendMetrics: props.sendMetrics,
603
- };
604
-
605
- return { workerAccount, workerContext };
606
- }
607
-
608
- /**
609
- * A component that allows the user to select from a list of available accounts.
610
- */
611
- function ChooseAccount(props: {
612
- accounts: ChooseAccountItem[];
613
- onSelect: (account: { name: string; id: string }) => void;
614
- onError: (error: Error) => void;
615
- }) {
616
- return (
617
- <>
618
- <Text bold>Select an account from below:</Text>
619
- <SelectInput
620
- items={props.accounts.map((item) => ({
621
- key: item.id,
622
- label: item.name,
623
- value: item,
624
- }))}
625
- onSelect={(item) => {
626
- logger.log(`Using account: "${item.value.name} - ${item.value.id}"`);
627
- props.onSelect({ id: item.value.id, name: item.value.name });
628
- }}
629
- />
630
- </>
631
- );
632
- }