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
@@ -1,219 +0,0 @@
1
- import fs from "node:fs/promises";
2
- import * as path from "path";
3
- import Table from "ink-table";
4
- import React from "react";
5
- import { fetchResult } from "../cfetch";
6
- import { performApiFetch } from "../cfetch/internal";
7
- import { withConfig } from "../config";
8
- import { logger } from "../logger";
9
- import { requireAuth } from "../user";
10
- import { renderToString } from "../utils/render";
11
- import { formatBytes, formatTimeAgo } from "./formatTimeAgo";
12
- import { Name } from "./options";
13
- import { d1BetaWarning, getDatabaseByNameOrBinding } from "./utils";
14
- import type {
15
- CommonYargsArgv,
16
- StrictYargsOptionsToInterface,
17
- } from "../yargs-types";
18
- import type { Backup, Database } from "./types";
19
- import type { Response } from "undici";
20
-
21
- export function ListOptions(yargs: CommonYargsArgv) {
22
- return Name(yargs);
23
- }
24
- type ListHandlerOptions = StrictYargsOptionsToInterface<typeof ListOptions>;
25
- export const ListHandler = withConfig<ListHandlerOptions>(
26
- async ({ config, name }): Promise<void> => {
27
- const accountId = await requireAuth(config);
28
- logger.log(d1BetaWarning);
29
- const db: Database = await getDatabaseByNameOrBinding(
30
- config,
31
- accountId,
32
- name
33
- );
34
-
35
- const backups: Backup[] = await listBackups(accountId, db.uuid);
36
- logger.log(
37
- renderToString(
38
- <Table
39
- data={backups}
40
- columns={["created_at", "id", "num_tables", "size"]}
41
- ></Table>
42
- )
43
- );
44
- }
45
- );
46
-
47
- export const listBackups = async (
48
- accountId: string,
49
- uuid: string
50
- ): Promise<Array<Backup>> => {
51
- const json: Backup[] = await fetchResult(
52
- `/accounts/${accountId}/d1/database/${uuid}/backup`,
53
- {}
54
- );
55
- const results: Record<string, Backup> = {};
56
-
57
- json
58
- // First, convert created_at to a Date
59
- .map((backup) => ({
60
- ...backup,
61
- created_at: new Date(backup.created_at),
62
- }))
63
- // Then, sort descending based on created_at
64
- .sort((a, b) => +b.created_at - +a.created_at)
65
- // then group_by their human-readable timestamp i.e. "2 days ago"
66
- // (storing only the first of each group)
67
- // and replace the Date version with this new human-readable one
68
- .forEach((backup) => {
69
- const timeAgo = formatTimeAgo(backup.created_at);
70
- if (!results[timeAgo]) {
71
- results[timeAgo] = {
72
- ...backup,
73
- created_at: timeAgo,
74
- size: formatBytes(backup.file_size),
75
- };
76
- }
77
- });
78
-
79
- // Take advantage of JS objects' sorting to return the newest backup of a certain age
80
- return Object.values(results);
81
- };
82
-
83
- export function CreateOptions(yargs: CommonYargsArgv) {
84
- return ListOptions(yargs);
85
- }
86
- type CreateHandlerOptions = StrictYargsOptionsToInterface<typeof CreateOptions>;
87
-
88
- export const CreateHandler = withConfig<CreateHandlerOptions>(
89
- async ({ config, name }): Promise<void> => {
90
- const accountId = await requireAuth(config);
91
- logger.log(d1BetaWarning);
92
- const db: Database = await getDatabaseByNameOrBinding(
93
- config,
94
- accountId,
95
- name
96
- );
97
-
98
- const backup: Backup = await createBackup(accountId, db.uuid);
99
- logger.log(
100
- renderToString(
101
- <Table
102
- data={[backup]}
103
- columns={["created_at", "id", "num_tables", "size", "state"]}
104
- ></Table>
105
- )
106
- );
107
- }
108
- );
109
-
110
- export const createBackup = async (
111
- accountId: string,
112
- uuid: string
113
- ): Promise<Backup> => {
114
- const backup: Backup = await fetchResult(
115
- `/accounts/${accountId}/d1/database/${uuid}/backup`,
116
- {
117
- method: "POST",
118
- }
119
- );
120
- return {
121
- ...backup,
122
- size: formatBytes(backup.file_size),
123
- };
124
- };
125
-
126
- export function RestoreOptions(yargs: CommonYargsArgv) {
127
- return ListOptions(yargs).positional("backup-id", {
128
- describe: "The Backup ID to restore",
129
- type: "string",
130
- demandOption: true,
131
- });
132
- }
133
- type RestoreHandlerOptions = StrictYargsOptionsToInterface<
134
- typeof RestoreOptions
135
- >;
136
- export const RestoreHandler = withConfig<RestoreHandlerOptions>(
137
- async ({ config, name, backupId }): Promise<void> => {
138
- const accountId = await requireAuth(config);
139
- logger.log(d1BetaWarning);
140
- const db: Database = await getDatabaseByNameOrBinding(
141
- config,
142
- accountId,
143
- name
144
- );
145
-
146
- logger.log(`Restoring ${name} from backup ${backupId}....`);
147
- await restoreBackup(accountId, db.uuid, backupId);
148
- logger.log(`Done!`);
149
- }
150
- );
151
-
152
- export const restoreBackup = async (
153
- accountId: string,
154
- uuid: string,
155
- backupId: string
156
- ): Promise<void> => {
157
- await fetchResult(
158
- `/accounts/${accountId}/d1/database/${uuid}/backup/${backupId}/restore`,
159
- {
160
- method: "POST",
161
- headers: {
162
- "Content-Type": "application/json",
163
- },
164
- }
165
- );
166
- };
167
-
168
- export function DownloadOptions(yargs: CommonYargsArgv) {
169
- return ListOptions(yargs)
170
- .positional("backup-id", {
171
- describe: "The Backup ID to download",
172
- type: "string",
173
- demandOption: true,
174
- })
175
- .option("output", {
176
- describe:
177
- "The .sqlite3 file to write to (defaults to '<db-name>.<short-backup-id>.sqlite3'",
178
- type: "string",
179
- });
180
- }
181
- type DownloadHandlerOptions = StrictYargsOptionsToInterface<
182
- typeof DownloadOptions
183
- >;
184
- export const DownloadHandler = withConfig<DownloadHandlerOptions>(
185
- async ({ name, backupId, output, config }): Promise<void> => {
186
- const accountId = await requireAuth(config);
187
- logger.log(d1BetaWarning);
188
- const db: Database = await getDatabaseByNameOrBinding(
189
- config,
190
- accountId,
191
- name
192
- );
193
- const filename =
194
- output || path.resolve(`${name}.${backupId.slice(0, 8)}.sqlite3`);
195
-
196
- logger.log(`šŸŒ€ Downloading backup ${backupId} from '${name}'`);
197
- const response = await getBackupResponse(accountId, db.uuid, backupId);
198
- if (!response.ok) {
199
- throw new Error(
200
- `Failed to download backup ${backupId} from '${name}' - got ${response.status} from the API`
201
- );
202
- }
203
- logger.log(`šŸŒ€ Saving to ${filename}`);
204
- // TODO: stream this once we upgrade to Node18 and can use Writable.fromWeb
205
- const buffer = await response.arrayBuffer();
206
- await fs.writeFile(filename, new Buffer(buffer));
207
- logger.log(`šŸŒ€ Done!`);
208
- }
209
- );
210
-
211
- export const getBackupResponse = async (
212
- accountId: string,
213
- uuid: string,
214
- backupId: string
215
- ): Promise<Response> => {
216
- return await performApiFetch(
217
- `/accounts/${accountId}/d1/database/${uuid}/backup/${backupId}/download`
218
- );
219
- };
@@ -1,2 +0,0 @@
1
- export const DEFAULT_MIGRATION_PATH = "./migrations";
2
- export const DEFAULT_MIGRATION_TABLE = "d1_migrations";
package/src/d1/create.tsx DELETED
@@ -1,70 +0,0 @@
1
- import { Text, Box } from "ink";
2
- import React from "react";
3
- import { fetchResult } from "../cfetch";
4
- import { withConfig } from "../config";
5
- import { logger } from "../logger";
6
- import { requireAuth } from "../user";
7
- import { renderToString } from "../utils/render";
8
- import { d1BetaWarning } from "./utils";
9
- import type {
10
- CommonYargsArgv,
11
- StrictYargsOptionsToInterface,
12
- } from "../yargs-types";
13
- import type { Database } from "./types";
14
-
15
- export function Options(yargs: CommonYargsArgv) {
16
- return yargs
17
- .positional("name", {
18
- describe: "The name of the new DB",
19
- type: "string",
20
- demandOption: true,
21
- })
22
- .epilogue(d1BetaWarning);
23
- }
24
-
25
- type HandlerOptions = StrictYargsOptionsToInterface<typeof Options>;
26
- export const Handler = withConfig<HandlerOptions>(
27
- async ({ name, config }): Promise<void> => {
28
- const accountId = await requireAuth(config);
29
-
30
- logger.log(d1BetaWarning);
31
-
32
- let db: Database;
33
- try {
34
- db = await fetchResult(`/accounts/${accountId}/d1/database`, {
35
- method: "POST",
36
- headers: {
37
- "Content-Type": "application/json",
38
- },
39
- body: JSON.stringify({
40
- name,
41
- }),
42
- });
43
- } catch (e) {
44
- if ((e as { code: number }).code === 7502) {
45
- throw new Error("A database with that name already exists");
46
- }
47
- throw e;
48
- }
49
-
50
- logger.log(
51
- renderToString(
52
- <Box flexDirection="column">
53
- <Text>āœ… Successfully created DB &apos;{db.name}&apos;!</Text>
54
- <Text>&nbsp;</Text>
55
- <Text>
56
- Add the following to your wrangler.toml to connect to it from a
57
- Worker:
58
- </Text>
59
- <Text>&nbsp;</Text>
60
- <Text>[[ d1_databases ]]</Text>
61
- <Text>
62
- binding = &quot;DB&quot; # i.e. available in your Worker on env.DB
63
- </Text>
64
- <Text>database_name = &quot;{db.name}&quot;</Text>
65
- <Text>database_id = &quot;{db.uuid}&quot;</Text>
66
- </Box>
67
- )
68
- );
69
- }
70
- );
package/src/d1/delete.ts DELETED
@@ -1,53 +0,0 @@
1
- import { fetchResult } from "../cfetch";
2
- import { withConfig } from "../config";
3
- import { confirm } from "../dialogs";
4
- import { logger } from "../logger";
5
- import { requireAuth } from "../user";
6
- import { Name } from "./options";
7
- import { d1BetaWarning, getDatabaseByNameOrBinding } from "./utils";
8
- import type {
9
- CommonYargsArgv,
10
- StrictYargsOptionsToInterface,
11
- } from "../yargs-types";
12
- import type { Database } from "./types";
13
-
14
- export function Options(d1ListYargs: CommonYargsArgv) {
15
- return Name(d1ListYargs)
16
- .option("skip-confirmation", {
17
- describe: "Skip confirmation",
18
- type: "boolean",
19
- alias: "y",
20
- default: false,
21
- })
22
- .epilogue(d1BetaWarning);
23
- }
24
- type HandlerOptions = StrictYargsOptionsToInterface<typeof Options>;
25
- export const Handler = withConfig<HandlerOptions>(
26
- async ({ name, skipConfirmation, config }): Promise<void> => {
27
- const accountId = await requireAuth(config);
28
- logger.log(d1BetaWarning);
29
-
30
- const db: Database = await getDatabaseByNameOrBinding(
31
- config,
32
- accountId,
33
- name
34
- );
35
-
36
- logger.log(`About to delete DB '${name}' (${db.uuid}).`);
37
- if (!skipConfirmation) {
38
- const response = await confirm(`Ok to proceed?`);
39
- if (!response) {
40
- logger.log(`Not deleting.`);
41
- return;
42
- }
43
- }
44
-
45
- logger.log("Deleting...");
46
-
47
- await fetchResult(`/accounts/${accountId}/d1/database/${db.uuid}`, {
48
- method: "DELETE",
49
- });
50
-
51
- logger.log(`Deleted '${name}' successfully.`);
52
- }
53
- );
@@ -1,357 +0,0 @@
1
- import { existsSync } from "node:fs";
2
- import { mkdir } from "node:fs/promises";
3
- import path from "node:path";
4
- import chalk from "chalk";
5
- import { Static, Text } from "ink";
6
- import Table from "ink-table";
7
- import { npxImport } from "npx-import";
8
- import React from "react";
9
- import { fetchResult } from "../cfetch";
10
- import { readConfig } from "../config";
11
- import { getLocalPersistencePath } from "../dev/get-local-persistence-path";
12
- import { confirm } from "../dialogs";
13
- import { logger } from "../logger";
14
- import { readFileSync } from "../parse";
15
- import { readableRelative } from "../paths";
16
- import { requireAuth } from "../user";
17
- import { renderToString } from "../utils/render";
18
- import * as options from "./options";
19
- import splitSqlQuery from "./splitter";
20
- import {
21
- d1BetaWarning,
22
- getDatabaseByNameOrBinding,
23
- getDatabaseInfoFromConfig,
24
- } from "./utils";
25
- import type { Config, ConfigFields, DevConfig, Environment } from "../config";
26
- import type {
27
- CommonYargsArgv,
28
- StrictYargsOptionsToInterface,
29
- } from "../yargs-types";
30
- import type { Database } from "./types";
31
-
32
- export type QueryResult = {
33
- results: Record<string, string | number | boolean>[];
34
- success: boolean;
35
- meta?: {
36
- duration?: number;
37
- };
38
- query?: string;
39
- };
40
- // Max number of statements to send in a single /execute call
41
- const QUERY_LIMIT = 10_000;
42
-
43
- export function Options(yargs: CommonYargsArgv) {
44
- return options
45
- .Database(yargs)
46
- .option("yes", {
47
- describe: 'Answer "yes" to any prompts',
48
- type: "boolean",
49
- alias: "y",
50
- })
51
- .option("local", {
52
- describe:
53
- "Execute commands/files against a local DB for use with wrangler dev",
54
- type: "boolean",
55
- })
56
- .option("file", {
57
- describe: "A .sql file to ingest",
58
- type: "string",
59
- })
60
- .option("command", {
61
- describe: "A single SQL statement to execute",
62
- type: "string",
63
- })
64
- .option("persist-to", {
65
- describe: "Specify directory to use for local persistence (for --local)",
66
- type: "string",
67
- requiresArg: true,
68
- })
69
- .option("json", {
70
- describe: "Return output as clean JSON",
71
- type: "boolean",
72
- default: false,
73
- })
74
- .option("preview", {
75
- describe: "Execute commands/files against a preview D1 DB",
76
- type: "boolean",
77
- default: false,
78
- });
79
- }
80
-
81
- type HandlerOptions = StrictYargsOptionsToInterface<typeof Options>;
82
-
83
- export const Handler = async (args: HandlerOptions): Promise<void> => {
84
- const { local, database, yes, persistTo, file, command, json, preview } =
85
- args;
86
- const existingLogLevel = logger.loggerLevel;
87
- if (json) {
88
- // set loggerLevel to error to avoid readConfig warnings appearing in JSON output
89
- logger.loggerLevel = "error";
90
- }
91
- const config = readConfig(args.config, args);
92
- logger.log(d1BetaWarning);
93
- if (file && command)
94
- return logger.error(`Error: can't provide both --command and --file.`);
95
-
96
- const isInteractive = process.stdout.isTTY;
97
- const response: QueryResult[] | null = await executeSql({
98
- local,
99
- config,
100
- name: database,
101
- shouldPrompt: isInteractive && !yes,
102
- persistTo,
103
- file,
104
- command,
105
- json,
106
- preview,
107
- });
108
-
109
- // Early exit if prompt rejected
110
- if (!response) return;
111
-
112
- if (isInteractive && !json) {
113
- // Render table if single result
114
- logger.log(
115
- renderToString(
116
- <Static items={response}>
117
- {(result) => {
118
- // batch results
119
- if (!Array.isArray(result)) {
120
- const { results, query } = result;
121
-
122
- if (Array.isArray(results) && results.length > 0) {
123
- const shortQuery = shorten(query, 48);
124
- return (
125
- <>
126
- {shortQuery ? <Text dimColor>{shortQuery}</Text> : null}
127
- <Table data={results}></Table>
128
- </>
129
- );
130
- }
131
- }
132
- }}
133
- </Static>
134
- )
135
- );
136
- } else {
137
- // set loggerLevel back to what it was before to actually output the JSON in stdout
138
- logger.loggerLevel = existingLogLevel;
139
- logger.log(JSON.stringify(response, null, 2));
140
- }
141
- };
142
-
143
- export async function executeSql({
144
- local,
145
- config,
146
- name,
147
- shouldPrompt,
148
- persistTo,
149
- file,
150
- command,
151
- json,
152
- preview,
153
- }: {
154
- local: boolean | undefined;
155
- config: ConfigFields<DevConfig> & Environment;
156
- name: string;
157
- shouldPrompt: boolean | undefined;
158
- persistTo: string | undefined;
159
- file: string | undefined;
160
- command: string | undefined;
161
- json: boolean | undefined;
162
- preview: boolean | undefined;
163
- }) {
164
- const sql = file ? readFileSync(file) : command;
165
- if (!sql) throw new Error(`Error: must provide --command or --file.`);
166
- if (preview && local)
167
- throw new Error(`Error: can't use --preview with --local`);
168
- if (persistTo && !local)
169
- throw new Error(`Error: can't use --persist-to without --local`);
170
- logger.log(`šŸŒ€ Mapping SQL input into an array of statements`);
171
- const queries = splitSqlQuery(sql);
172
-
173
- if (file && sql) {
174
- if (queries[0].startsWith("SQLite format 3")) {
175
- //TODO: update this error to recommend using `wrangler d1 restore` when it exists
176
- throw new Error(
177
- "Provided file is a binary SQLite database file instead of an SQL text file.\nThe execute command can only process SQL text files.\nPlease export an SQL file from your SQLite database and try again."
178
- );
179
- }
180
- }
181
-
182
- return local
183
- ? await executeLocally({
184
- config,
185
- name,
186
- shouldPrompt,
187
- queries,
188
- persistTo,
189
- json,
190
- })
191
- : await executeRemotely({
192
- config,
193
- name,
194
- shouldPrompt,
195
- batches: batchSplit(queries),
196
- json,
197
- preview,
198
- });
199
- }
200
-
201
- async function executeLocally({
202
- config,
203
- name,
204
- shouldPrompt,
205
- queries,
206
- persistTo,
207
- json,
208
- }: {
209
- config: Config;
210
- name: string;
211
- shouldPrompt: boolean | undefined;
212
- queries: string[];
213
- persistTo: string | undefined;
214
- json: boolean | undefined;
215
- }) {
216
- const localDB = getDatabaseInfoFromConfig(config, name);
217
- if (!localDB) {
218
- throw new Error(
219
- `Can't find a DB with name/binding '${name}' in local config. Check info in wrangler.toml...`
220
- );
221
- }
222
-
223
- const persistencePath = getLocalPersistencePath(
224
- persistTo,
225
- true,
226
- config.configPath
227
- );
228
-
229
- const dbDir = path.join(persistencePath, "d1");
230
- const dbPath = path.join(dbDir, `${localDB.binding}.sqlite3`);
231
- const [{ D1Database, D1DatabaseAPI }, { createSQLiteDB }] = await npxImport<
232
- // eslint-disable-next-line @typescript-eslint/consistent-type-imports
233
- [typeof import("@miniflare/d1"), typeof import("@miniflare/shared")]
234
- >(["@miniflare/d1", "@miniflare/shared"], logger.log);
235
-
236
- if (!existsSync(dbDir)) {
237
- const ok =
238
- json ||
239
- !shouldPrompt ||
240
- (await confirm(`About to create ${readableRelative(dbPath)}, ok?`));
241
- if (!ok) return null;
242
- await mkdir(dbDir, { recursive: true });
243
- }
244
-
245
- logger.log(`šŸŒ€ Loading DB at ${readableRelative(dbPath)}`);
246
-
247
- const sqliteDb = await createSQLiteDB(dbPath);
248
- const db = new D1Database(new D1DatabaseAPI(sqliteDb));
249
- const stmts = queries.map((query) => db.prepare(query));
250
- return (await db.batch(stmts)) as QueryResult[];
251
- }
252
-
253
- async function executeRemotely({
254
- config,
255
- name,
256
- shouldPrompt,
257
- batches,
258
- json,
259
- preview,
260
- }: {
261
- config: Config;
262
- name: string;
263
- shouldPrompt: boolean | undefined;
264
- batches: string[];
265
- json: boolean | undefined;
266
- preview: boolean | undefined;
267
- }) {
268
- const multiple_batches = batches.length > 1;
269
- // in JSON mode, we don't want a prompt here
270
- if (multiple_batches && !json) {
271
- const warning = `āš ļø Too much SQL to send at once, this execution will be sent as ${batches.length} batches.`;
272
-
273
- if (shouldPrompt) {
274
- const ok = await confirm(
275
- `${warning}\nā„¹ļø Each batch is sent individually and may leave your DB in an unexpected state if a later batch fails.\nāš ļø Make sure you have a recent backup. Ok to proceed?`
276
- );
277
- if (!ok) return null;
278
- logger.log(`šŸŒ€ Let's go`);
279
- } else {
280
- logger.error(warning);
281
- }
282
- }
283
-
284
- const accountId = await requireAuth(config);
285
- const db: Database = await getDatabaseByNameOrBinding(
286
- config,
287
- accountId,
288
- name
289
- );
290
- if (preview && !db.previewDatabaseUuid) {
291
- throw logger.error(
292
- "Please define a `preview_database_id` in your wrangler.toml to execute your queries against a preview database"
293
- );
294
- }
295
- const dbUuid = preview ? db.previewDatabaseUuid : db.uuid;
296
- logger.log(`šŸŒ€ Executing on ${name} (${dbUuid}):`);
297
-
298
- const results: QueryResult[] = [];
299
- for (const sql of batches) {
300
- if (multiple_batches)
301
- logger.log(
302
- chalk.gray(` ${sql.slice(0, 70)}${sql.length > 70 ? "..." : ""}`)
303
- );
304
-
305
- const result = await fetchResult<QueryResult[]>(
306
- `/accounts/${accountId}/d1/database/${dbUuid}/query`,
307
- {
308
- method: "POST",
309
- headers: {
310
- "Content-Type": "application/json",
311
- ...(db.internal_env ? { "x-d1-internal-env": db.internal_env } : {}),
312
- },
313
- body: JSON.stringify({ sql }),
314
- }
315
- );
316
- result.map(logResult);
317
- results.push(...result);
318
- }
319
- return results;
320
- }
321
-
322
- function logResult(r: QueryResult | QueryResult[]) {
323
- logger.log(
324
- `🚣 Executed ${
325
- Array.isArray(r) ? `${r.length} commands` : "1 command"
326
- } in ${
327
- Array.isArray(r)
328
- ? r
329
- .map((d: QueryResult) => d.meta?.duration || 0)
330
- .reduce((a: number, b: number) => a + b, 0)
331
- : r.meta?.duration
332
- }ms`
333
- );
334
- }
335
-
336
- function batchSplit(queries: string[]) {
337
- logger.log(`šŸŒ€ Parsing ${queries.length} statements`);
338
- const num_batches = Math.ceil(queries.length / QUERY_LIMIT);
339
- const batches: string[] = [];
340
- for (let i = 0; i < num_batches; i++) {
341
- batches.push(
342
- queries.slice(i * QUERY_LIMIT, (i + 1) * QUERY_LIMIT).join("; ")
343
- );
344
- }
345
- if (num_batches > 1) {
346
- logger.log(
347
- `šŸŒ€ We are sending ${num_batches} batch(es) to D1 (limited to ${QUERY_LIMIT} statements per batch)`
348
- );
349
- }
350
- return batches;
351
- }
352
-
353
- function shorten(query: string | undefined, length: number) {
354
- return query && query.length > length
355
- ? query.slice(0, length) + "..."
356
- : query;
357
- }