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,158 +0,0 @@
1
- import { URLSearchParams } from "node:url";
2
- import { logger } from "../logger";
3
- import { ParseError } from "../parse";
4
- import { fetchInternal, performApiFetch } from "./internal";
5
- import type { RequestInit } from "undici";
6
-
7
- // Check out https://api.cloudflare.com/ for API docs.
8
-
9
- export interface FetchError {
10
- code: number;
11
- message: string;
12
- error_chain?: FetchError[];
13
- }
14
- export interface FetchResult<ResponseType = unknown> {
15
- success: boolean;
16
- result: ResponseType;
17
- errors: FetchError[];
18
- messages: string[];
19
- result_info?: unknown;
20
- }
21
-
22
- export { fetchKVGetValue } from "./internal";
23
-
24
- /**
25
- * Make a fetch request, and extract the `result` from the JSON response.
26
- */
27
- export async function fetchResult<ResponseType>(
28
- resource: string,
29
- init: RequestInit = {},
30
- queryParams?: URLSearchParams,
31
- abortSignal?: AbortSignal
32
- ): Promise<ResponseType> {
33
- const json = await fetchInternal<FetchResult<ResponseType>>(
34
- resource,
35
- init,
36
- queryParams,
37
- abortSignal
38
- );
39
- if (json.success) {
40
- return json.result;
41
- } else {
42
- throwFetchError(resource, json);
43
- }
44
- }
45
-
46
- /**
47
- * Make a fetch request for a list of values,
48
- * extracting the `result` from the JSON response,
49
- * and repeating the request if the results are paginated.
50
- */
51
- export async function fetchListResult<ResponseType>(
52
- resource: string,
53
- init: RequestInit = {},
54
- queryParams?: URLSearchParams
55
- ): Promise<ResponseType[]> {
56
- const results: ResponseType[] = [];
57
- let getMoreResults = true;
58
- let cursor: string | undefined;
59
- while (getMoreResults) {
60
- if (cursor) {
61
- queryParams = new URLSearchParams(queryParams);
62
- queryParams.set("cursor", cursor);
63
- }
64
- const json = await fetchInternal<FetchResult<ResponseType[]>>(
65
- resource,
66
- init,
67
- queryParams
68
- );
69
- if (json.success) {
70
- results.push(...json.result);
71
- if (hasCursor(json.result_info)) {
72
- cursor = json.result_info?.cursor;
73
- } else {
74
- getMoreResults = false;
75
- }
76
- } else {
77
- throwFetchError(resource, json);
78
- }
79
- }
80
- return results;
81
- }
82
-
83
- function throwFetchError(
84
- resource: string,
85
- response: FetchResult<unknown>
86
- ): never {
87
- const error = new ParseError({
88
- text: `A request to the Cloudflare API (${resource}) failed.`,
89
- notes: response.errors.map((err) => ({
90
- text: renderError(err),
91
- })),
92
- });
93
- // add the first error code directly to this error
94
- // so consumers can use it for specific behaviour
95
- const code = response.errors[0]?.code;
96
- if (code) {
97
- //@ts-expect-error non-standard property on Error
98
- error.code = code;
99
- }
100
- throw error;
101
- }
102
-
103
- function hasCursor(result_info: unknown): result_info is { cursor: string } {
104
- const cursor = (result_info as { cursor: string } | undefined)?.cursor;
105
- return cursor !== undefined && cursor !== null && cursor !== "";
106
- }
107
-
108
- function renderError(err: FetchError, level = 0): string {
109
- const chainedMessages =
110
- err.error_chain
111
- ?.map(
112
- (chainedError) =>
113
- `\n${" ".repeat(level)}- ${renderError(chainedError, level + 1)}`
114
- )
115
- .join("\n") ?? "";
116
- return (
117
- (err.code ? `${err.message} [code: ${err.code}]` : err.message) +
118
- chainedMessages
119
- );
120
- }
121
-
122
- /**
123
- * Fetch the raw script content of a Worker
124
- * Note, this will concatenate the files of multi-module workers
125
- */
126
- export async function fetchScriptContent(
127
- resource: string,
128
- init: RequestInit = {},
129
- queryParams?: URLSearchParams,
130
- abortSignal?: AbortSignal
131
- ): Promise<string> {
132
- const response = await performApiFetch(
133
- resource,
134
- init,
135
- queryParams,
136
- abortSignal
137
- );
138
-
139
- logger.debug(
140
- "-- START CF API RESPONSE:",
141
- response.statusText,
142
- response.status
143
- );
144
-
145
- logger.debug("HEADERS:", { ...response.headers });
146
- // logger.debug("RESPONSE:", text);
147
- logger.debug("-- END CF API RESPONSE");
148
- const contentType = response.headers.get("content-type");
149
-
150
- const usesModules = contentType?.startsWith("multipart");
151
- if (usesModules && contentType) {
152
- const form = await response.formData();
153
- const entries = Array.from(form.entries());
154
- return entries.map((e) => e[1]).join("\n");
155
- } else {
156
- return await response.text();
157
- }
158
- }
@@ -1,258 +0,0 @@
1
- import assert from "node:assert";
2
- import { fetch, File, Headers } from "undici";
3
- import { version as wranglerVersion } from "../../package.json";
4
- import { getCloudflareApiBaseUrl } from "../environment-variables/misc-variables";
5
- import { logger } from "../logger";
6
- import { ParseError, parseJSON } from "../parse";
7
- import { loginOrRefreshIfRequired, requireApiToken } from "../user";
8
- import type { ApiCredentials } from "../user";
9
- import type { URLSearchParams } from "node:url";
10
- import type { RequestInit, HeadersInit, Response } from "undici";
11
-
12
- /*
13
- * performApiFetch does everything required to make a CF API request,
14
- * but doesn't parse the response as JSON. For normal V4 API responses,
15
- * use `fetchInternal`
16
- * */
17
- export async function performApiFetch(
18
- resource: string,
19
- init: RequestInit = {},
20
- queryParams?: URLSearchParams,
21
- abortSignal?: AbortSignal
22
- ) {
23
- const method = init.method ?? "GET";
24
- assert(
25
- resource.startsWith("/"),
26
- `CF API fetch - resource path must start with a "/" but got "${resource}"`
27
- );
28
- await requireLoggedIn();
29
- const apiToken = requireApiToken();
30
- const headers = cloneHeaders(init.headers);
31
- addAuthorizationHeaderIfUnspecified(headers, apiToken);
32
- addUserAgent(headers);
33
-
34
- const queryString = queryParams ? `?${queryParams.toString()}` : "";
35
- logger.debug(
36
- `-- START CF API REQUEST: ${method} ${getCloudflareApiBaseUrl()}${resource}${queryString}`
37
- );
38
- const logHeaders = cloneHeaders(headers);
39
- delete logHeaders["Authorization"];
40
- logger.debug("HEADERS:", JSON.stringify(logHeaders, null, 2));
41
- logger.debug(
42
- "INIT:",
43
- JSON.stringify({ ...init, headers: logHeaders }, null, 2)
44
- );
45
- logger.debug("-- END CF API REQUEST");
46
- return await fetch(`${getCloudflareApiBaseUrl()}${resource}${queryString}`, {
47
- method,
48
- ...init,
49
- headers,
50
- signal: abortSignal,
51
- });
52
- }
53
-
54
- /**
55
- * Make a fetch request to the Cloudflare API.
56
- *
57
- * This function handles acquiring the API token and logging the caller in, as necessary.
58
- *
59
- * Check out https://api.cloudflare.com/ for API docs.
60
- *
61
- * This function should not be used directly, instead use the functions in `cfetch/index.ts`.
62
- */
63
- export async function fetchInternal<ResponseType>(
64
- resource: string,
65
- init: RequestInit = {},
66
- queryParams?: URLSearchParams,
67
- abortSignal?: AbortSignal
68
- ): Promise<ResponseType> {
69
- const method = init.method ?? "GET";
70
- const response = await performApiFetch(
71
- resource,
72
- init,
73
- queryParams,
74
- abortSignal
75
- );
76
- const jsonText = await response.text();
77
- logger.debug(
78
- "-- START CF API RESPONSE:",
79
- response.statusText,
80
- response.status
81
- );
82
- const logHeaders = cloneHeaders(response.headers);
83
- delete logHeaders["Authorization"];
84
- logger.debug("HEADERS:", JSON.stringify(logHeaders, null, 2));
85
- logger.debug("RESPONSE:", jsonText);
86
- logger.debug("-- END CF API RESPONSE");
87
-
88
- try {
89
- return parseJSON<ResponseType>(jsonText);
90
- } catch (err) {
91
- throw new ParseError({
92
- text: "Received a malformed response from the API",
93
- notes: [
94
- {
95
- text: truncate(jsonText, 100),
96
- },
97
- {
98
- text: `${method} ${resource} -> ${response.status} ${response.statusText}`,
99
- },
100
- ],
101
- });
102
- }
103
- }
104
-
105
- function truncate(text: string, maxLength: number): string {
106
- const { length } = text;
107
- if (length <= maxLength) {
108
- return text;
109
- }
110
- return `${text.substring(0, maxLength)}... (length = ${length})`;
111
- }
112
-
113
- function cloneHeaders(
114
- headers: HeadersInit | undefined
115
- ): Record<string, string> {
116
- return headers instanceof Headers
117
- ? Object.fromEntries(headers.entries())
118
- : Array.isArray(headers)
119
- ? Object.fromEntries(headers)
120
- : { ...headers };
121
- }
122
-
123
- async function requireLoggedIn(): Promise<void> {
124
- const loggedIn = await loginOrRefreshIfRequired();
125
- if (!loggedIn) {
126
- throw new Error("Not logged in.");
127
- }
128
- }
129
-
130
- function addAuthorizationHeaderIfUnspecified(
131
- headers: Record<string, string>,
132
- auth: ApiCredentials
133
- ): void {
134
- if (!("Authorization" in headers)) {
135
- if ("apiToken" in auth) {
136
- headers["Authorization"] = `Bearer ${auth.apiToken}`;
137
- } else {
138
- headers["X-Auth-Key"] = auth.authKey;
139
- headers["X-Auth-Email"] = auth.authEmail;
140
- }
141
- }
142
- }
143
-
144
- function addUserAgent(headers: Record<string, string>): void {
145
- headers["User-Agent"] = `wrangler/${wranglerVersion}`;
146
- }
147
-
148
- /**
149
- * The implementation for fetching a kv value from the cloudflare API.
150
- * We special-case this one call, because it's the only API call that
151
- * doesn't return json. We inline the implementation and try not to share
152
- * any code with the other calls. We should push back on any new APIs that
153
- * try to introduce non-"standard" response structures.
154
- *
155
- * Note: any calls to fetchKVGetValue must call encodeURIComponent on key
156
- * before passing it
157
- */
158
- export async function fetchKVGetValue(
159
- accountId: string,
160
- namespaceId: string,
161
- key: string
162
- ): Promise<ArrayBuffer> {
163
- await requireLoggedIn();
164
- const auth = requireApiToken();
165
- const headers: Record<string, string> = {};
166
- addAuthorizationHeaderIfUnspecified(headers, auth);
167
- const resource = `${getCloudflareApiBaseUrl()}/accounts/${accountId}/storage/kv/namespaces/${namespaceId}/values/${key}`;
168
- const response = await fetch(resource, {
169
- method: "GET",
170
- headers,
171
- });
172
- if (response.ok) {
173
- return await response.arrayBuffer();
174
- } else {
175
- throw new Error(
176
- `Failed to fetch ${resource} - ${response.status}: ${response.statusText});`
177
- );
178
- }
179
- }
180
-
181
- /**
182
- * The implementation for fetching a R2 object from Cloudflare API.
183
- * We have a special implementation to handle the non-standard API response
184
- * that doesn't return JSON, likely due to the streaming nature.
185
- *
186
- * note: The implementation should be called from light wrappers for
187
- * different methods (GET, PUT)
188
- */
189
- type ResponseWithBody = Response & { body: NonNullable<Response["body"]> };
190
- export async function fetchR2Objects(
191
- resource: string,
192
- bodyInit: RequestInit = {}
193
- ): Promise<ResponseWithBody> {
194
- await requireLoggedIn();
195
- const auth = requireApiToken();
196
- const headers = cloneHeaders(bodyInit.headers);
197
- addAuthorizationHeaderIfUnspecified(headers, auth);
198
- addUserAgent(headers);
199
-
200
- const response = await fetch(`${getCloudflareApiBaseUrl()}${resource}`, {
201
- ...bodyInit,
202
- headers,
203
- });
204
-
205
- if (response.ok && response.body) {
206
- return response as ResponseWithBody;
207
- } else {
208
- throw new Error(
209
- `Failed to fetch ${resource} - ${response.status}: ${response.statusText});`
210
- );
211
- }
212
- }
213
-
214
- /**
215
- * This is a wrapper STOPGAP for getting the script which returns a raw text response.
216
- */
217
- export async function fetchDashboardScript(
218
- resource: string,
219
- bodyInit: RequestInit = {}
220
- ): Promise<string> {
221
- await requireLoggedIn();
222
- const auth = requireApiToken();
223
- const headers = cloneHeaders(bodyInit.headers);
224
- addAuthorizationHeaderIfUnspecified(headers, auth);
225
- addUserAgent(headers);
226
-
227
- const response = await fetch(`${getCloudflareApiBaseUrl()}${resource}`, {
228
- ...bodyInit,
229
- headers,
230
- });
231
-
232
- if (!response.ok || !response.body) {
233
- throw new Error(
234
- `Failed to fetch ${resource} - ${response.status}: ${response.statusText});`
235
- );
236
- }
237
-
238
- const usesModules = response.headers
239
- .get("content-type")
240
- ?.startsWith("multipart");
241
-
242
- if (usesModules) {
243
- // Response from edge contains generic "name = worker.js" for dashboard created scripts
244
- const form = await response.formData();
245
- const entries = Array.from(form.entries());
246
- if (entries.length > 1)
247
- throw new RangeError("Expected only one entry in multipart response");
248
- const [_, file] = entries[0];
249
-
250
- if (file instanceof File) {
251
- return await file.text();
252
- }
253
-
254
- return file ?? "";
255
- } else {
256
- return response.text();
257
- }
258
- }
package/src/cli.ts DELETED
@@ -1,28 +0,0 @@
1
- import process from "process";
2
- import { hideBin } from "yargs/helpers";
3
- import { unstable_dev, unstable_pages } from "./api";
4
- import { FatalError } from "./errors";
5
- import { main } from ".";
6
-
7
- import type { UnstableDevWorker, UnstableDevOptions } from "./api";
8
- /**
9
- * The main entrypoint for the CLI.
10
- * main only gets called when the script is run directly, not when it's imported as a module.
11
- */
12
- if (typeof jest === "undefined" && require.main === module) {
13
- main(hideBin(process.argv)).catch((e) => {
14
- // The logging of any error that was thrown from `main()` is handled in the `yargs.fail()` handler.
15
- // Here we just want to ensure that the process exits with a non-zero code.
16
- // We don't want to do this inside the `main()` function, since that would kill the process when running our tests.
17
- const exitCode = (e instanceof FatalError && e.code) || 1;
18
- process.exit(exitCode);
19
- });
20
- }
21
-
22
- /**
23
- * This is how we're exporting the API.
24
- * It makes it possible to import wrangler from 'wrangler',
25
- * and call wrangler.unstable_dev().
26
- */
27
- export { unstable_dev, unstable_pages };
28
- export type { UnstableDevWorker, UnstableDevOptions };
@@ -1,107 +0,0 @@
1
- # Configuration validation
2
-
3
- The files in this directory define and validate the configuration that is read from a `wrangler.toml` file.
4
-
5
- The configuration for a Worker is complicated since we can define different "environments", and each environment can have its own configuration.
6
- There is a default ("top-level") environment and then named environments that provide environment specific configuration.
7
-
8
- This is further complicated by the fact that there are three kinds of environment configuration:
9
-
10
- - **non-overridable**: these values are defined once in the top-level configuration, apply to all environments and cannot be overridden by an environment.
11
- - **inheritable**: these values can be defined at the top-level but can also be overridden by environment specific values.
12
- Named environments do not need to provide their own values, in which case they inherit the value from the top-level.
13
- - **non-inheritable**: these values must be explicitly defined in each environment if they are defined at the top-level.
14
- Named environments do not inherit such configuration and must provide their own values.
15
-
16
- All configuration values in `wrangler.toml` are optional and will receive a default value if not defined.
17
-
18
- ## Types
19
-
20
- ### Environment
21
-
22
- The fields that can be defined within the `env` containers are defined in the [`Environment`](./environment.ts) type.
23
- This includes the `EnvironmentInheritable` and `EnvironmentNonInheritable` fields.
24
-
25
- ### Config
26
-
27
- The "non-overridable" types are defined in the [`ConfigFields`](./config.ts) type.
28
- The `Config` type is the overall configuration, which consists of the `ConfigFields` and also an `Environment`.
29
- In this case the `Environment`, here, corresponds to the "currently active" environment. This is specified by the `--env` command line argument.
30
- If there is no argument passed then the currently active environment is the "top-level" environment.
31
- The fields in `Config` and `Environment` are not generally optional and so you can expect they have been filled with suitable inherited or default values.
32
- These types should be used when you are working with fields that should be passed to commands.
33
-
34
- ### RawConfig
35
-
36
- The `RawConfig` type is a version of `Config`, where all the fields are optional.
37
- The `RawConfig` type includes `DeprecatedConfigFields` and `EnvironmentMap`.
38
- It also extends the `RawEnvironment` type, which is a version of `Environment` where all the fields are optional.
39
- These optional fields map to the actual fields found in the `wrangler.toml`.
40
- These types should be used when you are working with raw configuration that is read or will be written to a `wrangler.toml`.
41
-
42
- ## Validation
43
-
44
- Validation is triggered by passing a `RawConfig` object, and the active environment name, to the `normalizeAndValidateConfig()` function.
45
- This function will return:
46
-
47
- - a `Config` object, where all the fields have suitable valid values
48
- - a `Diagnostics` object, which contains any errors or warnings from the validation process
49
-
50
- The field values may have been parsed directly from the `RawConfig`, inherited into a named environment from the top-level environment, or given a default value.
51
- Generally, if there are any warnings they should be presented to the user via `logger.warn()` messages,
52
- and if there are any errors then an `Error` should be thrown describing these errors.
53
-
54
- The `Diagnostics` object is hierarchical: each `Diagnostics` instance can contain a collection of child `Diagnostics` instance.
55
- When checking for or rendering warnings and errors, the `Diagnostics` class will automatically traverse down to all its children.
56
-
57
- ## Usage
58
-
59
- The [high level API](./index.ts) for configuration processing consists of the `findWranglerToml()` and `readConfig()` functions.
60
-
61
- ### readConfig()
62
-
63
- The `readConfig()` function will find the nearest `wrangler.toml` file, load and parse it, then validate and normalize the values into a `Config` object.
64
- Note that you should pass the current active environment name in as a parameter. The resulting `Config` object will contain only the fields appropriate to that environment.
65
- If there are validation errors then it will throw a suitable error.
66
-
67
- ## Changing configuration
68
-
69
- ### Add a new configuration field
70
-
71
- When a new field needs to be added to the `wrangler.toml` configuration you will need to add to the types and validation code in this directory.
72
-
73
- Here are some steps that you should consider when doing this:
74
-
75
- - add the new field to one of the interface:
76
- - if the field is not overridable in an environment then add it to the `ConfigFields` interface.
77
- - if the field can be inherited and overridden in a named environment then add it to the `EnvironmentInheritable` interface.
78
- - if the field cannot be inherited and must be specified in each named environment then add it to the `EnvironmentNonInheritable` interface.
79
- - if the field is experimental then add a call to the `experimental()` function:
80
- - if the field is now in the `ConfigDeprecated` interface then add the call to the `normalizeAndValidateConfig()` function.
81
- - if the field is now in the `EnvironmentDeprecated` interface then add the call to the `normalizeAndValidateEnvironment()` function.
82
- - add validation and normalization to the interface
83
- - if the field is in `ConfigFields` then add validation calls to `normalizeAndValidateConfig()` and assign the normalized value to the appropriate property in the `config` object.
84
- - if the field is in `EnvironmentInheritable` then call `inheritable()` in `normalizeAndValidateEnvironment()` and assign the normalized value to the appropriate property in the `environment` object.
85
- - if the field is in `EnvironmentNonInheritable` then call `notInheritable()` in `normalizeAndValidateEnvironment()` and assign the normalized value to the appropriate property in the `environment` object.
86
- - update the tests in `configuration.test.ts`
87
- - add to the `"should use defaults for empty configuration"` test to prove the correct default value is assigned
88
- - if the field is in `ConfigFields` add tests to the `"top-level non-environment configuration"` block to check the validation and normalization of values
89
- - if the field is in `EnvironmentInheritable` or `EnvironmentNonInheritable`
90
- - add tests to the `"top-level environment configuration"` block to check the validation and normalization of values
91
- - add tests to the `"named environment configuration"` block to check the inheritance of values
92
-
93
- ### Remove a configuration field
94
-
95
- We should not just remove a field from use, since users would not know that this field is no longer needed, nor how to migrate to any new usage.
96
- Instead we should first deprecate it, and then then remove it in a future major release.
97
-
98
- - move the field to a deprecation interface:
99
- - if the field was originally in `ConfigFields` then move it to the `ConfigDeprecated` interface.
100
- - if the field was originally in either `EnvironmentInheritable` or `EnvironmentNonInheritable` then move it to the `EnvironmentDeprecatedInterface`.
101
- - remove the validation for the field
102
- - the TypeScript compiler should indicate where there is now an unknown field, so that you can remove its validation and normalization from the code base.
103
- - add a deprecation warning by calling `deprecated()`
104
- - if the field is now in the `ConfigDeprecated` interface then add the call to the `normalizeAndValidateConfig()` function.
105
- - if the field is now in the `EnvironmentDeprecated` interface then add the call to the `normalizeAndValidateEnvironment()` function.
106
- - update the tests in `configuration.test.ts`
107
- - Find tests where the field is mentioned and either remove them (e.g. validation) or update to show the deprecation message.