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
@@ -0,0 +1,60 @@
1
+ import { Text } from "ink";
2
+ import SelectInput from "ink-select-input";
3
+ import React from "react";
4
+ import { fetchListResult } from "../cfetch";
5
+ import { logger } from "../logger";
6
+ import { getCloudflareAccountIdFromEnv } from "./env-vars";
7
+
8
+ export type ChooseAccountItem = {
9
+ id: string;
10
+ name: string;
11
+ };
12
+
13
+ /**
14
+ * A component that allows the user to select from a list of available accounts.
15
+ */
16
+ export function ChooseAccount(props: {
17
+ accounts: ChooseAccountItem[];
18
+ onSelect: (account: { name: string; id: string }) => void;
19
+ onError: (error: Error) => void;
20
+ }) {
21
+ return (
22
+ <>
23
+ <Text bold>Select an account from below:</Text>
24
+ <SelectInput
25
+ items={props.accounts.map((item) => ({
26
+ key: item.id,
27
+ label: item.name,
28
+ value: item,
29
+ }))}
30
+ onSelect={(item) => {
31
+ logger.log(`Using account: "${item.value.name} - ${item.value.id}"`);
32
+ props.onSelect({ id: item.value.id, name: item.value.name });
33
+ }}
34
+ />
35
+ </>
36
+ );
37
+ }
38
+
39
+ /**
40
+ * Infer a list of available accounts for the current user.
41
+ */
42
+ export async function getAccountChoices(): Promise<ChooseAccountItem[]> {
43
+ const accountIdFromEnv = getCloudflareAccountIdFromEnv();
44
+ if (accountIdFromEnv) {
45
+ return [{ id: accountIdFromEnv, name: "" }];
46
+ } else {
47
+ const response = await fetchListResult<{
48
+ account: ChooseAccountItem;
49
+ }>(`/memberships`);
50
+ const accounts = response.map((r) => r.account);
51
+ if (accounts.length === 0) {
52
+ throw new Error(
53
+ "Failed to automatically retrieve account IDs for the logged in user.\n" +
54
+ "In a non-interactive environment, it is mandatory to specify an account ID, either by assigning its value to CLOUDFLARE_ACCOUNT_ID, or as `account_id` in your `wrangler.toml` file."
55
+ );
56
+ } else {
57
+ return accounts;
58
+ }
59
+ }
60
+ }
@@ -0,0 +1,46 @@
1
+ import { getEnvironmentVariableFactory } from "../environment-variables";
2
+
3
+ export type ApiCredentials =
4
+ | {
5
+ apiToken: string;
6
+ }
7
+ | {
8
+ authKey: string;
9
+ authEmail: string;
10
+ };
11
+
12
+ const getCloudflareAPITokenFromEnv = getEnvironmentVariableFactory({
13
+ variableName: "CLOUDFLARE_API_TOKEN",
14
+ deprecatedName: "CF_API_TOKEN",
15
+ });
16
+ const getCloudflareGlobalAuthKeyFromEnv = getEnvironmentVariableFactory({
17
+ variableName: "CLOUDFLARE_API_KEY",
18
+ deprecatedName: "CF_API_KEY",
19
+ });
20
+ const getCloudflareGlobalAuthEmailFromEnv = getEnvironmentVariableFactory({
21
+ variableName: "CLOUDFLARE_EMAIL",
22
+ deprecatedName: "CF_EMAIL",
23
+ });
24
+
25
+ /**
26
+ * Try to read an API token or Global Auth from the environment.
27
+ */
28
+ export function getAuthFromEnv(): ApiCredentials | undefined {
29
+ const globalApiKey = getCloudflareGlobalAuthKeyFromEnv();
30
+ const globalApiEmail = getCloudflareGlobalAuthEmailFromEnv();
31
+ const apiToken = getCloudflareAPITokenFromEnv();
32
+
33
+ if (globalApiKey && globalApiEmail) {
34
+ return { authKey: globalApiKey, authEmail: globalApiEmail };
35
+ } else if (apiToken) {
36
+ return { apiToken };
37
+ }
38
+ }
39
+
40
+ /**
41
+ * Try to read the account ID from the environment.
42
+ */
43
+ export const getCloudflareAccountIdFromEnv = getEnvironmentVariableFactory({
44
+ variableName: "CLOUDFLARE_ACCOUNT_ID",
45
+ deprecatedName: "CF_ACCOUNT_ID",
46
+ });
@@ -0,0 +1,33 @@
1
+ interface GenerateAuthUrlProps {
2
+ authUrl: string;
3
+ clientId: string;
4
+ callbackUrl: string;
5
+ scopes: string[];
6
+ stateQueryParam: string;
7
+ codeChallenge: string;
8
+ }
9
+
10
+ /**
11
+ * generateAuthUrl was extracted from getAuthURL in user.tsx
12
+ * to make it possible to mock the generated URL
13
+ */
14
+ export const generateAuthUrl = ({
15
+ authUrl,
16
+ clientId,
17
+ callbackUrl,
18
+ scopes,
19
+ stateQueryParam,
20
+ codeChallenge,
21
+ }: GenerateAuthUrlProps) => {
22
+ return (
23
+ authUrl +
24
+ `?response_type=code&` +
25
+ `client_id=${encodeURIComponent(clientId)}&` +
26
+ `redirect_uri=${encodeURIComponent(callbackUrl)}&` +
27
+ // we add offline_access manually for every request
28
+ `scope=${encodeURIComponent([...scopes, "offline_access"].join(" "))}&` +
29
+ `state=${stateQueryParam}&` +
30
+ `code_challenge=${encodeURIComponent(codeChallenge)}&` +
31
+ `code_challenge_method=S256`
32
+ );
33
+ };
@@ -0,0 +1,16 @@
1
+ import { webcrypto as crypto } from "node:crypto";
2
+ import { PKCE_CHARSET } from "../user";
3
+
4
+ /**
5
+ * Generates random state to be passed for anti-csrf.
6
+ * extracted from user.tsx to make it possible to
7
+ * mock the generated URL
8
+ */
9
+ export function generateRandomState(lengthOfState: number): string {
10
+ const output = new Uint32Array(lengthOfState);
11
+ // @ts-expect-error crypto's types aren't there yet
12
+ crypto.getRandomValues(output);
13
+ return Array.from(output)
14
+ .map((num: number) => PKCE_CHARSET[num % PKCE_CHARSET.length])
15
+ .join("");
16
+ }
@@ -0,0 +1,3 @@
1
+ export * from "./user";
2
+ export * from "./env-vars";
3
+ export * from "./choose-account";