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.
- package/README.md +4 -4
- package/bin/wrangler.js +9 -75
- package/package.json +5 -13
- package/templates/__tests__/tsconfig.tsbuildinfo +1 -1
- package/templates/checked-fetch.js +1 -1
- package/templates/first-party-worker-module-facade.ts +2 -2
- package/templates/middleware/common.ts +9 -4
- package/templates/middleware/loader-sw.ts +2 -7
- package/templates/new-worker-scheduled.ts +1 -1
- package/templates/new-worker.ts +1 -1
- package/templates/pages-dev-util.ts +4 -1
- package/templates/pages-shim.ts +0 -3
- package/templates/tsconfig.tsbuildinfo +1 -1
- package/wrangler-dist/cli.d.ts +149 -75
- package/wrangler-dist/cli.js +60062 -64338
- package/import_meta_url.js +0 -3
- package/miniflare-config-stubs/.env.empty +0 -0
- package/miniflare-config-stubs/package.empty.json +0 -1
- package/miniflare-config-stubs/wrangler.empty.toml +0 -0
- package/miniflare-dist/index.mjs +0 -6442
- package/src/__tests__/access.test.ts +0 -25
- package/src/__tests__/api-dev.test.ts +0 -238
- package/src/__tests__/api-devregistry.test.ts +0 -121
- package/src/__tests__/api.test.ts +0 -102
- package/src/__tests__/config-cache-without-cache-dir.test.ts +0 -38
- package/src/__tests__/config-cache.test.ts +0 -42
- package/src/__tests__/configuration.test.ts +0 -4517
- package/src/__tests__/constellation.test.ts +0 -371
- package/src/__tests__/d1/d1.test.ts +0 -82
- package/src/__tests__/d1/execute.test.ts +0 -66
- package/src/__tests__/d1/migrate.test.ts +0 -257
- package/src/__tests__/d1/splitter.test.ts +0 -255
- package/src/__tests__/delete.test.ts +0 -272
- package/src/__tests__/deployments.test.ts +0 -369
- package/src/__tests__/dev.test.tsx +0 -1617
- package/src/__tests__/generate.test.ts +0 -237
- package/src/__tests__/get-host-from-url.test.ts +0 -16
- package/src/__tests__/guess-worker-format.test.ts +0 -120
- package/src/__tests__/helpers/clipboardy-mock.js +0 -4
- package/src/__tests__/helpers/cmd-shim.d.ts +0 -11
- package/src/__tests__/helpers/end-event-loop.ts +0 -6
- package/src/__tests__/helpers/mock-account-id.ts +0 -48
- package/src/__tests__/helpers/mock-auth-domain.ts +0 -20
- package/src/__tests__/helpers/mock-bin.ts +0 -36
- package/src/__tests__/helpers/mock-console.ts +0 -112
- package/src/__tests__/helpers/mock-dialogs.ts +0 -139
- package/src/__tests__/helpers/mock-get-pages-upload-token.ts +0 -25
- package/src/__tests__/helpers/mock-get-zone-from-host.ts +0 -11
- package/src/__tests__/helpers/mock-http-server.ts +0 -46
- package/src/__tests__/helpers/mock-istty.ts +0 -74
- package/src/__tests__/helpers/mock-known-routes.ts +0 -12
- package/src/__tests__/helpers/mock-kv.ts +0 -46
- package/src/__tests__/helpers/mock-oauth-flow.ts +0 -263
- package/src/__tests__/helpers/mock-process.ts +0 -34
- package/src/__tests__/helpers/mock-set-timeout.ts +0 -16
- package/src/__tests__/helpers/mock-stdin.ts +0 -108
- package/src/__tests__/helpers/mock-web-socket.ts +0 -29
- package/src/__tests__/helpers/msw/blob-worker.cjs +0 -19
- package/src/__tests__/helpers/msw/handlers/access.ts +0 -13
- package/src/__tests__/helpers/msw/handlers/deployments.ts +0 -160
- package/src/__tests__/helpers/msw/handlers/namespaces.ts +0 -81
- package/src/__tests__/helpers/msw/handlers/oauth.ts +0 -31
- package/src/__tests__/helpers/msw/handlers/r2.ts +0 -60
- package/src/__tests__/helpers/msw/handlers/script.ts +0 -56
- package/src/__tests__/helpers/msw/handlers/user.ts +0 -52
- package/src/__tests__/helpers/msw/handlers/zones.ts +0 -20
- package/src/__tests__/helpers/msw/index.ts +0 -52
- package/src/__tests__/helpers/msw/read-file-sync.js +0 -61
- package/src/__tests__/helpers/run-in-tmp.ts +0 -38
- package/src/__tests__/helpers/run-wrangler.ts +0 -16
- package/src/__tests__/helpers/string-dynamic-values-matcher.ts +0 -28
- package/src/__tests__/helpers/worker-scripts/child-wrangler.toml +0 -1
- package/src/__tests__/helpers/worker-scripts/hello-world-worker.js +0 -5
- package/src/__tests__/helpers/worker-scripts/hello-world-wrangler.toml +0 -1
- package/src/__tests__/helpers/worker-scripts/parent-worker.js +0 -11
- package/src/__tests__/helpers/worker-scripts/parent-wrangler.toml +0 -5
- package/src/__tests__/helpers/write-worker-source.ts +0 -31
- package/src/__tests__/helpers/write-wrangler-toml.ts +0 -17
- package/src/__tests__/https-options.test.ts +0 -163
- package/src/__tests__/index.test.ts +0 -282
- package/src/__tests__/init.test.ts +0 -3196
- package/src/__tests__/jest.setup.ts +0 -179
- package/src/__tests__/kv.test.ts +0 -1799
- package/src/__tests__/logger.test.ts +0 -207
- package/src/__tests__/logout.test.ts +0 -47
- package/src/__tests__/metrics.test.ts +0 -493
- package/src/__tests__/middleware.scheduled.test.ts +0 -145
- package/src/__tests__/middleware.test.ts +0 -816
- package/src/__tests__/mtls-certificates.test.ts +0 -589
- package/src/__tests__/package-manager.test.ts +0 -353
- package/src/__tests__/pages/deployment-list.test.ts +0 -80
- package/src/__tests__/pages/functions-build.test.ts +0 -528
- package/src/__tests__/pages/pages.test.ts +0 -81
- package/src/__tests__/pages/project-create.test.ts +0 -63
- package/src/__tests__/pages/project-list.test.ts +0 -110
- package/src/__tests__/pages/project-upload.test.ts +0 -500
- package/src/__tests__/pages/publish.test.ts +0 -2864
- package/src/__tests__/pages-deployment-tail.test.ts +0 -957
- package/src/__tests__/parse.test.ts +0 -436
- package/src/__tests__/paths.test.ts +0 -39
- package/src/__tests__/publish.test.ts +0 -8849
- package/src/__tests__/pubsub.test.ts +0 -496
- package/src/__tests__/queues.test.ts +0 -532
- package/src/__tests__/r2.test.ts +0 -374
- package/src/__tests__/route.test.ts +0 -45
- package/src/__tests__/secret.test.ts +0 -693
- package/src/__tests__/tail.test.ts +0 -989
- package/src/__tests__/test-old-node-version.js +0 -31
- package/src/__tests__/traverse-module-graph.test.ts +0 -220
- package/src/__tests__/tsconfig-sanity.ts +0 -12
- package/src/__tests__/tsconfig.json +0 -8
- package/src/__tests__/tsconfig.tsbuildinfo +0 -1
- package/src/__tests__/type-generation.test.ts +0 -234
- package/src/__tests__/user.test.ts +0 -118
- package/src/__tests__/utils-collectKeyValues.test.ts +0 -47
- package/src/__tests__/validate-dev-props.test.ts +0 -56
- package/src/__tests__/version.test.ts +0 -35
- package/src/__tests__/whoami.test.tsx +0 -172
- package/src/__tests__/worker-namespace.test.ts +0 -340
- package/src/abort.d.ts +0 -3
- package/src/api/dev.ts +0 -321
- package/src/api/index.ts +0 -11
- package/src/api/mtls-certificate.ts +0 -148
- package/src/api/pages/create-worker-bundle-contents.ts +0 -77
- package/src/api/pages/index.ts +0 -5
- package/src/api/pages/publish.tsx +0 -371
- package/src/bundle-reporter.ts +0 -68
- package/src/bundle.ts +0 -929
- package/src/cfetch/index.ts +0 -158
- package/src/cfetch/internal.ts +0 -258
- package/src/cli.ts +0 -28
- package/src/config/README.md +0 -107
- package/src/config/config.ts +0 -282
- package/src/config/diagnostics.ts +0 -80
- package/src/config/environment.ts +0 -625
- package/src/config/index.ts +0 -403
- package/src/config/validation-helpers.ts +0 -597
- package/src/config/validation.ts +0 -2369
- package/src/config-cache.ts +0 -85
- package/src/constellation/createProject.tsx +0 -51
- package/src/constellation/deleteProject.ts +0 -51
- package/src/constellation/deleteProjectModel.ts +0 -68
- package/src/constellation/index.ts +0 -75
- package/src/constellation/listCatalog.tsx +0 -35
- package/src/constellation/listModel.tsx +0 -41
- package/src/constellation/listProject.tsx +0 -28
- package/src/constellation/listRuntime.tsx +0 -28
- package/src/constellation/options.ts +0 -17
- package/src/constellation/types.ts +0 -17
- package/src/constellation/uploadModel.tsx +0 -64
- package/src/constellation/utils.ts +0 -90
- package/src/create-worker-preview.ts +0 -293
- package/src/create-worker-upload-form.ts +0 -363
- package/src/d1/backups.tsx +0 -219
- package/src/d1/constants.ts +0 -2
- package/src/d1/create.tsx +0 -70
- package/src/d1/delete.ts +0 -53
- package/src/d1/execute.tsx +0 -357
- package/src/d1/formatTimeAgo.ts +0 -14
- package/src/d1/index.ts +0 -100
- package/src/d1/list.tsx +0 -62
- package/src/d1/migrations/apply.tsx +0 -212
- package/src/d1/migrations/create.tsx +0 -79
- package/src/d1/migrations/helpers.ts +0 -169
- package/src/d1/migrations/index.ts +0 -3
- package/src/d1/migrations/list.tsx +0 -95
- package/src/d1/migrations/options.ts +0 -23
- package/src/d1/options.ts +0 -22
- package/src/d1/splitter.ts +0 -161
- package/src/d1/types.ts +0 -25
- package/src/d1/utils.ts +0 -49
- package/src/delete.ts +0 -100
- package/src/deployments.ts +0 -368
- package/src/deprecated/index.ts +0 -144
- package/src/dev/dev-vars.ts +0 -39
- package/src/dev/dev.tsx +0 -605
- package/src/dev/get-local-persistence-path.ts +0 -31
- package/src/dev/local.tsx +0 -952
- package/src/dev/remote.tsx +0 -635
- package/src/dev/start-server.ts +0 -545
- package/src/dev/use-esbuild.ts +0 -215
- package/src/dev/validate-dev-props.ts +0 -40
- package/src/dev-registry.ts +0 -202
- package/src/dev.tsx +0 -934
- package/src/dialogs.ts +0 -136
- package/src/dispatch-namespace.ts +0 -211
- package/src/docs/helpers.ts +0 -50
- package/src/docs/index.ts +0 -54
- package/src/durable.ts +0 -102
- package/src/entry.ts +0 -344
- package/src/environment-variables/factory.ts +0 -89
- package/src/environment-variables/misc-variables.ts +0 -30
- package/src/errors.ts +0 -11
- package/src/generate/index.ts +0 -298
- package/src/git-client.ts +0 -135
- package/src/global-wrangler-config-path.ts +0 -26
- package/src/https-options.ts +0 -127
- package/src/index.ts +0 -768
- package/src/init.ts +0 -1037
- package/src/inspect.ts +0 -883
- package/src/intl-polyfill.d.ts +0 -139
- package/src/is-ci.ts +0 -14
- package/src/is-interactive.ts +0 -16
- package/src/jest.d.ts +0 -4
- package/src/kv/helpers.ts +0 -433
- package/src/kv/index.ts +0 -594
- package/src/logger.ts +0 -123
- package/src/metrics/index.ts +0 -5
- package/src/metrics/metrics-config.ts +0 -239
- package/src/metrics/metrics-dispatcher.ts +0 -96
- package/src/metrics/metrics-usage-headers.ts +0 -24
- package/src/metrics/send-event.ts +0 -99
- package/src/miniflare-cli/README.md +0 -30
- package/src/miniflare-cli/assets.ts +0 -251
- package/src/miniflare-cli/index.ts +0 -210
- package/src/miniflare-cli/request-context.ts +0 -40
- package/src/miniflare-cli/tsconfig.json +0 -9
- package/src/miniflare-cli/tsconfig.tsbuildinfo +0 -1
- package/src/miniflare-cli/types.ts +0 -11
- package/src/module-collection.ts +0 -333
- package/src/mtls-certificate/cli.ts +0 -155
- package/src/open-in-browser.ts +0 -17
- package/src/package-manager.ts +0 -219
- package/src/pages/build.ts +0 -423
- package/src/pages/buildFunctions.ts +0 -140
- package/src/pages/constants.ts +0 -18
- package/src/pages/deployment-tails.ts +0 -281
- package/src/pages/deployments.tsx +0 -84
- package/src/pages/dev.ts +0 -734
- package/src/pages/errors.ts +0 -67
- package/src/pages/functions/buildPlugin.ts +0 -114
- package/src/pages/functions/buildWorker.ts +0 -350
- package/src/pages/functions/filepath-routing.test.ts +0 -234
- package/src/pages/functions/filepath-routing.ts +0 -189
- package/src/pages/functions/identifiers.ts +0 -78
- package/src/pages/functions/routes-consolidation.test.ts +0 -250
- package/src/pages/functions/routes-consolidation.ts +0 -73
- package/src/pages/functions/routes-transformation.test.ts +0 -282
- package/src/pages/functions/routes-transformation.ts +0 -115
- package/src/pages/functions/routes-validation.test.ts +0 -403
- package/src/pages/functions/routes-validation.ts +0 -202
- package/src/pages/functions/routes.ts +0 -151
- package/src/pages/functions/tsconfig.json +0 -8
- package/src/pages/functions/tsconfig.tsbuildinfo +0 -1
- package/src/pages/functions.ts +0 -86
- package/src/pages/hash.ts +0 -13
- package/src/pages/index.ts +0 -102
- package/src/pages/projects.tsx +0 -159
- package/src/pages/prompt-select-project.tsx +0 -31
- package/src/pages/publish.tsx +0 -267
- package/src/pages/types.ts +0 -46
- package/src/pages/upload.tsx +0 -469
- package/src/pages/utils.ts +0 -23
- package/src/parse.ts +0 -308
- package/src/paths.ts +0 -71
- package/src/proxy.ts +0 -694
- package/src/publish/index.ts +0 -274
- package/src/publish/publish.ts +0 -1065
- package/src/pubsub/index.ts +0 -286
- package/src/pubsub/pubsub-commands.ts +0 -623
- package/src/queues/cli/commands/consumer/add.ts +0 -71
- package/src/queues/cli/commands/consumer/index.ts +0 -19
- package/src/queues/cli/commands/consumer/remove.ts +0 -31
- package/src/queues/cli/commands/create.ts +0 -25
- package/src/queues/cli/commands/delete.ts +0 -26
- package/src/queues/cli/commands/index.ts +0 -35
- package/src/queues/cli/commands/list.ts +0 -25
- package/src/queues/client.ts +0 -136
- package/src/queues/utils.ts +0 -18
- package/src/r2/constants.ts +0 -4
- package/src/r2/helpers.ts +0 -132
- package/src/r2/index.ts +0 -289
- package/src/routes.ts +0 -140
- package/src/secret/index.ts +0 -377
- package/src/selfsigned.d.ts +0 -29
- package/src/sites.ts +0 -484
- package/src/tail/createTail.ts +0 -415
- package/src/tail/filters.ts +0 -277
- package/src/tail/index.ts +0 -211
- package/src/tail/printing.ts +0 -132
- package/src/traverse-module-graph.ts +0 -54
- package/src/tsconfig-sanity.ts +0 -16
- package/src/type-generation.ts +0 -181
- package/src/update-check.ts +0 -19
- package/src/user/access.ts +0 -68
- package/src/user/auth-variables.ts +0 -113
- package/src/user/choose-account.tsx +0 -39
- package/src/user/generate-auth-url.ts +0 -33
- package/src/user/generate-random-state.ts +0 -16
- package/src/user/index.ts +0 -2
- package/src/user/user.ts +0 -1234
- package/src/utils/collectKeyValues.ts +0 -14
- package/src/utils/render.ts +0 -93
- package/src/whoami.ts +0 -135
- package/src/worker.ts +0 -279
- package/src/yargs-types.ts +0 -37
- package/src/zones.ts +0 -191
package/src/pages/upload.tsx
DELETED
|
@@ -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
|
-
}
|
package/src/pages/utils.ts
DELETED
|
@@ -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
|
-
}
|