wrangler 2.20.0 → 3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (297) hide show
  1. package/README.md +4 -4
  2. package/bin/wrangler.js +9 -75
  3. package/package.json +5 -13
  4. package/templates/__tests__/tsconfig.tsbuildinfo +1 -1
  5. package/templates/checked-fetch.js +1 -1
  6. package/templates/first-party-worker-module-facade.ts +2 -2
  7. package/templates/middleware/common.ts +9 -4
  8. package/templates/middleware/loader-sw.ts +2 -7
  9. package/templates/new-worker-scheduled.ts +1 -1
  10. package/templates/new-worker.ts +1 -1
  11. package/templates/pages-dev-util.ts +4 -1
  12. package/templates/pages-shim.ts +0 -3
  13. package/templates/tsconfig.tsbuildinfo +1 -1
  14. package/wrangler-dist/cli.d.ts +149 -75
  15. package/wrangler-dist/cli.js +60062 -64338
  16. package/import_meta_url.js +0 -3
  17. package/miniflare-config-stubs/.env.empty +0 -0
  18. package/miniflare-config-stubs/package.empty.json +0 -1
  19. package/miniflare-config-stubs/wrangler.empty.toml +0 -0
  20. package/miniflare-dist/index.mjs +0 -6442
  21. package/src/__tests__/access.test.ts +0 -25
  22. package/src/__tests__/api-dev.test.ts +0 -238
  23. package/src/__tests__/api-devregistry.test.ts +0 -121
  24. package/src/__tests__/api.test.ts +0 -102
  25. package/src/__tests__/config-cache-without-cache-dir.test.ts +0 -38
  26. package/src/__tests__/config-cache.test.ts +0 -42
  27. package/src/__tests__/configuration.test.ts +0 -4517
  28. package/src/__tests__/constellation.test.ts +0 -371
  29. package/src/__tests__/d1/d1.test.ts +0 -82
  30. package/src/__tests__/d1/execute.test.ts +0 -66
  31. package/src/__tests__/d1/migrate.test.ts +0 -257
  32. package/src/__tests__/d1/splitter.test.ts +0 -255
  33. package/src/__tests__/delete.test.ts +0 -272
  34. package/src/__tests__/deployments.test.ts +0 -369
  35. package/src/__tests__/dev.test.tsx +0 -1617
  36. package/src/__tests__/generate.test.ts +0 -237
  37. package/src/__tests__/get-host-from-url.test.ts +0 -16
  38. package/src/__tests__/guess-worker-format.test.ts +0 -120
  39. package/src/__tests__/helpers/clipboardy-mock.js +0 -4
  40. package/src/__tests__/helpers/cmd-shim.d.ts +0 -11
  41. package/src/__tests__/helpers/end-event-loop.ts +0 -6
  42. package/src/__tests__/helpers/mock-account-id.ts +0 -48
  43. package/src/__tests__/helpers/mock-auth-domain.ts +0 -20
  44. package/src/__tests__/helpers/mock-bin.ts +0 -36
  45. package/src/__tests__/helpers/mock-console.ts +0 -112
  46. package/src/__tests__/helpers/mock-dialogs.ts +0 -139
  47. package/src/__tests__/helpers/mock-get-pages-upload-token.ts +0 -25
  48. package/src/__tests__/helpers/mock-get-zone-from-host.ts +0 -11
  49. package/src/__tests__/helpers/mock-http-server.ts +0 -46
  50. package/src/__tests__/helpers/mock-istty.ts +0 -74
  51. package/src/__tests__/helpers/mock-known-routes.ts +0 -12
  52. package/src/__tests__/helpers/mock-kv.ts +0 -46
  53. package/src/__tests__/helpers/mock-oauth-flow.ts +0 -263
  54. package/src/__tests__/helpers/mock-process.ts +0 -34
  55. package/src/__tests__/helpers/mock-set-timeout.ts +0 -16
  56. package/src/__tests__/helpers/mock-stdin.ts +0 -108
  57. package/src/__tests__/helpers/mock-web-socket.ts +0 -29
  58. package/src/__tests__/helpers/msw/blob-worker.cjs +0 -19
  59. package/src/__tests__/helpers/msw/handlers/access.ts +0 -13
  60. package/src/__tests__/helpers/msw/handlers/deployments.ts +0 -160
  61. package/src/__tests__/helpers/msw/handlers/namespaces.ts +0 -81
  62. package/src/__tests__/helpers/msw/handlers/oauth.ts +0 -31
  63. package/src/__tests__/helpers/msw/handlers/r2.ts +0 -60
  64. package/src/__tests__/helpers/msw/handlers/script.ts +0 -56
  65. package/src/__tests__/helpers/msw/handlers/user.ts +0 -52
  66. package/src/__tests__/helpers/msw/handlers/zones.ts +0 -20
  67. package/src/__tests__/helpers/msw/index.ts +0 -52
  68. package/src/__tests__/helpers/msw/read-file-sync.js +0 -61
  69. package/src/__tests__/helpers/run-in-tmp.ts +0 -38
  70. package/src/__tests__/helpers/run-wrangler.ts +0 -16
  71. package/src/__tests__/helpers/string-dynamic-values-matcher.ts +0 -28
  72. package/src/__tests__/helpers/worker-scripts/child-wrangler.toml +0 -1
  73. package/src/__tests__/helpers/worker-scripts/hello-world-worker.js +0 -5
  74. package/src/__tests__/helpers/worker-scripts/hello-world-wrangler.toml +0 -1
  75. package/src/__tests__/helpers/worker-scripts/parent-worker.js +0 -11
  76. package/src/__tests__/helpers/worker-scripts/parent-wrangler.toml +0 -5
  77. package/src/__tests__/helpers/write-worker-source.ts +0 -31
  78. package/src/__tests__/helpers/write-wrangler-toml.ts +0 -17
  79. package/src/__tests__/https-options.test.ts +0 -163
  80. package/src/__tests__/index.test.ts +0 -282
  81. package/src/__tests__/init.test.ts +0 -3196
  82. package/src/__tests__/jest.setup.ts +0 -179
  83. package/src/__tests__/kv.test.ts +0 -1799
  84. package/src/__tests__/logger.test.ts +0 -207
  85. package/src/__tests__/logout.test.ts +0 -47
  86. package/src/__tests__/metrics.test.ts +0 -493
  87. package/src/__tests__/middleware.scheduled.test.ts +0 -145
  88. package/src/__tests__/middleware.test.ts +0 -816
  89. package/src/__tests__/mtls-certificates.test.ts +0 -589
  90. package/src/__tests__/package-manager.test.ts +0 -353
  91. package/src/__tests__/pages/deployment-list.test.ts +0 -80
  92. package/src/__tests__/pages/functions-build.test.ts +0 -528
  93. package/src/__tests__/pages/pages.test.ts +0 -81
  94. package/src/__tests__/pages/project-create.test.ts +0 -63
  95. package/src/__tests__/pages/project-list.test.ts +0 -110
  96. package/src/__tests__/pages/project-upload.test.ts +0 -500
  97. package/src/__tests__/pages/publish.test.ts +0 -2864
  98. package/src/__tests__/pages-deployment-tail.test.ts +0 -957
  99. package/src/__tests__/parse.test.ts +0 -436
  100. package/src/__tests__/paths.test.ts +0 -39
  101. package/src/__tests__/publish.test.ts +0 -8849
  102. package/src/__tests__/pubsub.test.ts +0 -496
  103. package/src/__tests__/queues.test.ts +0 -532
  104. package/src/__tests__/r2.test.ts +0 -374
  105. package/src/__tests__/route.test.ts +0 -45
  106. package/src/__tests__/secret.test.ts +0 -693
  107. package/src/__tests__/tail.test.ts +0 -989
  108. package/src/__tests__/test-old-node-version.js +0 -31
  109. package/src/__tests__/traverse-module-graph.test.ts +0 -220
  110. package/src/__tests__/tsconfig-sanity.ts +0 -12
  111. package/src/__tests__/tsconfig.json +0 -8
  112. package/src/__tests__/tsconfig.tsbuildinfo +0 -1
  113. package/src/__tests__/type-generation.test.ts +0 -234
  114. package/src/__tests__/user.test.ts +0 -118
  115. package/src/__tests__/utils-collectKeyValues.test.ts +0 -47
  116. package/src/__tests__/validate-dev-props.test.ts +0 -56
  117. package/src/__tests__/version.test.ts +0 -35
  118. package/src/__tests__/whoami.test.tsx +0 -172
  119. package/src/__tests__/worker-namespace.test.ts +0 -340
  120. package/src/abort.d.ts +0 -3
  121. package/src/api/dev.ts +0 -321
  122. package/src/api/index.ts +0 -11
  123. package/src/api/mtls-certificate.ts +0 -148
  124. package/src/api/pages/create-worker-bundle-contents.ts +0 -77
  125. package/src/api/pages/index.ts +0 -5
  126. package/src/api/pages/publish.tsx +0 -371
  127. package/src/bundle-reporter.ts +0 -68
  128. package/src/bundle.ts +0 -929
  129. package/src/cfetch/index.ts +0 -158
  130. package/src/cfetch/internal.ts +0 -258
  131. package/src/cli.ts +0 -28
  132. package/src/config/README.md +0 -107
  133. package/src/config/config.ts +0 -282
  134. package/src/config/diagnostics.ts +0 -80
  135. package/src/config/environment.ts +0 -625
  136. package/src/config/index.ts +0 -403
  137. package/src/config/validation-helpers.ts +0 -597
  138. package/src/config/validation.ts +0 -2369
  139. package/src/config-cache.ts +0 -85
  140. package/src/constellation/createProject.tsx +0 -51
  141. package/src/constellation/deleteProject.ts +0 -51
  142. package/src/constellation/deleteProjectModel.ts +0 -68
  143. package/src/constellation/index.ts +0 -75
  144. package/src/constellation/listCatalog.tsx +0 -35
  145. package/src/constellation/listModel.tsx +0 -41
  146. package/src/constellation/listProject.tsx +0 -28
  147. package/src/constellation/listRuntime.tsx +0 -28
  148. package/src/constellation/options.ts +0 -17
  149. package/src/constellation/types.ts +0 -17
  150. package/src/constellation/uploadModel.tsx +0 -64
  151. package/src/constellation/utils.ts +0 -90
  152. package/src/create-worker-preview.ts +0 -293
  153. package/src/create-worker-upload-form.ts +0 -363
  154. package/src/d1/backups.tsx +0 -219
  155. package/src/d1/constants.ts +0 -2
  156. package/src/d1/create.tsx +0 -70
  157. package/src/d1/delete.ts +0 -53
  158. package/src/d1/execute.tsx +0 -357
  159. package/src/d1/formatTimeAgo.ts +0 -14
  160. package/src/d1/index.ts +0 -100
  161. package/src/d1/list.tsx +0 -62
  162. package/src/d1/migrations/apply.tsx +0 -212
  163. package/src/d1/migrations/create.tsx +0 -79
  164. package/src/d1/migrations/helpers.ts +0 -169
  165. package/src/d1/migrations/index.ts +0 -3
  166. package/src/d1/migrations/list.tsx +0 -95
  167. package/src/d1/migrations/options.ts +0 -23
  168. package/src/d1/options.ts +0 -22
  169. package/src/d1/splitter.ts +0 -161
  170. package/src/d1/types.ts +0 -25
  171. package/src/d1/utils.ts +0 -49
  172. package/src/delete.ts +0 -100
  173. package/src/deployments.ts +0 -368
  174. package/src/deprecated/index.ts +0 -144
  175. package/src/dev/dev-vars.ts +0 -39
  176. package/src/dev/dev.tsx +0 -605
  177. package/src/dev/get-local-persistence-path.ts +0 -31
  178. package/src/dev/local.tsx +0 -952
  179. package/src/dev/remote.tsx +0 -635
  180. package/src/dev/start-server.ts +0 -545
  181. package/src/dev/use-esbuild.ts +0 -215
  182. package/src/dev/validate-dev-props.ts +0 -40
  183. package/src/dev-registry.ts +0 -202
  184. package/src/dev.tsx +0 -934
  185. package/src/dialogs.ts +0 -136
  186. package/src/dispatch-namespace.ts +0 -211
  187. package/src/docs/helpers.ts +0 -50
  188. package/src/docs/index.ts +0 -54
  189. package/src/durable.ts +0 -102
  190. package/src/entry.ts +0 -344
  191. package/src/environment-variables/factory.ts +0 -89
  192. package/src/environment-variables/misc-variables.ts +0 -30
  193. package/src/errors.ts +0 -11
  194. package/src/generate/index.ts +0 -298
  195. package/src/git-client.ts +0 -135
  196. package/src/global-wrangler-config-path.ts +0 -26
  197. package/src/https-options.ts +0 -127
  198. package/src/index.ts +0 -768
  199. package/src/init.ts +0 -1037
  200. package/src/inspect.ts +0 -883
  201. package/src/intl-polyfill.d.ts +0 -139
  202. package/src/is-ci.ts +0 -14
  203. package/src/is-interactive.ts +0 -16
  204. package/src/jest.d.ts +0 -4
  205. package/src/kv/helpers.ts +0 -433
  206. package/src/kv/index.ts +0 -594
  207. package/src/logger.ts +0 -123
  208. package/src/metrics/index.ts +0 -5
  209. package/src/metrics/metrics-config.ts +0 -239
  210. package/src/metrics/metrics-dispatcher.ts +0 -96
  211. package/src/metrics/metrics-usage-headers.ts +0 -24
  212. package/src/metrics/send-event.ts +0 -99
  213. package/src/miniflare-cli/README.md +0 -30
  214. package/src/miniflare-cli/assets.ts +0 -251
  215. package/src/miniflare-cli/index.ts +0 -210
  216. package/src/miniflare-cli/request-context.ts +0 -40
  217. package/src/miniflare-cli/tsconfig.json +0 -9
  218. package/src/miniflare-cli/tsconfig.tsbuildinfo +0 -1
  219. package/src/miniflare-cli/types.ts +0 -11
  220. package/src/module-collection.ts +0 -333
  221. package/src/mtls-certificate/cli.ts +0 -155
  222. package/src/open-in-browser.ts +0 -17
  223. package/src/package-manager.ts +0 -219
  224. package/src/pages/build.ts +0 -423
  225. package/src/pages/buildFunctions.ts +0 -140
  226. package/src/pages/constants.ts +0 -18
  227. package/src/pages/deployment-tails.ts +0 -281
  228. package/src/pages/deployments.tsx +0 -84
  229. package/src/pages/dev.ts +0 -734
  230. package/src/pages/errors.ts +0 -67
  231. package/src/pages/functions/buildPlugin.ts +0 -114
  232. package/src/pages/functions/buildWorker.ts +0 -350
  233. package/src/pages/functions/filepath-routing.test.ts +0 -234
  234. package/src/pages/functions/filepath-routing.ts +0 -189
  235. package/src/pages/functions/identifiers.ts +0 -78
  236. package/src/pages/functions/routes-consolidation.test.ts +0 -250
  237. package/src/pages/functions/routes-consolidation.ts +0 -73
  238. package/src/pages/functions/routes-transformation.test.ts +0 -282
  239. package/src/pages/functions/routes-transformation.ts +0 -115
  240. package/src/pages/functions/routes-validation.test.ts +0 -403
  241. package/src/pages/functions/routes-validation.ts +0 -202
  242. package/src/pages/functions/routes.ts +0 -151
  243. package/src/pages/functions/tsconfig.json +0 -8
  244. package/src/pages/functions/tsconfig.tsbuildinfo +0 -1
  245. package/src/pages/functions.ts +0 -86
  246. package/src/pages/hash.ts +0 -13
  247. package/src/pages/index.ts +0 -102
  248. package/src/pages/projects.tsx +0 -159
  249. package/src/pages/prompt-select-project.tsx +0 -31
  250. package/src/pages/publish.tsx +0 -267
  251. package/src/pages/types.ts +0 -46
  252. package/src/pages/upload.tsx +0 -469
  253. package/src/pages/utils.ts +0 -23
  254. package/src/parse.ts +0 -308
  255. package/src/paths.ts +0 -71
  256. package/src/proxy.ts +0 -694
  257. package/src/publish/index.ts +0 -274
  258. package/src/publish/publish.ts +0 -1065
  259. package/src/pubsub/index.ts +0 -286
  260. package/src/pubsub/pubsub-commands.ts +0 -623
  261. package/src/queues/cli/commands/consumer/add.ts +0 -71
  262. package/src/queues/cli/commands/consumer/index.ts +0 -19
  263. package/src/queues/cli/commands/consumer/remove.ts +0 -31
  264. package/src/queues/cli/commands/create.ts +0 -25
  265. package/src/queues/cli/commands/delete.ts +0 -26
  266. package/src/queues/cli/commands/index.ts +0 -35
  267. package/src/queues/cli/commands/list.ts +0 -25
  268. package/src/queues/client.ts +0 -136
  269. package/src/queues/utils.ts +0 -18
  270. package/src/r2/constants.ts +0 -4
  271. package/src/r2/helpers.ts +0 -132
  272. package/src/r2/index.ts +0 -289
  273. package/src/routes.ts +0 -140
  274. package/src/secret/index.ts +0 -377
  275. package/src/selfsigned.d.ts +0 -29
  276. package/src/sites.ts +0 -484
  277. package/src/tail/createTail.ts +0 -415
  278. package/src/tail/filters.ts +0 -277
  279. package/src/tail/index.ts +0 -211
  280. package/src/tail/printing.ts +0 -132
  281. package/src/traverse-module-graph.ts +0 -54
  282. package/src/tsconfig-sanity.ts +0 -16
  283. package/src/type-generation.ts +0 -181
  284. package/src/update-check.ts +0 -19
  285. package/src/user/access.ts +0 -68
  286. package/src/user/auth-variables.ts +0 -113
  287. package/src/user/choose-account.tsx +0 -39
  288. package/src/user/generate-auth-url.ts +0 -33
  289. package/src/user/generate-random-state.ts +0 -16
  290. package/src/user/index.ts +0 -2
  291. package/src/user/user.ts +0 -1234
  292. package/src/utils/collectKeyValues.ts +0 -14
  293. package/src/utils/render.ts +0 -93
  294. package/src/whoami.ts +0 -135
  295. package/src/worker.ts +0 -279
  296. package/src/yargs-types.ts +0 -37
  297. package/src/zones.ts +0 -191
@@ -1,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
- };
@@ -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
- }