wrangler 2.0.12 → 2.0.16

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 (149) hide show
  1. package/README.md +7 -1
  2. package/bin/wrangler.js +111 -57
  3. package/miniflare-dist/index.mjs +9 -2
  4. package/package.json +156 -154
  5. package/src/__tests__/config-cache-without-cache-dir.test.ts +38 -0
  6. package/src/__tests__/config-cache.test.ts +30 -24
  7. package/src/__tests__/configuration.test.ts +3935 -3476
  8. package/src/__tests__/dev.test.tsx +1128 -979
  9. package/src/__tests__/guess-worker-format.test.ts +68 -68
  10. package/src/__tests__/helpers/cmd-shim.d.ts +6 -6
  11. package/src/__tests__/helpers/faye-websocket.d.ts +4 -4
  12. package/src/__tests__/helpers/mock-account-id.ts +24 -24
  13. package/src/__tests__/helpers/mock-bin.ts +20 -20
  14. package/src/__tests__/helpers/mock-cfetch.ts +92 -92
  15. package/src/__tests__/helpers/mock-console.ts +49 -39
  16. package/src/__tests__/helpers/mock-dialogs.ts +94 -71
  17. package/src/__tests__/helpers/mock-http-server.ts +30 -30
  18. package/src/__tests__/helpers/mock-istty.ts +65 -18
  19. package/src/__tests__/helpers/mock-kv.ts +26 -26
  20. package/src/__tests__/helpers/mock-oauth-flow.ts +223 -228
  21. package/src/__tests__/helpers/mock-process.ts +39 -0
  22. package/src/__tests__/helpers/mock-stdin.ts +82 -77
  23. package/src/__tests__/helpers/mock-web-socket.ts +21 -21
  24. package/src/__tests__/helpers/run-in-tmp.ts +27 -27
  25. package/src/__tests__/helpers/run-wrangler.ts +8 -8
  26. package/src/__tests__/helpers/write-worker-source.ts +16 -16
  27. package/src/__tests__/helpers/write-wrangler-toml.ts +9 -9
  28. package/src/__tests__/https-options.test.ts +104 -104
  29. package/src/__tests__/index.test.ts +239 -234
  30. package/src/__tests__/init.test.ts +1605 -1250
  31. package/src/__tests__/jest.setup.ts +63 -33
  32. package/src/__tests__/kv.test.ts +1128 -1011
  33. package/src/__tests__/logger.test.ts +100 -74
  34. package/src/__tests__/package-manager.test.ts +303 -303
  35. package/src/__tests__/pages.test.ts +1152 -652
  36. package/src/__tests__/parse.test.ts +252 -252
  37. package/src/__tests__/publish.test.ts +6371 -5622
  38. package/src/__tests__/pubsub.test.ts +367 -0
  39. package/src/__tests__/r2.test.ts +133 -133
  40. package/src/__tests__/route.test.ts +18 -18
  41. package/src/__tests__/secret.test.ts +382 -377
  42. package/src/__tests__/tail.test.ts +530 -530
  43. package/src/__tests__/user.test.ts +123 -111
  44. package/src/__tests__/whoami.test.tsx +198 -117
  45. package/src/__tests__/worker-namespace.test.ts +327 -0
  46. package/src/abort.d.ts +1 -1
  47. package/src/api/dev.ts +49 -0
  48. package/src/api/index.ts +1 -0
  49. package/src/bundle-reporter.tsx +29 -0
  50. package/src/bundle.ts +157 -149
  51. package/src/cfetch/index.ts +80 -80
  52. package/src/cfetch/internal.ts +90 -83
  53. package/src/cli.ts +21 -7
  54. package/src/config/config.ts +204 -195
  55. package/src/config/diagnostics.ts +61 -61
  56. package/src/config/environment.ts +390 -357
  57. package/src/config/index.ts +206 -193
  58. package/src/config/validation-helpers.ts +366 -366
  59. package/src/config/validation.ts +1573 -1376
  60. package/src/config-cache.ts +79 -41
  61. package/src/create-worker-preview.ts +206 -136
  62. package/src/create-worker-upload-form.ts +247 -238
  63. package/src/dev/dev-vars.ts +13 -13
  64. package/src/dev/dev.tsx +329 -307
  65. package/src/dev/local.tsx +304 -275
  66. package/src/dev/remote.tsx +366 -224
  67. package/src/dev/use-esbuild.ts +126 -91
  68. package/src/dev.tsx +538 -0
  69. package/src/dialogs.tsx +97 -97
  70. package/src/durable.ts +87 -87
  71. package/src/entry.ts +234 -228
  72. package/src/environment-variables.ts +23 -23
  73. package/src/errors.ts +6 -6
  74. package/src/generate.ts +33 -0
  75. package/src/git-client.ts +42 -0
  76. package/src/https-options.ts +79 -79
  77. package/src/index.tsx +1775 -2763
  78. package/src/init.ts +549 -0
  79. package/src/inspect.ts +593 -593
  80. package/src/intl-polyfill.d.ts +123 -123
  81. package/src/is-interactive.ts +12 -0
  82. package/src/kv.ts +277 -277
  83. package/src/logger.ts +46 -39
  84. package/src/miniflare-cli/enum-keys.ts +8 -8
  85. package/src/miniflare-cli/index.ts +42 -31
  86. package/src/miniflare-cli/request-context.ts +18 -18
  87. package/src/module-collection.ts +212 -212
  88. package/src/open-in-browser.ts +4 -6
  89. package/src/package-manager.ts +123 -123
  90. package/src/pages/build.tsx +202 -0
  91. package/src/pages/constants.ts +7 -0
  92. package/src/pages/deployments.tsx +101 -0
  93. package/src/pages/dev.tsx +964 -0
  94. package/src/pages/functions/buildPlugin.ts +105 -0
  95. package/src/pages/functions/buildWorker.ts +151 -0
  96. package/{pages → src/pages}/functions/filepath-routing.test.ts +113 -113
  97. package/src/pages/functions/filepath-routing.ts +189 -0
  98. package/src/pages/functions/identifiers.ts +78 -0
  99. package/src/pages/functions/routes.ts +151 -0
  100. package/src/pages/index.tsx +84 -0
  101. package/src/pages/projects.tsx +157 -0
  102. package/src/pages/publish.tsx +335 -0
  103. package/src/pages/types.ts +40 -0
  104. package/src/pages/upload.tsx +384 -0
  105. package/src/pages/utils.ts +12 -0
  106. package/src/parse.ts +202 -138
  107. package/src/paths.ts +6 -6
  108. package/src/preview.ts +31 -0
  109. package/src/proxy.ts +400 -402
  110. package/src/publish.ts +667 -621
  111. package/src/pubsub/index.ts +286 -0
  112. package/src/pubsub/pubsub-commands.tsx +577 -0
  113. package/src/r2.ts +19 -19
  114. package/src/selfsigned.d.ts +23 -23
  115. package/src/sites.tsx +271 -225
  116. package/src/tail/filters.ts +108 -108
  117. package/src/tail/index.ts +217 -217
  118. package/src/tail/printing.ts +45 -45
  119. package/src/update-check.ts +11 -11
  120. package/src/user/choose-account.tsx +60 -0
  121. package/src/user/env-vars.ts +46 -0
  122. package/src/user/generate-auth-url.ts +33 -0
  123. package/src/user/generate-random-state.ts +16 -0
  124. package/src/user/index.ts +3 -0
  125. package/src/user/user.tsx +1161 -0
  126. package/src/whoami.tsx +61 -42
  127. package/src/worker-namespace.ts +190 -0
  128. package/src/worker.ts +110 -100
  129. package/src/zones.ts +39 -36
  130. package/templates/checked-fetch.js +17 -0
  131. package/templates/new-worker-scheduled.js +3 -3
  132. package/templates/new-worker-scheduled.ts +15 -15
  133. package/templates/new-worker.js +3 -3
  134. package/templates/new-worker.ts +15 -15
  135. package/templates/no-op-worker.js +10 -0
  136. package/templates/pages-template-plugin.ts +155 -0
  137. package/templates/pages-template-worker.ts +161 -0
  138. package/templates/static-asset-facade.js +31 -31
  139. package/templates/tsconfig.json +95 -95
  140. package/wrangler-dist/cli.js +55383 -54138
  141. package/pages/functions/buildPlugin.ts +0 -105
  142. package/pages/functions/buildWorker.ts +0 -151
  143. package/pages/functions/filepath-routing.ts +0 -189
  144. package/pages/functions/identifiers.ts +0 -78
  145. package/pages/functions/routes.ts +0 -156
  146. package/pages/functions/template-plugin.ts +0 -147
  147. package/pages/functions/template-worker.ts +0 -143
  148. package/src/pages.tsx +0 -2093
  149. package/src/user.tsx +0 -1214
