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
package/src/cfetch/internal.ts
CHANGED
|
@@ -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
|
-
|
|
15
|
-
|
|
16
|
-
|
|
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
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
30
|
+
resource: string,
|
|
31
|
+
init: RequestInit = {},
|
|
32
|
+
queryParams?: URLSearchParams,
|
|
33
|
+
abortSignal?: AbortSignal
|
|
33
34
|
): Promise<ResponseType> {
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
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
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
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
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
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
|
-
|
|
83
|
+
headers: HeadersInit | undefined
|
|
83
84
|
): Record<string, string> {
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
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
|
-
|
|
93
|
-
|
|
94
|
-
|
|
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
|
-
|
|
100
|
-
|
|
100
|
+
headers: Record<string, string>,
|
|
101
|
+
auth: ApiCredentials
|
|
101
102
|
): void {
|
|
102
|
-
|
|
103
|
-
|
|
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
|
-
|
|
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
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
): Promise<
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
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
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
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 };
|