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/dev.ts
DELETED
|
@@ -1,734 +0,0 @@
|
|
|
1
|
-
import { execSync, spawn } from "node:child_process";
|
|
2
|
-
import { existsSync, lstatSync, readFileSync } from "node:fs";
|
|
3
|
-
import { homedir, tmpdir } from "node:os";
|
|
4
|
-
import { join, resolve } from "node:path";
|
|
5
|
-
import { watch } from "chokidar";
|
|
6
|
-
import * as esbuild from "esbuild";
|
|
7
|
-
import { unstable_dev } from "../api";
|
|
8
|
-
import { esbuildAliasExternalPlugin } from "../bundle";
|
|
9
|
-
import { FatalError } from "../errors";
|
|
10
|
-
import { logger } from "../logger";
|
|
11
|
-
import * as metrics from "../metrics";
|
|
12
|
-
import { getBasePath } from "../paths";
|
|
13
|
-
import { buildFunctions } from "./buildFunctions";
|
|
14
|
-
import { ROUTES_SPEC_VERSION, SECONDS_TO_WAIT_FOR_PROXY } from "./constants";
|
|
15
|
-
import { FunctionsNoRoutesError, getFunctionsNoRoutesWarning } from "./errors";
|
|
16
|
-
import { buildRawWorker, checkRawWorker } from "./functions/buildWorker";
|
|
17
|
-
import { validateRoutes } from "./functions/routes-validation";
|
|
18
|
-
import { CLEANUP, CLEANUP_CALLBACKS, pagesBetaWarning } from "./utils";
|
|
19
|
-
import type { AdditionalDevProps } from "../dev";
|
|
20
|
-
import type {
|
|
21
|
-
CommonYargsArgv,
|
|
22
|
-
StrictYargsOptionsToInterface,
|
|
23
|
-
} from "../yargs-types";
|
|
24
|
-
import type { RoutesJSONSpec } from "./functions/routes-transformation";
|
|
25
|
-
|
|
26
|
-
const DURABLE_OBJECTS_BINDING_REGEXP = new RegExp(
|
|
27
|
-
/^(?<binding>[^=]+)=(?<className>[^@\s]+)(@(?<scriptName>.*)$)?$/
|
|
28
|
-
);
|
|
29
|
-
|
|
30
|
-
export function Options(yargs: CommonYargsArgv) {
|
|
31
|
-
return yargs
|
|
32
|
-
.positional("directory", {
|
|
33
|
-
type: "string",
|
|
34
|
-
demandOption: undefined,
|
|
35
|
-
description: "The directory of static assets to serve",
|
|
36
|
-
})
|
|
37
|
-
.positional("command", {
|
|
38
|
-
type: "string",
|
|
39
|
-
demandOption: undefined,
|
|
40
|
-
description: "The proxy command to run",
|
|
41
|
-
})
|
|
42
|
-
.options({
|
|
43
|
-
local: {
|
|
44
|
-
type: "boolean",
|
|
45
|
-
default: true,
|
|
46
|
-
description: "Run on my machine",
|
|
47
|
-
},
|
|
48
|
-
"compatibility-date": {
|
|
49
|
-
describe: "Date to use for compatibility checks",
|
|
50
|
-
type: "string",
|
|
51
|
-
},
|
|
52
|
-
"compatibility-flags": {
|
|
53
|
-
describe: "Flags to use for compatibility checks",
|
|
54
|
-
alias: "compatibility-flag",
|
|
55
|
-
type: "string",
|
|
56
|
-
array: true,
|
|
57
|
-
},
|
|
58
|
-
ip: {
|
|
59
|
-
type: "string",
|
|
60
|
-
default: "0.0.0.0",
|
|
61
|
-
description: "The IP address to listen on",
|
|
62
|
-
},
|
|
63
|
-
port: {
|
|
64
|
-
type: "number",
|
|
65
|
-
default: 8788,
|
|
66
|
-
description: "The port to listen on (serve from)",
|
|
67
|
-
},
|
|
68
|
-
"inspector-port": {
|
|
69
|
-
type: "number",
|
|
70
|
-
describe: "Port for devtools to connect to",
|
|
71
|
-
},
|
|
72
|
-
proxy: {
|
|
73
|
-
type: "number",
|
|
74
|
-
description: "The port to proxy (where the static assets are served)",
|
|
75
|
-
},
|
|
76
|
-
"script-path": {
|
|
77
|
-
type: "string",
|
|
78
|
-
default: "_worker.js",
|
|
79
|
-
description:
|
|
80
|
-
"The location of the single Worker script if not using functions",
|
|
81
|
-
},
|
|
82
|
-
bundle: {
|
|
83
|
-
type: "boolean",
|
|
84
|
-
default: undefined,
|
|
85
|
-
hidden: true,
|
|
86
|
-
},
|
|
87
|
-
"no-bundle": {
|
|
88
|
-
type: "boolean",
|
|
89
|
-
default: false,
|
|
90
|
-
description: "Whether to run bundling on `_worker.js`",
|
|
91
|
-
},
|
|
92
|
-
binding: {
|
|
93
|
-
type: "array",
|
|
94
|
-
description: "Bind variable/secret (KEY=VALUE)",
|
|
95
|
-
alias: "b",
|
|
96
|
-
},
|
|
97
|
-
kv: {
|
|
98
|
-
type: "array",
|
|
99
|
-
description: "KV namespace to bind (--kv KV_BINDING)",
|
|
100
|
-
alias: "k",
|
|
101
|
-
},
|
|
102
|
-
d1: {
|
|
103
|
-
type: "array",
|
|
104
|
-
description: "D1 database to bind",
|
|
105
|
-
},
|
|
106
|
-
do: {
|
|
107
|
-
type: "array",
|
|
108
|
-
description: "Durable Object to bind (--do NAME=CLASS)",
|
|
109
|
-
alias: "o",
|
|
110
|
-
},
|
|
111
|
-
r2: {
|
|
112
|
-
type: "array",
|
|
113
|
-
description: "R2 bucket to bind (--r2 R2_BINDING)",
|
|
114
|
-
},
|
|
115
|
-
"live-reload": {
|
|
116
|
-
type: "boolean",
|
|
117
|
-
default: false,
|
|
118
|
-
description: "Auto reload HTML pages when change is detected",
|
|
119
|
-
},
|
|
120
|
-
"local-protocol": {
|
|
121
|
-
describe: "Protocol to listen to requests on, defaults to http.",
|
|
122
|
-
choices: ["http", "https"] as const,
|
|
123
|
-
},
|
|
124
|
-
"experimental-enable-local-persistence": {
|
|
125
|
-
describe:
|
|
126
|
-
"Enable persistence for local mode (deprecated, use --persist)",
|
|
127
|
-
type: "boolean",
|
|
128
|
-
deprecated: true,
|
|
129
|
-
hidden: true,
|
|
130
|
-
},
|
|
131
|
-
persist: {
|
|
132
|
-
describe:
|
|
133
|
-
"Enable persistence for local mode, using default path: .wrangler/state",
|
|
134
|
-
type: "boolean",
|
|
135
|
-
},
|
|
136
|
-
"persist-to": {
|
|
137
|
-
describe:
|
|
138
|
-
"Specify directory to use for local persistence (implies --persist)",
|
|
139
|
-
type: "string",
|
|
140
|
-
requiresArg: true,
|
|
141
|
-
},
|
|
142
|
-
"node-compat": {
|
|
143
|
-
describe: "Enable Node.js compatibility",
|
|
144
|
-
default: false,
|
|
145
|
-
type: "boolean",
|
|
146
|
-
hidden: true,
|
|
147
|
-
},
|
|
148
|
-
"experimental-local": {
|
|
149
|
-
describe: "Run on my machine using the Cloudflare Workers runtime",
|
|
150
|
-
type: "boolean",
|
|
151
|
-
default: false,
|
|
152
|
-
},
|
|
153
|
-
config: {
|
|
154
|
-
describe: "Pages does not support wrangler.toml",
|
|
155
|
-
type: "string",
|
|
156
|
-
hidden: true,
|
|
157
|
-
},
|
|
158
|
-
"log-level": {
|
|
159
|
-
choices: ["debug", "info", "log", "warn", "error", "none"] as const,
|
|
160
|
-
describe: "Specify logging level",
|
|
161
|
-
},
|
|
162
|
-
})
|
|
163
|
-
.epilogue(pagesBetaWarning);
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
export const Handler = async ({
|
|
167
|
-
local,
|
|
168
|
-
directory,
|
|
169
|
-
compatibilityDate,
|
|
170
|
-
compatibilityFlags,
|
|
171
|
-
ip,
|
|
172
|
-
port,
|
|
173
|
-
inspectorPort,
|
|
174
|
-
proxy: requestedProxyPort,
|
|
175
|
-
bundle,
|
|
176
|
-
noBundle,
|
|
177
|
-
scriptPath: singleWorkerScriptPath,
|
|
178
|
-
binding: bindings = [],
|
|
179
|
-
kv: kvs = [],
|
|
180
|
-
do: durableObjects = [],
|
|
181
|
-
d1: d1s = [],
|
|
182
|
-
r2: r2s = [],
|
|
183
|
-
liveReload,
|
|
184
|
-
localProtocol,
|
|
185
|
-
experimentalEnableLocalPersistence,
|
|
186
|
-
persist,
|
|
187
|
-
persistTo,
|
|
188
|
-
nodeCompat: legacyNodeCompat,
|
|
189
|
-
experimentalLocal,
|
|
190
|
-
config: config,
|
|
191
|
-
_: [_pages, _dev, ...remaining],
|
|
192
|
-
logLevel,
|
|
193
|
-
}: StrictYargsOptionsToInterface<typeof Options>) => {
|
|
194
|
-
// Beta message for `wrangler pages <commands>` usage
|
|
195
|
-
logger.log(pagesBetaWarning);
|
|
196
|
-
|
|
197
|
-
if (logLevel) {
|
|
198
|
-
logger.loggerLevel = logLevel;
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
if (!local) {
|
|
202
|
-
throw new FatalError("Only local mode is supported at the moment.", 1);
|
|
203
|
-
}
|
|
204
|
-
|
|
205
|
-
if (config) {
|
|
206
|
-
throw new FatalError("Pages does not support wrangler.toml", 1);
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
const command = remaining;
|
|
210
|
-
|
|
211
|
-
let proxyPort: number | undefined;
|
|
212
|
-
|
|
213
|
-
if (directory !== undefined && command.length > 0) {
|
|
214
|
-
throw new FatalError(
|
|
215
|
-
"Specify either a directory OR a proxy command, not both.",
|
|
216
|
-
1
|
|
217
|
-
);
|
|
218
|
-
} else if (directory === undefined) {
|
|
219
|
-
proxyPort = await spawnProxyProcess({
|
|
220
|
-
port: requestedProxyPort,
|
|
221
|
-
command,
|
|
222
|
-
});
|
|
223
|
-
if (proxyPort === undefined) return undefined;
|
|
224
|
-
} else {
|
|
225
|
-
directory = resolve(directory);
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
if (!compatibilityDate) {
|
|
229
|
-
const currentDate = new Date().toISOString().substring(0, 10);
|
|
230
|
-
logger.warn(
|
|
231
|
-
`No compatibility_date was specified. Using today's date: ${currentDate}.\n` +
|
|
232
|
-
"Pass it in your terminal:\n" +
|
|
233
|
-
"```\n" +
|
|
234
|
-
`--compatibility-date=${currentDate}\n` +
|
|
235
|
-
"```\n" +
|
|
236
|
-
"See https://developers.cloudflare.com/workers/platform/compatibility-dates/ for more information."
|
|
237
|
-
);
|
|
238
|
-
compatibilityDate = currentDate;
|
|
239
|
-
}
|
|
240
|
-
|
|
241
|
-
if (experimentalEnableLocalPersistence) {
|
|
242
|
-
logger.warn(
|
|
243
|
-
`--experimental-enable-local-persistence is deprecated.\n` +
|
|
244
|
-
`Move any existing data to .wrangler/state and use --persist, or\n` +
|
|
245
|
-
`use --persist-to=./wrangler-local-state to keep using the old path.`
|
|
246
|
-
);
|
|
247
|
-
}
|
|
248
|
-
|
|
249
|
-
let scriptReadyResolve: () => void;
|
|
250
|
-
const scriptReadyPromise = new Promise<void>(
|
|
251
|
-
(promiseResolve) => (scriptReadyResolve = promiseResolve)
|
|
252
|
-
);
|
|
253
|
-
|
|
254
|
-
const workerScriptPath =
|
|
255
|
-
directory !== undefined
|
|
256
|
-
? join(directory, singleWorkerScriptPath)
|
|
257
|
-
: singleWorkerScriptPath;
|
|
258
|
-
const usingWorkerDirectory =
|
|
259
|
-
existsSync(workerScriptPath) && lstatSync(workerScriptPath).isDirectory();
|
|
260
|
-
const usingWorkerScript = existsSync(workerScriptPath);
|
|
261
|
-
// TODO: Here lies a known bug. If you specify both `--bundle` and `--no-bundle`, this behavior is undefined and you will get unexpected results.
|
|
262
|
-
// There is no sane way to get the true value out of yargs, so here we are.
|
|
263
|
-
const enableBundling = bundle ?? !noBundle;
|
|
264
|
-
|
|
265
|
-
const functionsDirectory = "./functions";
|
|
266
|
-
let usingFunctions = !usingWorkerScript && existsSync(functionsDirectory);
|
|
267
|
-
|
|
268
|
-
let scriptPath = "";
|
|
269
|
-
|
|
270
|
-
const nodejsCompat = compatibilityFlags?.includes("nodejs_compat");
|
|
271
|
-
|
|
272
|
-
if (usingWorkerScript) {
|
|
273
|
-
scriptPath = workerScriptPath;
|
|
274
|
-
let runBuild = async () => {
|
|
275
|
-
await checkRawWorker(workerScriptPath, () => scriptReadyResolve());
|
|
276
|
-
};
|
|
277
|
-
|
|
278
|
-
if (enableBundling) {
|
|
279
|
-
// We want to actually run the `_worker.js` script through the bundler
|
|
280
|
-
// So update the final path to the script that will be uploaded and
|
|
281
|
-
// change the `runBuild()` function to bundle the `_worker.js`.
|
|
282
|
-
scriptPath = join(tmpdir(), `./bundledWorker-${Math.random()}.mjs`);
|
|
283
|
-
runBuild = async () => {
|
|
284
|
-
try {
|
|
285
|
-
await buildRawWorker({
|
|
286
|
-
workerScriptPath: usingWorkerDirectory
|
|
287
|
-
? join(workerScriptPath, "index.js")
|
|
288
|
-
: workerScriptPath,
|
|
289
|
-
outfile: scriptPath,
|
|
290
|
-
directory: directory ?? ".",
|
|
291
|
-
nodejsCompat,
|
|
292
|
-
local: true,
|
|
293
|
-
sourcemap: true,
|
|
294
|
-
watch: true,
|
|
295
|
-
onEnd: () => scriptReadyResolve(),
|
|
296
|
-
});
|
|
297
|
-
} catch (e: unknown) {
|
|
298
|
-
logger.warn("Failed to bundle _worker.js.", e);
|
|
299
|
-
}
|
|
300
|
-
};
|
|
301
|
-
}
|
|
302
|
-
|
|
303
|
-
await runBuild();
|
|
304
|
-
watch([workerScriptPath], {
|
|
305
|
-
persistent: true,
|
|
306
|
-
ignoreInitial: true,
|
|
307
|
-
}).on("all", async () => {
|
|
308
|
-
await runBuild();
|
|
309
|
-
});
|
|
310
|
-
} else if (usingFunctions) {
|
|
311
|
-
// Try to use Functions
|
|
312
|
-
scriptPath = join(tmpdir(), `./functionsWorker-${Math.random()}.mjs`);
|
|
313
|
-
|
|
314
|
-
if (legacyNodeCompat) {
|
|
315
|
-
console.warn(
|
|
316
|
-
"Enabling Node.js compatibility mode for builtins and globals. This is experimental and has serious tradeoffs. Please see https://github.com/ionic-team/rollup-plugin-node-polyfills/ for more details."
|
|
317
|
-
);
|
|
318
|
-
}
|
|
319
|
-
|
|
320
|
-
if (legacyNodeCompat && nodejsCompat) {
|
|
321
|
-
throw new FatalError(
|
|
322
|
-
"The `nodejs_compat` compatibility flag cannot be used in conjunction with the legacy `--node-compat` flag. If you want to use the Workers runtime Node.js compatibility features, please remove the `--node-compat` argument from your CLI command or `node_compat = true` from your config file.",
|
|
323
|
-
1
|
|
324
|
-
);
|
|
325
|
-
}
|
|
326
|
-
|
|
327
|
-
logger.log(`Compiling worker to "${scriptPath}"...`);
|
|
328
|
-
const onEnd = () => scriptReadyResolve();
|
|
329
|
-
try {
|
|
330
|
-
const buildFn = async () => {
|
|
331
|
-
await buildFunctions({
|
|
332
|
-
outfile: scriptPath,
|
|
333
|
-
functionsDirectory,
|
|
334
|
-
sourcemap: true,
|
|
335
|
-
watch: true,
|
|
336
|
-
onEnd,
|
|
337
|
-
buildOutputDirectory: directory,
|
|
338
|
-
legacyNodeCompat,
|
|
339
|
-
nodejsCompat,
|
|
340
|
-
local: true,
|
|
341
|
-
});
|
|
342
|
-
await metrics.sendMetricsEvent("build pages functions");
|
|
343
|
-
};
|
|
344
|
-
|
|
345
|
-
await buildFn();
|
|
346
|
-
// If Functions found routes, continue using Functions
|
|
347
|
-
watch([functionsDirectory], {
|
|
348
|
-
persistent: true,
|
|
349
|
-
ignoreInitial: true,
|
|
350
|
-
}).on("all", async () => {
|
|
351
|
-
try {
|
|
352
|
-
await buildFn();
|
|
353
|
-
} catch (e) {
|
|
354
|
-
if (e instanceof FunctionsNoRoutesError) {
|
|
355
|
-
logger.warn(
|
|
356
|
-
getFunctionsNoRoutesWarning(functionsDirectory, "skipping")
|
|
357
|
-
);
|
|
358
|
-
} else {
|
|
359
|
-
throw e;
|
|
360
|
-
}
|
|
361
|
-
}
|
|
362
|
-
});
|
|
363
|
-
} catch (e) {
|
|
364
|
-
// If there are no Functions, then Pages will only serve assets.
|
|
365
|
-
if (e instanceof FunctionsNoRoutesError) {
|
|
366
|
-
logger.warn(
|
|
367
|
-
getFunctionsNoRoutesWarning(functionsDirectory, "skipping")
|
|
368
|
-
);
|
|
369
|
-
// Resolve anyway and run without Functions
|
|
370
|
-
onEnd();
|
|
371
|
-
// Turn off Functions
|
|
372
|
-
usingFunctions = false;
|
|
373
|
-
} else {
|
|
374
|
-
throw e;
|
|
375
|
-
}
|
|
376
|
-
}
|
|
377
|
-
}
|
|
378
|
-
|
|
379
|
-
// Depending on the result of building Functions, we may not actually be using
|
|
380
|
-
// Functions even if the directory exists.
|
|
381
|
-
if (!usingFunctions && !usingWorkerScript) {
|
|
382
|
-
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
383
|
-
scriptReadyResolve!();
|
|
384
|
-
|
|
385
|
-
logger.log("No functions. Shimming...");
|
|
386
|
-
scriptPath = resolve(getBasePath(), "templates/pages-shim.ts");
|
|
387
|
-
}
|
|
388
|
-
|
|
389
|
-
await scriptReadyPromise;
|
|
390
|
-
|
|
391
|
-
if (scriptPath === "") {
|
|
392
|
-
// Failed to get a script with or without Functions,
|
|
393
|
-
// something really bad must have happened.
|
|
394
|
-
throw new FatalError(
|
|
395
|
-
"Failed to start wrangler pages dev due to an unknown error",
|
|
396
|
-
1
|
|
397
|
-
);
|
|
398
|
-
}
|
|
399
|
-
|
|
400
|
-
let entrypoint = scriptPath;
|
|
401
|
-
|
|
402
|
-
// custom _routes.json apply only to Functions or Advanced Mode Pages projects
|
|
403
|
-
if (
|
|
404
|
-
directory &&
|
|
405
|
-
(usingFunctions || usingWorkerScript || usingWorkerDirectory)
|
|
406
|
-
) {
|
|
407
|
-
const routesJSONPath = join(directory, "_routes.json");
|
|
408
|
-
|
|
409
|
-
if (existsSync(routesJSONPath)) {
|
|
410
|
-
let routesJSONContents: string;
|
|
411
|
-
const runBuild = async (
|
|
412
|
-
entrypointFile: string,
|
|
413
|
-
outfile: string,
|
|
414
|
-
routes: string
|
|
415
|
-
) => {
|
|
416
|
-
await esbuild.build({
|
|
417
|
-
entryPoints: [
|
|
418
|
-
resolve(getBasePath(), "templates/pages-dev-pipeline.ts"),
|
|
419
|
-
],
|
|
420
|
-
bundle: true,
|
|
421
|
-
sourcemap: true,
|
|
422
|
-
format: "esm",
|
|
423
|
-
plugins: [
|
|
424
|
-
esbuildAliasExternalPlugin({
|
|
425
|
-
__ENTRY_POINT__: entrypointFile,
|
|
426
|
-
"./pages-dev-util": resolve(
|
|
427
|
-
getBasePath(),
|
|
428
|
-
"templates/pages-dev-util.ts"
|
|
429
|
-
),
|
|
430
|
-
}),
|
|
431
|
-
],
|
|
432
|
-
outfile,
|
|
433
|
-
define: {
|
|
434
|
-
__ROUTES__: routes,
|
|
435
|
-
},
|
|
436
|
-
});
|
|
437
|
-
};
|
|
438
|
-
|
|
439
|
-
try {
|
|
440
|
-
// always run the routes validation first. If _routes.json is invalid we
|
|
441
|
-
// want to throw accordingly and exit.
|
|
442
|
-
routesJSONContents = readFileSync(routesJSONPath, "utf-8");
|
|
443
|
-
validateRoutes(JSON.parse(routesJSONContents), directory);
|
|
444
|
-
|
|
445
|
-
entrypoint = join(
|
|
446
|
-
tmpdir(),
|
|
447
|
-
`${Math.random().toString(36).slice(2)}.js`
|
|
448
|
-
);
|
|
449
|
-
await runBuild(scriptPath, entrypoint, routesJSONContents);
|
|
450
|
-
} catch (err) {
|
|
451
|
-
if (err instanceof FatalError) {
|
|
452
|
-
throw err;
|
|
453
|
-
} else {
|
|
454
|
-
throw new FatalError(
|
|
455
|
-
`Could not validate _routes.json at ${directory}: ${err}`,
|
|
456
|
-
1
|
|
457
|
-
);
|
|
458
|
-
}
|
|
459
|
-
}
|
|
460
|
-
|
|
461
|
-
watch([routesJSONPath], {
|
|
462
|
-
persistent: true,
|
|
463
|
-
ignoreInitial: true,
|
|
464
|
-
}).on("all", async () => {
|
|
465
|
-
try {
|
|
466
|
-
/**
|
|
467
|
-
* Watch for _routes.json file changes and validate file each time.
|
|
468
|
-
* If file is valid proceed to running the build.
|
|
469
|
-
*/
|
|
470
|
-
routesJSONContents = readFileSync(routesJSONPath, "utf-8");
|
|
471
|
-
validateRoutes(JSON.parse(routesJSONContents), directory as string);
|
|
472
|
-
await runBuild(scriptPath, entrypoint, routesJSONContents);
|
|
473
|
-
} catch (err) {
|
|
474
|
-
/**
|
|
475
|
-
* If _routes.json is invalid, don't exit but instead fallback to a sensible default
|
|
476
|
-
* and continue to serve the assets. At the same time make sure we warn users that we
|
|
477
|
-
* we detected an invalid file and that we'll be using a default.
|
|
478
|
-
* This basically equates to serving a Functions or _worker.js project as is,
|
|
479
|
-
* without applying any additional routing rules on top.
|
|
480
|
-
*/
|
|
481
|
-
const error =
|
|
482
|
-
err instanceof FatalError
|
|
483
|
-
? err
|
|
484
|
-
: `Could not validate _routes.json at ${directory}: ${err}`;
|
|
485
|
-
const defaultRoutesJSONSpec: RoutesJSONSpec = {
|
|
486
|
-
version: ROUTES_SPEC_VERSION,
|
|
487
|
-
include: ["/*"],
|
|
488
|
-
exclude: [],
|
|
489
|
-
};
|
|
490
|
-
|
|
491
|
-
logger.error(error);
|
|
492
|
-
logger.warn(
|
|
493
|
-
`Falling back to the following _routes.json default: ${JSON.stringify(
|
|
494
|
-
defaultRoutesJSONSpec,
|
|
495
|
-
null,
|
|
496
|
-
2
|
|
497
|
-
)}`
|
|
498
|
-
);
|
|
499
|
-
|
|
500
|
-
routesJSONContents = JSON.stringify(defaultRoutesJSONSpec);
|
|
501
|
-
await runBuild(scriptPath, entrypoint, routesJSONContents);
|
|
502
|
-
}
|
|
503
|
-
});
|
|
504
|
-
}
|
|
505
|
-
}
|
|
506
|
-
|
|
507
|
-
const { stop, waitUntilExit } = await unstable_dev(entrypoint, {
|
|
508
|
-
ip,
|
|
509
|
-
port,
|
|
510
|
-
inspectorPort,
|
|
511
|
-
localProtocol,
|
|
512
|
-
compatibilityDate,
|
|
513
|
-
compatibilityFlags,
|
|
514
|
-
nodeCompat: legacyNodeCompat,
|
|
515
|
-
vars: Object.fromEntries(
|
|
516
|
-
bindings
|
|
517
|
-
.map((binding) => binding.toString().split("="))
|
|
518
|
-
.map(([key, ...values]) => [key, values.join("=")])
|
|
519
|
-
),
|
|
520
|
-
kv: kvs.map((binding) => ({
|
|
521
|
-
binding: binding.toString(),
|
|
522
|
-
id: "",
|
|
523
|
-
})),
|
|
524
|
-
durableObjects: durableObjects
|
|
525
|
-
.map((durableObject) => {
|
|
526
|
-
const { binding, className, scriptName } =
|
|
527
|
-
DURABLE_OBJECTS_BINDING_REGEXP.exec(durableObject.toString())
|
|
528
|
-
?.groups || {};
|
|
529
|
-
|
|
530
|
-
if (!binding || !className) {
|
|
531
|
-
logger.warn(
|
|
532
|
-
"Could not parse Durable Object binding:",
|
|
533
|
-
durableObject.toString()
|
|
534
|
-
);
|
|
535
|
-
return;
|
|
536
|
-
}
|
|
537
|
-
|
|
538
|
-
return {
|
|
539
|
-
name: binding,
|
|
540
|
-
class_name: className,
|
|
541
|
-
script_name: scriptName,
|
|
542
|
-
};
|
|
543
|
-
})
|
|
544
|
-
.filter(Boolean) as AdditionalDevProps["durableObjects"],
|
|
545
|
-
r2: r2s.map((binding) => {
|
|
546
|
-
return { binding: binding.toString(), bucket_name: "" };
|
|
547
|
-
}),
|
|
548
|
-
processEntrypoint: true,
|
|
549
|
-
moduleRoot: workerScriptPath,
|
|
550
|
-
rules: usingWorkerDirectory
|
|
551
|
-
? [
|
|
552
|
-
{
|
|
553
|
-
type: "ESModule",
|
|
554
|
-
globs: ["**/*.js"],
|
|
555
|
-
},
|
|
556
|
-
]
|
|
557
|
-
: undefined,
|
|
558
|
-
bundle: enableBundling,
|
|
559
|
-
persist,
|
|
560
|
-
persistTo,
|
|
561
|
-
inspect: undefined,
|
|
562
|
-
logLevel,
|
|
563
|
-
experimental: {
|
|
564
|
-
d1Databases: d1s.map((binding) => ({
|
|
565
|
-
binding: binding.toString(),
|
|
566
|
-
database_id: "", // Required for types, but unused by dev
|
|
567
|
-
database_name: `local-${binding}`,
|
|
568
|
-
})),
|
|
569
|
-
disableExperimentalWarning: true,
|
|
570
|
-
enablePagesAssetsServiceBinding: {
|
|
571
|
-
proxyPort,
|
|
572
|
-
directory,
|
|
573
|
-
},
|
|
574
|
-
experimentalLocal,
|
|
575
|
-
liveReload,
|
|
576
|
-
forceLocal: true,
|
|
577
|
-
showInteractiveDevSession: undefined,
|
|
578
|
-
testMode: false,
|
|
579
|
-
watch: true,
|
|
580
|
-
},
|
|
581
|
-
});
|
|
582
|
-
await metrics.sendMetricsEvent("run pages dev");
|
|
583
|
-
|
|
584
|
-
CLEANUP_CALLBACKS.push(stop);
|
|
585
|
-
|
|
586
|
-
void waitUntilExit().then(() => {
|
|
587
|
-
CLEANUP();
|
|
588
|
-
process.exit(0);
|
|
589
|
-
});
|
|
590
|
-
|
|
591
|
-
process.on("exit", CLEANUP);
|
|
592
|
-
process.on("SIGINT", CLEANUP);
|
|
593
|
-
process.on("SIGTERM", CLEANUP);
|
|
594
|
-
};
|
|
595
|
-
|
|
596
|
-
function isWindows() {
|
|
597
|
-
return process.platform === "win32";
|
|
598
|
-
}
|
|
599
|
-
|
|
600
|
-
async function sleep(ms: number) {
|
|
601
|
-
await new Promise((promiseResolve) => setTimeout(promiseResolve, ms));
|
|
602
|
-
}
|
|
603
|
-
|
|
604
|
-
function getPids(pid: number) {
|
|
605
|
-
const pids: number[] = [pid];
|
|
606
|
-
let command: string, regExp: RegExp;
|
|
607
|
-
|
|
608
|
-
if (isWindows()) {
|
|
609
|
-
command = `wmic process where (ParentProcessId=${pid}) get ProcessId`;
|
|
610
|
-
regExp = new RegExp(/(\d+)/);
|
|
611
|
-
} else {
|
|
612
|
-
command = `pgrep -P ${pid}`;
|
|
613
|
-
regExp = new RegExp(/(\d+)/);
|
|
614
|
-
}
|
|
615
|
-
|
|
616
|
-
try {
|
|
617
|
-
const newPids = (
|
|
618
|
-
execSync(command)
|
|
619
|
-
.toString()
|
|
620
|
-
.split("\n")
|
|
621
|
-
.map((line) => line.match(regExp))
|
|
622
|
-
.filter((line) => line !== null) as RegExpExecArray[]
|
|
623
|
-
).map((match) => parseInt(match[1]));
|
|
624
|
-
|
|
625
|
-
pids.push(...newPids.map(getPids).flat());
|
|
626
|
-
} catch {}
|
|
627
|
-
|
|
628
|
-
return pids;
|
|
629
|
-
}
|
|
630
|
-
|
|
631
|
-
function getPort(pid: number) {
|
|
632
|
-
let command: string, regExp: RegExp;
|
|
633
|
-
|
|
634
|
-
if (isWindows()) {
|
|
635
|
-
const drive = homedir().split(":\\")[0];
|
|
636
|
-
command = drive + ":\\windows\\system32\\netstat.exe -nao";
|
|
637
|
-
regExp = new RegExp(`TCP\\s+.*:(\\d+)\\s+.*:\\d+\\s+LISTENING\\s+${pid}`);
|
|
638
|
-
} else {
|
|
639
|
-
command = "lsof -nPi";
|
|
640
|
-
regExp = new RegExp(`${pid}\\s+.*TCP\\s+.*:(\\d+)\\s+\\(LISTEN\\)`);
|
|
641
|
-
}
|
|
642
|
-
|
|
643
|
-
try {
|
|
644
|
-
const matches = execSync(command)
|
|
645
|
-
.toString()
|
|
646
|
-
.split("\n")
|
|
647
|
-
.map((line) => line.match(regExp))
|
|
648
|
-
.filter((line) => line !== null) as RegExpExecArray[];
|
|
649
|
-
|
|
650
|
-
const match = matches[0];
|
|
651
|
-
if (match) return parseInt(match[1]);
|
|
652
|
-
} catch (thrown) {
|
|
653
|
-
logger.error(
|
|
654
|
-
`Error scanning for ports of process with PID ${pid}: ${thrown}`
|
|
655
|
-
);
|
|
656
|
-
}
|
|
657
|
-
}
|
|
658
|
-
|
|
659
|
-
async function spawnProxyProcess({
|
|
660
|
-
port,
|
|
661
|
-
command,
|
|
662
|
-
}: {
|
|
663
|
-
port?: number;
|
|
664
|
-
command: (string | number)[];
|
|
665
|
-
}): Promise<undefined | number> {
|
|
666
|
-
if (command.length === 0) {
|
|
667
|
-
if (port !== undefined) {
|
|
668
|
-
return port;
|
|
669
|
-
}
|
|
670
|
-
|
|
671
|
-
CLEANUP();
|
|
672
|
-
throw new FatalError(
|
|
673
|
-
"Must specify a directory of static assets to serve or a command to run or a proxy port.",
|
|
674
|
-
1
|
|
675
|
-
);
|
|
676
|
-
}
|
|
677
|
-
|
|
678
|
-
logger.log(`Running ${command.join(" ")}...`);
|
|
679
|
-
const proxy = spawn(
|
|
680
|
-
command[0].toString(),
|
|
681
|
-
command.slice(1).map((value) => value.toString()),
|
|
682
|
-
{
|
|
683
|
-
shell: isWindows(),
|
|
684
|
-
env: {
|
|
685
|
-
BROWSER: "none",
|
|
686
|
-
...process.env,
|
|
687
|
-
},
|
|
688
|
-
}
|
|
689
|
-
);
|
|
690
|
-
CLEANUP_CALLBACKS.push(() => {
|
|
691
|
-
proxy.kill();
|
|
692
|
-
});
|
|
693
|
-
|
|
694
|
-
proxy.stdout.on("data", (data) => {
|
|
695
|
-
logger.log(`[proxy]: ${data}`);
|
|
696
|
-
});
|
|
697
|
-
|
|
698
|
-
proxy.stderr.on("data", (data) => {
|
|
699
|
-
logger.error(`[proxy]: ${data}`);
|
|
700
|
-
});
|
|
701
|
-
|
|
702
|
-
proxy.on("close", (code) => {
|
|
703
|
-
logger.error(`Proxy exited with status ${code}.`);
|
|
704
|
-
CLEANUP();
|
|
705
|
-
process.exitCode = code ?? 0;
|
|
706
|
-
});
|
|
707
|
-
|
|
708
|
-
// Wait for proxy process to start...
|
|
709
|
-
while (!proxy.pid) {}
|
|
710
|
-
|
|
711
|
-
if (port === undefined) {
|
|
712
|
-
logger.log(
|
|
713
|
-
`Sleeping ${SECONDS_TO_WAIT_FOR_PROXY} seconds to allow proxy process to start before attempting to automatically determine port...`
|
|
714
|
-
);
|
|
715
|
-
logger.log("To skip, specify the proxy port with --proxy.");
|
|
716
|
-
await sleep(SECONDS_TO_WAIT_FOR_PROXY * 1000);
|
|
717
|
-
|
|
718
|
-
port = getPids(proxy.pid)
|
|
719
|
-
.map(getPort)
|
|
720
|
-
.filter((nr) => nr !== undefined)[0];
|
|
721
|
-
|
|
722
|
-
if (port === undefined) {
|
|
723
|
-
CLEANUP();
|
|
724
|
-
throw new FatalError(
|
|
725
|
-
"Could not automatically determine proxy port. Please specify the proxy port with --proxy.",
|
|
726
|
-
1
|
|
727
|
-
);
|
|
728
|
-
} else {
|
|
729
|
-
logger.log(`Automatically determined the proxy port to be ${port}.`);
|
|
730
|
-
}
|
|
731
|
-
}
|
|
732
|
-
|
|
733
|
-
return port;
|
|
734
|
-
}
|