@@ -4,6 +4,7 @@ import { version as wranglerVersion } from "../../package.json";
4
4
  import { getEnvironmentVariableFactory } from "../environment-variables";
5
5
  import { ParseError, parseJSON } from "../parse";
6
6
  import { loginOrRefreshIfRequired, requireApiToken } from "../user";
7
+ import type { ApiCredentials } from "../user";
7
8
  import type { URLSearchParams } from "node:url";
8
9
  import type { RequestInit, HeadersInit } from "undici";
9
10
 
@@ -11,9 +12,9 @@ import type { RequestInit, HeadersInit } from "undici";
11
12
  * Get the URL to use to access the Cloudflare API.
12
13
  */
13
14
  export const getCloudflareAPIBaseURL = getEnvironmentVariableFactory({
14
- variableName: "CLOUDFLARE_API_BASE_URL",
15
- deprecatedName: "CF_API_BASE_URL",
16
- defaultValue: "https://api.cloudflare.com/client/v4",
15
+ variableName: "CLOUDFLARE_API_BASE_URL",
16
+ deprecatedName: "CF_API_BASE_URL",
17
+ defaultValue: "https://api.cloudflare.com/client/v4",
17
18
  });
18
19
 
19
20
  /**
@@ -26,86 +27,91 @@ export const getCloudflareAPIBaseURL = getEnvironmentVariableFactory({
26
27
  * This function should not be used directly, instead use the functions in `cfetch/index.ts`.
27
28
  */
