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.
- package/README.md +4 -4
- package/bin/wrangler.js +9 -75
- package/package.json +5 -13
- package/templates/__tests__/tsconfig.tsbuildinfo +1 -1
- package/templates/checked-fetch.js +1 -1
- package/templates/first-party-worker-module-facade.ts +2 -2
- package/templates/middleware/common.ts +9 -4
- package/templates/middleware/loader-sw.ts +2 -7
- package/templates/new-worker-scheduled.ts +1 -1
- package/templates/new-worker.ts +1 -1
- package/templates/pages-dev-util.ts +4 -1
- package/templates/pages-shim.ts +0 -3
- package/templates/tsconfig.tsbuildinfo +1 -1
- package/wrangler-dist/cli.d.ts +149 -75
- package/wrangler-dist/cli.js +60062 -64338
- package/import_meta_url.js +0 -3
- package/miniflare-config-stubs/.env.empty +0 -0
- package/miniflare-config-stubs/package.empty.json +0 -1
- package/miniflare-config-stubs/wrangler.empty.toml +0 -0
- package/miniflare-dist/index.mjs +0 -6442
- package/src/__tests__/access.test.ts +0 -25
- package/src/__tests__/api-dev.test.ts +0 -238
- package/src/__tests__/api-devregistry.test.ts +0 -121
- package/src/__tests__/api.test.ts +0 -102
- package/src/__tests__/config-cache-without-cache-dir.test.ts +0 -38
- package/src/__tests__/config-cache.test.ts +0 -42
- package/src/__tests__/configuration.test.ts +0 -4517
- package/src/__tests__/constellation.test.ts +0 -371
- package/src/__tests__/d1/d1.test.ts +0 -82
- package/src/__tests__/d1/execute.test.ts +0 -66
- package/src/__tests__/d1/migrate.test.ts +0 -257
- package/src/__tests__/d1/splitter.test.ts +0 -255
- package/src/__tests__/delete.test.ts +0 -272
- package/src/__tests__/deployments.test.ts +0 -369
- package/src/__tests__/dev.test.tsx +0 -1617
- package/src/__tests__/generate.test.ts +0 -237
- package/src/__tests__/get-host-from-url.test.ts +0 -16
- package/src/__tests__/guess-worker-format.test.ts +0 -120
- package/src/__tests__/helpers/clipboardy-mock.js +0 -4
- package/src/__tests__/helpers/cmd-shim.d.ts +0 -11
- package/src/__tests__/helpers/end-event-loop.ts +0 -6
- package/src/__tests__/helpers/mock-account-id.ts +0 -48
- package/src/__tests__/helpers/mock-auth-domain.ts +0 -20
- package/src/__tests__/helpers/mock-bin.ts +0 -36
- package/src/__tests__/helpers/mock-console.ts +0 -112
- package/src/__tests__/helpers/mock-dialogs.ts +0 -139
- package/src/__tests__/helpers/mock-get-pages-upload-token.ts +0 -25
- package/src/__tests__/helpers/mock-get-zone-from-host.ts +0 -11
- package/src/__tests__/helpers/mock-http-server.ts +0 -46
- package/src/__tests__/helpers/mock-istty.ts +0 -74
- package/src/__tests__/helpers/mock-known-routes.ts +0 -12
- package/src/__tests__/helpers/mock-kv.ts +0 -46
- package/src/__tests__/helpers/mock-oauth-flow.ts +0 -263
- package/src/__tests__/helpers/mock-process.ts +0 -34
- package/src/__tests__/helpers/mock-set-timeout.ts +0 -16
- package/src/__tests__/helpers/mock-stdin.ts +0 -108
- package/src/__tests__/helpers/mock-web-socket.ts +0 -29
- package/src/__tests__/helpers/msw/blob-worker.cjs +0 -19
- package/src/__tests__/helpers/msw/handlers/access.ts +0 -13
- package/src/__tests__/helpers/msw/handlers/deployments.ts +0 -160
- package/src/__tests__/helpers/msw/handlers/namespaces.ts +0 -81
- package/src/__tests__/helpers/msw/handlers/oauth.ts +0 -31
- package/src/__tests__/helpers/msw/handlers/r2.ts +0 -60
- package/src/__tests__/helpers/msw/handlers/script.ts +0 -56
- package/src/__tests__/helpers/msw/handlers/user.ts +0 -52
- package/src/__tests__/helpers/msw/handlers/zones.ts +0 -20
- package/src/__tests__/helpers/msw/index.ts +0 -52
- package/src/__tests__/helpers/msw/read-file-sync.js +0 -61
- package/src/__tests__/helpers/run-in-tmp.ts +0 -38
- package/src/__tests__/helpers/run-wrangler.ts +0 -16
- package/src/__tests__/helpers/string-dynamic-values-matcher.ts +0 -28
- package/src/__tests__/helpers/worker-scripts/child-wrangler.toml +0 -1
- package/src/__tests__/helpers/worker-scripts/hello-world-worker.js +0 -5
- package/src/__tests__/helpers/worker-scripts/hello-world-wrangler.toml +0 -1
- package/src/__tests__/helpers/worker-scripts/parent-worker.js +0 -11
- package/src/__tests__/helpers/worker-scripts/parent-wrangler.toml +0 -5
- package/src/__tests__/helpers/write-worker-source.ts +0 -31
- package/src/__tests__/helpers/write-wrangler-toml.ts +0 -17
- package/src/__tests__/https-options.test.ts +0 -163
- package/src/__tests__/index.test.ts +0 -282
- package/src/__tests__/init.test.ts +0 -3196
- package/src/__tests__/jest.setup.ts +0 -179
- package/src/__tests__/kv.test.ts +0 -1799
- package/src/__tests__/logger.test.ts +0 -207
- package/src/__tests__/logout.test.ts +0 -47
- package/src/__tests__/metrics.test.ts +0 -493
- package/src/__tests__/middleware.scheduled.test.ts +0 -145
- package/src/__tests__/middleware.test.ts +0 -816
- package/src/__tests__/mtls-certificates.test.ts +0 -589
- package/src/__tests__/package-manager.test.ts +0 -353
- package/src/__tests__/pages/deployment-list.test.ts +0 -80
- package/src/__tests__/pages/functions-build.test.ts +0 -528
- package/src/__tests__/pages/pages.test.ts +0 -81
- package/src/__tests__/pages/project-create.test.ts +0 -63
- package/src/__tests__/pages/project-list.test.ts +0 -110
- package/src/__tests__/pages/project-upload.test.ts +0 -500
- package/src/__tests__/pages/publish.test.ts +0 -2864
- package/src/__tests__/pages-deployment-tail.test.ts +0 -957
- package/src/__tests__/parse.test.ts +0 -436
- package/src/__tests__/paths.test.ts +0 -39
- package/src/__tests__/publish.test.ts +0 -8849
- package/src/__tests__/pubsub.test.ts +0 -496
- package/src/__tests__/queues.test.ts +0 -532
- package/src/__tests__/r2.test.ts +0 -374
- package/src/__tests__/route.test.ts +0 -45
- package/src/__tests__/secret.test.ts +0 -693
- package/src/__tests__/tail.test.ts +0 -989
- package/src/__tests__/test-old-node-version.js +0 -31
- package/src/__tests__/traverse-module-graph.test.ts +0 -220
- package/src/__tests__/tsconfig-sanity.ts +0 -12
- package/src/__tests__/tsconfig.json +0 -8
- package/src/__tests__/tsconfig.tsbuildinfo +0 -1
- package/src/__tests__/type-generation.test.ts +0 -234
- package/src/__tests__/user.test.ts +0 -118
- package/src/__tests__/utils-collectKeyValues.test.ts +0 -47
- package/src/__tests__/validate-dev-props.test.ts +0 -56
- package/src/__tests__/version.test.ts +0 -35
- package/src/__tests__/whoami.test.tsx +0 -172
- package/src/__tests__/worker-namespace.test.ts +0 -340
- package/src/abort.d.ts +0 -3
- package/src/api/dev.ts +0 -321
- package/src/api/index.ts +0 -11
- package/src/api/mtls-certificate.ts +0 -148
- package/src/api/pages/create-worker-bundle-contents.ts +0 -77
- package/src/api/pages/index.ts +0 -5
- package/src/api/pages/publish.tsx +0 -371
- package/src/bundle-reporter.ts +0 -68
- package/src/bundle.ts +0 -929
- package/src/cfetch/index.ts +0 -158
- package/src/cfetch/internal.ts +0 -258
- package/src/cli.ts +0 -28
- package/src/config/README.md +0 -107
- package/src/config/config.ts +0 -282
- package/src/config/diagnostics.ts +0 -80
- package/src/config/environment.ts +0 -625
- package/src/config/index.ts +0 -403
- package/src/config/validation-helpers.ts +0 -597
- package/src/config/validation.ts +0 -2369
- package/src/config-cache.ts +0 -85
- package/src/constellation/createProject.tsx +0 -51
- package/src/constellation/deleteProject.ts +0 -51
- package/src/constellation/deleteProjectModel.ts +0 -68
- package/src/constellation/index.ts +0 -75
- package/src/constellation/listCatalog.tsx +0 -35
- package/src/constellation/listModel.tsx +0 -41
- package/src/constellation/listProject.tsx +0 -28
- package/src/constellation/listRuntime.tsx +0 -28
- package/src/constellation/options.ts +0 -17
- package/src/constellation/types.ts +0 -17
- package/src/constellation/uploadModel.tsx +0 -64
- package/src/constellation/utils.ts +0 -90
- package/src/create-worker-preview.ts +0 -293
- package/src/create-worker-upload-form.ts +0 -363
- package/src/d1/backups.tsx +0 -219
- package/src/d1/constants.ts +0 -2
- package/src/d1/create.tsx +0 -70
- package/src/d1/delete.ts +0 -53
- package/src/d1/execute.tsx +0 -357
- package/src/d1/formatTimeAgo.ts +0 -14
- package/src/d1/index.ts +0 -100
- package/src/d1/list.tsx +0 -62
- package/src/d1/migrations/apply.tsx +0 -212
- package/src/d1/migrations/create.tsx +0 -79
- package/src/d1/migrations/helpers.ts +0 -169
- package/src/d1/migrations/index.ts +0 -3
- package/src/d1/migrations/list.tsx +0 -95
- package/src/d1/migrations/options.ts +0 -23
- package/src/d1/options.ts +0 -22
- package/src/d1/splitter.ts +0 -161
- package/src/d1/types.ts +0 -25
- package/src/d1/utils.ts +0 -49
- package/src/delete.ts +0 -100
- package/src/deployments.ts +0 -368
- package/src/deprecated/index.ts +0 -144
- package/src/dev/dev-vars.ts +0 -39
- package/src/dev/dev.tsx +0 -605
- package/src/dev/get-local-persistence-path.ts +0 -31
- package/src/dev/local.tsx +0 -952
- package/src/dev/remote.tsx +0 -635
- package/src/dev/start-server.ts +0 -545
- package/src/dev/use-esbuild.ts +0 -215
- package/src/dev/validate-dev-props.ts +0 -40
- package/src/dev-registry.ts +0 -202
- package/src/dev.tsx +0 -934
- package/src/dialogs.ts +0 -136
- package/src/dispatch-namespace.ts +0 -211
- package/src/docs/helpers.ts +0 -50
- package/src/docs/index.ts +0 -54
- package/src/durable.ts +0 -102
- package/src/entry.ts +0 -344
- package/src/environment-variables/factory.ts +0 -89
- package/src/environment-variables/misc-variables.ts +0 -30
- package/src/errors.ts +0 -11
- package/src/generate/index.ts +0 -298
- package/src/git-client.ts +0 -135
- package/src/global-wrangler-config-path.ts +0 -26
- package/src/https-options.ts +0 -127
- package/src/index.ts +0 -768
- package/src/init.ts +0 -1037
- package/src/inspect.ts +0 -883
- package/src/intl-polyfill.d.ts +0 -139
- package/src/is-ci.ts +0 -14
- package/src/is-interactive.ts +0 -16
- package/src/jest.d.ts +0 -4
- package/src/kv/helpers.ts +0 -433
- package/src/kv/index.ts +0 -594
- package/src/logger.ts +0 -123
- package/src/metrics/index.ts +0 -5
- package/src/metrics/metrics-config.ts +0 -239
- package/src/metrics/metrics-dispatcher.ts +0 -96
- package/src/metrics/metrics-usage-headers.ts +0 -24
- package/src/metrics/send-event.ts +0 -99
- package/src/miniflare-cli/README.md +0 -30
- package/src/miniflare-cli/assets.ts +0 -251
- package/src/miniflare-cli/index.ts +0 -210
- package/src/miniflare-cli/request-context.ts +0 -40
- package/src/miniflare-cli/tsconfig.json +0 -9
- package/src/miniflare-cli/tsconfig.tsbuildinfo +0 -1
- package/src/miniflare-cli/types.ts +0 -11
- package/src/module-collection.ts +0 -333
- package/src/mtls-certificate/cli.ts +0 -155
- package/src/open-in-browser.ts +0 -17
- package/src/package-manager.ts +0 -219
- package/src/pages/build.ts +0 -423
- package/src/pages/buildFunctions.ts +0 -140
- package/src/pages/constants.ts +0 -18
- package/src/pages/deployment-tails.ts +0 -281
- package/src/pages/deployments.tsx +0 -84
- package/src/pages/dev.ts +0 -734
- package/src/pages/errors.ts +0 -67
- package/src/pages/functions/buildPlugin.ts +0 -114
- package/src/pages/functions/buildWorker.ts +0 -350
- package/src/pages/functions/filepath-routing.test.ts +0 -234
- package/src/pages/functions/filepath-routing.ts +0 -189
- package/src/pages/functions/identifiers.ts +0 -78
- package/src/pages/functions/routes-consolidation.test.ts +0 -250
- package/src/pages/functions/routes-consolidation.ts +0 -73
- package/src/pages/functions/routes-transformation.test.ts +0 -282
- package/src/pages/functions/routes-transformation.ts +0 -115
- package/src/pages/functions/routes-validation.test.ts +0 -403
- package/src/pages/functions/routes-validation.ts +0 -202
- package/src/pages/functions/routes.ts +0 -151
- package/src/pages/functions/tsconfig.json +0 -8
- package/src/pages/functions/tsconfig.tsbuildinfo +0 -1
- package/src/pages/functions.ts +0 -86
- package/src/pages/hash.ts +0 -13
- package/src/pages/index.ts +0 -102
- package/src/pages/projects.tsx +0 -159
- package/src/pages/prompt-select-project.tsx +0 -31
- package/src/pages/publish.tsx +0 -267
- package/src/pages/types.ts +0 -46
- package/src/pages/upload.tsx +0 -469
- package/src/pages/utils.ts +0 -23
- package/src/parse.ts +0 -308
- package/src/paths.ts +0 -71
- package/src/proxy.ts +0 -694
- package/src/publish/index.ts +0 -274
- package/src/publish/publish.ts +0 -1065
- package/src/pubsub/index.ts +0 -286
- package/src/pubsub/pubsub-commands.ts +0 -623
- package/src/queues/cli/commands/consumer/add.ts +0 -71
- package/src/queues/cli/commands/consumer/index.ts +0 -19
- package/src/queues/cli/commands/consumer/remove.ts +0 -31
- package/src/queues/cli/commands/create.ts +0 -25
- package/src/queues/cli/commands/delete.ts +0 -26
- package/src/queues/cli/commands/index.ts +0 -35
- package/src/queues/cli/commands/list.ts +0 -25
- package/src/queues/client.ts +0 -136
- package/src/queues/utils.ts +0 -18
- package/src/r2/constants.ts +0 -4
- package/src/r2/helpers.ts +0 -132
- package/src/r2/index.ts +0 -289
- package/src/routes.ts +0 -140
- package/src/secret/index.ts +0 -377
- package/src/selfsigned.d.ts +0 -29
- package/src/sites.ts +0 -484
- package/src/tail/createTail.ts +0 -415
- package/src/tail/filters.ts +0 -277
- package/src/tail/index.ts +0 -211
- package/src/tail/printing.ts +0 -132
- package/src/traverse-module-graph.ts +0 -54
- package/src/tsconfig-sanity.ts +0 -16
- package/src/type-generation.ts +0 -181
- package/src/update-check.ts +0 -19
- package/src/user/access.ts +0 -68
- package/src/user/auth-variables.ts +0 -113
- package/src/user/choose-account.tsx +0 -39
- package/src/user/generate-auth-url.ts +0 -33
- package/src/user/generate-random-state.ts +0 -16
- package/src/user/index.ts +0 -2
- package/src/user/user.ts +0 -1234
- package/src/utils/collectKeyValues.ts +0 -14
- package/src/utils/render.ts +0 -93
- package/src/whoami.ts +0 -135
- package/src/worker.ts +0 -279
- package/src/yargs-types.ts +0 -37
- package/src/zones.ts +0 -191
package/src/cfetch/index.ts
DELETED
|
@@ -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
|
-
}
|
package/src/cfetch/internal.ts
DELETED
|
@@ -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 };
|
package/src/config/README.md
DELETED
|
@@ -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.
|