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
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
- }
@@ -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
- }
@@ -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 {};
@@ -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
- }
@@ -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
- }
@@ -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
- }