28
29
  export async function fetchInternal<ResponseType>(
29
- resource: string,
30
- init: RequestInit = {},
31
- queryParams?: URLSearchParams,
32
- abortSignal?: AbortSignal
30
+ resource: string,
31
+ init: RequestInit = {},
32
+ queryParams?: URLSearchParams,
33
+ abortSignal?: AbortSignal
33
34
  ): Promise<ResponseType> {
34
- assert(
35
- resource.startsWith("/"),
36
- `CF API fetch - resource path must start with a "/" but got "${resource}"`
37
- );
38
- await requireLoggedIn();
39
- const apiToken = requireApiToken();
40
- const headers = cloneHeaders(init.headers);
41
- addAuthorizationHeaderIfUnspecified(headers, apiToken);
42
- addUserAgent(headers);
35
+ assert(
36
+ resource.startsWith("/"),
37
+ `CF API fetch - resource path must start with a "/" but got "${resource}"`
38
+ );
39
+ await requireLoggedIn();
40
+ const apiToken = requireApiToken();
41
+ const headers = cloneHeaders(init.headers);
42
+ addAuthorizationHeaderIfUnspecified(headers, apiToken);
43
+ addUserAgent(headers);
43
44
 
44
- const queryString = queryParams ? `?${queryParams.toString()}` : "";
45
- const method = init.method ?? "GET";
46
- const response = await fetch(
47
- `${getCloudflareAPIBaseURL()}${resource}${queryString}`,
48
- {
49
- method,
50
- ...init,
51
- headers,
52
- signal: abortSignal,
53
- }
54
- );
55
- const jsonText = await response.text();
56
- try {
57
- return parseJSON<ResponseType>(jsonText);
58
- } catch (err) {
59
- throw new ParseError({
60
- text: "Received a malformed response from the API",
61
- notes: [
62
- {
63
- text: truncate(jsonText, 100),
64
- },
65
- {
66
- text: `${method} ${resource} -> ${response.status} ${response.statusText}`,
67
- },
68
- ],
69
- });
70
- }
45
+ const queryString = queryParams ? `?${queryParams.toString()}` : "";
46
+ const method = init.method ?? "GET";
47
+ const response = await fetch(
48
+ `${getCloudflareAPIBaseURL()}${resource}${queryString}`,
49
+ {
50
+ method,
51
+ ...init,
52
+ headers,
53
+ signal: abortSignal,
54
+ }
55
+ );
56
+ const jsonText = await response.text();
57
+ try {
58
+ return parseJSON<ResponseType>(jsonText);
59
+ } catch (err) {
60
+ throw new ParseError({
61
+ text: "Received a malformed response from the API",
62
+ notes: [
63
+ {
64
+ text: truncate(jsonText, 100),
65
+ },
66
+ {
67
+ text: `${method} ${resource} -> ${response.status} ${response.statusText}`,
68
+ },
69
+ ],
70
+ });
71
+ }
71
72
  }
72
73
 
73
74
  function truncate(text: string, maxLength: number): string {
74
- const { length } = text;
75
- if (length <= maxLength) {
76
- return text;
77
- }
78
- return `${text.substring(0, maxLength)}... (length = ${length})`;
75
+ const { length } = text;
76
+ if (length <= maxLength) {
77
+ return text;
78
+ }
79
+ return `${text.substring(0, maxLength)}... (length = ${length})`;
79
80
  }
80
81
 
