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/index.ts DELETED
@@ -1,768 +0,0 @@
1
- import os from "node:os";
2
- import TOML from "@iarna/toml";
3
- import chalk from "chalk";
4
- import supportsColor from "supports-color";
5
- import { ProxyAgent, setGlobalDispatcher } from "undici";
6
- import makeCLI from "yargs";
7
- import { version as wranglerVersion } from "../package.json";
8
- import { isBuildFailure } from "./bundle";
9
- import { loadDotEnv, readConfig } from "./config";
10
- import { constellation } from "./constellation";
11
- import { d1 } from "./d1";
12
- import { deleteHandler, deleteOptions } from "./delete";
13
- import {
14
- deployments,
15
- commonDeploymentCMDSetup,
16
- rollbackDeployment,
17
- viewDeployment,
18
- } from "./deployments";
19
- import {
20
- buildHandler,
21
- buildOptions,
22
- configHandler,
23
- noOpOptions,
24
- previewHandler,
25
- previewOptions,
26
- route,
27
- routeHandler,
28
- subdomainHandler,
29
- subdomainOptions,
30
- } from "./deprecated";
31
- import { devHandler, devOptions } from "./dev";
32
- import { workerNamespaceCommands } from "./dispatch-namespace";
33
- import { docsHandler, docsOptions } from "./docs";
34
- import { generateHandler, generateOptions } from "./generate";
35
- import { initHandler, initOptions } from "./init";
36
- import { kvNamespace, kvKey, kvBulk } from "./kv";
37
- import { logBuildFailure, logger } from "./logger";
38
- import * as metrics from "./metrics";
39
- import { mTlsCertificateCommands } from "./mtls-certificate/cli";
40
- import { pages } from "./pages";
41
- import { formatMessage, ParseError } from "./parse";
42
- import { publishOptions, publishHandler } from "./publish";
43
- import { pubSubCommands } from "./pubsub/pubsub-commands";
44
- import { queues } from "./queues/cli/commands";
45
- import { r2 } from "./r2";
46
- import { secret, secretBulkHandler, secretBulkOptions } from "./secret";
47
- import { tailOptions, tailHandler } from "./tail";
48
- import { generateTypes } from "./type-generation";
49
- import { updateCheck } from "./update-check";
50
- import { listScopes, login, logout, validateScopeKeys } from "./user";
51
- import { whoami } from "./whoami";
52
-
53
- import type { Config } from "./config";
54
- import type { CommonYargsArgv, CommonYargsOptions } from "./yargs-types";
55
- import type Yargs from "yargs";
56
-
57
- const resetColor = "\x1b[0m";
58
- const fgGreenColor = "\x1b[32m";
59
- export const DEFAULT_LOCAL_PORT = 8787;
60
- export const DEFAULT_INSPECTOR_PORT = 9229;
61
-
62
- const proxy =
63
- process.env.https_proxy ||
64
- process.env.HTTPS_PROXY ||
65
- process.env.http_proxy ||
66
- process.env.HTTP_PROXY ||
67
- undefined;
68
-
69
- if (proxy) {
70
- setGlobalDispatcher(new ProxyAgent(proxy));
71
- logger.log(
72
- `Proxy environment variables detected. We'll use your proxy for fetch requests.`
73
- );
74
- }
75
-
76
- export function getRules(config: Config): Config["rules"] {
77
- const rules = config.rules ?? config.build?.upload?.rules ?? [];
78
-
79
- if (config.rules && config.build?.upload?.rules) {
80
- throw new Error(
81
- `You cannot configure both [rules] and [build.upload.rules] in your wrangler.toml. Delete the \`build.upload\` section.`
82
- );
83
- }
84
-
85
- if (config.build?.upload?.rules) {
86
- logger.warn(
87
- `Deprecation: The \`build.upload.rules\` config field is no longer used, the rules should be specified via the \`rules\` config field. Delete the \`build.upload\` field from the configuration file, and add this:
88
-
89
- ${TOML.stringify({ rules: config.build.upload.rules })}`
90
- );
91
- }
92
- return rules;
93
- }
94
-
95
- export async function printWranglerBanner() {
96
- // Let's not print this in tests
97
- if (typeof jest !== "undefined") {
98
- return;
99
- }
100
-
101
- const text = ` ⛅️ wrangler ${wranglerVersion} ${await updateCheck()}`;
102
-
103
- logger.log(
104
- text +
105
- "\n" +
106
- (supportsColor.stdout
107
- ? chalk.hex("#FF8800")("-".repeat(text.length))
108
- : "-".repeat(text.length))
109
- );
110
- }
111
-
112
- export function isLegacyEnv(config: Config): boolean {
113
- // We only read from config here, because we've already accounted for
114
- // args["legacy-env"] in https://github.com/cloudflare/workers-sdk/blob/b24aeb5722370c2e04bce97a84a1fa1e55725d79/packages/wrangler/src/config/validation.ts#L94-L98
115
- return config.legacy_env;
116
- }
117
-
118
- export function getScriptName(
119
- args: { name: string | undefined; env: string | undefined },
120
- config: Config
121
- ): string | undefined {
122
- if (args.name && isLegacyEnv(config) && args.env) {
123
- throw new CommandLineArgsError(
124
- "In legacy environment mode you cannot use --name and --env together. If you want to specify a Worker name for a specific environment you can add the following to your wrangler.toml config:" +
125
- `
126
- [env.${args.env}]
127
- name = "${args.name}"
128
- `
129
- );
130
- }
131
-
132
- return args.name ?? config.name;
133
- }
134
-
135
- /**
136
- * Alternative to the getScriptName() because special Legacy cases allowed "name", and "env" together in Wrangler v1
137
- */
138
- export function getLegacyScriptName(
139
- args: { name: string | undefined; env: string | undefined },
140
- config: Config
141
- ) {
142
- return args.name && args.env && isLegacyEnv(config)
143
- ? `${args.name}-${args.env}`
144
- : args.name ?? config.name;
145
- }
146
-
147
- // a helper to demand one of a set of options
148
- // via https://github.com/yargs/yargs/issues/1093#issuecomment-491299261
149
- export function demandOneOfOption(...options: string[]) {
150
- return function (argv: Yargs.Arguments) {
151
- const count = options.filter((option) => argv[option]).length;
152
- const lastOption = options.pop();
153
-
154
- if (count === 0) {
155
- throw new CommandLineArgsError(
156
- `Exactly one of the arguments ${options.join(
157
- ", "
158
- )} and ${lastOption} is required`
159
- );
160
- } else if (count > 1) {
161
- throw new CommandLineArgsError(
162
- `Arguments ${options.join(
163
- ", "
164
- )} and ${lastOption} are mutually exclusive`
165
- );
166
- }
167
-
168
- return true;
169
- };
170
- }
171
-
172
- export class CommandLineArgsError extends Error {}
173
-
174
- export function createCLIParser(argv: string[]) {
175
- // Type check result against CommonYargsOptions to make sure we've included
176
- // all common options
177
- const wrangler: CommonYargsArgv = makeCLI(argv)
178
- .strict()
179
- // We handle errors ourselves in a try-catch around `yargs.parse`.
180
- // If you want the "help info" to be displayed then throw an instance of `CommandLineArgsError`.
181
- // Otherwise we just log the error that was thrown without any "help info".
182
- .showHelpOnFail(false)
183
- .fail((msg, error) => {
184
- if (!error || error.name === "YError") {
185
- // If there is no error or the error is a "YError", then this came from yargs own validation
186
- // Wrap it in a `CommandLineArgsError` so that we can handle it appropriately further up.
187
- error = new CommandLineArgsError(msg);
188
- }
189
- throw error;
190
- })
191
- .scriptName("wrangler")
192
- .wrap(null)
193
- // Define global options here, so they get included in the `Argv` type of
194
- // the `wrangler` variable
195
- .version(false)
196
- .option("v", {
197
- describe: "Show version number",
198
- alias: "version",
199
- type: "boolean",
200
- })
201
- .option("config", {
202
- alias: "c",
203
- describe: "Path to .toml configuration file",
204
- type: "string",
205
- requiresArg: true,
206
- })
207
- .option("env", {
208
- alias: "e",
209
- describe: "Environment to use for operations and .env files",
210
- type: "string",
211
- requiresArg: true,
212
- })
213
- .option("experimental-json-config", {
214
- alias: "j",
215
- describe: `Experimental: Support wrangler.json`,
216
- type: "boolean",
217
- })
218
- .check((args) => {
219
- // Grab locally specified env params from `.env` file
220
- const loaded = loadDotEnv(".env", args.env);
221
- for (const [key, value] of Object.entries(loaded?.parsed ?? {})) {
222
- if (!(key in process.env)) process.env[key] = value;
223
- }
224
- return true;
225
- });
226
-
227
- wrangler.group(
228
- ["experimental-json-config", "config", "env", "help", "version"],
229
- "Flags:"
230
- );
231
- wrangler.help().alias("h", "help");
232
-
233
- // Default help command that supports the subcommands
234
- const subHelp: Yargs.CommandModule<CommonYargsOptions, CommonYargsOptions> = {
235
- command: ["*"],
236
- handler: async (args) => {
237
- setImmediate(() =>
238
- wrangler.parse([...args._.map((a) => `${a}`), "--help"])
239
- );
240
- },
241
- };
242
- wrangler.command(
243
- ["*"],
244
- false,
245
- () => {},
246
- async (args) => {
247
- if (args._.length > 0) {
248
- throw new CommandLineArgsError(`Unknown command: ${args._}.`);
249
- } else {
250
- // args.v will exist and be true in the case that no command is called, and the -v
251
- // option is present. This is to allow for running asynchronous printWranglerBanner
252
- // in the version command.
253
- if (args.v) {
254
- if (process.stdout.isTTY) {
255
- await printWranglerBanner();
256
- } else {
257
- logger.log(wranglerVersion);
258
- }
259
- } else {
260
- wrangler.showHelp("log");
261
- }
262
- }
263
- }
264
- );
265
-
266
- // You will note that we use the form for all commands where we use the builder function
267
- // to define options and subcommands.
268
- // Further we return the result of this builder even though it's not completely necessary.
269
- // The reason is that it's required for type inference of the args in the handle function.
270
- // I wish we could enforce this pattern, but this comment will have to do for now.
271
- // (It's also annoying that choices[] doesn't get inferred as an enum. 🤷‍♂.)
272
-
273
- // docs
274
- wrangler.command(
275
- "docs [command..]",
276
- "📚 Open wrangler's docs in your browser",
277
- docsOptions,
278
- docsHandler
279
- );
280
-
281
- // init
282
- wrangler.command(
283
- "init [name]",
284
- "📥 Initialize a basic Worker project, including a wrangler.toml file",
285
- initOptions,
286
- initHandler
287
- );
288
-
289
- // generate
290
- wrangler.command(
291
- "generate [name] [template]",
292
- "✨ Generate a new Worker project from an existing Worker template. See https://github.com/cloudflare/templates",
293
- generateOptions,
294
- generateHandler
295
- );
296
-
297
- // [DEPRECATED] build
298
- wrangler.command("build", false, buildOptions, buildHandler);
299
-
300
- // [DEPRECATED] config
301
- wrangler.command("config", false, noOpOptions, configHandler);
302
-
303
- // dev
304
- wrangler.command(
305
- "dev [script]",
306
- "👂 Start a local server for developing your worker",
307
- devOptions,
308
- devHandler
309
- );
310
-
311
- // publish
312
- wrangler.command(
313
- "publish [script]",
314
- "🆙 Publish your Worker to Cloudflare.",
315
- publishOptions,
316
- publishHandler
317
- );
318
-
319
- // delete
320
- wrangler.command(
321
- "delete [script]",
322
- "🗑 Delete your Worker from Cloudflare.",
323
- deleteOptions,
324
- deleteHandler
325
- );
326
-
327
- // tail
328
- wrangler.command(
329
- "tail [worker]",
330
- "🦚 Starts a log tailing session for a published Worker.",
331
- tailOptions,
332
- tailHandler
333
- );
334
-
335
- // [DEPRECATED] preview
336
- wrangler.command(
337
- "preview [method] [body]",
338
- false,
339
- previewOptions,
340
- previewHandler
341
- );
342
-
343
- // [DEPRECATED] route
344
- wrangler.command(
345
- "route",
346
- false, // I think we want to hide this command
347
- // "➡️ List or delete worker routes",
348
- (routeYargs) => {
349
- return route(routeYargs);
350
- },
351
- routeHandler
352
- );
353
-
354
- // [DEPRECATED] subdomain
355
- wrangler.command(
356
- "subdomain [name]",
357
- false,
358
- // "👷 Create or change your workers.dev subdomain.",
359
- subdomainOptions,
360
- subdomainHandler
361
- );
362
-
363
- // secret
364
- wrangler.command(
365
- "secret",
366
- "🤫 Generate a secret that can be referenced in a Worker",
367
- (secretYargs) => {
368
- return secret(secretYargs.command(subHelp));
369
- }
370
- );
371
-
372
- wrangler.command(
373
- "secret:bulk <json>",
374
- "🗄️ Bulk upload secrets for a Worker",
375
- secretBulkOptions,
376
- secretBulkHandler
377
- );
378
-
379
- // kv namespace
380
- wrangler.command(
381
- "kv:namespace",
382
- "🗂️ Interact with your Workers KV Namespaces",
383
- (namespaceYargs) => {
384
- return kvNamespace(namespaceYargs.command(subHelp));
385
- }
386
- );
387
-
388
- // kv key
389
- wrangler.command(
390
- "kv:key",
391
- "🔑 Individually manage Workers KV key-value pairs",
392
- (keyYargs) => {
393
- return kvKey(keyYargs.command(subHelp));
394
- }
395
- );
396
-
397
- // kv bulk
398
- wrangler.command(
399
- "kv:bulk",
400
- "💪 Interact with multiple Workers KV key-value pairs at once",
401
- (bulkYargs) => {
402
- return kvBulk(bulkYargs.command(subHelp));
403
- }
404
- );
405
-
406
- // pages
407
- wrangler.command("pages", "⚡️ Configure Cloudflare Pages", (pagesYargs) => {
408
- return pages(pagesYargs.command(subHelp));
409
- });
410
-
411
- // queues
412
- wrangler.command("queues", "🇶 Configure Workers Queues", (queuesYargs) => {
413
- return queues(queuesYargs.command(subHelp));
414
- });
415
-
416
- // r2
417
- wrangler.command("r2", "📦 Interact with an R2 store", (r2Yargs) => {
418
- return r2(r2Yargs.command(subHelp));
419
- });
420
-
421
- // dispatch-namespace
422
- wrangler.command(
423
- "dispatch-namespace",
424
- "📦 Interact with a dispatch namespace",
425
- (workerNamespaceYargs) => {
426
- return workerNamespaceCommands(workerNamespaceYargs, subHelp);
427
- }
428
- );
429
-
430
- // d1
431
- wrangler.command("d1", "🗄 Interact with a D1 database", (d1Yargs) => {
432
- return d1(d1Yargs.command(subHelp));
433
- });
434
-
435
- // ai
436
- wrangler.command(
437
- "constellation",
438
- "🤖 Interact with Constellation AI models",
439
- (aiYargs) => {
440
- return constellation(aiYargs.command(subHelp));
441
- }
442
- );
443
-
444
- // pubsub
445
- wrangler.command(
446
- "pubsub",
447
- "📮 Interact and manage Pub/Sub Brokers",
448
- (pubsubYargs) => {
449
- return pubSubCommands(pubsubYargs, subHelp);
450
- }
451
- );
452
-
453
- // mtls-certificate
454
- wrangler.command(
455
- "mtls-certificate",
456
- "🪪 Manage certificates used for mTLS connections",
457
- (mtlsYargs) => {
458
- return mTlsCertificateCommands(mtlsYargs.command(subHelp));
459
- }
460
- );
461
-
462
- /**
463
- * User Group: login, logout, and whoami
464
- * TODO: group commands into User group similar to .group() for flags in yargs
465
- */
466
- // login
467
- wrangler.command(
468
- // this needs scopes as an option?
469
- "login",
470
- "🔓 Login to Cloudflare",
471
- (yargs) => {
472
- // TODO: This needs some copy editing
473
- // I mean, this entire app does, but this too.
474
- return yargs
475
- .option("scopes-list", {
476
- describe: "List all the available OAuth scopes with descriptions",
477
- })
478
- .option("browser", {
479
- default: true,
480
- type: "boolean",
481
- describe: "Automatically open the OAuth link in a browser",
482
- })
483
- .option("scopes", {
484
- describe: "Pick the set of applicable OAuth scopes when logging in",
485
- array: true,
486
- type: "string",
487
- requiresArg: true,
488
- });
489
-
490
- // TODO: scopes
491
- },
492
- async (args) => {
493
- await printWranglerBanner();
494
- if (args["scopes-list"]) {
495
- listScopes();
496
- return;
497
- }
498
- if (args.scopes) {
499
- if (args.scopes.length === 0) {
500
- // don't allow no scopes to be passed, that would be weird
501
- listScopes();
502
- return;
503
- }
504
- if (!validateScopeKeys(args.scopes)) {
505
- throw new CommandLineArgsError(
506
- `One of ${args.scopes} is not a valid authentication scope. Run "wrangler login --list-scopes" to see the valid scopes.`
507
- );
508
- }
509
- await login({ scopes: args.scopes, browser: args.browser });
510
- return;
511
- }
512
- await login({ browser: args.browser });
513
- const config = readConfig(args.config, args);
514
- await metrics.sendMetricsEvent("login user", {
515
- sendMetrics: config.send_metrics,
516
- });
517
-
518
- // TODO: would be nice if it optionally saved login
519
- // credentials inside node_modules/.cache or something
520
- // this way you could have multiple users on a single machine
521
- }
522
- );
523
-
524
- // logout
525
- wrangler.command(
526
- // this needs scopes as an option?
527
- "logout",
528
- "🚪 Logout from Cloudflare",
529
- () => {},
530
- async (args) => {
531
- await printWranglerBanner();
532
- await logout();
533
- const config = readConfig(undefined, args);
534
- await metrics.sendMetricsEvent("logout user", {
535
- sendMetrics: config.send_metrics,
536
- });
537
- }
538
- );
539
-
540
- // whoami
541
- wrangler.command(
542
- "whoami",
543
- "🕵️ Retrieve your user info and test your auth config",
544
- () => {},
545
- async (args) => {
546
- await printWranglerBanner();
547
- await whoami();
548
- const config = readConfig(undefined, args);
549
- await metrics.sendMetricsEvent("view accounts", {
550
- sendMetrics: config.send_metrics,
551
- });
552
- }
553
- );
554
-
555
- // type generation
556
- wrangler.command(
557
- "types",
558
- "📝 Generate types from bindings & module rules in config",
559
- () => {},
560
- async (args) => {
561
- await printWranglerBanner();
562
- const config = readConfig(undefined, args);
563
-
564
- const configBindings: Partial<Config> = {
565
- kv_namespaces: config.kv_namespaces ?? [],
566
- vars: { ...config.vars },
567
- wasm_modules: config.wasm_modules,
568
- text_blobs: {
569
- ...config.text_blobs,
570
- },
571
- data_blobs: config.data_blobs,
572
- durable_objects: config.durable_objects,
573
- r2_buckets: config.r2_buckets,
574
- d1_databases: config.d1_databases,
575
- services: config.services,
576
- analytics_engine_datasets: config.analytics_engine_datasets,
577
- dispatch_namespaces: config.dispatch_namespaces,
578
- logfwdr: config.logfwdr,
579
- unsafe: config.unsafe,
580
- rules: config.rules,
581
- queues: config.queues,
582
- };
583
-
584
- await generateTypes(configBindings, config);
585
- }
586
- );
587
-
588
- //deployments
589
- const deploymentsWarning =
590
- "🚧`wrangler deployments` is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose";
591
- wrangler.command(
592
- "deployments",
593
- "🚢 List and view details for deployments",
594
- (yargs) =>
595
- yargs
596
- .option("name", {
597
- describe: "The name of your worker",
598
- type: "string",
599
- })
600
- .command(
601
- "list",
602
- "🚢 Displays the 10 most recent deployments for a worker",
603
- async (listYargs) => listYargs,
604
- async (listYargs) => {
605
- const { accountId, scriptName, config } =
606
- await commonDeploymentCMDSetup(listYargs, deploymentsWarning);
607
- await deployments(accountId, scriptName, config);
608
- }
609
- )
610
- .command(
611
- "view [deployment-id]",
612
- "🔍 View a deployment",
613
- async (viewYargs) =>
614
- viewYargs.positional("deployment-id", {
615
- describe: "The ID of the deployment you want to inspect",
616
- type: "string",
617
- demandOption: false,
618
- }),
619
- async (viewYargs) => {
620
- const { accountId, scriptName, config } =
621
- await commonDeploymentCMDSetup(viewYargs, deploymentsWarning);
622
-
623
- await viewDeployment(
624
- accountId,
625
- scriptName,
626
- config,
627
- viewYargs.deploymentId
628
- );
629
- }
630
- )
631
- .command(subHelp)
632
- .epilogue(deploymentsWarning)
633
- );
634
- const rollbackWarning =
635
- "🚧`wrangler rollback` is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose";
636
- wrangler
637
- .command(
638
- "rollback [deployment-id]",
639
- "🔙 Rollback a deployment",
640
- (rollbackYargs) =>
641
- rollbackYargs
642
- .positional("deployment-id", {
643
- describe: "The ID of the deployment to rollback to",
644
- type: "string",
645
- demandOption: false,
646
- })
647
- .option("message", {
648
- alias: "m",
649
- describe:
650
- "Skip confirmation and message prompts, uses provided argument as message",
651
- type: "string",
652
- default: undefined,
653
- }),
654
- async (rollbackYargs) => {
655
- const { accountId, scriptName, config } =
656
- await commonDeploymentCMDSetup(rollbackYargs, rollbackWarning);
657
-
658
- await rollbackDeployment(
659
- accountId,
660
- scriptName,
661
- config,
662
- rollbackYargs.deploymentId,
663
- rollbackYargs.message
664
- );
665
- }
666
- )
667
- .epilogue(rollbackWarning);
668
-
669
- // This set to false to allow overwrite of default behaviour
670
- wrangler.version(false);
671
-
672
- // version
673
- wrangler.command(
674
- "version",
675
- false,
676
- () => {},
677
- async () => {
678
- if (process.stdout.isTTY) {
679
- await printWranglerBanner();
680
- } else {
681
- logger.log(wranglerVersion);
682
- }
683
- }
684
- );
685
-
686
- wrangler.exitProcess(false);
687
-
688
- return wrangler;
689
- }
690
-
691
- export async function main(argv: string[]): Promise<void> {
692
- const wrangler = createCLIParser(argv);
693
- try {
694
- await wrangler.parse();
695
- } catch (e) {
696
- logger.log(""); // Just adds a bit of space
697
- if (e instanceof CommandLineArgsError) {
698
- logger.error(e.message);
699
- // We are not able to ask the `wrangler` CLI parser to show help for a subcommand programmatically.
700
- // The workaround is to re-run the parsing with an additional `--help` flag, which will result in the correct help message being displayed.
701
- // The `wrangler` object is "frozen"; we cannot reuse that with different args, so we must create a new CLI parser to generate the help message.
702
- await createCLIParser([...argv, "--help"]).parse();
703
- } else if (e instanceof ParseError) {
704
- e.notes.push({
705
- text: "\nIf you think this is a bug, please open an issue at: https://github.com/cloudflare/workers-sdk/issues/new/choose",
706
- });
707
- logger.log(formatMessage(e));
708
- } else if (
709
- e instanceof Error &&
710
- e.message.includes("Raw mode is not supported on")
711
- ) {
712
- // the current terminal doesn't support raw mode, which Ink needs to render
713
- // Ink doesn't throw a typed error or subclass or anything, so we just check the message content.
714
- // https://github.com/vadimdemedes/ink/blob/546fe16541fd05ad4e638d6842ca4cbe88b4092b/src/components/App.tsx#L138-L148
715
-
716
- const currentPlatform = os.platform();
717
-
718
- const thisTerminalIsUnsupported =
719
- "This terminal doesn't support raw mode.";
720
- const soWranglerWontWork =
721
- "Wrangler uses raw mode to read user input and write output to the terminal, and won't function correctly without it.";
722
- const tryRunningItIn =
723
- "Try running your previous command in a terminal that supports raw mode";
724
- const oneOfThese =
725
- currentPlatform === "win32"
726
- ? ", such as Command Prompt or Powershell."
727
- : currentPlatform === "darwin"
728
- ? ", such as Terminal.app or iTerm."
729
- : "."; // linux user detected, hand holding disengaged.
730
-
731
- logger.error(
732
- `${thisTerminalIsUnsupported}\n${soWranglerWontWork}\n${tryRunningItIn}${oneOfThese}`
733
- );
734
- } else if (isBuildFailure(e)) {
735
- logBuildFailure(e);
736
- logger.error(e.message);
737
- } else {
738
- logger.error(e instanceof Error ? e.message : e);
739
- logger.log(
740
- `${fgGreenColor}%s${resetColor}`,
741
- "If you think this is a bug then please create an issue at https://github.com/cloudflare/workers-sdk/issues/new/choose"
742
- );
743
- }
744
- throw e;
745
- }
746
- }
747
-
748
- export function getDevCompatibilityDate(
749
- config: Config,
750
- compatibilityDate = config.compatibility_date
751
- ) {
752
- const currentDate = new Date().toISOString().substring(0, 10);
753
- if (config.configPath !== undefined && compatibilityDate === undefined) {
754
- logger.warn(
755
- `No compatibility_date was specified. Using today's date: ${currentDate}.\n` +
756
- "Add one to your wrangler.toml file:\n" +
757
- "```\n" +
758
- `compatibility_date = "${currentDate}"\n` +
759
- "```\n" +
760
- "or pass it in your terminal:\n" +
761
- "```\n" +
762
- `--compatibility-date=${currentDate}\n` +
763
- "```\n" +
764
- "See https://developers.cloudflare.com/workers/platform/compatibility-dates/ for more information."
765
- );
766
- }
767
- return compatibilityDate ?? currentDate;
768
- }