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/tail/index.ts
DELETED
|
@@ -1,211 +0,0 @@
|
|
|
1
|
-
import { setTimeout } from "node:timers/promises";
|
|
2
|
-
import onExit from "signal-exit";
|
|
3
|
-
|
|
4
|
-
import { fetchResult, fetchScriptContent } from "../cfetch";
|
|
5
|
-
import { readConfig } from "../config";
|
|
6
|
-
import { confirm } from "../dialogs";
|
|
7
|
-
import {
|
|
8
|
-
isLegacyEnv,
|
|
9
|
-
printWranglerBanner,
|
|
10
|
-
getLegacyScriptName,
|
|
11
|
-
} from "../index";
|
|
12
|
-
import { logger } from "../logger";
|
|
13
|
-
import * as metrics from "../metrics";
|
|
14
|
-
import { requireAuth } from "../user";
|
|
15
|
-
import { getWorkerForZone } from "../zones";
|
|
16
|
-
import {
|
|
17
|
-
createTail,
|
|
18
|
-
jsonPrintLogs,
|
|
19
|
-
prettyPrintLogs,
|
|
20
|
-
translateCLICommandToFilterMessage,
|
|
21
|
-
} from "./createTail";
|
|
22
|
-
import type { WorkerMetadata } from "../create-worker-upload-form";
|
|
23
|
-
import type {
|
|
24
|
-
CommonYargsArgv,
|
|
25
|
-
StrictYargsOptionsToInterface,
|
|
26
|
-
} from "../yargs-types";
|
|
27
|
-
import type { TailCLIFilters } from "./createTail";
|
|
28
|
-
import type { RawData } from "ws";
|
|
29
|
-
|
|
30
|
-
export function tailOptions(yargs: CommonYargsArgv) {
|
|
31
|
-
return yargs
|
|
32
|
-
.positional("worker", {
|
|
33
|
-
describe: "Name or route of the worker to tail",
|
|
34
|
-
type: "string",
|
|
35
|
-
})
|
|
36
|
-
.option("format", {
|
|
37
|
-
default: process.stdout.isTTY ? "pretty" : "json",
|
|
38
|
-
choices: ["json", "pretty"],
|
|
39
|
-
describe: "The format of log entries",
|
|
40
|
-
})
|
|
41
|
-
.option("status", {
|
|
42
|
-
choices: ["ok", "error", "canceled"],
|
|
43
|
-
describe: "Filter by invocation status",
|
|
44
|
-
array: true,
|
|
45
|
-
})
|
|
46
|
-
.option("header", {
|
|
47
|
-
type: "string",
|
|
48
|
-
requiresArg: true,
|
|
49
|
-
describe: "Filter by HTTP header",
|
|
50
|
-
})
|
|
51
|
-
.option("method", {
|
|
52
|
-
type: "string",
|
|
53
|
-
requiresArg: true,
|
|
54
|
-
describe: "Filter by HTTP method",
|
|
55
|
-
array: true,
|
|
56
|
-
})
|
|
57
|
-
.option("sampling-rate", {
|
|
58
|
-
type: "number",
|
|
59
|
-
describe: "Adds a percentage of requests to log sampling rate",
|
|
60
|
-
})
|
|
61
|
-
.option("search", {
|
|
62
|
-
type: "string",
|
|
63
|
-
requiresArg: true,
|
|
64
|
-
describe: "Filter by a text match in console.log messages",
|
|
65
|
-
})
|
|
66
|
-
.option("ip", {
|
|
67
|
-
type: "string",
|
|
68
|
-
requiresArg: true,
|
|
69
|
-
describe:
|
|
70
|
-
'Filter by the IP address the request originates from. Use "self" to filter for your own IP',
|
|
71
|
-
array: true,
|
|
72
|
-
})
|
|
73
|
-
.option("debug", {
|
|
74
|
-
type: "boolean",
|
|
75
|
-
hidden: true,
|
|
76
|
-
default: false,
|
|
77
|
-
describe:
|
|
78
|
-
"If a log would have been filtered out, send it through anyway alongside the filter which would have blocked it.",
|
|
79
|
-
})
|
|
80
|
-
.option("legacy-env", {
|
|
81
|
-
type: "boolean",
|
|
82
|
-
describe: "Use legacy environments",
|
|
83
|
-
hidden: true,
|
|
84
|
-
});
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
type TailArgs = StrictYargsOptionsToInterface<typeof tailOptions>;
|
|
88
|
-
|
|
89
|
-
export async function tailHandler(args: TailArgs) {
|
|
90
|
-
if (args.format === "pretty") {
|
|
91
|
-
await printWranglerBanner();
|
|
92
|
-
}
|
|
93
|
-
const config = readConfig(args.config, args);
|
|
94
|
-
await metrics.sendMetricsEvent("begin log stream", {
|
|
95
|
-
sendMetrics: config.send_metrics,
|
|
96
|
-
});
|
|
97
|
-
|
|
98
|
-
let scriptName;
|
|
99
|
-
|
|
100
|
-
// Worker names can't contain "." (and most routes should), so use that as a discriminator
|
|
101
|
-
if (args.worker?.includes(".")) {
|
|
102
|
-
scriptName = await getWorkerForZone(args.worker);
|
|
103
|
-
if (args.format === "pretty") {
|
|
104
|
-
logger.log(`Connecting to worker ${scriptName} at route ${args.worker}`);
|
|
105
|
-
}
|
|
106
|
-
} else {
|
|
107
|
-
scriptName = getLegacyScriptName({ name: args.worker, ...args }, config);
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
if (!scriptName) {
|
|
111
|
-
throw new Error(
|
|
112
|
-
"Required Worker name missing. Please specify the Worker name in wrangler.toml, or pass it as an argument with `wrangler tail <worker-name>`"
|
|
113
|
-
);
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
const accountId = await requireAuth(config);
|
|
117
|
-
|
|
118
|
-
const cliFilters: TailCLIFilters = {
|
|
119
|
-
status: args.status as ("ok" | "error" | "canceled")[] | undefined,
|
|
120
|
-
header: args.header,
|
|
121
|
-
method: args.method,
|
|
122
|
-
samplingRate: args.samplingRate,
|
|
123
|
-
search: args.search,
|
|
124
|
-
clientIp: args.ip,
|
|
125
|
-
};
|
|
126
|
-
const scriptContent: string = await fetchScriptContent(
|
|
127
|
-
(!isLegacyEnv(config) ? args.env : undefined)
|
|
128
|
-
? `/accounts/${accountId}/workers/services/${scriptName}/environments/${args.env}/content`
|
|
129
|
-
: `/accounts/${accountId}/workers/scripts/${scriptName}`
|
|
130
|
-
);
|
|
131
|
-
|
|
132
|
-
const bindings = await fetchResult<WorkerMetadata["bindings"]>(
|
|
133
|
-
(!isLegacyEnv(config) ? args.env : undefined)
|
|
134
|
-
? `/accounts/${accountId}/workers/services/${scriptName}/environments/${args.env}/bindings`
|
|
135
|
-
: `/accounts/${accountId}/workers/scripts/${scriptName}/bindings`
|
|
136
|
-
);
|
|
137
|
-
if (
|
|
138
|
-
scriptContent.toLowerCase().includes("websocket") &&
|
|
139
|
-
bindings.find((b) => b.type === "durable_object_namespace")
|
|
140
|
-
) {
|
|
141
|
-
logger.warn(
|
|
142
|
-
`Beginning log collection requires restarting the Durable Objects associated with ${scriptName}. Any WebSocket connections or other non-persisted state will be lost as part of this restart.`
|
|
143
|
-
);
|
|
144
|
-
|
|
145
|
-
if (!(await confirm("Would you like to continue?"))) {
|
|
146
|
-
return;
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
const filters = translateCLICommandToFilterMessage(cliFilters);
|
|
150
|
-
|
|
151
|
-
const { tail, expiration, deleteTail } = await createTail(
|
|
152
|
-
accountId,
|
|
153
|
-
scriptName,
|
|
154
|
-
filters,
|
|
155
|
-
args.debug,
|
|
156
|
-
!isLegacyEnv(config) ? args.env : undefined
|
|
157
|
-
);
|
|
158
|
-
|
|
159
|
-
const scriptDisplayName = `${scriptName}${
|
|
160
|
-
args.env && !isLegacyEnv(config) ? ` (${args.env})` : ""
|
|
161
|
-
}`;
|
|
162
|
-
|
|
163
|
-
if (args.format === "pretty") {
|
|
164
|
-
logger.log(
|
|
165
|
-
`Successfully created tail, expires at ${expiration.toLocaleString()}`
|
|
166
|
-
);
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
onExit(async () => {
|
|
170
|
-
tail.terminate();
|
|
171
|
-
await deleteTail();
|
|
172
|
-
await metrics.sendMetricsEvent("end log stream", {
|
|
173
|
-
sendMetrics: config.send_metrics,
|
|
174
|
-
});
|
|
175
|
-
});
|
|
176
|
-
|
|
177
|
-
const printLog: (data: RawData) => void =
|
|
178
|
-
args.format === "pretty" ? prettyPrintLogs : jsonPrintLogs;
|
|
179
|
-
|
|
180
|
-
tail.on("message", printLog);
|
|
181
|
-
|
|
182
|
-
while (tail.readyState !== tail.OPEN) {
|
|
183
|
-
switch (tail.readyState) {
|
|
184
|
-
case tail.CONNECTING:
|
|
185
|
-
await setTimeout(100);
|
|
186
|
-
break;
|
|
187
|
-
case tail.CLOSING:
|
|
188
|
-
await setTimeout(100);
|
|
189
|
-
break;
|
|
190
|
-
case tail.CLOSED:
|
|
191
|
-
await metrics.sendMetricsEvent("end log stream", {
|
|
192
|
-
sendMetrics: config.send_metrics,
|
|
193
|
-
});
|
|
194
|
-
throw new Error(
|
|
195
|
-
`Connection to ${scriptDisplayName} closed unexpectedly.`
|
|
196
|
-
);
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
if (args.format === "pretty") {
|
|
201
|
-
logger.log(`Connected to ${scriptDisplayName}, waiting for logs...`);
|
|
202
|
-
}
|
|
203
|
-
|
|
204
|
-
tail.on("close", async () => {
|
|
205
|
-
tail.terminate();
|
|
206
|
-
await deleteTail();
|
|
207
|
-
await metrics.sendMetricsEvent("end log stream", {
|
|
208
|
-
sendMetrics: config.send_metrics,
|
|
209
|
-
});
|
|
210
|
-
});
|
|
211
|
-
}
|
package/src/tail/printing.ts
DELETED
|
@@ -1,132 +0,0 @@
|
|
|
1
|
-
import chalk from "chalk";
|
|
2
|
-
import { logger } from "../logger";
|
|
3
|
-
import type {
|
|
4
|
-
AlarmEvent,
|
|
5
|
-
EmailEvent,
|
|
6
|
-
RequestEvent,
|
|
7
|
-
ScheduledEvent,
|
|
8
|
-
TailInfo,
|
|
9
|
-
TailEventMessage,
|
|
10
|
-
} from "./createTail";
|
|
11
|
-
import type { Outcome } from "./filters";
|
|
12
|
-
import type WebSocket from "ws";
|
|
13
|
-
|
|
14
|
-
export function prettyPrintLogs(data: WebSocket.RawData): void {
|
|
15
|
-
const eventMessage: TailEventMessage = JSON.parse(data.toString());
|
|
16
|
-
|
|
17
|
-
if (isScheduledEvent(eventMessage.event)) {
|
|
18
|
-
const cronPattern = eventMessage.event.cron;
|
|
19
|
-
const datetime = new Date(
|
|
20
|
-
eventMessage.event.scheduledTime
|
|
21
|
-
).toLocaleString();
|
|
22
|
-
const outcome = prettifyOutcome(eventMessage.outcome);
|
|
23
|
-
|
|
24
|
-
logger.log(`"${cronPattern}" @ ${datetime} - ${outcome}`);
|
|
25
|
-
} else if (isRequestEvent(eventMessage.event)) {
|
|
26
|
-
const requestMethod = eventMessage.event?.request.method.toUpperCase();
|
|
27
|
-
const url = eventMessage.event?.request.url;
|
|
28
|
-
const outcome = prettifyOutcome(eventMessage.outcome);
|
|
29
|
-
const datetime = new Date(eventMessage.eventTimestamp).toLocaleString();
|
|
30
|
-
|
|
31
|
-
logger.log(
|
|
32
|
-
url
|
|
33
|
-
? `${requestMethod} ${url} - ${outcome} @ ${datetime}`
|
|
34
|
-
: `[missing request] - ${outcome} @ ${datetime}`
|
|
35
|
-
);
|
|
36
|
-
} else if (isEmailEvent(eventMessage.event)) {
|
|
37
|
-
const outcome = prettifyOutcome(eventMessage.outcome);
|
|
38
|
-
const datetime = new Date(eventMessage.eventTimestamp).toLocaleString();
|
|
39
|
-
const mailFrom = eventMessage.event.mailFrom;
|
|
40
|
-
const rcptTo = eventMessage.event.rcptTo;
|
|
41
|
-
const rawSize = eventMessage.event.rawSize;
|
|
42
|
-
|
|
43
|
-
logger.log(
|
|
44
|
-
`Email from:${mailFrom} to:${rcptTo} size:${rawSize} @ ${datetime} - ${outcome}`
|
|
45
|
-
);
|
|
46
|
-
} else if (isAlarmEvent(eventMessage.event)) {
|
|
47
|
-
const outcome = prettifyOutcome(eventMessage.outcome);
|
|
48
|
-
const datetime = new Date(
|
|
49
|
-
eventMessage.event.scheduledTime
|
|
50
|
-
).toLocaleString();
|
|
51
|
-
|
|
52
|
-
logger.log(`Alarm @ ${datetime} - ${outcome}`);
|
|
53
|
-
} else if (isTailInfo(eventMessage.event)) {
|
|
54
|
-
if (eventMessage.event.type === "overload") {
|
|
55
|
-
logger.log(`${chalk.red.bold(eventMessage.event.message)}`);
|
|
56
|
-
}
|
|
57
|
-
} else {
|
|
58
|
-
// Unknown event type
|
|
59
|
-
const outcome = prettifyOutcome(eventMessage.outcome);
|
|
60
|
-
const datetime = new Date(eventMessage.eventTimestamp).toLocaleString();
|
|
61
|
-
|
|
62
|
-
logger.log(`Unknown Event - ${outcome} @ ${datetime}`);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
if (eventMessage.logs.length > 0) {
|
|
66
|
-
eventMessage.logs.forEach(({ level, message }) => {
|
|
67
|
-
logger.log(` (${level})`, ...message);
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
if (eventMessage.exceptions.length > 0) {
|
|
72
|
-
eventMessage.exceptions.forEach(({ name, message }) => {
|
|
73
|
-
logger.error(` ${name}:`, message);
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
export function jsonPrintLogs(data: WebSocket.RawData): void {
|
|
79
|
-
console.log(JSON.stringify(JSON.parse(data.toString()), null, 2));
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
function isRequestEvent(
|
|
83
|
-
event: TailEventMessage["event"]
|
|
84
|
-
): event is RequestEvent {
|
|
85
|
-
return Boolean(event && "request" in event);
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
function isScheduledEvent(
|
|
89
|
-
event: TailEventMessage["event"]
|
|
90
|
-
): event is ScheduledEvent {
|
|
91
|
-
return Boolean(event && "cron" in event);
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
function isEmailEvent(event: TailEventMessage["event"]): event is EmailEvent {
|
|
95
|
-
return Boolean(event && "mailFrom" in event);
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
/**
|
|
99
|
-
* Check to see if an event sent from a worker is an AlarmEvent.
|
|
100
|
-
*
|
|
101
|
-
* Because the only property on `AlarmEvent` is "scheduledTime", which it
|
|
102
|
-
* shares with `ScheduledEvent`, `isAlarmEvent` checks if there's _not_
|
|
103
|
-
* a "cron" property in `event` to confirm it's an alarm event.
|
|
104
|
-
*
|
|
105
|
-
* @param event An event
|
|
106
|
-
* @returns true if the event is an AlarmEvent
|
|
107
|
-
*/
|
|
108
|
-
function isAlarmEvent(event: TailEventMessage["event"]): event is AlarmEvent {
|
|
109
|
-
return Boolean(event && "scheduledTime" in event && !("cron" in event));
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
function isTailInfo(event: TailEventMessage["event"]): event is TailInfo {
|
|
113
|
-
return Boolean(event && "message" in event && "type" in event);
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
function prettifyOutcome(outcome: Outcome): string {
|
|
117
|
-
switch (outcome) {
|
|
118
|
-
case "ok":
|
|
119
|
-
return "Ok";
|
|
120
|
-
case "canceled":
|
|
121
|
-
return "Canceled";
|
|
122
|
-
case "exceededCpu":
|
|
123
|
-
return "Exceeded CPU Limit";
|
|
124
|
-
case "exceededMemory":
|
|
125
|
-
return "Exceeded Memory Limit";
|
|
126
|
-
case "exception":
|
|
127
|
-
return "Exception Thrown";
|
|
128
|
-
case "unknown":
|
|
129
|
-
default:
|
|
130
|
-
return "Unknown";
|
|
131
|
-
}
|
|
132
|
-
}
|
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
import { readdir } from "node:fs/promises";
|
|
2
|
-
import path from "node:path";
|
|
3
|
-
import chalk from "chalk";
|
|
4
|
-
import { logger } from "./logger";
|
|
5
|
-
import { matchFiles, parseRules } from "./module-collection";
|
|
6
|
-
import type { BundleResult } from "./bundle";
|
|
7
|
-
import type { Config } from "./config";
|
|
8
|
-
import type { Entry } from "./entry";
|
|
9
|
-
|
|
10
|
-
async function getFiles(root: string, relativeTo: string): Promise<string[]> {
|
|
11
|
-
const files = [];
|
|
12
|
-
for (const file of await readdir(root, { withFileTypes: true })) {
|
|
13
|
-
if (file.isDirectory()) {
|
|
14
|
-
files.push(...(await getFiles(path.join(root, file.name), relativeTo)));
|
|
15
|
-
} else {
|
|
16
|
-
files.push(path.relative(relativeTo, path.join(root, file.name)));
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
return files;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export default async function traverseModuleGraph(
|
|
23
|
-
entry: Entry,
|
|
24
|
-
rules: Config["rules"]
|
|
25
|
-
): Promise<BundleResult> {
|
|
26
|
-
const files = await getFiles(entry.moduleRoot, entry.moduleRoot);
|
|
27
|
-
const relativeEntryPoint = path.relative(entry.moduleRoot, entry.file);
|
|
28
|
-
|
|
29
|
-
const modules = (await matchFiles(files, entry.moduleRoot, parseRules(rules)))
|
|
30
|
-
.filter((m) => m.name !== relativeEntryPoint)
|
|
31
|
-
.map((m) => ({
|
|
32
|
-
...m,
|
|
33
|
-
name: m.name,
|
|
34
|
-
}));
|
|
35
|
-
|
|
36
|
-
const bundleType = entry.format === "modules" ? "esm" : "commonjs";
|
|
37
|
-
|
|
38
|
-
if (modules.length > 0) {
|
|
39
|
-
logger.info(`Uploading additional modules:`);
|
|
40
|
-
modules.forEach(({ name, type }) => {
|
|
41
|
-
logger.info(`- ${chalk.blue(name)} (${chalk.green(type ?? "")})`);
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
return {
|
|
46
|
-
modules,
|
|
47
|
-
dependencies: {},
|
|
48
|
-
resolvedEntryPointPath: entry.file,
|
|
49
|
-
bundleType,
|
|
50
|
-
stop: undefined,
|
|
51
|
-
sourceMapPath: undefined,
|
|
52
|
-
sourceMapMetadata: undefined,
|
|
53
|
-
};
|
|
54
|
-
}
|
package/src/tsconfig-sanity.ts
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
// `@types/node` should be included
|
|
2
|
-
Buffer.from("test");
|
|
3
|
-
|
|
4
|
-
// @ts-expect-error `@types/jest` should NOT be included
|
|
5
|
-
test("test");
|
|
6
|
-
|
|
7
|
-
// @ts-expect-error `@cloudflare/workers-types` should NOT be included
|
|
8
|
-
const _handler: ExportedHandler = {};
|
|
9
|
-
// @ts-expect-error `@cloudflare/workers-types` should NOT be included
|
|
10
|
-
new HTMLRewriter();
|
|
11
|
-
|
|
12
|
-
// @ts-expect-error `fetch` should NOT be included as our minimum supported
|
|
13
|
-
// Node version is 16.13.0 which does not include `fetch` on the global scope
|
|
14
|
-
void fetch("http://localhost/");
|
|
15
|
-
|
|
16
|
-
export {};
|
package/src/type-generation.ts
DELETED
|
@@ -1,181 +0,0 @@
|
|
|
1
|
-
import * as fs from "fs";
|
|
2
|
-
import { findUpSync } from "find-up";
|
|
3
|
-
import { getEntry } from "./entry";
|
|
4
|
-
import { logger } from "./logger";
|
|
5
|
-
import type { Config } from "./config";
|
|
6
|
-
|
|
7
|
-
// Currently includes bindings & rules for declaring modules
|
|
8
|
-
|
|
9
|
-
export async function generateTypes(
|
|
10
|
-
configToDTS: Partial<Config>,
|
|
11
|
-
config: Config
|
|
12
|
-
) {
|
|
13
|
-
const entry = await getEntry({}, config, "types");
|
|
14
|
-
const envTypeStructure: string[] = [];
|
|
15
|
-
|
|
16
|
-
if (configToDTS.kv_namespaces) {
|
|
17
|
-
for (const kvNamespace of configToDTS.kv_namespaces) {
|
|
18
|
-
envTypeStructure.push(`${kvNamespace.binding}: KVNamespace;`);
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
if (configToDTS.vars) {
|
|
23
|
-
for (const varName in configToDTS.vars) {
|
|
24
|
-
const varValue = configToDTS.vars[varName];
|
|
25
|
-
if (
|
|
26
|
-
typeof varValue === "string" ||
|
|
27
|
-
typeof varValue === "number" ||
|
|
28
|
-
typeof varValue === "boolean"
|
|
29
|
-
) {
|
|
30
|
-
envTypeStructure.push(`${varName}: "${varValue}";`);
|
|
31
|
-
}
|
|
32
|
-
if (typeof varValue === "object" && varValue !== null) {
|
|
33
|
-
envTypeStructure.push(`${varName}: ${JSON.stringify(varValue)};`);
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
if (configToDTS.durable_objects?.bindings) {
|
|
39
|
-
for (const durableObject of configToDTS.durable_objects.bindings) {
|
|
40
|
-
envTypeStructure.push(`${durableObject.name}: DurableObjectNamespace;`);
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
if (configToDTS.r2_buckets) {
|
|
45
|
-
for (const R2Bucket of configToDTS.r2_buckets) {
|
|
46
|
-
envTypeStructure.push(`${R2Bucket.binding}: R2Bucket;`);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
if (configToDTS.d1_databases) {
|
|
51
|
-
for (const d1 of configToDTS.d1_databases) {
|
|
52
|
-
envTypeStructure.push(`${d1.binding}: D1Database;`);
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
if (configToDTS.services) {
|
|
57
|
-
for (const service of configToDTS.services) {
|
|
58
|
-
envTypeStructure.push(`${service.binding}: Fetcher;`);
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
if (configToDTS.analytics_engine_datasets) {
|
|
63
|
-
for (const analyticsEngine of configToDTS.analytics_engine_datasets) {
|
|
64
|
-
envTypeStructure.push(
|
|
65
|
-
`${analyticsEngine.binding}: AnalyticsEngineDataset;`
|
|
66
|
-
);
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
if (configToDTS.dispatch_namespaces) {
|
|
71
|
-
for (const namespace of configToDTS.dispatch_namespaces) {
|
|
72
|
-
envTypeStructure.push(`${namespace.binding}: any;`);
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
if (configToDTS.logfwdr?.schema) {
|
|
77
|
-
envTypeStructure.push(`LOGFWDR_SCHEMA: any;`);
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
if (configToDTS.data_blobs) {
|
|
81
|
-
for (const dataBlobs in configToDTS.data_blobs) {
|
|
82
|
-
envTypeStructure.push(`${dataBlobs}: ArrayBuffer;`);
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
if (configToDTS.text_blobs) {
|
|
87
|
-
for (const textBlobs in configToDTS.text_blobs) {
|
|
88
|
-
envTypeStructure.push(`${textBlobs}: string;`);
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
if (configToDTS.unsafe?.bindings) {
|
|
93
|
-
for (const unsafe of configToDTS.unsafe.bindings) {
|
|
94
|
-
envTypeStructure.push(`${unsafe.name}: any;`);
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
if (configToDTS.queues) {
|
|
99
|
-
if (configToDTS.queues.producers) {
|
|
100
|
-
for (const queue of configToDTS.queues.producers) {
|
|
101
|
-
envTypeStructure.push(`${queue.binding}: Queue;`);
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
const modulesTypeStructure: string[] = [];
|
|
107
|
-
if (configToDTS.rules) {
|
|
108
|
-
const moduleTypeMap = {
|
|
109
|
-
Text: "string",
|
|
110
|
-
Data: "ArrayBuffer",
|
|
111
|
-
CompiledWasm: "WebAssembly.Module",
|
|
112
|
-
};
|
|
113
|
-
for (const ruleObject of configToDTS.rules) {
|
|
114
|
-
const typeScriptType =
|
|
115
|
-
moduleTypeMap[ruleObject.type as keyof typeof moduleTypeMap];
|
|
116
|
-
if (typeScriptType !== undefined) {
|
|
117
|
-
ruleObject.globs.forEach((glob) => {
|
|
118
|
-
modulesTypeStructure.push(`declare module "*.${glob
|
|
119
|
-
.split(".")
|
|
120
|
-
.at(-1)}" {
|
|
121
|
-
const value: ${typeScriptType};
|
|
122
|
-
export default value;
|
|
123
|
-
}`);
|
|
124
|
-
});
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
writeDTSFile({
|
|
130
|
-
envTypeStructure,
|
|
131
|
-
modulesTypeStructure,
|
|
132
|
-
formatType: entry.format,
|
|
133
|
-
});
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
function writeDTSFile({
|
|
137
|
-
envTypeStructure,
|
|
138
|
-
modulesTypeStructure,
|
|
139
|
-
formatType,
|
|
140
|
-
}: {
|
|
141
|
-
envTypeStructure: string[];
|
|
142
|
-
modulesTypeStructure: string[];
|
|
143
|
-
formatType: "modules" | "service-worker";
|
|
144
|
-
}) {
|
|
145
|
-
const wranglerOverrideDTSPath = findUpSync("worker-configuration.d.ts");
|
|
146
|
-
try {
|
|
147
|
-
if (
|
|
148
|
-
wranglerOverrideDTSPath !== undefined &&
|
|
149
|
-
!fs
|
|
150
|
-
.readFileSync(wranglerOverrideDTSPath, "utf8")
|
|
151
|
-
.includes("Generated by Wrangler")
|
|
152
|
-
) {
|
|
153
|
-
throw new Error(
|
|
154
|
-
"A non-wrangler worker-configuration.d.ts already exists, please rename and try again."
|
|
155
|
-
);
|
|
156
|
-
}
|
|
157
|
-
} catch (error) {
|
|
158
|
-
if (error instanceof Error && !error.message.includes("not found")) {
|
|
159
|
-
throw error;
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
let combinedTypeStrings = "";
|
|
164
|
-
if (formatType === "modules") {
|
|
165
|
-
combinedTypeStrings += `interface Env {\n${envTypeStructure
|
|
166
|
-
.map((value) => `\t${value}`)
|
|
167
|
-
.join("\n")}\n}\n${modulesTypeStructure.join("\n")}`;
|
|
168
|
-
} else {
|
|
169
|
-
combinedTypeStrings += `export {};\ndeclare global {\n${envTypeStructure
|
|
170
|
-
.map((value) => `\tconst ${value}`)
|
|
171
|
-
.join("\n")}\n}\n${modulesTypeStructure.join("\n")}`;
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
if (envTypeStructure.length || modulesTypeStructure.length) {
|
|
175
|
-
fs.writeFileSync(
|
|
176
|
-
"worker-configuration.d.ts",
|
|
177
|
-
`// Generated by Wrangler on ${new Date()}` + "\n" + combinedTypeStrings
|
|
178
|
-
);
|
|
179
|
-
logger.log(combinedTypeStrings);
|
|
180
|
-
}
|
|
181
|
-
}
|
package/src/update-check.ts
DELETED
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import chalk from "chalk";
|
|
2
|
-
import checkForUpdate from "update-check";
|
|
3
|
-
import pkg from "../package.json";
|
|
4
|
-
|
|
5
|
-
export async function updateCheck(): Promise<string> {
|
|
6
|
-
let update = null;
|
|
7
|
-
try {
|
|
8
|
-
// default cache for update check is 1 day
|
|
9
|
-
update = await checkForUpdate(pkg, {
|
|
10
|
-
distTag: pkg.version.startsWith("0.0.0") ? "beta" : "latest",
|
|
11
|
-
});
|
|
12
|
-
} catch (err) {
|
|
13
|
-
// ignore error
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
if (update) return `(update available ${chalk.green(update.latest)})`;
|
|
17
|
-
|
|
18
|
-
return "";
|
|
19
|
-
}
|
package/src/user/access.ts
DELETED
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
import { spawnSync } from "child_process";
|
|
2
|
-
import { fetch } from "undici";
|
|
3
|
-
import { logger } from "../logger";
|
|
4
|
-
|
|
5
|
-
const cache: Record<string, string> = {};
|
|
6
|
-
|
|
7
|
-
const usesAccessCache = new Map();
|
|
8
|
-
|
|
9
|
-
export async function domainUsesAccess(domain: string): Promise<boolean> {
|
|
10
|
-
logger.debug("Checking if domain has Access enabled:", domain);
|
|
11
|
-
|
|
12
|
-
if (usesAccessCache.has(domain)) {
|
|
13
|
-
logger.debug(
|
|
14
|
-
"Using cached Access switch for:",
|
|
15
|
-
domain,
|
|
16
|
-
usesAccessCache.get(domain)
|
|
17
|
-
);
|
|
18
|
-
return usesAccessCache.get(domain);
|
|
19
|
-
}
|
|
20
|
-
logger.debug("Access switch not cached for:", domain);
|
|
21
|
-
try {
|
|
22
|
-
const controller = new AbortController();
|
|
23
|
-
const cancel = setTimeout(() => {
|
|
24
|
-
controller.abort();
|
|
25
|
-
}, 1000);
|
|
26
|
-
|
|
27
|
-
const output = await fetch(`https://${domain}`, {
|
|
28
|
-
redirect: "manual",
|
|
29
|
-
signal: controller.signal,
|
|
30
|
-
});
|
|
31
|
-
clearTimeout(cancel);
|
|
32
|
-
const usesAccess = !!(
|
|
33
|
-
output.status === 302 &&
|
|
34
|
-
output.headers.get("location")?.includes("cloudflareaccess.com")
|
|
35
|
-
);
|
|
36
|
-
logger.debug("Caching access switch for:", domain);
|
|
37
|
-
|
|
38
|
-
usesAccessCache.set(domain, usesAccess);
|
|
39
|
-
return usesAccess;
|
|
40
|
-
} catch (e) {
|
|
41
|
-
usesAccessCache.set(domain, false);
|
|
42
|
-
return false;
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
export async function getAccessToken(
|
|
46
|
-
domain: string
|
|
47
|
-
): Promise<string | undefined> {
|
|
48
|
-
if (!(await domainUsesAccess(domain))) {
|
|
49
|
-
return undefined;
|
|
50
|
-
}
|
|
51
|
-
if (cache[domain]) {
|
|
52
|
-
return cache[domain];
|
|
53
|
-
}
|
|
54
|
-
const output = await spawnSync("cloudflared", ["access", "login", domain]);
|
|
55
|
-
if (output.error) {
|
|
56
|
-
// The cloudflared binary is not installed
|
|
57
|
-
throw new Error(
|
|
58
|
-
"To use Wrangler with Cloudflare Access, please install `cloudflared` from https://developers.cloudflare.com/cloudflare-one/connections/connect-apps/install-and-setup/installation"
|
|
59
|
-
);
|
|
60
|
-
}
|
|
61
|
-
const stringOutput = output.stdout.toString();
|
|
62
|
-
const matches = stringOutput.match(/fetched your token:\n\n(.*)/m);
|
|
63
|
-
if (matches && matches.length >= 2) {
|
|
64
|
-
cache[domain] = matches[1];
|
|
65
|
-
return matches[1];
|
|
66
|
-
}
|
|
67
|
-
throw new Error("Failed to authenticate with Cloudflare Access");
|
|
68
|
-
}
|