81
82
  function cloneHeaders(
82
- headers: HeadersInit | undefined
83
+ headers: HeadersInit | undefined
83
84
  ): Record<string, string> {
84
- return headers instanceof Headers
85
- ? Object.fromEntries(headers.entries())
86
- : Array.isArray(headers)
87
- ? Object.fromEntries(headers)
88
- : { ...headers };
85
+ return headers instanceof Headers
86
+ ? Object.fromEntries(headers.entries())
87
+ : Array.isArray(headers)
88
+ ? Object.fromEntries(headers)
89
+ : { ...headers };
89
90
  }
90
91
 
91
92
  async function requireLoggedIn(): Promise<void> {
92
- const loggedIn = await loginOrRefreshIfRequired();
93
- if (!loggedIn) {
94
- throw new Error("Not logged in.");
95
- }
93
+ const loggedIn = await loginOrRefreshIfRequired();
94
+ if (!loggedIn) {
95
+ throw new Error("Not logged in.");
96
+ }
96
97
  }
97
98
 
98
99
  function addAuthorizationHeaderIfUnspecified(
99
- headers: Record<string, string>,
100
- apiToken: string
100
+ headers: Record<string, string>,
101
+ auth: ApiCredentials
101
102
  ): void {
102
- if (!("Authorization" in headers)) {
103
- headers["Authorization"] = `Bearer ${apiToken}`;
104
- }
103
+ if (!("Authorization" in headers)) {
104
+ if ("apiToken" in auth) {
105
+ headers["Authorization"] = `Bearer ${auth.apiToken}`;
106
+ } else {
107
+ headers["X-Auth-Key"] = auth.authKey;
108
+ headers["X-Auth-Email"] = auth.authEmail;
109
+ }
110
+ }
105
111
  }
106
112
 
107
113
  function addUserAgent(headers: Record<string, string>): void {
108
- headers["User-Agent"] = `wrangler/${wranglerVersion}`;
114
+ headers["User-Agent"] = `wrangler/${wranglerVersion}`;
109
115
  }
110
116
 
111
117
  /**
@@ -120,23 +126,24 @@ function addUserAgent(headers: Record<string, string>): void {
120
126
  */
121
127
 
122
128
  export async function fetchKVGetValue(
123
- accountId: string,
124
- namespaceId: string,
125
- key: string
126
- ): Promise<string> {
127
- await requireLoggedIn();
128
- const apiToken = requireApiToken();
129
- const headers = { Authorization: `Bearer ${apiToken}` };
130
- const resource = `${getCloudflareAPIBaseURL()}/accounts/${accountId}/storage/kv/namespaces/${namespaceId}/values/${key}`;
131
- const response = await fetch(resource, {
132
- method: "GET",
133
- headers,
134
- });
135
- if (response.ok) {
136
- return await response.text();
137
- } else {
138
- throw new Error(
139
- `Failed to fetch ${resource} - ${response.status}: ${response.statusText});`
140
- );
141
- }
129
+ accountId: string,
130
+ namespaceId: string,
131
+ key: string
132
+ ): Promise<ArrayBuffer> {
133
+ await requireLoggedIn();
134
+ const auth = requireApiToken();
135
+ const headers: Record<string, string> = {};
136
+ addAuthorizationHeaderIfUnspecified(headers, auth);
137
+ const resource = `${getCloudflareAPIBaseURL()}/accounts/${accountId}/storage/kv/namespaces/${namespaceId}/values/${key}`;
138
+ const response = await fetch(resource, {
139
+ method: "GET",
140
+ headers,
141
+ });
142
+ if (response.ok) {
143
+ return await response.arrayBuffer();
144
+ } else {
145
+ throw new Error(
146
+ `Failed to fetch ${resource} - ${response.status}: ${response.statusText});`
147
+ );
148
+ }
142
149
  }
package/src/cli.ts CHANGED
@@ -1,13 +1,27 @@
1
1
  import "dotenv/config"; // Grab locally specified env params from a `.env` file.
2
2
  import process from "process";
3
3
  import { hideBin } from "yargs/helpers";
4
+ import { unstable_dev } from "./api";
4
5
  import { FatalError } from "./errors";
5
6
  import { main } from ".";
6
7
 
7
- main(hideBin(process.argv)).catch((e) => {
8
- // The logging of any error that was thrown from `main()` is handled in the `yargs.fail()` handler.
9
- // Here we just want to ensure that the process exits with a non-zero code.
10
- // We don't want to do this inside the `main()` function, since that would kill the process when running our tests.
11
- const exitCode = (e instanceof FatalError && e.code) || 1;
12
- process.exit(exitCode);
13
- });
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) {
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
+ module.exports = { unstable_dev };