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,469 +0,0 @@
1
- import { mkdir, readdir, readFile, stat, writeFile } from "node:fs/promises";
2
- import { dirname, join, relative, resolve, sep } from "node:path";
3
- import { render, Text } from "ink";
4
- import Spinner from "ink-spinner";
5
- import { getType } from "mime";
6
- import { Minimatch } from "minimatch";
7
- import PQueue from "p-queue";
8
- import prettyBytes from "pretty-bytes";
9
- import React from "react";
10
- import { fetchResult } from "../cfetch";
11
- import { FatalError } from "../errors";
12
- import isInteractive from "../is-interactive";
13
- import { logger } from "../logger";
14
- import {
15
- MAX_ASSET_COUNT,
16
- MAX_ASSET_SIZE,
17
- BULK_UPLOAD_CONCURRENCY,
18
- MAX_BUCKET_FILE_COUNT,
19
- MAX_BUCKET_SIZE,
20
- MAX_CHECK_MISSING_ATTEMPTS,
21
- MAX_UPLOAD_ATTEMPTS,
22
- } from "./constants";
23
- import { hashFile } from "./hash";
24
- import { pagesBetaWarning } from "./utils";
25
- import type {
26
- CommonYargsArgv,
27
- StrictYargsOptionsToInterface,
28
- } from "../yargs-types";
29
- import type { UploadPayloadFile } from "./types";
30
-
31
- type UploadArgs = StrictYargsOptionsToInterface<typeof Options>;
32
-
33
- export function Options(yargs: CommonYargsArgv) {
34
- return yargs
35
- .positional("directory", {
36
- type: "string",
37
- demandOption: true,
38
- description: "The directory of static files to upload",
39
- })
40
- .options({
41
- "output-manifest-path": {
42
- type: "string",
43
- description: "The name of the project you want to deploy to",
44
- },
45
- "skip-caching": {
46
- type: "boolean",
47
- description: "Skip asset caching which speeds up builds",
48
- },
49
- })
50
- .epilogue(pagesBetaWarning);
51
- }
52
-
53
- export const Handler = async ({
54
- directory,
55
- outputManifestPath,
56
- skipCaching,
57
- }: UploadArgs) => {
58
- if (!directory) {
59
- throw new FatalError("Must specify a directory.", 1);
60
- }
61
-
62
- if (!process.env.CF_PAGES_UPLOAD_JWT) {
63
- throw new FatalError("No JWT given.", 1);
64
- }
65
-
66
- const manifest = await upload({
67
- directory,
68
- jwt: process.env.CF_PAGES_UPLOAD_JWT,
69
- skipCaching: skipCaching ?? false,
70
- });
71
-
72
- if (outputManifestPath) {
73
- await mkdir(dirname(outputManifestPath), { recursive: true });
74
- await writeFile(outputManifestPath, JSON.stringify(manifest));
75
- }
76
-
77
- logger.log(`✨ Upload complete!`);
78
- };
79
-
80
- export const upload = async (
81
- args:
82
- | {
83
- directory: string;
84
- jwt: string;
85
- skipCaching: boolean;
86
- }
87
- | {
88
- directory: string;
89
- accountId: string;
90
- projectName: string;
91
- skipCaching: boolean;
92
- }
93
- ) => {
94
- async function fetchJwt(): Promise<string> {
95
- if ("jwt" in args) {
96
- return args.jwt;
97
- } else {
98
- return (
99
- await fetchResult<{ jwt: string }>(
100
- `/accounts/${args.accountId}/pages/projects/${args.projectName}/upload-token`
101
- )
102
- ).jwt;
103
- }
104
- }
105
-
106
- type FileContainer = {
107
- path: string;
108
- contentType: string;
109
- sizeInBytes: number;
110
- hash: string;
111
- };
112
-
113
- const IGNORE_LIST = [
114
- "_worker.js",
115
- "_redirects",
116
- "_headers",
117
- "_routes.json",
118
- "functions",
119
- "**/.DS_Store",
120
- "**/node_modules",
121
- "**/.git",
122
- ].map((pattern) => new Minimatch(pattern));
123
-
124
- const directory = resolve(args.directory);
125
-
126
- // TODO(future): Use this to more efficiently load files in and speed up uploading
127
- // Limit memory to 1 GB unless more is specified
128
- // let maxMemory = 1_000_000_000;
129
- // if (process.env.NODE_OPTIONS && (process.env.NODE_OPTIONS.includes('--max-old-space-size=') || process.env.NODE_OPTIONS.includes('--max_old_space_size='))) {
130
- // const parsed = parser(process.env.NODE_OPTIONS);
131
- // maxMemory = (parsed['max-old-space-size'] ? parsed['max-old-space-size'] : parsed['max_old_space_size']) * 1000 * 1000; // Turn MB into bytes
132
- // }
133
-
134
- const walk = async (
135
- dir: string,
136
- fileMap: Map<string, FileContainer> = new Map(),
137
- startingDir: string = dir
138
- ) => {
139
- const files = await readdir(dir);
140
-
141
- await Promise.all(
142
- files.map(async (file) => {
143
- const filepath = join(dir, file);
144
- const relativeFilepath = relative(startingDir, filepath);
145
- const filestat = await stat(filepath);
146
-
147
- for (const minimatch of IGNORE_LIST) {
148
- if (minimatch.match(relativeFilepath)) {
149
- return;
150
- }
151
- }
152
-
153
- if (filestat.isSymbolicLink()) {
154
- return;
155
- }
156
-
157
- if (filestat.isDirectory()) {
158
- fileMap = await walk(filepath, fileMap, startingDir);
159
- } else {
160
- const name = relativeFilepath.split(sep).join("/");
161
-
162
- if (filestat.size > MAX_ASSET_SIZE) {
163
- throw new FatalError(
164
- `Error: Pages only supports files up to ${prettyBytes(
165
- MAX_ASSET_SIZE
166
- )} in size\n${name} is ${prettyBytes(filestat.size)} in size`,
167
- 1
168
- );
169
- }
170
-
171
- // We don't want to hold the content in memory. We instead only want to read it when it's needed
172
- fileMap.set(name, {
173
- path: filepath,
174
- contentType: getType(name) || "application/octet-stream",
175
- sizeInBytes: filestat.size,
176
- hash: hashFile(filepath),
177
- });
178
- }
179
- })
180
- );
181
-
182
- return fileMap;
183
- };
184
-
185
- const fileMap = await walk(directory);
186
-
187
- if (fileMap.size > MAX_ASSET_COUNT) {
188
- throw new FatalError(
189
- `Error: Pages only supports up to ${MAX_ASSET_COUNT.toLocaleString()} files in a deployment. Ensure you have specified your build output directory correctly.`,
190
- 1
191
- );
192
- }
193
-
194
- const files = [...fileMap.values()];
195
-
196
- let jwt = await fetchJwt();
197
-
198
- const start = Date.now();
199
-
200
- let attempts = 0;
201
- const getMissingHashes = async (skipCaching: boolean): Promise<string[]> => {
202
- if (skipCaching) {
203
- logger.debug("Force skipping cache");
204
- return files.map(({ hash }) => hash);
205
- }
206
-
207
- try {
208
- return await fetchResult<string[]>(`/pages/assets/check-missing`, {
209
- method: "POST",
210
- headers: {
211
- "Content-Type": "application/json",
212
- Authorization: `Bearer ${jwt}`,
213
- },
214
- body: JSON.stringify({
215
- hashes: files.map(({ hash }) => hash),
216
- }),
217
- });
218
- } catch (e) {
219
- if (attempts < MAX_CHECK_MISSING_ATTEMPTS) {
220
- // Exponential backoff, 1 second first time, then 2 second, then 4 second etc.
221
- await new Promise((resolvePromise) =>
222
- setTimeout(resolvePromise, Math.pow(2, attempts++) * 1000)
223
- );
224
-
225
- if ((e as { code: number }).code === 8000013) {
226
- // Looks like the JWT expired, fetch another one
227
- jwt = await fetchJwt();
228
- }
229
- return getMissingHashes(skipCaching);
230
- } else {
231
- throw e;
232
- }
233
- }
234
- };
235
- const missingHashes = await getMissingHashes(args.skipCaching);
236
-
237
- const sortedFiles = files
238
- .filter((file) => missingHashes.includes(file.hash))
239
- .sort((a, b) => b.sizeInBytes - a.sizeInBytes);
240
-
241
- // Start with a few buckets so small projects still get
242
- // the benefit of multiple upload streams
243
- const buckets: {
244
- files: FileContainer[];
245
- remainingSize: number;
246
- }[] = new Array(BULK_UPLOAD_CONCURRENCY).fill(null).map(() => ({
247
- files: [],
248
- remainingSize: MAX_BUCKET_SIZE,
249
- }));
250
-
251
- let bucketOffset = 0;
252
- for (const file of sortedFiles) {
253
- let inserted = false;
254
-
255
- for (let i = 0; i < buckets.length; i++) {
256
- // Start at a different bucket for each new file
257
- const bucket = buckets[(i + bucketOffset) % buckets.length];
258
- if (
259
- bucket.remainingSize >= file.sizeInBytes &&
260
- bucket.files.length < MAX_BUCKET_FILE_COUNT
261
- ) {
262
- bucket.files.push(file);
263
- bucket.remainingSize -= file.sizeInBytes;
264
- inserted = true;
265
- break;
266
- }
267
- }
268
-
269
- if (!inserted) {
270
- buckets.push({
271
- files: [file],
272
- remainingSize: MAX_BUCKET_SIZE - file.sizeInBytes,
273
- });
274
- }
275
- bucketOffset++;
276
- }
277
-
278
- let counter = fileMap.size - sortedFiles.length;
279
- const { rerender, unmount } = renderProgress(counter, fileMap.size);
280
-
281
- const queue = new PQueue({ concurrency: BULK_UPLOAD_CONCURRENCY });
282
-
283
- for (const bucket of buckets) {
284
- // Don't upload empty buckets (can happen for tiny projects)
285
- if (bucket.files.length === 0) continue;
286
-
287
- attempts = 0;
288
- const doUpload = async (): Promise<void> => {
289
- // Populate the payload only when actually uploading (this is limited to 3 concurrent uploads at 50 MiB per bucket meaning we'd only load in a max of ~150 MiB)
290
- // This is so we don't run out of memory trying to upload the files.
291
- const payload: UploadPayloadFile[] = await Promise.all(
292
- bucket.files.map(async (file) => ({
293
- key: file.hash,
294
- value: (await readFile(file.path)).toString("base64"),
295
- metadata: {
296
- contentType: file.contentType,
297
- },
298
- base64: true,
299
- }))
300
- );
301
-
302
- try {
303
- logger.debug("POST /pages/assets/upload");
304
- const res = await fetchResult(`/pages/assets/upload`, {
305
- method: "POST",
306
- headers: {
307
- "Content-Type": "application/json",
308
- Authorization: `Bearer ${jwt}`,
309
- },
310
- body: JSON.stringify(payload),
311
- });
312
- logger.debug("result:", res);
313
- } catch (e) {
314
- if (attempts < MAX_UPLOAD_ATTEMPTS) {
315
- logger.debug("failed:", e, "retrying...");
316
- // Exponential backoff, 1 second first time, then 2 second, then 4 second etc.
317
- await new Promise((resolvePromise) =>
318
- setTimeout(resolvePromise, Math.pow(2, attempts++) * 1000)
319
- );
320
-
321
- if ((e as { code: number }).code === 8000013 || isJwtExpired(jwt)) {
322
- // Looks like the JWT expired, fetch another one
323
- jwt = await fetchJwt();
324
- }
325
- return doUpload();
326
- } else {
327
- logger.debug("failed:", e);
328
- throw e;
329
- }
330
- }
331
- };
332
-
333
- void queue.add(() =>
334
- doUpload().then(
335
- () => {
336
- counter += bucket.files.length;
337
- rerender(counter, fileMap.size);
338
- },
339
- (error) => {
340
- return Promise.reject(
341
- new FatalError(
342
- `Failed to upload files. Please try again. Error: ${JSON.stringify(
343
- error
344
- )})`,
345
- error.code || 1
346
- )
347
- );
348
- }
349
- )
350
- );
351
- }
352
-
353
- await queue.onIdle();
354
-
355
- unmount();
356
-
357
- const uploadMs = Date.now() - start;
358
-
359
- const skipped = fileMap.size - missingHashes.length;
360
- const skippedMessage = skipped > 0 ? `(${skipped} already uploaded) ` : "";
361
-
362
- logger.log(
363
- `✨ Success! Uploaded ${
364
- sortedFiles.length
365
- } files ${skippedMessage}${formatTime(uploadMs)}\n`
366
- );
367
-
368
- const doUpsertHashes = async (): Promise<void> => {
369
- try {
370
- return await fetchResult(`/pages/assets/upsert-hashes`, {
371
- method: "POST",
372
- headers: {
373
- "Content-Type": "application/json",
374
- Authorization: `Bearer ${jwt}`,
375
- },
376
- body: JSON.stringify({
377
- hashes: files.map(({ hash }) => hash),
378
- }),
379
- });
380
- } catch (e) {
381
- await new Promise((resolvePromise) => setTimeout(resolvePromise, 1000));
382
-
383
- if ((e as { code: number }).code === 8000013 || isJwtExpired(jwt)) {
384
- // Looks like the JWT expired, fetch another one
385
- jwt = await fetchJwt();
386
- }
387
-
388
- return await fetchResult(`/pages/assets/upsert-hashes`, {
389
- method: "POST",
390
- headers: {
391
- "Content-Type": "application/json",
392
- Authorization: `Bearer ${jwt}`,
393
- },
394
- body: JSON.stringify({
395
- hashes: files.map(({ hash }) => hash),
396
- }),
397
- });
398
- }
399
- };
400
-
401
- try {
402
- await doUpsertHashes();
403
- } catch {
404
- logger.warn(
405
- "Failed to update file hashes. Every upload appeared to succeed for this deployment, but you might need to re-upload for future deployments. This shouldn't have any impact other than slowing the upload speed of your next deployment."
406
- );
407
- }
408
-
409
- return Object.fromEntries(
410
- [...fileMap.entries()].map(([fileName, file]) => [
411
- `/${fileName}`,
412
- file.hash,
413
- ])
414
- );
415
- };
416
-
417
- // Decode and check that the current JWT has not expired
418
- function isJwtExpired(token: string): boolean | undefined {
419
- try {
420
- const decodedJwt = JSON.parse(
421
- Buffer.from(token.split(".")[1], "base64").toString()
422
- );
423
-
424
- const dateNow = new Date().getTime() / 1000;
425
-
426
- return decodedJwt.exp <= dateNow;
427
- } catch (e) {
428
- if (e instanceof Error) {
429
- throw new Error(`Invalid token: ${e.message}`);
430
- }
431
- }
432
- }
433
-
434
- function formatTime(duration: number) {
435
- return `(${(duration / 1000).toFixed(2)} sec)`;
436
- }
437
-
438
- function renderProgress(done: number, total: number) {
439
- if (isInteractive()) {
440
- const { rerender, unmount } = render(
441
- <Progress done={done} total={total} />
442
- );
443
- return {
444
- // eslint-disable-next-line no-shadow
445
- rerender(done: number, total: number) {
446
- rerender(<Progress done={done} total={total} />);
447
- },
448
- unmount,
449
- };
450
- } else {
451
- // eslint-disable-next-line no-shadow
452
- const rerender = (done: number, total: number) => {
453
- logger.log(`Uploading... (${done}/${total})`);
454
- };
455
- rerender(done, total);
456
- return { rerender, unmount() {} };
457
- }
458
- }
459
-
460
- function Progress({ done, total }: { done: number; total: number }) {
461
- return (
462
- <>
463
- <Text>
464
- {isInteractive() ? <Spinner type="earth" /> : null}
465
- {` Uploading... (${done}/${total})\n`}
466
- </Text>
467
- </>
468
- );
469
- }
@@ -1,23 +0,0 @@
1
- import type { BundleResult } from "../bundle";
2
-
3
- export const RUNNING_BUILDERS: BundleResult[] = [];
4
-
5
- export const CLEANUP_CALLBACKS: (() => void)[] = [];
6
- export const CLEANUP = () => {
7
- CLEANUP_CALLBACKS.forEach((callback) => callback());
8
- RUNNING_BUILDERS.forEach((builder) => builder.stop?.());
9
- };
10
-
11
- export const pagesBetaWarning =
12
- "🚧 'wrangler pages <command>' is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose";
13
-
14
- export function isUrl(maybeUrl?: string): maybeUrl is string {
15
- if (!maybeUrl) return false;
16
-
17
- try {
18
- new URL(maybeUrl);
19
- return true;
20
- } catch (e) {
21
- return false;
22
- }
23
- }