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,42 @@
|
|
|
1
|
+
import { execa } from "execa";
|
|
2
|
+
import { findUp } from "find-up";
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Check whether the given current working directory is within a git repository
|
|
6
|
+
* by looking for a `.git` directory in this or an ancestor directory.
|
|
7
|
+
*/
|
|
8
|
+
export async function isInsideGitRepo(cwd: string) {
|
|
9
|
+
const res = await findUp(".git", { cwd, type: "directory" });
|
|
10
|
+
return res !== undefined;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Check whether git is installed by trying to run it.
|
|
15
|
+
*/
|
|
16
|
+
export async function isGitInstalled() {
|
|
17
|
+
try {
|
|
18
|
+
return (await execa("git", ["--version"])).exitCode === 0;
|
|
19
|
+
} catch (err) {
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* Initialize a new Worker project with a git repository.
|
|
26
|
+
*
|
|
27
|
+
* We want the branch to be called `main` but earlier versions of git do not support `--initial-branch`.
|
|
28
|
+
* If that is the case then we just fallback to the default initial branch name.
|
|
29
|
+
*/
|
|
30
|
+
export async function initializeGit(cwd: string) {
|
|
31
|
+
try {
|
|
32
|
+
// Try to create the repository with the HEAD branch of `main`.
|
|
33
|
+
await execa("git", ["init", "--initial-branch", "main"], {
|
|
34
|
+
cwd,
|
|
35
|
+
});
|
|
36
|
+
} catch {
|
|
37
|
+
// Unable to create the repo with a HEAD branch name, so just fall back to the default.
|
|
38
|
+
await execa("git", ["init"], {
|
|
39
|
+
cwd,
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
}
|
package/src/https-options.ts
CHANGED
|
@@ -17,36 +17,36 @@ const ONE_DAY_IN_MS = 86400000;
|
|
|
17
17
|
* The certificates are self-signed and generated locally, and cached in the `CERT_ROOT` directory.
|
|
18
18
|
*/
|
|
19
19
|
export async function getHttpsOptions() {
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
20
|
+
const certDirectory = path.join(homedir(), ".wrangler/local-cert");
|
|
21
|
+
const keyPath = path.join(certDirectory, "key.pem");
|
|
22
|
+
const certPath = path.join(certDirectory, "cert.pem");
|
|
23
23
|
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
24
|
+
const regenerate =
|
|
25
|
+
!fs.existsSync(keyPath) ||
|
|
26
|
+
!fs.existsSync(certPath) ||
|
|
27
|
+
hasCertificateExpired(keyPath, certPath);
|
|
28
28
|
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
29
|
+
if (regenerate) {
|
|
30
|
+
logger.log("Generating new self-signed certificate...");
|
|
31
|
+
const { key, cert } = await generateCertificate();
|
|
32
|
+
try {
|
|
33
|
+
// Write certificate files so we can reuse them later.
|
|
34
|
+
fs.mkdirSync(certDirectory, { recursive: true });
|
|
35
|
+
fs.writeFileSync(keyPath, key, "utf8");
|
|
36
|
+
fs.writeFileSync(certPath, cert, "utf8");
|
|
37
|
+
} catch (e) {
|
|
38
|
+
const message = e instanceof Error ? e.message : `${e}`;
|
|
39
|
+
logger.warn(
|
|
40
|
+
`Unable to cache generated self-signed certificate in ${certDirectory}.\n${message}`
|
|
41
|
+
);
|
|
42
|
+
}
|
|
43
|
+
return { key, cert };
|
|
44
|
+
} else {
|
|
45
|
+
return {
|
|
46
|
+
key: fs.readFileSync(keyPath, "utf8"),
|
|
47
|
+
cert: fs.readFileSync(certPath, "utf8"),
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
50
|
}
|
|
51
51
|
|
|
52
52
|
/**
|
|
@@ -54,70 +54,70 @@ export async function getHttpsOptions() {
|
|
|
54
54
|
* have expired based on the date when they were last modified.
|
|
55
55
|
*/
|
|
56
56
|
function hasCertificateExpired(keyPath: string, certPath: string): boolean {
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
57
|
+
const keyStat = fs.statSync(keyPath);
|
|
58
|
+
const certStat = fs.statSync(certPath);
|
|
59
|
+
const created = Math.max(keyStat.mtimeMs, certStat.mtimeMs);
|
|
60
|
+
return Date.now() - created > (CERT_EXPIRY_DAYS - 2) * ONE_DAY_IN_MS;
|
|
61
61
|
}
|
|
62
62
|
|
|
63
63
|
/**
|
|
64
64
|
* Generate a new self-signed certificate and cache it in `CERT_ROOT` directory.
|
|
65
65
|
*/
|
|
66
66
|
async function generateCertificate() {
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
67
|
+
// `selfsigned` imports `node-forge`, which is a pretty big library.
|
|
68
|
+
// To reduce startup time, only load this dynamically when needed.
|
|
69
|
+
// eslint-disable-next-line @typescript-eslint/consistent-type-imports
|
|
70
|
+
const generate: typeof import("selfsigned").generate = promisify(
|
|
71
|
+
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
72
|
+
require("selfsigned").generate
|
|
73
|
+
);
|
|
74
74
|
|
|
75
|
-
|
|
75
|
+
const certAttrs: Attributes = [{ name: "commonName", value: "localhost" }];
|
|
76
76
|
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
77
|
+
const certOptions: Options = {
|
|
78
|
+
algorithm: "sha256",
|
|
79
|
+
days: CERT_EXPIRY_DAYS,
|
|
80
|
+
keySize: 2048,
|
|
81
|
+
extensions: [
|
|
82
|
+
{ name: "basicConstraints", cA: true },
|
|
83
|
+
{
|
|
84
|
+
name: "keyUsage",
|
|
85
|
+
keyCertSign: true,
|
|
86
|
+
digitalSignature: true,
|
|
87
|
+
nonRepudiation: true,
|
|
88
|
+
keyEncipherment: true,
|
|
89
|
+
dataEncipherment: true,
|
|
90
|
+
},
|
|
91
|
+
{
|
|
92
|
+
name: "extKeyUsage",
|
|
93
|
+
serverAuth: true,
|
|
94
|
+
clientAuth: true,
|
|
95
|
+
codeSigning: true,
|
|
96
|
+
timeStamping: true,
|
|
97
|
+
},
|
|
98
|
+
{
|
|
99
|
+
name: "subjectAltName",
|
|
100
|
+
altNames: [
|
|
101
|
+
{ type: 2, value: "localhost" },
|
|
102
|
+
...getAccessibleHosts().map((ip) => ({ type: 7, ip })),
|
|
103
|
+
],
|
|
104
|
+
},
|
|
105
|
+
],
|
|
106
|
+
};
|
|
107
107
|
|
|
108
|
-
|
|
109
|
-
|
|
108
|
+
const { private: key, cert } = await generate(certAttrs, certOptions);
|
|
109
|
+
return { key, cert };
|
|
110
110
|
}
|
|
111
111
|
|
|
112
112
|
/**
|
|
113
113
|
* Ask the OS for the addresses of locally accessible hosts.
|
|
114
114
|
*/
|
|
115
115
|
function getAccessibleHosts(ipv4 = false): string[] {
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
116
|
+
const hosts: string[] = [];
|
|
117
|
+
Object.values(networkInterfaces()).forEach((net) =>
|
|
118
|
+
net?.forEach(({ family, address }) => {
|
|
119
|
+
if (!ipv4 || family === "IPv4") hosts.push(address);
|
|
120
|
+
})
|
|
121
|
+
);
|
|
122
|
+
return hosts;
|
|
123
123
|
}
|