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,5 +0,0 @@
1
- export { getMetricsDispatcher } from "./metrics-dispatcher";
2
- export type { Properties } from "./metrics-dispatcher";
3
- export { getMetricsConfig } from "./metrics-config";
4
- export * from "./send-event";
5
- export { getMetricsUsageHeaders } from "./metrics-usage-headers";
@@ -1,239 +0,0 @@
1
- import { randomUUID } from "node:crypto";
2
- import { readFileSync, mkdirSync, writeFileSync } from "node:fs";
3
- import path from "node:path";
4
- import { fetchResult } from "../cfetch";
5
- import { getConfigCache, saveToConfigCache } from "../config-cache";
6
- import { confirm } from "../dialogs";
7
- import { getEnvironmentVariableFactory } from "../environment-variables/factory";
8
- import { getGlobalWranglerConfigPath } from "../global-wrangler-config-path";
9
- import { CI } from "../is-ci";
10
- import isInteractive from "../is-interactive";
11
- import { logger } from "../logger";
12
- import { getAPIToken } from "../user";
13
-
14
- /**
15
- * The date that the metrics being gathered was last updated in a way that would require
16
- * the user to give their permission again.
17
- *
18
- * When reading from a config file, we check the recorded date in the config file against
19
- * this one here. We ignore the permissions set in the the file if the recorded date is older.
20
- * This allows us to prompt the user to re-opt-in when we make substantive changes to our metrics
21
- * gathering.
22
- */
23
- export const CURRENT_METRICS_DATE = new Date(2022, 6, 4);
24
- export const USER_ID_CACHE_PATH = "user-id.json";
25
-
26
- export const getWranglerSendMetricsFromEnv = getEnvironmentVariableFactory({
27
- variableName: "WRANGLER_SEND_METRICS",
28
- });
29
-
30
- export interface MetricsConfigOptions {
31
- /**
32
- * Defines whether to send metrics to Cloudflare:
33
- * If defined, then use this value for whether the dispatch is enabled.
34
- * Otherwise, infer the enabled value from the user configuration.
35
- */
36
- sendMetrics?: boolean;
37
- /**
38
- * When true, do not make any CF API requests.
39
- */
40
- offline?: boolean;
41
- }
42
-
43
- /**
44
- * The information needed to set up the MetricsDispatcher.
45
- */
46
- export interface MetricsConfig {
47
- /** True if usage tracking is enabled. */
48
- enabled: boolean;
49
- /** A UID that identifies this user and machine pair for Wrangler. */
50
- deviceId: string;
51
- /** The currently logged in user - undefined if not logged in. */
52
- userId: string | undefined;
53
- }
54
-
55
- /**
56
- * Get hold of the permissions and device-id for metrics dispatch.
57
- *
58
- * The device-id is just a unique identifier sent along with events to help
59
- * to collate metrics. Once generated, this id is cached in the metrics config file.
60
- *
61
- * The permissions define whether we can send metrics or not. They can come from a variety of places:
62
- * - the `send_metrics` setting in `wrangler.toml`
63
- * - a cached response from the current user
64
- * - prompting the user to opt-in to metrics
65
- *
66
- * If the user was prompted to opt-in, then their response is cached in the metrics config file.
67
- *
68
- * If the current process is not interactive then we will cannot prompt the user and just assume
69
- * we cannot send metrics if there is no cached or project-level preference available.
70
- */
71
- export async function getMetricsConfig({
72
- sendMetrics,
73
- offline = false,
74
- }: MetricsConfigOptions): Promise<MetricsConfig> {
75
- const config = readMetricsConfig();
76
- const deviceId = getDeviceId(config);
77
- const userId = await getUserId(offline);
78
-
79
- // If the WRANGLER_SEND_METRICS environment variable has been set use that
80
- // and ignore everything else.
81
- const sendMetricsEnv = getWranglerSendMetricsFromEnv();
82
- if (sendMetricsEnv !== undefined) {
83
- return {
84
- enabled: sendMetricsEnv.toLowerCase() === "true",
85
- deviceId,
86
- userId,
87
- };
88
- }
89
-
90
- // If the project is explicitly set the `send_metrics` options in `wrangler.toml`
91
- // then use that and ignore any user preference.
92
- if (sendMetrics !== undefined) {
93
- return { enabled: sendMetrics, deviceId, userId };
94
- }
95
-
96
- // Get the user preference from the metrics config.
97
- const permission = config.permission;
98
- if (permission !== undefined) {
99
- if (new Date(permission.date) >= CURRENT_METRICS_DATE) {
100
- return { enabled: permission.enabled, deviceId, userId };
101
- } else if (permission.enabled) {
102
- logger.log(
103
- "Usage metrics tracking has changed since you last granted permission."
104
- );
105
- }
106
- }
107
-
108
- // We couldn't get the metrics permission from the project-level nor the user-level config.
109
- // If we are not interactive or in a CI build then just bail out.
110
- if (!isInteractive() || CI.isCI()) {
111
- return { enabled: false, deviceId, userId };
112
- }
113
-
114
- // Otherwise, let's ask the user and store the result in the metrics config.
115
- const enabled = await confirm(
116
- "Would you like to help improve Wrangler by sending usage metrics to Cloudflare?"
117
- );
118
- logger.log(
119
- `Your choice has been saved in the following file: ${path.relative(
120
- process.cwd(),
121
- getMetricsConfigPath()
122
- )}.\n\n` +
123
- " You can override the user level setting for a project in `wrangler.toml`:\n\n" +
124
- " - to disable sending metrics for a project: `send_metrics = false`\n" +
125
- " - to enable sending metrics for a project: `send_metrics = true`"
126
- );
127
- writeMetricsConfig({
128
- permission: {
129
- enabled,
130
- date: CURRENT_METRICS_DATE,
131
- },
132
- deviceId,
133
- });
134
- return { enabled, deviceId, userId };
135
- }
136
-
137
- /**
138
- * Stringify and write the given info to the metrics config file.
139
- */
140
- export function writeMetricsConfig(config: MetricsConfigFile) {
141
- mkdirSync(path.dirname(getMetricsConfigPath()), { recursive: true });
142
- writeFileSync(
143
- getMetricsConfigPath(),
144
- JSON.stringify(
145
- config,
146
- (_key, value) => (value instanceof Date ? value.toISOString() : value),
147
- "\t"
148
- )
149
- );
150
- }
151
-
152
- /**
153
- * Read and parse the metrics config file.
154
- */
155
- export function readMetricsConfig(): MetricsConfigFile {
156
- try {
157
- const config = readFileSync(getMetricsConfigPath(), "utf8");
158
- return JSON.parse(config, (key, value) =>
159
- key === "date" ? new Date(value) : value
160
- );
161
- } catch {
162
- return {};
163
- }
164
- }
165
-
166
- /**
167
- * Get the path to the metrics config file.
168
- */
169
- function getMetricsConfigPath(): string {
170
- return path.resolve(getGlobalWranglerConfigPath(), "metrics.json");
171
- }
172
-
173
- /**
174
- * The format of the metrics config file.
175
- */
176
- export interface MetricsConfigFile {
177
- permission?: {
178
- /** True if Wrangler should send metrics to Cloudflare. */
179
- enabled: boolean;
180
- /** The date that this permission was set. */
181
- date: Date;
182
- };
183
- /** A unique UUID that identifies this device for metrics purposes. */
184
- deviceId?: string;
185
- }
186
-
187
- /**
188
- * Returns an ID that uniquely identifies Wrangler on this device to help collate events.
189
- *
190
- * Once created this ID is stored in the metrics config file.
191
- */
192
- function getDeviceId(config: MetricsConfigFile) {
193
- // Get or create the deviceId.
194
- const deviceId = config.deviceId ?? randomUUID();
195
- if (config.deviceId === undefined) {
196
- // We had to create a new deviceID so store it now.
197
- writeMetricsConfig({ ...config, deviceId });
198
- }
199
- return deviceId;
200
- }
201
-
202
- /**
203
- * Returns the ID of the current user, which will be sent with each event.
204
- *
205
- * The ID is retrieved from the CF API `/user` endpoint if the user is authenticated and then
206
- * stored in the `node_modules/.cache`.
207
- *
208
- * If it is not possible to retrieve the ID (perhaps the user is not logged in) then we just use
209
- * `undefined`.
210
- */
211
- async function getUserId(offline: boolean) {
212
- // Get the userId from the cache.
213
- // If it has not been found in the cache and we are not offline then make an API call to get it.
214
- // If we can't work in out then just use `anonymous`.
215
- let userId = getConfigCache<{ userId: string }>(USER_ID_CACHE_PATH).userId;
216
- if (userId === undefined && !offline) {
217
- userId = await fetchUserId();
218
- if (userId !== undefined) {
219
- saveToConfigCache(USER_ID_CACHE_PATH, { userId });
220
- }
221
- }
222
- return userId;
223
- }
224
-
225
- /**
226
- * Ask the Cloudflare API for the User ID of the current user.
227
- *
228
- * We will only do this if we are not "offline", e.g. not running `wrangler dev --local`.
229
- * Quietly return undefined if anything goes wrong.
230
- */
231
- async function fetchUserId(): Promise<string | undefined> {
232
- try {
233
- return getAPIToken()
234
- ? (await fetchResult<{ id: string }>("/user")).id
235
- : undefined;
236
- } catch (e) {
237
- return undefined;
238
- }
239
- }
@@ -1,96 +0,0 @@
1
- import { fetch } from "undici";
2
- import { version as wranglerVersion } from "../../package.json";
3
- import { logger } from "../logger";
4
- import { getMetricsConfig } from "./metrics-config";
5
- import type { MetricsConfigOptions } from "./metrics-config";
6
-
7
- // The SPARROW_SOURCE_KEY is provided at esbuild time as a `define` for production and beta
8
- // releases. Otherwise it is left undefined, which automatically disables metrics requests.
9
- declare const SPARROW_SOURCE_KEY: string;
10
- const SPARROW_URL = "https://sparrow.cloudflare.com";
11
-
12
- export async function getMetricsDispatcher(options: MetricsConfigOptions) {
13
- return {
14
- /**
15
- * Dispatch a event to the analytics target.
16
- *
17
- * The event should follow these conventions
18
- * - name is of the form `[action] [object]` (lower case)
19
- * - additional properties are camelCased
20
- */
21
- async sendEvent(name: string, properties: Properties = {}): Promise<void> {
22
- await dispatch({ type: "event", name, properties });
23
- },
24
-
25
- /**
26
- * Dispatch a user profile information to the analytics target.
27
- *
28
- * This call can be used to inform the analytics target of relevant properties associated
29
- * with the current user.
30
- */
31
- async identify(properties: Properties): Promise<void> {
32
- await dispatch({ type: "identify", name: "identify", properties });
33
- },
34
- };
35
-
36
- async function dispatch(event: {
37
- type: "identify" | "event";
38
- name: string;
39
- properties: Properties;
40
- }): Promise<void> {
41
- if (!SPARROW_SOURCE_KEY) {
42
- logger.debug(
43
- "Metrics dispatcher: Source Key not provided. Be sure to initialize before sending events.",
44
- event
45
- );
46
- return;
47
- }
48
-
49
- // Lazily get the config for this dispatcher only when an event is being dispatched.
50
- // We must await this since it might trigger user interaction that would break other UI
51
- // in Wrangler if it was allowed to run in parallel.
52
- const metricsConfig = await getMetricsConfig(options);
53
- if (!metricsConfig.enabled) {
54
- logger.debug(
55
- `Metrics dispatcher: Dispatching disabled - would have sent ${JSON.stringify(
56
- event
57
- )}.`
58
- );
59
- return;
60
- }
61
-
62
- logger.debug(`Metrics dispatcher: Posting data ${JSON.stringify(event)}`);
63
- const body = JSON.stringify({
64
- deviceId: metricsConfig.deviceId,
65
- userId: metricsConfig.userId,
66
- event: event.name,
67
- properties: {
68
- category: "Workers",
69
- wranglerVersion,
70
- os: process.platform + ":" + process.arch,
71
- ...event.properties,
72
- },
73
- });
74
-
75
- // Do not await this fetch call.
76
- // Just fire-and-forget, otherwise we might slow down the rest of Wrangler.
77
- fetch(`${SPARROW_URL}/api/v1/${event.type}`, {
78
- method: "POST",
79
- headers: {
80
- Accept: "*/*",
81
- "Content-Type": "application/json",
82
- "Sparrow-Source-Key": SPARROW_SOURCE_KEY,
83
- },
84
- mode: "cors",
85
- keepalive: true,
86
- body,
87
- }).catch((e) => {
88
- logger.debug(
89
- "Metrics dispatcher: Failed to send request:",
90
- (e as Error).message
91
- );
92
- });
93
- }
94
- }
95
-
96
- export type Properties = Record<string, unknown>;
@@ -1,24 +0,0 @@
1
- import { getMetricsConfig } from "./metrics-config";
2
-
3
- /**
4
- * Add an additional header to publish requests if the user has opted into sending usage metrics.
5
- *
6
- * This allows us to estimate the number of instances of Wrangler that have opted-in
7
- * without breaking our agreement not to send stuff if you have not opted-in.
8
- */
9
- export async function getMetricsUsageHeaders(
10
- sendMetrics: boolean | undefined
11
- ): Promise<Record<string, string> | undefined> {
12
- const metricsEnabled = (
13
- await getMetricsConfig({
14
- sendMetrics,
15
- })
16
- ).enabled;
17
- if (metricsEnabled) {
18
- return {
19
- metricsEnabled: "true",
20
- };
21
- } else {
22
- return undefined;
23
- }
24
- }
@@ -1,99 +0,0 @@
1
- import { logger } from "../logger";
2
- import { getMetricsDispatcher } from "./metrics-dispatcher";
3
- import type { MetricsConfigOptions } from "./metrics-config";
4
- import type { Properties } from "./metrics-dispatcher";
5
-
6
- /** These are event names used by this wrangler client. */
7
- export type EventNames =
8
- | "view accounts"
9
- | "deploy worker script"
10
- | "delete worker script"
11
- | "begin log stream"
12
- | "end log stream"
13
- | "begin pages log stream"
14
- | "end pages log stream"
15
- | "create encrypted variable"
16
- | "delete encrypted variable"
17
- | "list encrypted variables"
18
- | "create kv namespace"
19
- | "list kv namespaces"
20
- | "delete kv namespace"
21
- | "write kv key-value"
22
- | "list kv keys"
23
- | "read kv value"
24
- | "delete kv key-value"
25
- | "write kv key-values (bulk)"
26
- | "delete kv key-values (bulk)"
27
- | "create r2 bucket"
28
- | "list r2 buckets"
29
- | "delete r2 bucket"
30
- | "login user"
31
- | "logout user"
32
- | "create pubsub namespace"
33
- | "list pubsub namespaces"
34
- | "delete pubsub namespace"
35
- | "view pubsub namespace"
36
- | "create pubsub broker"
37
- | "update pubsub broker"
38
- | "list pubsub brokers"
39
- | "delete pubsub broker"
40
- | "view pubsub broker"
41
- | "issue pubsub broker credentials"
42
- | "revoke pubsub broker credentials"
43
- | "unrevoke pubsub broker credentials"
44
- | "list pubsub broker revoked credentials"
45
- | "list pubsub broker public-keys"
46
- | "list dispatch namespaces"
47
- | "view dispatch namespace"
48
- | "create dispatch namespace"
49
- | "delete dispatch namespace"
50
- | "rename dispatch namespace"
51
- | "create pages project"
52
- | "list pages projects"
53
- | "create pages deployment"
54
- | "list pages deployments"
55
- | "build pages functions"
56
- | "run dev"
57
- | "run dev (api)"
58
- | "run pages dev"
59
- | "view docs"
60
- | "view deployments"
61
- | "rollback deployments";
62
-
63
- /**
64
- * Send a metrics event, with no extra properties, to Cloudflare, if usage tracking is enabled.
65
- *
66
- * This overload assumes that you do not want to configure analytics with options.
67
- */
68
- export function sendMetricsEvent(event: EventNames): Promise<void>;
69
- /**
70
- * Send a metrics event, with no extra properties, to Cloudflare, if usage tracking is enabled.
71
- */
72
- export function sendMetricsEvent(
73
- event: EventNames,
74
- options: MetricsConfigOptions
75
- ): Promise<void>;
76
- /**
77
- * Send a metrics event to Cloudflare, if usage tracking is enabled.
78
- *
79
- * Generally you should pass the `send_metrics` property from the wrangler.toml config here,
80
- * which would override any user permissions.
81
- */
82
- export function sendMetricsEvent(
83
- event: EventNames,
84
- properties: Properties,
85
- options: MetricsConfigOptions
86
- ): Promise<void>;
87
- export async function sendMetricsEvent(
88
- event: EventNames,
89
- ...args: [] | [MetricsConfigOptions] | [Properties, MetricsConfigOptions]
90
- ): Promise<void> {
91
- try {
92
- const options = args.pop() ?? {};
93
- const properties = (args.pop() ?? {}) as Properties;
94
- const metricsDispatcher = await getMetricsDispatcher(options);
95
- await metricsDispatcher.sendEvent(event, properties);
96
- } catch (err) {
97
- logger.debug("Error sending metrics event", err);
98
- }
99
- }
@@ -1,30 +0,0 @@
1
- # Custom Miniflare CLI
2
-
3
- This directory contains a simple wrapper around the programmatic Miniflare API,
4
- which Wrangler spawns when running `wrangler dev` in local mode.
5
-
6
- ## Building
7
-
8
- This CLI is built at the same time as Wrangler by running
9
-
10
- ```
11
- npm run -w wrangler build
12
- ```
13
-
14
- The output of the build is `miniflare-dist/index.mjs`.
15
-
16
- ## Running
17
-
18
- The CLI expects a single command line argument which is the Miniflare options formatted as a string of JSON.
19
-
20
- ```bash
21
- node --no-warnings ./packages/wrangler/miniflare-dist/index.mjs '{"watch": true, "script": ""}' --log VERBOSE
22
- ```
23
-
24
- The `--log` argument is optional and takes one of Miniflare's LogLevels: "NONE", "ERROR", "WARN", "INFO", "DEBUG", "VERBOSE".
25
- It defaults to `INFO`.
26
-
27
- ## Debugging
28
-
29
- Simply place a breakpoint in the code and run the above command in the VS Code "JavaScript Debug Terminal".
30
- The code will stop at the breakpoint as expected.