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.
- package/README.md +7 -1
- package/bin/wrangler.js +111 -57
- package/miniflare-dist/index.mjs +9 -2
- package/package.json +156 -154
- package/src/__tests__/config-cache-without-cache-dir.test.ts +38 -0
- package/src/__tests__/config-cache.test.ts +30 -24
- package/src/__tests__/configuration.test.ts +3935 -3476
- package/src/__tests__/dev.test.tsx +1128 -979
- package/src/__tests__/guess-worker-format.test.ts +68 -68
- package/src/__tests__/helpers/cmd-shim.d.ts +6 -6
- package/src/__tests__/helpers/faye-websocket.d.ts +4 -4
- package/src/__tests__/helpers/mock-account-id.ts +24 -24
- package/src/__tests__/helpers/mock-bin.ts +20 -20
- package/src/__tests__/helpers/mock-cfetch.ts +92 -92
- package/src/__tests__/helpers/mock-console.ts +49 -39
- package/src/__tests__/helpers/mock-dialogs.ts +94 -71
- package/src/__tests__/helpers/mock-http-server.ts +30 -30
- package/src/__tests__/helpers/mock-istty.ts +65 -18
- package/src/__tests__/helpers/mock-kv.ts +26 -26
- package/src/__tests__/helpers/mock-oauth-flow.ts +223 -228
- package/src/__tests__/helpers/mock-process.ts +39 -0
- package/src/__tests__/helpers/mock-stdin.ts +82 -77
- package/src/__tests__/helpers/mock-web-socket.ts +21 -21
- package/src/__tests__/helpers/run-in-tmp.ts +27 -27
- package/src/__tests__/helpers/run-wrangler.ts +8 -8
- package/src/__tests__/helpers/write-worker-source.ts +16 -16
- package/src/__tests__/helpers/write-wrangler-toml.ts +9 -9
- package/src/__tests__/https-options.test.ts +104 -104
- package/src/__tests__/index.test.ts +239 -234
- package/src/__tests__/init.test.ts +1605 -1250
- package/src/__tests__/jest.setup.ts +63 -33
- package/src/__tests__/kv.test.ts +1128 -1011
- package/src/__tests__/logger.test.ts +100 -74
- package/src/__tests__/package-manager.test.ts +303 -303
- package/src/__tests__/pages.test.ts +1152 -652
- package/src/__tests__/parse.test.ts +252 -252
- package/src/__tests__/publish.test.ts +6371 -5622
- package/src/__tests__/pubsub.test.ts +367 -0
- package/src/__tests__/r2.test.ts +133 -133
- package/src/__tests__/route.test.ts +18 -18
- package/src/__tests__/secret.test.ts +382 -377
- package/src/__tests__/tail.test.ts +530 -530
- package/src/__tests__/user.test.ts +123 -111
- package/src/__tests__/whoami.test.tsx +198 -117
- package/src/__tests__/worker-namespace.test.ts +327 -0
- package/src/abort.d.ts +1 -1
- package/src/api/dev.ts +49 -0
- package/src/api/index.ts +1 -0
- package/src/bundle-reporter.tsx +29 -0
- package/src/bundle.ts +157 -149
- package/src/cfetch/index.ts +80 -80
- package/src/cfetch/internal.ts +90 -83
- package/src/cli.ts +21 -7
- package/src/config/config.ts +204 -195
- package/src/config/diagnostics.ts +61 -61
- package/src/config/environment.ts +390 -357
- package/src/config/index.ts +206 -193
- package/src/config/validation-helpers.ts +366 -366
- package/src/config/validation.ts +1573 -1376
- package/src/config-cache.ts +79 -41
- package/src/create-worker-preview.ts +206 -136
- package/src/create-worker-upload-form.ts +247 -238
- package/src/dev/dev-vars.ts +13 -13
- package/src/dev/dev.tsx +329 -307
- package/src/dev/local.tsx +304 -275
- package/src/dev/remote.tsx +366 -224
- package/src/dev/use-esbuild.ts +126 -91
- package/src/dev.tsx +538 -0
- package/src/dialogs.tsx +97 -97
- package/src/durable.ts +87 -87
- package/src/entry.ts +234 -228
- package/src/environment-variables.ts +23 -23
- package/src/errors.ts +6 -6
- package/src/generate.ts +33 -0
- package/src/git-client.ts +42 -0
- package/src/https-options.ts +79 -79
- package/src/index.tsx +1775 -2763
- package/src/init.ts +549 -0
- package/src/inspect.ts +593 -593
- package/src/intl-polyfill.d.ts +123 -123
- package/src/is-interactive.ts +12 -0
- package/src/kv.ts +277 -277
- package/src/logger.ts +46 -39
- package/src/miniflare-cli/enum-keys.ts +8 -8
- package/src/miniflare-cli/index.ts +42 -31
- package/src/miniflare-cli/request-context.ts +18 -18
- package/src/module-collection.ts +212 -212
- package/src/open-in-browser.ts +4 -6
- package/src/package-manager.ts +123 -123
- package/src/pages/build.tsx +202 -0
- package/src/pages/constants.ts +7 -0
- package/src/pages/deployments.tsx +101 -0
- package/src/pages/dev.tsx +964 -0
- package/src/pages/functions/buildPlugin.ts +105 -0
- package/src/pages/functions/buildWorker.ts +151 -0
- package/{pages → src/pages}/functions/filepath-routing.test.ts +113 -113
- package/src/pages/functions/filepath-routing.ts +189 -0
- package/src/pages/functions/identifiers.ts +78 -0
- package/src/pages/functions/routes.ts +151 -0
- package/src/pages/index.tsx +84 -0
- package/src/pages/projects.tsx +157 -0
- package/src/pages/publish.tsx +335 -0
- package/src/pages/types.ts +40 -0
- package/src/pages/upload.tsx +384 -0
- package/src/pages/utils.ts +12 -0
- package/src/parse.ts +202 -138
- package/src/paths.ts +6 -6
- package/src/preview.ts +31 -0
- package/src/proxy.ts +400 -402
- package/src/publish.ts +667 -621
- package/src/pubsub/index.ts +286 -0
- package/src/pubsub/pubsub-commands.tsx +577 -0
- package/src/r2.ts +19 -19
- package/src/selfsigned.d.ts +23 -23
- package/src/sites.tsx +271 -225
- package/src/tail/filters.ts +108 -108
- package/src/tail/index.ts +217 -217
- package/src/tail/printing.ts +45 -45
- package/src/update-check.ts +11 -11
- package/src/user/choose-account.tsx +60 -0
- package/src/user/env-vars.ts +46 -0
- package/src/user/generate-auth-url.ts +33 -0
- package/src/user/generate-random-state.ts +16 -0
- package/src/user/index.ts +3 -0
- package/src/user/user.tsx +1161 -0
- package/src/whoami.tsx +61 -42
- package/src/worker-namespace.ts +190 -0
- package/src/worker.ts +110 -100
- package/src/zones.ts +39 -36
- package/templates/checked-fetch.js +17 -0
- package/templates/new-worker-scheduled.js +3 -3
- package/templates/new-worker-scheduled.ts +15 -15
- package/templates/new-worker.js +3 -3
- package/templates/new-worker.ts +15 -15
- package/templates/no-op-worker.js +10 -0
- package/templates/pages-template-plugin.ts +155 -0
- package/templates/pages-template-worker.ts +161 -0
- package/templates/static-asset-facade.js +31 -31
- package/templates/tsconfig.json +95 -95
- package/wrangler-dist/cli.js +55383 -54138
- package/pages/functions/buildPlugin.ts +0 -105
- package/pages/functions/buildWorker.ts +0 -151
- package/pages/functions/filepath-routing.ts +0 -189
- package/pages/functions/identifiers.ts +0 -78
- package/pages/functions/routes.ts +0 -156
- package/pages/functions/template-plugin.ts +0 -147
- package/pages/functions/template-worker.ts +0 -143
- package/src/pages.tsx +0 -2093
- 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
|
+
}
|