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/createTail.ts
DELETED
|
@@ -1,415 +0,0 @@
|
|
|
1
|
-
import WebSocket from "ws";
|
|
2
|
-
import { version as packageVersion } from "../../package.json";
|
|
3
|
-
import { fetchResult } from "../cfetch";
|
|
4
|
-
import type { TailFilterMessage, Outcome } from "./filters";
|
|
5
|
-
export type { TailCLIFilters } from "./filters";
|
|
6
|
-
export { translateCLICommandToFilterMessage } from "./filters";
|
|
7
|
-
export { jsonPrintLogs, prettyPrintLogs } from "./printing";
|
|
8
|
-
import type { Request } from "undici";
|
|
9
|
-
|
|
10
|
-
const TRACE_VERSION = "trace-v1";
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* When creating a Tail, the response from the API contains
|
|
14
|
-
* - an ID used for identifying the tail
|
|
15
|
-
* - a URL to a WebSocket connection available for the tail to connect to
|
|
16
|
-
* - an expiration date when the tail is no longer guaranteed to be valid
|
|
17
|
-
*/
|
|
18
|
-
type TailCreationApiResponse = {
|
|
19
|
-
id: string;
|
|
20
|
-
url: string;
|
|
21
|
-
expires_at: Date;
|
|
22
|
-
};
|
|
23
|
-
|
|
24
|
-
/**
|
|
25
|
-
* Generate a URL that, when `cfetch`ed, creates a tail.
|
|
26
|
-
*
|
|
27
|
-
* https://api.cloudflare.com/#worker-tail-logs-start-tail
|
|
28
|
-
*
|
|
29
|
-
* @param accountId the account ID associated with the worker to tail
|
|
30
|
-
* @param workerName the name of the worker to tail
|
|
31
|
-
* @returns a `cfetch`-ready URL for creating a new tail
|
|
32
|
-
*/
|
|
33
|
-
function makeCreateTailUrl(
|
|
34
|
-
accountId: string,
|
|
35
|
-
workerName: string,
|
|
36
|
-
env: string | undefined
|
|
37
|
-
): string {
|
|
38
|
-
return env
|
|
39
|
-
? `/accounts/${accountId}/workers/services/${workerName}/environments/${env}/tails`
|
|
40
|
-
: `/accounts/${accountId}/workers/scripts/${workerName}/tails`;
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* Generate a URL that, when `cfetch`ed, deletes a tail
|
|
45
|
-
*
|
|
46
|
-
* https://api.cloudflare.com/#worker-tail-logs-delete-tail
|
|
47
|
-
*
|
|
48
|
-
* @param accountId the account ID associated with the worker we're tailing
|
|
49
|
-
* @param workerName the name of the worker we're tailing
|
|
50
|
-
* @param tailId the ID of the tail we want to delete
|
|
51
|
-
* @returns a `cfetch`-ready URL for deleting a tail
|
|
52
|
-
*/
|
|
53
|
-
function makeDeleteTailUrl(
|
|
54
|
-
accountId: string,
|
|
55
|
-
workerName: string,
|
|
56
|
-
tailId: string,
|
|
57
|
-
env: string | undefined
|
|
58
|
-
): string {
|
|
59
|
-
return env
|
|
60
|
-
? `/accounts/${accountId}/workers/services/${workerName}/environments/${env}/tails/${tailId}`
|
|
61
|
-
: `/accounts/${accountId}/workers/scripts/${workerName}/tails/${tailId}`;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
interface CreatePagesTailOptions {
|
|
65
|
-
accountId: string;
|
|
66
|
-
projectName: string;
|
|
67
|
-
deploymentId: string;
|
|
68
|
-
filters: TailFilterMessage;
|
|
69
|
-
debug?: boolean;
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
/**
|
|
73
|
-
* Create and connect to a Pages Function Tail.
|
|
74
|
-
*
|
|
75
|
-
* Under the hood, this function
|
|
76
|
-
* - Registers a new Tail with the API
|
|
77
|
-
* - Connects to the tail worker
|
|
78
|
-
* - Sends any filters over the connection
|
|
79
|
-
*
|
|
80
|
-
* @returns a websocket connection, an expiration, and a function to call to delete the tail
|
|
81
|
-
*/
|
|
82
|
-
export async function createPagesTail({
|
|
83
|
-
accountId,
|
|
84
|
-
projectName,
|
|
85
|
-
deploymentId,
|
|
86
|
-
filters,
|
|
87
|
-
debug = false,
|
|
88
|
-
}: CreatePagesTailOptions) {
|
|
89
|
-
const tailRecord = await fetchResult<TailCreationApiResponse>(
|
|
90
|
-
`/accounts/${accountId}/pages/projects/${projectName}/deployments/${deploymentId}/tails`,
|
|
91
|
-
{
|
|
92
|
-
method: "POST",
|
|
93
|
-
body: JSON.stringify(filters),
|
|
94
|
-
}
|
|
95
|
-
);
|
|
96
|
-
|
|
97
|
-
const deleteTail = async () =>
|
|
98
|
-
fetchResult(
|
|
99
|
-
`/accounts/${accountId}/pages/projects/${projectName}/deployments/${deploymentId}/tails/${tailRecord.id}`,
|
|
100
|
-
{ method: "DELETE" }
|
|
101
|
-
);
|
|
102
|
-
|
|
103
|
-
const tail = new WebSocket(tailRecord.url, TRACE_VERSION, {
|
|
104
|
-
headers: {
|
|
105
|
-
"Sec-WebSocket-Protocol": TRACE_VERSION, // needs to be `trace-v1` to be accepted
|
|
106
|
-
"User-Agent": `wrangler-js/${packageVersion}`,
|
|
107
|
-
},
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
// send filters when we open up
|
|
111
|
-
tail.on("open", () => {
|
|
112
|
-
tail.send(
|
|
113
|
-
JSON.stringify({ debug: debug }),
|
|
114
|
-
{ binary: false, compress: false, mask: false, fin: true },
|
|
115
|
-
(err) => {
|
|
116
|
-
if (err) {
|
|
117
|
-
throw err;
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
);
|
|
121
|
-
});
|
|
122
|
-
|
|
123
|
-
return { tail, deleteTail, expiration: tailRecord.expires_at };
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
/**
|
|
127
|
-
* Create and connect to a tail.
|
|
128
|
-
*
|
|
129
|
-
* Under the hood, this function
|
|
130
|
-
* - Registers a new Tail with the API
|
|
131
|
-
* - Connects to the tail worker
|
|
132
|
-
* - Sends any filters over the connection
|
|
133
|
-
*
|
|
134
|
-
* @param accountId the account ID associated with the worker to tail
|
|
135
|
-
* @param workerName the name of the worker to tail
|
|
136
|
-
* @param filters A list of `TailAPIFilters` given to the tail
|
|
137
|
-
* @param debug Flag to run tail in debug mode
|
|
138
|
-
* @returns a websocket connection, an expiration, and a function to call to delete the tail
|
|
139
|
-
*/
|
|
140
|
-
export async function createTail(
|
|
141
|
-
accountId: string,
|
|
142
|
-
workerName: string,
|
|
143
|
-
filters: TailFilterMessage,
|
|
144
|
-
debug: boolean,
|
|
145
|
-
env: string | undefined
|
|
146
|
-
): Promise<{
|
|
147
|
-
tail: WebSocket;
|
|
148
|
-
expiration: Date;
|
|
149
|
-
deleteTail: () => Promise<void>;
|
|
150
|
-
}> {
|
|
151
|
-
// create the tail
|
|
152
|
-
const createTailUrl = makeCreateTailUrl(accountId, workerName, env);
|
|
153
|
-
const {
|
|
154
|
-
id: tailId,
|
|
155
|
-
url: websocketUrl,
|
|
156
|
-
expires_at: expiration,
|
|
157
|
-
} = await fetchResult<TailCreationApiResponse>(createTailUrl, {
|
|
158
|
-
method: "POST",
|
|
159
|
-
body: JSON.stringify(filters),
|
|
160
|
-
});
|
|
161
|
-
|
|
162
|
-
// delete the tail (not yet!)
|
|
163
|
-
const deleteUrl = makeDeleteTailUrl(accountId, workerName, tailId, env);
|
|
164
|
-
async function deleteTail() {
|
|
165
|
-
await fetchResult(deleteUrl, { method: "DELETE" });
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
// connect to the tail
|
|
169
|
-
const tail = new WebSocket(websocketUrl, TRACE_VERSION, {
|
|
170
|
-
headers: {
|
|
171
|
-
"Sec-WebSocket-Protocol": TRACE_VERSION, // needs to be `trace-v1` to be accepted
|
|
172
|
-
"User-Agent": `wrangler-js/${packageVersion}`,
|
|
173
|
-
},
|
|
174
|
-
});
|
|
175
|
-
|
|
176
|
-
// send filters when we open up
|
|
177
|
-
tail.on("open", function () {
|
|
178
|
-
tail.send(
|
|
179
|
-
JSON.stringify({ debug: debug }),
|
|
180
|
-
{ binary: false, compress: false, mask: false, fin: true },
|
|
181
|
-
(err) => {
|
|
182
|
-
if (err) {
|
|
183
|
-
throw err;
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
);
|
|
187
|
-
});
|
|
188
|
-
|
|
189
|
-
return { tail, expiration, deleteTail };
|
|
190
|
-
}
|
|
191
|
-
|
|
192
|
-
/**
|
|
193
|
-
* Everything captured by the trace worker and sent to us via
|
|
194
|
-
* `wrangler tail` is structured JSON that deserializes to this type.
|
|
195
|
-
*/
|
|
196
|
-
export type TailEventMessage = {
|
|
197
|
-
/**
|
|
198
|
-
* Whether the execution of this worker succeeded or failed
|
|
199
|
-
*/
|
|
200
|
-
outcome: Outcome;
|
|
201
|
-
|
|
202
|
-
/**
|
|
203
|
-
* The name of the script we're tailing
|
|
204
|
-
*/
|
|
205
|
-
scriptName?: string;
|
|
206
|
-
|
|
207
|
-
/**
|
|
208
|
-
* Any exceptions raised by the worker
|
|
209
|
-
*/
|
|
210
|
-
exceptions: {
|
|
211
|
-
/**
|
|
212
|
-
* The name of the exception.
|
|
213
|
-
*/
|
|
214
|
-
name: string;
|
|
215
|
-
|
|
216
|
-
/**
|
|
217
|
-
* The error message
|
|
218
|
-
*/
|
|
219
|
-
message: unknown;
|
|
220
|
-
|
|
221
|
-
/**
|
|
222
|
-
* When the exception was raised/thrown
|
|
223
|
-
*/
|
|
224
|
-
timestamp: number;
|
|
225
|
-
}[];
|
|
226
|
-
|
|
227
|
-
/**
|
|
228
|
-
* Any logs sent out by the worker
|
|
229
|
-
*/
|
|
230
|
-
logs: {
|
|
231
|
-
message: unknown[];
|
|
232
|
-
level: string; // TODO: make this a union of possible values
|
|
233
|
-
timestamp: number;
|
|
234
|
-
}[];
|
|
235
|
-
|
|
236
|
-
/**
|
|
237
|
-
* When the event was triggered
|
|
238
|
-
*/
|
|
239
|
-
eventTimestamp: number;
|
|
240
|
-
|
|
241
|
-
/**
|
|
242
|
-
* The event that triggered the worker. In the case of an HTTP request,
|
|
243
|
-
* this will be a RequestEvent. If it's a cron trigger, it'll be a
|
|
244
|
-
* ScheduledEvent. If it's a durable object alarm, it's an AlarmEvent.
|
|
245
|
-
* If it's a email, it'a an EmailEvent
|
|
246
|
-
*
|
|
247
|
-
* Until workers-types exposes individual types for export, we'll have
|
|
248
|
-
* to just re-define these types ourselves.
|
|
249
|
-
*/
|
|
250
|
-
event:
|
|
251
|
-
| RequestEvent
|
|
252
|
-
| ScheduledEvent
|
|
253
|
-
| AlarmEvent
|
|
254
|
-
| EmailEvent
|
|
255
|
-
| TailInfo
|
|
256
|
-
| undefined
|
|
257
|
-
| null;
|
|
258
|
-
};
|
|
259
|
-
|
|
260
|
-
/**
|
|
261
|
-
* A request that triggered worker execution
|
|
262
|
-
*/
|
|
263
|
-
|
|
264
|
-
export type RequestEvent = {
|
|
265
|
-
request: Pick<Request, "url" | "method" | "headers"> & {
|
|
266
|
-
/**
|
|
267
|
-
* Cloudflare-specific properties
|
|
268
|
-
* https://developers.cloudflare.com/workers/runtime-apis/request#incomingrequestcfproperties
|
|
269
|
-
*/
|
|
270
|
-
cf: {
|
|
271
|
-
/**
|
|
272
|
-
* How long (in ms) it took for the client's TCP connection to make a
|
|
273
|
-
* round trip to the worker and back. For all my gamers out there,
|
|
274
|
-
* this is the request's ping
|
|
275
|
-
*/
|
|
276
|
-
clientTcpRtt?: number;
|
|
277
|
-
|
|
278
|
-
/**
|
|
279
|
-
* Longitude and Latitude of where the request originated from
|
|
280
|
-
*/
|
|
281
|
-
longitude?: string;
|
|
282
|
-
latitude?: string;
|
|
283
|
-
|
|
284
|
-
/**
|
|
285
|
-
* What cipher was used to establish the TLS connection
|
|
286
|
-
*/
|
|
287
|
-
tlsCipher: string;
|
|
288
|
-
|
|
289
|
-
/**
|
|
290
|
-
* Which continent the request came from.
|
|
291
|
-
*/
|
|
292
|
-
continent?: "NA";
|
|
293
|
-
|
|
294
|
-
/**
|
|
295
|
-
* ASN of the incoming request
|
|
296
|
-
*/
|
|
297
|
-
asn: number;
|
|
298
|
-
|
|
299
|
-
/**
|
|
300
|
-
* The country the incoming request is coming from
|
|
301
|
-
*/
|
|
302
|
-
country?: string;
|
|
303
|
-
|
|
304
|
-
/**
|
|
305
|
-
* The TLS version the connection used
|
|
306
|
-
*/
|
|
307
|
-
tlsVersion: string;
|
|
308
|
-
|
|
309
|
-
/**
|
|
310
|
-
* The colo that processed the request (i.e. the airport code
|
|
311
|
-
* of the closest city to the server that spun up the worker)
|
|
312
|
-
*/
|
|
313
|
-
colo: string;
|
|
314
|
-
|
|
315
|
-
/**
|
|
316
|
-
* The timezone where the request came from
|
|
317
|
-
*/
|
|
318
|
-
timezone?: string;
|
|
319
|
-
|
|
320
|
-
/**
|
|
321
|
-
* The city where the request came from
|
|
322
|
-
*/
|
|
323
|
-
city?: string;
|
|
324
|
-
|
|
325
|
-
/**
|
|
326
|
-
* The browser-requested prioritization information in the request object
|
|
327
|
-
*/
|
|
328
|
-
requestPriority?: string;
|
|
329
|
-
|
|
330
|
-
/**
|
|
331
|
-
* Which version of HTTP the request came over e.g. "HTTP/2"
|
|
332
|
-
*/
|
|
333
|
-
httpProtocol: string;
|
|
334
|
-
|
|
335
|
-
/**
|
|
336
|
-
* The region where the request originated from
|
|
337
|
-
*/
|
|
338
|
-
region?: string;
|
|
339
|
-
regionCode?: string;
|
|
340
|
-
|
|
341
|
-
/**
|
|
342
|
-
* The organization which owns the ASN of the incoming request, for example, Google Cloud.
|
|
343
|
-
*/
|
|
344
|
-
asOrganization: string;
|
|
345
|
-
|
|
346
|
-
/**
|
|
347
|
-
* Metro code (DMA) of the incoming request, for example, "635".
|
|
348
|
-
*/
|
|
349
|
-
metroCode?: string;
|
|
350
|
-
|
|
351
|
-
/**
|
|
352
|
-
* Postal code of the incoming request, for example, "78701".
|
|
353
|
-
*/
|
|
354
|
-
postalCode?: string;
|
|
355
|
-
};
|
|
356
|
-
};
|
|
357
|
-
};
|
|
358
|
-
|
|
359
|
-
/**
|
|
360
|
-
* An event that was triggered at a certain time
|
|
361
|
-
*/
|
|
362
|
-
export type ScheduledEvent = {
|
|
363
|
-
/**
|
|
364
|
-
* The cron pattern that matched when this event fired
|
|
365
|
-
*/
|
|
366
|
-
cron: string;
|
|
367
|
-
|
|
368
|
-
/**
|
|
369
|
-
* The time this worker was scheduled to run.
|
|
370
|
-
* For some reason, this doesn't...work correctly when we
|
|
371
|
-
* do it directly as a Date. So parse it later on your own.
|
|
372
|
-
*/
|
|
373
|
-
scheduledTime: number;
|
|
374
|
-
};
|
|
375
|
-
|
|
376
|
-
/**
|
|
377
|
-
* A event that was triggered from a durable object alarm
|
|
378
|
-
*/
|
|
379
|
-
export type AlarmEvent = {
|
|
380
|
-
/**
|
|
381
|
-
* The datetime the alarm was scheduled for.
|
|
382
|
-
*
|
|
383
|
-
* This is sent as an ISO timestamp string (different than ScheduledEvent.scheduledTime),
|
|
384
|
-
* you should parse it later on on your own.
|
|
385
|
-
*/
|
|
386
|
-
scheduledTime: string;
|
|
387
|
-
};
|
|
388
|
-
|
|
389
|
-
/**
|
|
390
|
-
* An event that was triggered from an email
|
|
391
|
-
*/
|
|
392
|
-
export type EmailEvent = {
|
|
393
|
-
/**
|
|
394
|
-
* Who sent the email
|
|
395
|
-
*/
|
|
396
|
-
mailFrom: string;
|
|
397
|
-
|
|
398
|
-
/**
|
|
399
|
-
* Who was the email sent to
|
|
400
|
-
*/
|
|
401
|
-
rcptTo: string;
|
|
402
|
-
|
|
403
|
-
/**
|
|
404
|
-
* Size of the email in bytes
|
|
405
|
-
*/
|
|
406
|
-
rawSize: number;
|
|
407
|
-
};
|
|
408
|
-
|
|
409
|
-
/**
|
|
410
|
-
* Message from tail with information about the tail itself
|
|
411
|
-
*/
|
|
412
|
-
export type TailInfo = {
|
|
413
|
-
message: string;
|
|
414
|
-
type: string;
|
|
415
|
-
};
|
package/src/tail/filters.ts
DELETED
|
@@ -1,277 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* When tailing logs from a worker, oftentimes you don't want to see _every
|
|
3
|
-
* single event_. That's where filters come in. We can send a set of filters
|
|
4
|
-
* to the tail worker, and it will pre-filter any logs for us so that we
|
|
5
|
-
* only recieve the ones we care about.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
* These are the filters we accept in the CLI. They
|
|
10
|
-
* were copied directly from Wrangler v1 in order to
|
|
11
|
-
* maintain compatability, so they aren't actually the exact
|
|
12
|
-
* filters we need to send up to the tail worker. They generally map 1:1,
|
|
13
|
-
* but often require some transformation or
|
|
14
|
-
* renaming to match what it expects.
|
|
15
|
-
*
|
|
16
|
-
* For a full description of each filter, either check the
|
|
17
|
-
* CLI description or see the documentation for `ApiFilter`.
|
|
18
|
-
*/
|
|
19
|
-
export type TailCLIFilters = {
|
|
20
|
-
status?: ("ok" | "error" | "canceled")[];
|
|
21
|
-
header?: string;
|
|
22
|
-
method?: string[];
|
|
23
|
-
search?: string;
|
|
24
|
-
samplingRate?: number;
|
|
25
|
-
clientIp?: string[];
|
|
26
|
-
};
|
|
27
|
-
|
|
28
|
-
/**
|
|
29
|
-
* These are the filters we send to the tail worker. We
|
|
30
|
-
* actually send a list of filters (an array of objects),
|
|
31
|
-
* so rather than having a single TailAPIFilters type,
|
|
32
|
-
* each kind of filter gets its own type and we define
|
|
33
|
-
* TailAPIFilter to be the union of those types.
|
|
34
|
-
*/
|
|
35
|
-
export type TailAPIFilter =
|
|
36
|
-
| SamplingRateFilter
|
|
37
|
-
| OutcomeFilter
|
|
38
|
-
| MethodFilter
|
|
39
|
-
| HeaderFilter
|
|
40
|
-
| ClientIPFilter
|
|
41
|
-
| QueryFilter;
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* Filters logs based on a given sampling rate.
|
|
45
|
-
* For example, a `sampling_rate` of 0.25 will let one-quarter of the
|
|
46
|
-
* logs through.
|
|
47
|
-
*/
|
|
48
|
-
type SamplingRateFilter = {
|
|
49
|
-
sampling_rate: number;
|
|
50
|
-
};
|
|
51
|
-
|
|
52
|
-
/**
|
|
53
|
-
* Filters logs based on the outcome of the worker's event handler.
|
|
54
|
-
*/
|
|
55
|
-
type OutcomeFilter = {
|
|
56
|
-
outcome: Outcome[];
|
|
57
|
-
};
|
|
58
|
-
|
|
59
|
-
/**
|
|
60
|
-
* There are five possible outcomes we can get, three of which
|
|
61
|
-
* (exception, exceededCpu, exceededMemory, and unknown) are considered errors
|
|
62
|
-
*/
|
|
63
|
-
export type Outcome =
|
|
64
|
-
| "ok"
|
|
65
|
-
| "canceled"
|
|
66
|
-
| "exception"
|
|
67
|
-
| "exceededCpu"
|
|
68
|
-
| "exceededMemory"
|
|
69
|
-
| "unknown";
|
|
70
|
-
|
|
71
|
-
/**
|
|
72
|
-
* Filters logs based on the HTTP method used for the request
|
|
73
|
-
* that triggered the worker.
|
|
74
|
-
*/
|
|
75
|
-
type MethodFilter = {
|
|
76
|
-
method: string[];
|
|
77
|
-
};
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* Filters logs based on an HTTP header on the request that
|
|
81
|
-
* triggered the worker.
|
|
82
|
-
*/
|
|
83
|
-
type HeaderFilter = {
|
|
84
|
-
header: {
|
|
85
|
-
/**
|
|
86
|
-
* Filters on the header "key", e.g. "X-CLOUDFLARE-HEADER"
|
|
87
|
-
* or "X-CUSTOM-HEADER"
|
|
88
|
-
*/
|
|
89
|
-
key: string;
|
|
90
|
-
|
|
91
|
-
/**
|
|
92
|
-
* Filters on the header "value", e.g. if this is set to
|
|
93
|
-
* "filter-for-me" and the "key" is "X-SHOULD-LOG", only
|
|
94
|
-
* events triggered by requests with the header
|
|
95
|
-
* "X-SHOULD-LOG:filter-for-me" will be logged.
|
|
96
|
-
*/
|
|
97
|
-
query?: string;
|
|
98
|
-
};
|
|
99
|
-
};
|
|
100
|
-
|
|
101
|
-
/**
|
|
102
|
-
* Filters on the IP address the request came from that triggered
|
|
103
|
-
* the worker. A value of "self" will be replaced with the IP
|
|
104
|
-
* address that is running `wrangler tail`
|
|
105
|
-
*/
|
|
106
|
-
type ClientIPFilter = {
|
|
107
|
-
client_ip: string[];
|
|
108
|
-
};
|
|
109
|
-
|
|
110
|
-
/**
|
|
111
|
-
* Filters logs by a query string. This means only logs that
|
|
112
|
-
* contain the given string will be sent to wrangler, and any
|
|
113
|
-
* that don't will be discarded by the tail worker.
|
|
114
|
-
*/
|
|
115
|
-
type QueryFilter = {
|
|
116
|
-
query: string;
|
|
117
|
-
};
|
|
118
|
-
|
|
119
|
-
/**
|
|
120
|
-
* The full message we send to the tail worker includes our
|
|
121
|
-
* filters and a debug flag.
|
|
122
|
-
*/
|
|
123
|
-
export type TailFilterMessage = {
|
|
124
|
-
filters: TailAPIFilter[];
|
|
125
|
-
};
|
|
126
|
-
|
|
127
|
-
/**
|
|
128
|
-
* Translate the flags passed in via a CLI invokation of wrangler
|
|
129
|
-
* into a message that we can send to the tail worker.
|
|
130
|
-
*
|
|
131
|
-
* @param cliFilters An object containing all the filters passed in from the CLI
|
|
132
|
-
* @returns A filter message ready to be sent to the tail worker
|
|
133
|
-
*/
|
|
134
|
-
export function translateCLICommandToFilterMessage(
|
|
135
|
-
cliFilters: TailCLIFilters
|
|
136
|
-
): TailFilterMessage {
|
|
137
|
-
const apiFilters: TailAPIFilter[] = [];
|
|
138
|
-
|
|
139
|
-
if (cliFilters.samplingRate) {
|
|
140
|
-
apiFilters.push(parseSamplingRate(cliFilters.samplingRate));
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
if (cliFilters.status) {
|
|
144
|
-
apiFilters.push(parseOutcome(cliFilters.status));
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
if (cliFilters.method) {
|
|
148
|
-
apiFilters.push(parseMethod(cliFilters.method));
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
if (cliFilters.header) {
|
|
152
|
-
apiFilters.push(parseHeader(cliFilters.header));
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
if (cliFilters.clientIp) {
|
|
156
|
-
apiFilters.push(parseIP(cliFilters.clientIp));
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
if (cliFilters.search) {
|
|
160
|
-
apiFilters.push(parseQuery(cliFilters.search));
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
return {
|
|
164
|
-
filters: apiFilters,
|
|
165
|
-
};
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
/**
|
|
169
|
-
* Parse the sampling rate passed in via command line
|
|
170
|
-
*
|
|
171
|
-
* @param sampling_rate the sampling rate passed in via CLI
|
|
172
|
-
* @throws an Error if the rate doesn't make sense
|
|
173
|
-
* @returns a SamplingRateFilter for use with the API
|
|
174
|
-
*/
|
|
175
|
-
function parseSamplingRate(sampling_rate: number): SamplingRateFilter {
|
|
176
|
-
if (sampling_rate <= 0 || sampling_rate >= 1) {
|
|
177
|
-
throw new Error(
|
|
178
|
-
"A sampling rate must be between 0 and 1 in order to have any effect.\nFor example, a sampling rate of 0.25 means 25% of events will be logged."
|
|
179
|
-
);
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
return { sampling_rate };
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
/**
|
|
186
|
-
* Translate from CLI "status"es to API "outcome"s, including
|
|
187
|
-
* broadening "error" into "exception", "exceededCpu", and "unknown".
|
|
188
|
-
*
|
|
189
|
-
* @param statuses statuses passed in via CLI
|
|
190
|
-
* @returns an OutcomeFilter for use with the API
|
|
191
|
-
*/
|
|
192
|
-
function parseOutcome(
|
|
193
|
-
statuses: ("ok" | "error" | "canceled")[]
|
|
194
|
-
): OutcomeFilter {
|
|
195
|
-
const outcomes = new Set<Outcome>();
|
|
196
|
-
|
|
197
|
-
for (const status of statuses) {
|
|
198
|
-
switch (status) {
|
|
199
|
-
case "ok":
|
|
200
|
-
outcomes.add("ok");
|
|
201
|
-
break;
|
|
202
|
-
|
|
203
|
-
case "canceled":
|
|
204
|
-
outcomes.add("canceled");
|
|
205
|
-
break;
|
|
206
|
-
|
|
207
|
-
case "error":
|
|
208
|
-
outcomes.add("exception");
|
|
209
|
-
outcomes.add("exceededCpu");
|
|
210
|
-
outcomes.add("exceededMemory");
|
|
211
|
-
outcomes.add("unknown");
|
|
212
|
-
break;
|
|
213
|
-
|
|
214
|
-
default:
|
|
215
|
-
break;
|
|
216
|
-
}
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
return {
|
|
220
|
-
outcome: Array.from(outcomes),
|
|
221
|
-
};
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
/**
|
|
225
|
-
* We just send silly methods through to the API anyway, since they don't
|
|
226
|
-
* cause any harm.
|
|
227
|
-
*
|
|
228
|
-
* @param method an array of HTTP request methods passed in via CLI
|
|
229
|
-
* @returns a MethodFilter for use with the API
|
|
230
|
-
*/
|
|
231
|
-
function parseMethod(method: string[]): MethodFilter {
|
|
232
|
-
return { method };
|
|
233
|
-
}
|
|
234
|
-
|
|
235
|
-
/**
|
|
236
|
-
* Header filters can contain either just a key ("X-HEADER-KEY") or both
|
|
237
|
-
* a key and a value ("X-HEADER-KEY:some-value"). This function parses
|
|
238
|
-
* a given string according to that pattern.
|
|
239
|
-
*
|
|
240
|
-
* @param header a header string, "X-HEADER-KEY" or "X-HEADER-KEY:some-value"
|
|
241
|
-
* @returns a HeaderFilter for use with the API
|
|
242
|
-
*/
|
|
243
|
-
function parseHeader(header: string): HeaderFilter {
|
|
244
|
-
const [headerKey, headerQuery] = header.split(":", 2);
|
|
245
|
-
|
|
246
|
-
return {
|
|
247
|
-
header: {
|
|
248
|
-
key: headerKey.trim(),
|
|
249
|
-
query: headerQuery?.trim(),
|
|
250
|
-
},
|
|
251
|
-
};
|
|
252
|
-
}
|
|
253
|
-
|
|
254
|
-
/**
|
|
255
|
-
* A list of IPs can be passed in to filter for messages that come from
|
|
256
|
-
* a worker triggered by a request originating from one of those IPs.
|
|
257
|
-
* You can also pass in the string "self" to filter for the IP of the
|
|
258
|
-
* machine running `wrangler tail`.
|
|
259
|
-
*
|
|
260
|
-
* @param client_ip an array of IP addresses to filter
|
|
261
|
-
* @returns a ClientIPFilter for use with the API
|
|
262
|
-
*/
|
|
263
|
-
function parseIP(client_ip: string[]): ClientIPFilter {
|
|
264
|
-
return { client_ip };
|
|
265
|
-
}
|
|
266
|
-
|
|
267
|
-
/**
|
|
268
|
-
* Users can filter for logs that contain a "search" or a "query string".
|
|
269
|
-
* For example, if `--search findme` is passed to then we will only
|
|
270
|
-
* receive logs that contain the string "findme".
|
|
271
|
-
*
|
|
272
|
-
* @param query a query string to search for
|
|
273
|
-
* @returns a QueryFilter for use with the API
|
|
274
|
-
*/
|
|
275
|
-
function parseQuery(query: string): QueryFilter {
|
|
276
|
-
return { query };
|
|
277
|
-
}
|