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/kv/index.ts DELETED
@@ -1,594 +0,0 @@
1
- import { StringDecoder } from "node:string_decoder";
2
- import { readConfig } from "../config";
3
- import { confirm } from "../dialogs";
4
- import {
5
- demandOneOfOption,
6
- printWranglerBanner,
7
- CommandLineArgsError,
8
- } from "../index";
9
- import { logger } from "../logger";
10
- import * as metrics from "../metrics";
11
- import { parseJSON, readFileSync, readFileSyncToBuffer } from "../parse";
12
- import { requireAuth } from "../user";
13
- import {
14
- createKVNamespace,
15
- deleteKVNamespace,
16
- getKVNamespaceId,
17
- isValidKVNamespaceBinding,
18
- listKVNamespaces,
19
- deleteKVBulkKeyValue,
20
- deleteKVKeyValue,
21
- getKVKeyValue,
22
- isKVKeyValue,
23
- listKVNamespaceKeys,
24
- putKVBulkKeyValue,
25
- putKVKeyValue,
26
- unexpectedKVKeyValueProps,
27
- } from "./helpers";
28
- import type { CommonYargsArgv } from "../yargs-types";
29
- import type { KeyValue } from "./helpers";
30
-
31
- export function kvNamespace(kvYargs: CommonYargsArgv) {
32
- return kvYargs
33
- .command(
34
- "create <namespace>",
35
- "Create a new namespace",
36
- (yargs) => {
37
- return yargs
38
- .positional("namespace", {
39
- describe: "The name of the new namespace",
40
- type: "string",
41
- demandOption: true,
42
- })
43
- .option("preview", {
44
- type: "boolean",
45
- describe: "Interact with a preview namespace",
46
- });
47
- },
48
- async (args) => {
49
- await printWranglerBanner();
50
-
51
- if (!isValidKVNamespaceBinding(args.namespace)) {
52
- throw new CommandLineArgsError(
53
- `The namespace binding name "${args.namespace}" is invalid. It can only have alphanumeric and _ characters, and cannot begin with a number.`
54
- );
55
- }
56
-
57
- const config = readConfig(args.config, args);
58
- if (!config.name) {
59
- logger.warn(
60
- "No configured name present, using `worker` as a prefix for the title"
61
- );
62
- }
63
-
64
- const name = config.name || "worker";
65
- const environment = args.env ? `-${args.env}` : "";
66
- const preview = args.preview ? "_preview" : "";
67
- const title = `${name}${environment}-${args.namespace}${preview}`;
68
-
69
- const accountId = await requireAuth(config);
70
-
71
- // TODO: generate a binding name stripping non alphanumeric chars
72
-
73
- logger.log(`🌀 Creating namespace with title "${title}"`);
74
- const namespaceId = await createKVNamespace(accountId, title);
75
- await metrics.sendMetricsEvent("create kv namespace", {
76
- sendMetrics: config.send_metrics,
77
- });
78
-
79
- logger.log("✨ Success!");
80
- const envString = args.env ? ` under [env.${args.env}]` : "";
81
- const previewString = args.preview ? "preview_" : "";
82
- logger.log(
83
- `Add the following to your configuration file in your kv_namespaces array${envString}:`
84
- );
85
- logger.log(
86
- `{ binding = "${args.namespace}", ${previewString}id = "${namespaceId}" }`
87
- );
88
-
89
- // TODO: automatically write this block to the wrangler.toml config file??
90
- }
91
- )
92
- .command(
93
- "list",
94
- "Outputs a list of all KV namespaces associated with your account id.",
95
- (listArgs) => listArgs,
96
- async (args) => {
97
- const config = readConfig(args.config, args);
98
-
99
- const accountId = await requireAuth(config);
100
-
101
- // TODO: we should show bindings if they exist for given ids
102
-
103
- logger.log(
104
- JSON.stringify(await listKVNamespaces(accountId), null, " ")
105
- );
106
- await metrics.sendMetricsEvent("list kv namespaces", {
107
- sendMetrics: config.send_metrics,
108
- });
109
- }
110
- )
111
- .command(
112
- "delete",
113
- "Deletes a given namespace.",
114
- (yargs) => {
115
- return yargs
116
- .option("binding", {
117
- type: "string",
118
- requiresArg: true,
119
- describe: "The name of the namespace to delete",
120
- })
121
- .option("namespace-id", {
122
- type: "string",
123
- requiresArg: true,
124
- describe: "The id of the namespace to delete",
125
- })
126
- .check(demandOneOfOption("binding", "namespace-id"))
127
- .option("preview", {
128
- type: "boolean",
129
- describe: "Interact with a preview namespace",
130
- });
131
- },
132
- async (args) => {
133
- await printWranglerBanner();
134
- const config = readConfig(args.config, args);
135
-
136
- let id;
137
- try {
138
- id = getKVNamespaceId(args, config);
139
- } catch (e) {
140
- throw new CommandLineArgsError(
141
- "Not able to delete namespace.\n" + ((e as Error).message ?? e)
142
- );
143
- }
144
-
145
- const accountId = await requireAuth(config);
146
-
147
- logger.log(`Deleting KV namespace ${id}.`);
148
- await deleteKVNamespace(accountId, id);
149
- logger.log(`Deleted KV namespace ${id}.`);
150
- await metrics.sendMetricsEvent("delete kv namespace", {
151
- sendMetrics: config.send_metrics,
152
- });
153
-
154
- // TODO: recommend they remove it from wrangler.toml
155
-
156
- // test-mf wrangler kv:namespace delete --namespace-id 2a7d3d8b23fc4159b5afa489d6cfd388
157
- // Are you sure you want to delete namespace 2a7d3d8b23fc4159b5afa489d6cfd388? [y/n]
158
- // n
159
- // 💁 Not deleting namespace 2a7d3d8b23fc4159b5afa489d6cfd388
160
- // ➜ test-mf wrangler kv:namespace delete --namespace-id 2a7d3d8b23fc4159b5afa489d6cfd388
161
- // Are you sure you want to delete namespace 2a7d3d8b23fc4159b5afa489d6cfd388? [y/n]
162
- // y
163
- // 🌀 Deleting namespace 2a7d3d8b23fc4159b5afa489d6cfd388
164
- // ✨ Success
165
- // ⚠️ Make sure to remove this "kv-namespace" entry from your configuration file!
166
- // ➜ test-mf
167
-
168
- // TODO: do it automatically
169
-
170
- // TODO: delete the preview namespace as well?
171
- }
172
- );
173
- }
174
-
175
- export const kvKey = (kvYargs: CommonYargsArgv) => {
176
- return kvYargs
177
- .command(
178
- "put <key> [value]",
179
- "Writes a single key/value pair to the given namespace.",
180
- (yargs) => {
181
- return yargs
182
- .positional("key", {
183
- type: "string",
184
- describe: "The key to write to",
185
- demandOption: true,
186
- })
187
- .positional("value", {
188
- type: "string",
189
- describe: "The value to write",
190
- })
191
- .option("binding", {
192
- type: "string",
193
- requiresArg: true,
194
- describe: "The binding of the namespace to write to",
195
- })
196
- .option("namespace-id", {
197
- type: "string",
198
- requiresArg: true,
199
- describe: "The id of the namespace to write to",
200
- })
201
- .check(demandOneOfOption("binding", "namespace-id"))
202
- .option("preview", {
203
- type: "boolean",
204
- describe: "Interact with a preview namespace",
205
- })
206
- .option("ttl", {
207
- type: "number",
208
- describe: "Time for which the entries should be visible",
209
- })
210
- .option("expiration", {
211
- type: "number",
212
- describe: "Time since the UNIX epoch after which the entry expires",
213
- })
214
- .option("metadata", {
215
- type: "string",
216
- describe: "Arbitrary JSON that is associated with a key",
217
- coerce: (jsonStr: string): KeyValue["metadata"] => {
218
- try {
219
- return JSON.parse(jsonStr);
220
- } catch (_) {}
221
- },
222
- })
223
- .option("path", {
224
- type: "string",
225
- requiresArg: true,
226
- describe: "Read value from the file at a given path",
227
- })
228
- .check(demandOneOfOption("value", "path"));
229
- },
230
- async ({ key, ttl, expiration, metadata, ...args }) => {
231
- await printWranglerBanner();
232
- const config = readConfig(args.config, args);
233
- const namespaceId = getKVNamespaceId(args, config);
234
- // One of `args.path` and `args.value` must be defined
235
- const value = args.path
236
- ? readFileSyncToBuffer(args.path)
237
- : // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
238
- args.value!;
239
-
240
- const metadataLog = metadata
241
- ? ` with metadata "${JSON.stringify(metadata)}"`
242
- : "";
243
-
244
- if (args.path) {
245
- logger.log(
246
- `Writing the contents of ${args.path} to the key "${key}" on namespace ${namespaceId}${metadataLog}.`
247
- );
248
- } else {
249
- logger.log(
250
- `Writing the value "${value}" to key "${key}" on namespace ${namespaceId}${metadataLog}.`
251
- );
252
- }
253
-
254
- const accountId = await requireAuth(config);
255
-
256
- await putKVKeyValue(accountId, namespaceId, {
257
- key,
258
- value,
259
- expiration,
260
- expiration_ttl: ttl,
261
- metadata: metadata as KeyValue["metadata"],
262
- });
263
- await metrics.sendMetricsEvent("write kv key-value", {
264
- sendMetrics: config.send_metrics,
265
- });
266
- }
267
- )
268
- .command(
269
- "list",
270
- "Outputs a list of all keys in a given namespace.",
271
- (yargs) => {
272
- return yargs
273
- .option("binding", {
274
- type: "string",
275
- requiresArg: true,
276
- describe: "The name of the namespace to list",
277
- })
278
- .option("namespace-id", {
279
- type: "string",
280
- requiresArg: true,
281
- describe: "The id of the namespace to list",
282
- })
283
- .check(demandOneOfOption("binding", "namespace-id"))
284
- .option("preview", {
285
- type: "boolean",
286
- // In the case of listing keys we will default to non-preview mode
287
- default: false,
288
- describe: "Interact with a preview namespace",
289
- })
290
- .option("prefix", {
291
- type: "string",
292
- requiresArg: true,
293
- describe: "A prefix to filter listed keys",
294
- });
295
- },
296
- async ({ prefix, ...args }) => {
297
- // TODO: support for limit+cursor (pagination)
298
- const config = readConfig(args.config, args);
299
- const namespaceId = getKVNamespaceId(args, config);
300
-
301
- const accountId = await requireAuth(config);
302
-
303
- const results = await listKVNamespaceKeys(
304
- accountId,
305
- namespaceId,
306
- prefix
307
- );
308
- logger.log(JSON.stringify(results, undefined, 2));
309
- await metrics.sendMetricsEvent("list kv keys", {
310
- sendMetrics: config.send_metrics,
311
- });
312
- }
313
- )
314
- .command(
315
- "get <key>",
316
- "Reads a single value by key from the given namespace.",
317
- (yargs) => {
318
- return yargs
319
- .positional("key", {
320
- describe: "The key value to get.",
321
- type: "string",
322
- demandOption: true,
323
- })
324
- .option("binding", {
325
- type: "string",
326
- requiresArg: true,
327
- describe: "The name of the namespace to get from",
328
- })
329
- .option("namespace-id", {
330
- type: "string",
331
- requiresArg: true,
332
- describe: "The id of the namespace to get from",
333
- })
334
- .check(demandOneOfOption("binding", "namespace-id"))
335
- .option("preview", {
336
- type: "boolean",
337
- describe: "Interact with a preview namespace",
338
- })
339
- .option("preview", {
340
- type: "boolean",
341
- // In the case of getting key values we will default to non-preview mode
342
- default: false,
343
- describe: "Interact with a preview namespace",
344
- })
345
- .option("text", {
346
- type: "boolean",
347
- default: false,
348
- describe: "Decode the returned value as a utf8 string",
349
- });
350
- },
351
- async ({ key, ...args }) => {
352
- const config = readConfig(args.config, args);
353
- const namespaceId = getKVNamespaceId(args, config);
354
-
355
- const accountId = await requireAuth(config);
356
- const bufferKVValue = Buffer.from(
357
- await getKVKeyValue(accountId, namespaceId, key)
358
- );
359
-
360
- if (args.text) {
361
- const decoder = new StringDecoder("utf8");
362
- logger.log(decoder.write(bufferKVValue));
363
- } else {
364
- process.stdout.write(bufferKVValue);
365
- }
366
- await metrics.sendMetricsEvent("read kv value", {
367
- sendMetrics: config.send_metrics,
368
- });
369
- }
370
- )
371
- .command(
372
- "delete <key>",
373
- "Removes a single key value pair from the given namespace.",
374
- (yargs) => {
375
- return yargs
376
- .positional("key", {
377
- describe: "The key value to delete",
378
- type: "string",
379
- demandOption: true,
380
- })
381
- .option("binding", {
382
- type: "string",
383
- requiresArg: true,
384
- describe: "The name of the namespace to delete from",
385
- })
386
- .option("namespace-id", {
387
- type: "string",
388
- requiresArg: true,
389
- describe: "The id of the namespace to delete from",
390
- })
391
- .check(demandOneOfOption("binding", "namespace-id"))
392
- .option("preview", {
393
- type: "boolean",
394
- describe: "Interact with a preview namespace",
395
- });
396
- },
397
- async ({ key, ...args }) => {
398
- await printWranglerBanner();
399
- const config = readConfig(args.config, args);
400
- const namespaceId = getKVNamespaceId(args, config);
401
-
402
- logger.log(`Deleting the key "${key}" on namespace ${namespaceId}.`);
403
-
404
- const accountId = await requireAuth(config);
405
-
406
- await deleteKVKeyValue(accountId, namespaceId, key);
407
- await metrics.sendMetricsEvent("delete kv key-value", {
408
- sendMetrics: config.send_metrics,
409
- });
410
- }
411
- );
412
- };
413
-
414
- export const kvBulk = (kvYargs: CommonYargsArgv) => {
415
- return kvYargs
416
- .command(
417
- "put <filename>",
418
- "Upload multiple key-value pairs to a namespace",
419
- (yargs) => {
420
- return yargs
421
- .positional("filename", {
422
- describe: `The JSON file of key-value pairs to upload, in form [{"key":..., "value":...}"...]`,
423
- type: "string",
424
- demandOption: true,
425
- })
426
- .option("binding", {
427
- type: "string",
428
- requiresArg: true,
429
- describe: "The name of the namespace to insert values into",
430
- })
431
- .option("namespace-id", {
432
- type: "string",
433
- requiresArg: true,
434
- describe: "The id of the namespace to insert values into",
435
- })
436
- .check(demandOneOfOption("binding", "namespace-id"))
437
- .option("preview", {
438
- type: "boolean",
439
- describe: "Interact with a preview namespace",
440
- });
441
- },
442
- async ({ filename, ...args }) => {
443
- await printWranglerBanner();
444
- // The simplest implementation I could think of.
445
- // This could be made more efficient with a streaming parser/uploader
446
- // but we'll do that in the future if needed.
447
-
448
- const config = readConfig(args.config, args);
449
- const namespaceId = getKVNamespaceId(args, config);
450
- const content = parseJSON(readFileSync(filename), filename);
451
-
452
- if (!Array.isArray(content)) {
453
- throw new Error(
454
- `Unexpected JSON input from "${filename}".\n` +
455
- `Expected an array of key-value objects but got type "${typeof content}".`
456
- );
457
- }
458
-
459
- const errors: string[] = [];
460
- const warnings: string[] = [];
461
- for (let i = 0; i < content.length; i++) {
462
- const keyValue = content[i];
463
- if (!isKVKeyValue(keyValue)) {
464
- errors.push(
465
- `The item at index ${i} is ${JSON.stringify(keyValue)}`
466
- );
467
- } else {
468
- const props = unexpectedKVKeyValueProps(keyValue);
469
- if (props.length > 0) {
470
- warnings.push(
471
- `The item at index ${i} contains unexpected properties: ${JSON.stringify(
472
- props
473
- )}.`
474
- );
475
- }
476
- }
477
- }
478
- if (warnings.length > 0) {
479
- logger.warn(
480
- `Unexpected key-value properties in "${filename}".\n` +
481
- warnings.join("\n")
482
- );
483
- }
484
- if (errors.length > 0) {
485
- throw new Error(
486
- `Unexpected JSON input from "${filename}".\n` +
487
- `Each item in the array should be an object that matches:\n\n` +
488
- `interface KeyValue {\n` +
489
- ` key: string;\n` +
490
- ` value: string;\n` +
491
- ` expiration?: number;\n` +
492
- ` expiration_ttl?: number;\n` +
493
- ` metadata?: object;\n` +
494
- ` base64?: boolean;\n` +
495
- `}\n\n` +
496
- errors.join("\n")
497
- );
498
- }
499
-
500
- const accountId = await requireAuth(config);
501
- await putKVBulkKeyValue(accountId, namespaceId, content);
502
- await metrics.sendMetricsEvent("write kv key-values (bulk)", {
503
- sendMetrics: config.send_metrics,
504
- });
505
-
506
- logger.log("Success!");
507
- }
508
- )
509
- .command(
510
- "delete <filename>",
511
- "Delete multiple key-value pairs from a namespace",
512
- (yargs) => {
513
- return yargs
514
- .positional("filename", {
515
- describe: `The JSON file of keys to delete, in the form ["key1", "key2", ...]`,
516
- type: "string",
517
- demandOption: true,
518
- })
519
- .option("binding", {
520
- type: "string",
521
- requiresArg: true,
522
- describe: "The name of the namespace to delete from",
523
- })
524
- .option("namespace-id", {
525
- type: "string",
526
- requiresArg: true,
527
- describe: "The id of the namespace to delete from",
528
- })
529
- .check(demandOneOfOption("binding", "namespace-id"))
530
- .option("preview", {
531
- type: "boolean",
532
- describe: "Interact with a preview namespace",
533
- })
534
- .option("force", {
535
- type: "boolean",
536
- alias: "f",
537
- describe: "Do not ask for confirmation before deleting",
538
- });
539
- },
540
- async ({ filename, ...args }) => {
541
- await printWranglerBanner();
542
- const config = readConfig(args.config, args);
543
- const namespaceId = getKVNamespaceId(args, config);
544
-
545
- if (!args.force) {
546
- const result = await confirm(
547
- `Are you sure you want to delete all the keys read from "${filename}" from kv-namespace with id "${namespaceId}"?`
548
- );
549
- if (!result) {
550
- logger.log(`Not deleting keys read from "${filename}".`);
551
- return;
552
- }
553
- }
554
-
555
- const content = parseJSON(readFileSync(filename), filename) as string[];
556
-
557
- if (!Array.isArray(content)) {
558
- throw new Error(
559
- `Unexpected JSON input from "${filename}".\n` +
560
- `Expected an array of strings but got:\n${content}`
561
- );
562
- }
563
-
564
- const errors: string[] = [];
565
- for (let i = 0; i < content.length; i++) {
566
- const key = content[i];
567
- if (typeof key !== "string") {
568
- errors.push(
569
- `The item at index ${i} is type: "${typeof key}" - ${JSON.stringify(
570
- key
571
- )}`
572
- );
573
- }
574
- }
575
-
576
- if (errors.length > 0) {
577
- throw new Error(
578
- `Unexpected JSON input from "${filename}".\n` +
579
- `Expected an array of strings.\n` +
580
- errors.join("\n")
581
- );
582
- }
583
-
584
- const accountId = await requireAuth(config);
585
-
586
- await deleteKVBulkKeyValue(accountId, namespaceId, content);
587
- await metrics.sendMetricsEvent("delete kv key-values (bulk)", {
588
- sendMetrics: config.send_metrics,
589
- });
590
-
591
- logger.log("Success!");
592
- }
593
- );
594
- };
package/src/logger.ts DELETED
@@ -1,123 +0,0 @@
1
- import { format } from "node:util";
2
- import chalk from "chalk";
3
- import CLITable from "cli-table3";
4
- import { formatMessagesSync } from "esbuild";
5
- import { getEnvironmentVariableFactory } from "./environment-variables/factory";
6
- import type { BuildFailure } from "esbuild";
7
- export const LOGGER_LEVELS = {
8
- none: -1,
9
- error: 0,
10
- warn: 1,
11
- info: 2,
12
- log: 3,
13
- debug: 4,
14
- } as const;
15
-
16
- export type LoggerLevel = keyof typeof LOGGER_LEVELS;
17
-
18
- /** A map from LOGGER_LEVEL to the error `kind` needed by `formatMessagesSync()`. */
19
- const LOGGER_LEVEL_FORMAT_TYPE_MAP = {
20
- error: "error",
21
- warn: "warning",
22
- info: undefined,
23
- log: undefined,
24
- debug: undefined,
25
- } as const;
26
-
27
- const getLogLevelFromEnv = getEnvironmentVariableFactory({
28
- variableName: "WRANGLER_LOG",
29
- });
30
-
31
- function getLoggerLevel(): LoggerLevel {
32
- const fromEnv = getLogLevelFromEnv()?.toLowerCase();
33
- if (fromEnv !== undefined) {
34
- if (fromEnv in LOGGER_LEVELS) return fromEnv as LoggerLevel;
35
- const expected = Object.keys(LOGGER_LEVELS)
36
- .map((level) => `"${level}"`)
37
- .join(" | ");
38
- console.warn(
39
- `Unrecognised WRANGLER_LOG value ${JSON.stringify(
40
- fromEnv
41
- )}, expected ${expected}, defaulting to "log"...`
42
- );
43
- }
44
- return "log";
45
- }
46
-
47
- export type TableRow<Keys extends string> = Record<Keys, string>;
48
-
49
- export class Logger {
50
- constructor() {}
51
-
52
- loggerLevel = getLoggerLevel();
53
- columns = process.stdout.columns;
54
-
55
- debug = (...args: unknown[]) => this.doLog("debug", args);
56
- info = (...args: unknown[]) => this.doLog("info", args);
57
- log = (...args: unknown[]) => this.doLog("log", args);
58
- warn = (...args: unknown[]) => this.doLog("warn", args);
59
- error = (...args: unknown[]) => this.doLog("error", args);
60
- table<Keys extends string>(data: TableRow<Keys>[]) {
61
- const keys: Keys[] =
62
- data.length === 0 ? [] : (Object.keys(data[0]) as Keys[]);
63
- const t = new CLITable({
64
- head: keys,
65
- style: {
66
- head: chalk.level ? ["blue"] : [],
67
- border: chalk.level ? ["gray"] : [],
68
- },
69
- });
70
- t.push(...data.map((row) => keys.map((k) => row[k])));
71
- return this.doLog("log", [t.toString()]);
72
- }
73
-
74
- private doLog(messageLevel: Exclude<LoggerLevel, "none">, args: unknown[]) {
75
- if (LOGGER_LEVELS[this.loggerLevel] >= LOGGER_LEVELS[messageLevel]) {
76
- console[messageLevel](this.formatMessage(messageLevel, format(...args)));
77
- }
78
- }
79
-
80
- private formatMessage(
81
- level: Exclude<LoggerLevel, "none">,
82
- message: string
83
- ): string {
84
- const kind = LOGGER_LEVEL_FORMAT_TYPE_MAP[level];
85
- if (kind) {
86
- // Format the message using the esbuild formatter.
87
- // The first line of the message is the main `text`,
88
- // subsequent lines are put into the `notes`.
89
- const [firstLine, ...otherLines] = message.split("\n");
90
- const notes =
91
- otherLines.length > 0
92
- ? otherLines.map((text) => ({ text }))
93
- : undefined;
94
- return formatMessagesSync([{ text: firstLine, notes }], {
95
- color: true,
96
- kind,
97
- terminalWidth: this.columns,
98
- })[0];
99
- } else {
100
- return message;
101
- }
102
- }
103
- }
104
-
105
- /**
106
- * A drop-in replacement for `console` for outputting logging messages.
107
- *
108
- * Errors and Warnings will get additional formatting to highlight them to the user.
109
- * You can also set a `logger.loggerLevel` value to one of "debug", "log", "warn" or "error",
110
- * to filter out logging messages.
111
- */
112
- export const logger = new Logger();
113
-
114
- /**
115
- * Logs all errors/warnings associated with an esbuild BuildFailure in the same
116
- * style esbuild would.
117
- */
118
- export function logBuildFailure(failure: BuildFailure) {
119
- let logs = formatMessagesSync(failure.errors, { kind: "error", color: true });
120
- for (const log of logs) console.error(log);
121
- logs = formatMessagesSync(failure.warnings, { kind: "warning", color: true });
122
- for (const log of logs) console.warn(log);
123
- }