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/generate/index.ts
DELETED
|
@@ -1,298 +0,0 @@
|
|
|
1
|
-
import fs from "node:fs";
|
|
2
|
-
import path from "node:path";
|
|
3
|
-
import { cloneIntoDirectory, initializeGit } from "../git-client";
|
|
4
|
-
import { CommandLineArgsError, printWranglerBanner } from "../index";
|
|
5
|
-
import { initHandler } from "../init";
|
|
6
|
-
import { logger } from "../logger";
|
|
7
|
-
import type {
|
|
8
|
-
CommonYargsArgv,
|
|
9
|
-
StrictYargsOptionsToInterface,
|
|
10
|
-
} from "../yargs-types";
|
|
11
|
-
|
|
12
|
-
export function generateOptions(yargs: CommonYargsArgv) {
|
|
13
|
-
return yargs
|
|
14
|
-
.positional("name", {
|
|
15
|
-
describe: "Name of the Workers project",
|
|
16
|
-
type: "string",
|
|
17
|
-
demandOption: true,
|
|
18
|
-
})
|
|
19
|
-
.positional("template", {
|
|
20
|
-
type: "string",
|
|
21
|
-
describe: "The URL of a GitHub template",
|
|
22
|
-
})
|
|
23
|
-
.option("type", {
|
|
24
|
-
alias: "t",
|
|
25
|
-
type: "string",
|
|
26
|
-
hidden: true,
|
|
27
|
-
deprecated: true,
|
|
28
|
-
})
|
|
29
|
-
.option("site", {
|
|
30
|
-
alias: "s",
|
|
31
|
-
type: "boolean",
|
|
32
|
-
hidden: true,
|
|
33
|
-
deprecated: true,
|
|
34
|
-
});
|
|
35
|
-
}
|
|
36
|
-
type GenerateArgs = StrictYargsOptionsToInterface<typeof generateOptions>;
|
|
37
|
-
|
|
38
|
-
// Originally, generate was a rust function: https://github.com/cloudflare/wrangler-legacy/blob/master/src/cli/mod.rs#L106-L123
|
|
39
|
-
export async function generateHandler(args: GenerateArgs) {
|
|
40
|
-
// somehow, `init` marks name as required but then also runs fine
|
|
41
|
-
// with the name omitted, and then substitutes it at runtime with ""
|
|
42
|
-
// delegate to `wrangler init` if no template is specified
|
|
43
|
-
if (args.template === undefined) {
|
|
44
|
-
return initHandler({
|
|
45
|
-
name: args.name,
|
|
46
|
-
site: undefined,
|
|
47
|
-
yes: undefined,
|
|
48
|
-
fromDash: undefined,
|
|
49
|
-
v: undefined,
|
|
50
|
-
config: undefined,
|
|
51
|
-
env: undefined,
|
|
52
|
-
type: undefined,
|
|
53
|
-
_: args._,
|
|
54
|
-
$0: args.$0,
|
|
55
|
-
experimentalJsonConfig: false,
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
// print down here cuz `init` prints it own its own
|
|
60
|
-
await printWranglerBanner();
|
|
61
|
-
|
|
62
|
-
if (args.type) {
|
|
63
|
-
let message = "The --type option is no longer supported.";
|
|
64
|
-
if (args.type === "webpack") {
|
|
65
|
-
message +=
|
|
66
|
-
"\nIf you wish to use webpack then you will need to create a custom build.";
|
|
67
|
-
// TODO: Add a link to docs
|
|
68
|
-
}
|
|
69
|
-
throw new CommandLineArgsError(message);
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
if (args.name && isRemote(args.name)) {
|
|
73
|
-
[args.template, args.name] = [args.name, args.template];
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
const creationDirectory = generateWorkerDirectoryName(args.name);
|
|
77
|
-
|
|
78
|
-
if (args.site) {
|
|
79
|
-
const gitDirectory =
|
|
80
|
-
creationDirectory !== process.cwd()
|
|
81
|
-
? path.basename(creationDirectory)
|
|
82
|
-
: "my-site";
|
|
83
|
-
const message =
|
|
84
|
-
"The --site option is no longer supported.\n" +
|
|
85
|
-
"If you wish to create a brand new Worker Sites project then clone the `worker-sites-template` starter repository:\n\n" +
|
|
86
|
-
"```\n" +
|
|
87
|
-
`git clone --depth=1 --branch=wrangler2 https://github.com/cloudflare/worker-sites-template ${gitDirectory}\n` +
|
|
88
|
-
`cd ${gitDirectory}\n` +
|
|
89
|
-
"```\n\n" +
|
|
90
|
-
"Find out more about how to create and maintain Sites projects at https://developers.cloudflare.com/workers/platform/sites.\n" +
|
|
91
|
-
"Have you considered using Cloudflare Pages instead? See https://pages.cloudflare.com/.";
|
|
92
|
-
throw new CommandLineArgsError(message);
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
logger.log(
|
|
96
|
-
`Creating a worker in ${path.basename(creationDirectory)} from ${
|
|
97
|
-
args.template
|
|
98
|
-
}`
|
|
99
|
-
);
|
|
100
|
-
|
|
101
|
-
const { remote, subdirectory } = parseTemplatePath(args.template);
|
|
102
|
-
|
|
103
|
-
await cloneIntoDirectory(remote, creationDirectory, subdirectory);
|
|
104
|
-
await initializeGit(creationDirectory);
|
|
105
|
-
|
|
106
|
-
logger.log("✨ Success!");
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
/**
|
|
110
|
-
* Creates a path based on the current working directory and a worker name.
|
|
111
|
-
* Automatically increments a counter when searching for an available directory.
|
|
112
|
-
*
|
|
113
|
-
* Running `wrangler generate worker https://some-git-repo` in a directory
|
|
114
|
-
* with the structure:
|
|
115
|
-
* ```
|
|
116
|
-
* - workers
|
|
117
|
-
* |
|
|
118
|
-
* | - worker
|
|
119
|
-
* | | - wrangler.toml
|
|
120
|
-
* | | ...
|
|
121
|
-
* |
|
|
122
|
-
* | - worker-1
|
|
123
|
-
* | | - wrangler.toml
|
|
124
|
-
* | | ...
|
|
125
|
-
* ```
|
|
126
|
-
*
|
|
127
|
-
* will result in a new worker called `worker-2` being generated.
|
|
128
|
-
*
|
|
129
|
-
* @param workerName the name of the generated worker
|
|
130
|
-
* @returns an absolute path to the directory to generate the worker into
|
|
131
|
-
*/
|
|
132
|
-
function generateWorkerDirectoryName(workerName: string): string {
|
|
133
|
-
let workerDirectoryPath = path.resolve(process.cwd(), workerName);
|
|
134
|
-
let i = 1;
|
|
135
|
-
|
|
136
|
-
while (fs.existsSync(workerDirectoryPath)) {
|
|
137
|
-
workerDirectoryPath = path.resolve(process.cwd(), `${workerName}-${i}`);
|
|
138
|
-
i++;
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
return workerDirectoryPath;
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
/**
|
|
145
|
-
* Checks if an arg is a template, which can be useful if the order
|
|
146
|
-
* of template & worker name args is switched
|
|
147
|
-
*
|
|
148
|
-
* @param arg a template to generate from, or a folder to generate into
|
|
149
|
-
* @returns true if the given arg was remote (a template)
|
|
150
|
-
*/
|
|
151
|
-
function isRemote(arg: string) {
|
|
152
|
-
return /^(https?|ftps?|file|git|ssh):\/\//.test(arg) || arg.includes(":");
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
/**
|
|
156
|
-
* unreadable regex basically copied from degit. i put some named capture groups in,
|
|
157
|
-
* but uhh...there's not much to do short of using pomsky or some other tool.
|
|
158
|
-
*
|
|
159
|
-
* notably: this only supports `https://` and `git@` urls,
|
|
160
|
-
* and is missing support for:
|
|
161
|
-
* - `http`
|
|
162
|
-
* - `ftp(s)`
|
|
163
|
-
* - `file`
|
|
164
|
-
* - `ssh`
|
|
165
|
-
*/
|
|
166
|
-
const TEMPLATE_REGEX =
|
|
167
|
-
/^(?:(?:https:\/\/)?(?<httpsUrl>[^:/]+\.[^:/]+)\/|git@(?<gitUrl>[^:/]+)[:/]|(?<shorthandUrl>[^/]+):)?(?<user>[^/\s]+)\/(?<repository>[^/\s#]+)(?:(?<subdirectoryPath>(?:\/[^/\s#]+)+))?(?:\/)?(?:#(?<tag>.+))?/;
|
|
168
|
-
|
|
169
|
-
// there are a few URL formats we support:
|
|
170
|
-
// - `user/repo` -> assume github, use "https://github.com/user/repo.git"
|
|
171
|
-
// - `https://<httpsUrl>
|
|
172
|
-
// - `git@<gitUrl>`
|
|
173
|
-
// - `(bb|bitbucket|gh|github|gl|gitlab):user/repo` -> parse shorthand into https url
|
|
174
|
-
|
|
175
|
-
/**
|
|
176
|
-
* There's no URL, so assume a github repo
|
|
177
|
-
*/
|
|
178
|
-
type NoUrl = {
|
|
179
|
-
httpsUrl: undefined;
|
|
180
|
-
gitUrl: undefined;
|
|
181
|
-
shorthandUrl: undefined;
|
|
182
|
-
};
|
|
183
|
-
|
|
184
|
-
/**
|
|
185
|
-
* A https url (e.g. https://bitbucket.org/user/repo)
|
|
186
|
-
*/
|
|
187
|
-
type HttpsUrl = Omit<NoUrl, "httpsUrl"> & { httpsUrl: string };
|
|
188
|
-
|
|
189
|
-
/**
|
|
190
|
-
* A git url (e.g. git@gitlab.com:user/repo)
|
|
191
|
-
*/
|
|
192
|
-
type GitUrl = Omit<NoUrl, "gitUrl"> & { gitUrl: string };
|
|
193
|
-
|
|
194
|
-
/**
|
|
195
|
-
* A shorthand url (e.g. github:user/repo)
|
|
196
|
-
*/
|
|
197
|
-
type ShorthandUrl = Omit<NoUrl, "shorthandUrl"> & { shorthandUrl: string };
|
|
198
|
-
|
|
199
|
-
/**
|
|
200
|
-
* Union of all possible URL groups. Exactly one will be present, the rest
|
|
201
|
-
* will be `undefined`.
|
|
202
|
-
*/
|
|
203
|
-
type TemplateRegexUrlGroup = NoUrl | HttpsUrl | GitUrl | ShorthandUrl;
|
|
204
|
-
|
|
205
|
-
/**
|
|
206
|
-
* Possible matches of `TEMPLATE_REGEX` against a passed-in template arg
|
|
207
|
-
*/
|
|
208
|
-
type TemplateRegexGroups = {
|
|
209
|
-
/** The user the repo is under */
|
|
210
|
-
user: string;
|
|
211
|
-
|
|
212
|
-
/** The repo name */
|
|
213
|
-
repository: string;
|
|
214
|
-
|
|
215
|
-
/** Optional, path to subdirectory containing template. Begins with `/` */
|
|
216
|
-
subdirectoryPath?: string;
|
|
217
|
-
|
|
218
|
-
/** Optional tag (or branch, etc.) to clone */
|
|
219
|
-
tag?: string;
|
|
220
|
-
} & TemplateRegexUrlGroup;
|
|
221
|
-
|
|
222
|
-
/**
|
|
223
|
-
* Parses a regex match on any of the URL groups into a URL base
|
|
224
|
-
*
|
|
225
|
-
* @param urlGroup a regex hit for a URL of any sort
|
|
226
|
-
* @returns the protocol and domain name of the url to clone from
|
|
227
|
-
*/
|
|
228
|
-
function toUrlBase({ httpsUrl, gitUrl, shorthandUrl }: TemplateRegexUrlGroup) {
|
|
229
|
-
if (httpsUrl !== undefined) {
|
|
230
|
-
return `https://${httpsUrl}`;
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
if (gitUrl !== undefined) {
|
|
234
|
-
return `git@${gitUrl}`;
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
if (shorthandUrl !== undefined) {
|
|
238
|
-
switch (shorthandUrl) {
|
|
239
|
-
case "github":
|
|
240
|
-
case "gh":
|
|
241
|
-
return "https://github.com";
|
|
242
|
-
case "gitlab":
|
|
243
|
-
case "gl":
|
|
244
|
-
return "https://gitlab.com";
|
|
245
|
-
case "bitbucket":
|
|
246
|
-
case "bb":
|
|
247
|
-
return "https://bitbucket.org";
|
|
248
|
-
default:
|
|
249
|
-
throw new Error(
|
|
250
|
-
`Unable to parse shorthand ${shorthandUrl}. Supported options are "bitbucket" ("bb"), "github" ("gh"), and "gitlab" ("gl")`
|
|
251
|
-
);
|
|
252
|
-
}
|
|
253
|
-
}
|
|
254
|
-
|
|
255
|
-
return "https://github.com";
|
|
256
|
-
}
|
|
257
|
-
|
|
258
|
-
/**
|
|
259
|
-
* Parses a template string (e.g. "user/repo", "github:user/repo/path/to/subdirectory")
|
|
260
|
-
* into a remote URL to clone from and an optional subdirectory to filter for
|
|
261
|
-
*
|
|
262
|
-
* @param templatePath the template string to parse
|
|
263
|
-
* @returns an object containing the remote url and an optional subdirectory to clone
|
|
264
|
-
*/
|
|
265
|
-
function parseTemplatePath(templatePath: string): {
|
|
266
|
-
remote: string;
|
|
267
|
-
subdirectory?: string;
|
|
268
|
-
} {
|
|
269
|
-
if (!templatePath.includes("/")) {
|
|
270
|
-
// template is a cloudflare canonical template, it doesn't include a slash in the name
|
|
271
|
-
return {
|
|
272
|
-
remote: "https://github.com/cloudflare/workers-sdk.git",
|
|
273
|
-
subdirectory: `templates/${templatePath}`,
|
|
274
|
-
};
|
|
275
|
-
}
|
|
276
|
-
|
|
277
|
-
const groups = TEMPLATE_REGEX.exec(templatePath)?.groups as unknown as
|
|
278
|
-
| TemplateRegexGroups
|
|
279
|
-
| undefined;
|
|
280
|
-
|
|
281
|
-
if (!groups) {
|
|
282
|
-
throw new Error(`Unable to parse ${templatePath} as a template`);
|
|
283
|
-
}
|
|
284
|
-
|
|
285
|
-
const { user, repository, subdirectoryPath, tag, ...urlGroups } = groups;
|
|
286
|
-
|
|
287
|
-
const urlBase = toUrlBase(urlGroups);
|
|
288
|
-
const isHttp = urlBase.startsWith("http");
|
|
289
|
-
|
|
290
|
-
const remote = `${urlBase}${isHttp ? "/" : ":"}${user}/${repository}.git${
|
|
291
|
-
tag ? `#${tag}` : ""
|
|
292
|
-
}`;
|
|
293
|
-
|
|
294
|
-
// remove starting /
|
|
295
|
-
const subdirectory = subdirectoryPath?.slice(1);
|
|
296
|
-
|
|
297
|
-
return { remote, subdirectory };
|
|
298
|
-
}
|
package/src/git-client.ts
DELETED
|
@@ -1,135 +0,0 @@
|
|
|
1
|
-
import fs from "node:fs";
|
|
2
|
-
import os from "node:os";
|
|
3
|
-
import path from "node:path";
|
|
4
|
-
import { execa } from "execa";
|
|
5
|
-
import { findUp } from "find-up";
|
|
6
|
-
import semiver from "semiver";
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
* Check whether the given current working directory is within a git repository
|
|
10
|
-
* by looking for a `.git` directory in this or an ancestor directory.
|
|
11
|
-
*/
|
|
12
|
-
export async function isInsideGitRepo(cwd: string) {
|
|
13
|
-
const res = await findUp(".git", { cwd, type: "directory" });
|
|
14
|
-
return res !== undefined;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* Check whether git is installed by trying to run it.
|
|
19
|
-
*
|
|
20
|
-
* @returns a `string` containing the version of git that's installed, or `null` if git isn't installed
|
|
21
|
-
*/
|
|
22
|
-
export async function getGitVersioon(): Promise<string | null> {
|
|
23
|
-
try {
|
|
24
|
-
const gitVersionExecutionResult = await execa("git", ["--version"]);
|
|
25
|
-
if (gitVersionExecutionResult.exitCode !== 0) {
|
|
26
|
-
return null;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
const [gitVersion] =
|
|
30
|
-
/\d+.\d+.\d+/.exec(gitVersionExecutionResult.stdout) || [];
|
|
31
|
-
return gitVersion;
|
|
32
|
-
} catch (err) {
|
|
33
|
-
return null;
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
/**
|
|
38
|
-
* Initialize a new Worker project with a git repository.
|
|
39
|
-
*
|
|
40
|
-
* We want the branch to be called `main` but earlier versions of git do not support `--initial-branch`.
|
|
41
|
-
* If that is the case then we just fallback to the default initial branch name.
|
|
42
|
-
*/
|
|
43
|
-
export async function initializeGit(cwd: string) {
|
|
44
|
-
try {
|
|
45
|
-
// Get the default init branch name
|
|
46
|
-
const { stdout: defaultBranchName } = await execa("git", [
|
|
47
|
-
"config",
|
|
48
|
-
"--get",
|
|
49
|
-
"init.defaultBranch",
|
|
50
|
-
]);
|
|
51
|
-
|
|
52
|
-
// Try to create the repository with the HEAD branch of defaultBranchName ?? `main`.
|
|
53
|
-
await execa(
|
|
54
|
-
"git",
|
|
55
|
-
["init", "--initial-branch", defaultBranchName.trim() ?? "main"],
|
|
56
|
-
{
|
|
57
|
-
cwd,
|
|
58
|
-
}
|
|
59
|
-
);
|
|
60
|
-
} catch {
|
|
61
|
-
// Unable to create the repo with a HEAD branch name, so just fall back to the default.
|
|
62
|
-
await execa("git", ["init"], {
|
|
63
|
-
cwd,
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
/**
|
|
69
|
-
* Clone a repository into a given directory, optionally applying a given filter for a sparse checkout.
|
|
70
|
-
* Note: this does NOT initialize a git repository, that must be done separately.
|
|
71
|
-
*
|
|
72
|
-
* @param remote the remote repository to clone
|
|
73
|
-
* @param targetDirectory the directory to clone into
|
|
74
|
-
* @param subdirectory optional, clone a subdirectory instead of the whole repo
|
|
75
|
-
*/
|
|
76
|
-
export async function cloneIntoDirectory(
|
|
77
|
-
remote: string,
|
|
78
|
-
targetDirectory: string,
|
|
79
|
-
subdirectory?: string
|
|
80
|
-
) {
|
|
81
|
-
const args = ["clone", "--depth", "1"];
|
|
82
|
-
|
|
83
|
-
const gitVersion = await getGitVersioon();
|
|
84
|
-
if (!gitVersion) {
|
|
85
|
-
throw new Error("Failed to find git installation");
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
// sparse checkouts were added in git 2.26.0, and allow for...sparse...checkouts...
|
|
89
|
-
// basically it means you can checkout only certain files/folders/etc. instead of
|
|
90
|
-
// the whole repo. useful for monorepos that may, for example,
|
|
91
|
-
// contain multiple wrangler templates
|
|
92
|
-
const useSparseCheckout = subdirectory && semiver(gitVersion, "2.26.0") > -1;
|
|
93
|
-
if (useSparseCheckout) {
|
|
94
|
-
args.push("--filter=blob:none", "--sparse");
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
const tagIndex = remote.lastIndexOf("#");
|
|
98
|
-
if (tagIndex === -1) {
|
|
99
|
-
args.push(remote);
|
|
100
|
-
} else {
|
|
101
|
-
args.push("-b", remote.substring(tagIndex + 1));
|
|
102
|
-
args.push(remote.substring(0, tagIndex));
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
// we first clone into a temporary directory so that if something goes wrong,
|
|
106
|
-
// the user's filesystem isn't left in a messed-up state
|
|
107
|
-
const tempDir = fs.mkdtempSync(
|
|
108
|
-
path.join(os.tmpdir(), `wrangler-generate-repo-`)
|
|
109
|
-
);
|
|
110
|
-
args.push(tempDir);
|
|
111
|
-
|
|
112
|
-
await execa("git", args);
|
|
113
|
-
|
|
114
|
-
// if we can use sparse checkout, run it now.
|
|
115
|
-
// otherwise, the entire repo was cloned anyway, so skip this step
|
|
116
|
-
if (useSparseCheckout) {
|
|
117
|
-
await execa("git", [`sparse-checkout`, `set`, subdirectory], {
|
|
118
|
-
cwd: tempDir,
|
|
119
|
-
});
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
const templatePath =
|
|
123
|
-
subdirectory !== undefined ? path.join(tempDir, subdirectory) : tempDir;
|
|
124
|
-
|
|
125
|
-
// cleanup: move the template to the target directory and delete `.git`
|
|
126
|
-
try {
|
|
127
|
-
fs.renameSync(templatePath, targetDirectory);
|
|
128
|
-
} catch {
|
|
129
|
-
throw new Error(`Failed to find "${subdirectory}" in ${remote}`);
|
|
130
|
-
}
|
|
131
|
-
fs.rmSync(path.join(targetDirectory, ".git"), {
|
|
132
|
-
recursive: true,
|
|
133
|
-
force: true,
|
|
134
|
-
});
|
|
135
|
-
}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import fs from "node:fs";
|
|
2
|
-
import os from "node:os";
|
|
3
|
-
import path from "node:path";
|
|
4
|
-
import xdgAppPaths from "xdg-app-paths";
|
|
5
|
-
|
|
6
|
-
function isDirectory(configPath: string) {
|
|
7
|
-
try {
|
|
8
|
-
return fs.statSync(configPath).isDirectory();
|
|
9
|
-
} catch (error) {
|
|
10
|
-
// ignore error
|
|
11
|
-
return false;
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
export function getGlobalWranglerConfigPath() {
|
|
16
|
-
//TODO: We should implement a custom path --global-config and/or the WRANGLER_HOME type environment variable
|
|
17
|
-
const configDir = xdgAppPaths(".wrangler").config(); // New XDG compliant config path
|
|
18
|
-
const legacyConfigDir = path.join(os.homedir(), ".wrangler"); // Legacy config in user's home directory
|
|
19
|
-
|
|
20
|
-
// Check for the .wrangler directory in root if it is not there then use the XDG compliant path.
|
|
21
|
-
if (isDirectory(legacyConfigDir)) {
|
|
22
|
-
return legacyConfigDir;
|
|
23
|
-
} else {
|
|
24
|
-
return configDir;
|
|
25
|
-
}
|
|
26
|
-
}
|
package/src/https-options.ts
DELETED
|
@@ -1,127 +0,0 @@
|
|
|
1
|
-
import * as fs from "node:fs";
|
|
2
|
-
import os from "node:os";
|
|
3
|
-
import * as path from "node:path";
|
|
4
|
-
import { promisify } from "node:util";
|
|
5
|
-
import { getGlobalWranglerConfigPath } from "./global-wrangler-config-path";
|
|
6
|
-
import { logger } from "./logger";
|
|
7
|
-
import type { Attributes, Options } from "selfsigned";
|
|
8
|
-
|
|
9
|
-
// Most of this file has been borrowed from the implementation in Miniflare.
|
|
10
|
-
// See https://github.com/cloudflare/miniflare/blob/870b401ef5/packages/http-server/src/plugin.ts#L313-L397
|
|
11
|
-
// Thanks @mrbbot.
|
|
12
|
-
const CERT_EXPIRY_DAYS = 30;
|
|
13
|
-
const ONE_DAY_IN_MS = 86400000;
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* Get the options (i.e. SSL certificates) for running an HTTPS server.
|
|
17
|
-
*
|
|
18
|
-
* The certificates are self-signed and generated locally, and cached in the `CERT_ROOT` directory.
|
|
19
|
-
*/
|
|
20
|
-
export async function getHttpsOptions() {
|
|
21
|
-
const certDirectory = path.join(getGlobalWranglerConfigPath(), "local-cert");
|
|
22
|
-
const keyPath = path.join(certDirectory, "key.pem");
|
|
23
|
-
const certPath = path.join(certDirectory, "cert.pem");
|
|
24
|
-
|
|
25
|
-
const regenerate =
|
|
26
|
-
!fs.existsSync(keyPath) ||
|
|
27
|
-
!fs.existsSync(certPath) ||
|
|
28
|
-
hasCertificateExpired(keyPath, certPath);
|
|
29
|
-
|
|
30
|
-
if (regenerate) {
|
|
31
|
-
logger.log("Generating new self-signed certificate...");
|
|
32
|
-
const { key, cert } = await generateCertificate();
|
|
33
|
-
try {
|
|
34
|
-
// Write certificate files so we can reuse them later.
|
|
35
|
-
fs.mkdirSync(certDirectory, { recursive: true });
|
|
36
|
-
fs.writeFileSync(keyPath, key, "utf8");
|
|
37
|
-
fs.writeFileSync(certPath, cert, "utf8");
|
|
38
|
-
} catch (e) {
|
|
39
|
-
const message = e instanceof Error ? e.message : `${e}`;
|
|
40
|
-
logger.warn(
|
|
41
|
-
`Unable to cache generated self-signed certificate in ${path.relative(
|
|
42
|
-
process.cwd(),
|
|
43
|
-
certDirectory
|
|
44
|
-
)}.\n${message}`
|
|
45
|
-
);
|
|
46
|
-
}
|
|
47
|
-
return { key, cert };
|
|
48
|
-
} else {
|
|
49
|
-
return {
|
|
50
|
-
key: fs.readFileSync(keyPath, "utf8"),
|
|
51
|
-
cert: fs.readFileSync(certPath, "utf8"),
|
|
52
|
-
};
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
/**
|
|
57
|
-
* Determine if the certificate defined in `keyPath` and `certPath` files
|
|
58
|
-
* have expired based on the date when they were last modified.
|
|
59
|
-
*/
|
|
60
|
-
function hasCertificateExpired(keyPath: string, certPath: string): boolean {
|
|
61
|
-
const keyStat = fs.statSync(keyPath);
|
|
62
|
-
const certStat = fs.statSync(certPath);
|
|
63
|
-
const created = Math.max(keyStat.mtimeMs, certStat.mtimeMs);
|
|
64
|
-
return Date.now() - created > (CERT_EXPIRY_DAYS - 2) * ONE_DAY_IN_MS;
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
/**
|
|
68
|
-
* Generate a new self-signed certificate and cache it in `CERT_ROOT` directory.
|
|
69
|
-
*/
|
|
70
|
-
async function generateCertificate() {
|
|
71
|
-
// `selfsigned` imports `node-forge`, which is a pretty big library.
|
|
72
|
-
// To reduce startup time, only load this dynamically when needed.
|
|
73
|
-
// eslint-disable-next-line @typescript-eslint/consistent-type-imports
|
|
74
|
-
const generate: typeof import("selfsigned").generate = promisify(
|
|
75
|
-
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
76
|
-
require("selfsigned").generate
|
|
77
|
-
);
|
|
78
|
-
|
|
79
|
-
const certAttrs: Attributes = [{ name: "commonName", value: "localhost" }];
|
|
80
|
-
|
|
81
|
-
const certOptions: Options = {
|
|
82
|
-
algorithm: "sha256",
|
|
83
|
-
days: CERT_EXPIRY_DAYS,
|
|
84
|
-
keySize: 2048,
|
|
85
|
-
extensions: [
|
|
86
|
-
{ name: "basicConstraints", cA: true },
|
|
87
|
-
{
|
|
88
|
-
name: "keyUsage",
|
|
89
|
-
keyCertSign: true,
|
|
90
|
-
digitalSignature: true,
|
|
91
|
-
nonRepudiation: true,
|
|
92
|
-
keyEncipherment: true,
|
|
93
|
-
dataEncipherment: true,
|
|
94
|
-
},
|
|
95
|
-
{
|
|
96
|
-
name: "extKeyUsage",
|
|
97
|
-
serverAuth: true,
|
|
98
|
-
clientAuth: true,
|
|
99
|
-
codeSigning: true,
|
|
100
|
-
timeStamping: true,
|
|
101
|
-
},
|
|
102
|
-
{
|
|
103
|
-
name: "subjectAltName",
|
|
104
|
-
altNames: [
|
|
105
|
-
{ type: 2, value: "localhost" },
|
|
106
|
-
...getAccessibleHosts().map((ip) => ({ type: 7, ip })),
|
|
107
|
-
],
|
|
108
|
-
},
|
|
109
|
-
],
|
|
110
|
-
};
|
|
111
|
-
|
|
112
|
-
const { private: key, cert } = await generate(certAttrs, certOptions);
|
|
113
|
-
return { key, cert };
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
/**
|
|
117
|
-
* Ask the OS for the addresses of locally accessible hosts.
|
|
118
|
-
*/
|
|
119
|
-
function getAccessibleHosts(ipv4 = false): string[] {
|
|
120
|
-
const hosts: string[] = [];
|
|
121
|
-
Object.values(os.networkInterfaces()).forEach((net) =>
|
|
122
|
-
net?.forEach(({ family, address }) => {
|
|
123
|
-
if (!ipv4 || family === "IPv4") hosts.push(address);
|
|
124
|
-
})
|
|
125
|
-
);
|
|
126
|
-
return hosts;
|
|
127
|
-
}
|