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.
Files changed (297) hide show
  1. package/README.md +4 -4
  2. package/bin/wrangler.js +9 -75
  3. package/package.json +5 -13
  4. package/templates/__tests__/tsconfig.tsbuildinfo +1 -1
  5. package/templates/checked-fetch.js +1 -1
  6. package/templates/first-party-worker-module-facade.ts +2 -2
  7. package/templates/middleware/common.ts +9 -4
  8. package/templates/middleware/loader-sw.ts +2 -7
  9. package/templates/new-worker-scheduled.ts +1 -1
  10. package/templates/new-worker.ts +1 -1
  11. package/templates/pages-dev-util.ts +4 -1
  12. package/templates/pages-shim.ts +0 -3
  13. package/templates/tsconfig.tsbuildinfo +1 -1
  14. package/wrangler-dist/cli.d.ts +149 -75
  15. package/wrangler-dist/cli.js +60062 -64338
  16. package/import_meta_url.js +0 -3
  17. package/miniflare-config-stubs/.env.empty +0 -0
  18. package/miniflare-config-stubs/package.empty.json +0 -1
  19. package/miniflare-config-stubs/wrangler.empty.toml +0 -0
  20. package/miniflare-dist/index.mjs +0 -6442
  21. package/src/__tests__/access.test.ts +0 -25
  22. package/src/__tests__/api-dev.test.ts +0 -238
  23. package/src/__tests__/api-devregistry.test.ts +0 -121
  24. package/src/__tests__/api.test.ts +0 -102
  25. package/src/__tests__/config-cache-without-cache-dir.test.ts +0 -38
  26. package/src/__tests__/config-cache.test.ts +0 -42
  27. package/src/__tests__/configuration.test.ts +0 -4517
  28. package/src/__tests__/constellation.test.ts +0 -371
  29. package/src/__tests__/d1/d1.test.ts +0 -82
  30. package/src/__tests__/d1/execute.test.ts +0 -66
  31. package/src/__tests__/d1/migrate.test.ts +0 -257
  32. package/src/__tests__/d1/splitter.test.ts +0 -255
  33. package/src/__tests__/delete.test.ts +0 -272
  34. package/src/__tests__/deployments.test.ts +0 -369
  35. package/src/__tests__/dev.test.tsx +0 -1617
  36. package/src/__tests__/generate.test.ts +0 -237
  37. package/src/__tests__/get-host-from-url.test.ts +0 -16
  38. package/src/__tests__/guess-worker-format.test.ts +0 -120
  39. package/src/__tests__/helpers/clipboardy-mock.js +0 -4
  40. package/src/__tests__/helpers/cmd-shim.d.ts +0 -11
  41. package/src/__tests__/helpers/end-event-loop.ts +0 -6
  42. package/src/__tests__/helpers/mock-account-id.ts +0 -48
  43. package/src/__tests__/helpers/mock-auth-domain.ts +0 -20
  44. package/src/__tests__/helpers/mock-bin.ts +0 -36
  45. package/src/__tests__/helpers/mock-console.ts +0 -112
  46. package/src/__tests__/helpers/mock-dialogs.ts +0 -139
  47. package/src/__tests__/helpers/mock-get-pages-upload-token.ts +0 -25
  48. package/src/__tests__/helpers/mock-get-zone-from-host.ts +0 -11
  49. package/src/__tests__/helpers/mock-http-server.ts +0 -46
  50. package/src/__tests__/helpers/mock-istty.ts +0 -74
  51. package/src/__tests__/helpers/mock-known-routes.ts +0 -12
  52. package/src/__tests__/helpers/mock-kv.ts +0 -46
  53. package/src/__tests__/helpers/mock-oauth-flow.ts +0 -263
  54. package/src/__tests__/helpers/mock-process.ts +0 -34
  55. package/src/__tests__/helpers/mock-set-timeout.ts +0 -16
  56. package/src/__tests__/helpers/mock-stdin.ts +0 -108
  57. package/src/__tests__/helpers/mock-web-socket.ts +0 -29
  58. package/src/__tests__/helpers/msw/blob-worker.cjs +0 -19
  59. package/src/__tests__/helpers/msw/handlers/access.ts +0 -13
  60. package/src/__tests__/helpers/msw/handlers/deployments.ts +0 -160
  61. package/src/__tests__/helpers/msw/handlers/namespaces.ts +0 -81
  62. package/src/__tests__/helpers/msw/handlers/oauth.ts +0 -31
  63. package/src/__tests__/helpers/msw/handlers/r2.ts +0 -60
  64. package/src/__tests__/helpers/msw/handlers/script.ts +0 -56
  65. package/src/__tests__/helpers/msw/handlers/user.ts +0 -52
  66. package/src/__tests__/helpers/msw/handlers/zones.ts +0 -20
  67. package/src/__tests__/helpers/msw/index.ts +0 -52
  68. package/src/__tests__/helpers/msw/read-file-sync.js +0 -61
  69. package/src/__tests__/helpers/run-in-tmp.ts +0 -38
  70. package/src/__tests__/helpers/run-wrangler.ts +0 -16
  71. package/src/__tests__/helpers/string-dynamic-values-matcher.ts +0 -28
  72. package/src/__tests__/helpers/worker-scripts/child-wrangler.toml +0 -1
  73. package/src/__tests__/helpers/worker-scripts/hello-world-worker.js +0 -5
  74. package/src/__tests__/helpers/worker-scripts/hello-world-wrangler.toml +0 -1
  75. package/src/__tests__/helpers/worker-scripts/parent-worker.js +0 -11
  76. package/src/__tests__/helpers/worker-scripts/parent-wrangler.toml +0 -5
  77. package/src/__tests__/helpers/write-worker-source.ts +0 -31
  78. package/src/__tests__/helpers/write-wrangler-toml.ts +0 -17
  79. package/src/__tests__/https-options.test.ts +0 -163
  80. package/src/__tests__/index.test.ts +0 -282
  81. package/src/__tests__/init.test.ts +0 -3196
  82. package/src/__tests__/jest.setup.ts +0 -179
  83. package/src/__tests__/kv.test.ts +0 -1799
  84. package/src/__tests__/logger.test.ts +0 -207
  85. package/src/__tests__/logout.test.ts +0 -47
  86. package/src/__tests__/metrics.test.ts +0 -493
  87. package/src/__tests__/middleware.scheduled.test.ts +0 -145
  88. package/src/__tests__/middleware.test.ts +0 -816
  89. package/src/__tests__/mtls-certificates.test.ts +0 -589
  90. package/src/__tests__/package-manager.test.ts +0 -353
  91. package/src/__tests__/pages/deployment-list.test.ts +0 -80
  92. package/src/__tests__/pages/functions-build.test.ts +0 -528
  93. package/src/__tests__/pages/pages.test.ts +0 -81
  94. package/src/__tests__/pages/project-create.test.ts +0 -63
  95. package/src/__tests__/pages/project-list.test.ts +0 -110
  96. package/src/__tests__/pages/project-upload.test.ts +0 -500
  97. package/src/__tests__/pages/publish.test.ts +0 -2864
  98. package/src/__tests__/pages-deployment-tail.test.ts +0 -957
  99. package/src/__tests__/parse.test.ts +0 -436
  100. package/src/__tests__/paths.test.ts +0 -39
  101. package/src/__tests__/publish.test.ts +0 -8849
  102. package/src/__tests__/pubsub.test.ts +0 -496
  103. package/src/__tests__/queues.test.ts +0 -532
  104. package/src/__tests__/r2.test.ts +0 -374
  105. package/src/__tests__/route.test.ts +0 -45
  106. package/src/__tests__/secret.test.ts +0 -693
  107. package/src/__tests__/tail.test.ts +0 -989
  108. package/src/__tests__/test-old-node-version.js +0 -31
  109. package/src/__tests__/traverse-module-graph.test.ts +0 -220
  110. package/src/__tests__/tsconfig-sanity.ts +0 -12
  111. package/src/__tests__/tsconfig.json +0 -8
  112. package/src/__tests__/tsconfig.tsbuildinfo +0 -1
  113. package/src/__tests__/type-generation.test.ts +0 -234
  114. package/src/__tests__/user.test.ts +0 -118
  115. package/src/__tests__/utils-collectKeyValues.test.ts +0 -47
  116. package/src/__tests__/validate-dev-props.test.ts +0 -56
  117. package/src/__tests__/version.test.ts +0 -35
  118. package/src/__tests__/whoami.test.tsx +0 -172
  119. package/src/__tests__/worker-namespace.test.ts +0 -340
  120. package/src/abort.d.ts +0 -3
  121. package/src/api/dev.ts +0 -321
  122. package/src/api/index.ts +0 -11
  123. package/src/api/mtls-certificate.ts +0 -148
  124. package/src/api/pages/create-worker-bundle-contents.ts +0 -77
  125. package/src/api/pages/index.ts +0 -5
  126. package/src/api/pages/publish.tsx +0 -371
  127. package/src/bundle-reporter.ts +0 -68
  128. package/src/bundle.ts +0 -929
  129. package/src/cfetch/index.ts +0 -158
  130. package/src/cfetch/internal.ts +0 -258
  131. package/src/cli.ts +0 -28
  132. package/src/config/README.md +0 -107
  133. package/src/config/config.ts +0 -282
  134. package/src/config/diagnostics.ts +0 -80
  135. package/src/config/environment.ts +0 -625
  136. package/src/config/index.ts +0 -403
  137. package/src/config/validation-helpers.ts +0 -597
  138. package/src/config/validation.ts +0 -2369
  139. package/src/config-cache.ts +0 -85
  140. package/src/constellation/createProject.tsx +0 -51
  141. package/src/constellation/deleteProject.ts +0 -51
  142. package/src/constellation/deleteProjectModel.ts +0 -68
  143. package/src/constellation/index.ts +0 -75
  144. package/src/constellation/listCatalog.tsx +0 -35
  145. package/src/constellation/listModel.tsx +0 -41
  146. package/src/constellation/listProject.tsx +0 -28
  147. package/src/constellation/listRuntime.tsx +0 -28
  148. package/src/constellation/options.ts +0 -17
  149. package/src/constellation/types.ts +0 -17
  150. package/src/constellation/uploadModel.tsx +0 -64
  151. package/src/constellation/utils.ts +0 -90
  152. package/src/create-worker-preview.ts +0 -293
  153. package/src/create-worker-upload-form.ts +0 -363
  154. package/src/d1/backups.tsx +0 -219
  155. package/src/d1/constants.ts +0 -2
  156. package/src/d1/create.tsx +0 -70
  157. package/src/d1/delete.ts +0 -53
  158. package/src/d1/execute.tsx +0 -357
  159. package/src/d1/formatTimeAgo.ts +0 -14
  160. package/src/d1/index.ts +0 -100
  161. package/src/d1/list.tsx +0 -62
  162. package/src/d1/migrations/apply.tsx +0 -212
  163. package/src/d1/migrations/create.tsx +0 -79
  164. package/src/d1/migrations/helpers.ts +0 -169
  165. package/src/d1/migrations/index.ts +0 -3
  166. package/src/d1/migrations/list.tsx +0 -95
  167. package/src/d1/migrations/options.ts +0 -23
  168. package/src/d1/options.ts +0 -22
  169. package/src/d1/splitter.ts +0 -161
  170. package/src/d1/types.ts +0 -25
  171. package/src/d1/utils.ts +0 -49
  172. package/src/delete.ts +0 -100
  173. package/src/deployments.ts +0 -368
  174. package/src/deprecated/index.ts +0 -144
  175. package/src/dev/dev-vars.ts +0 -39
  176. package/src/dev/dev.tsx +0 -605
  177. package/src/dev/get-local-persistence-path.ts +0 -31
  178. package/src/dev/local.tsx +0 -952
  179. package/src/dev/remote.tsx +0 -635
  180. package/src/dev/start-server.ts +0 -545
  181. package/src/dev/use-esbuild.ts +0 -215
  182. package/src/dev/validate-dev-props.ts +0 -40
  183. package/src/dev-registry.ts +0 -202
  184. package/src/dev.tsx +0 -934
  185. package/src/dialogs.ts +0 -136
  186. package/src/dispatch-namespace.ts +0 -211
  187. package/src/docs/helpers.ts +0 -50
  188. package/src/docs/index.ts +0 -54
  189. package/src/durable.ts +0 -102
  190. package/src/entry.ts +0 -344
  191. package/src/environment-variables/factory.ts +0 -89
  192. package/src/environment-variables/misc-variables.ts +0 -30
  193. package/src/errors.ts +0 -11
  194. package/src/generate/index.ts +0 -298
  195. package/src/git-client.ts +0 -135
  196. package/src/global-wrangler-config-path.ts +0 -26
  197. package/src/https-options.ts +0 -127
  198. package/src/index.ts +0 -768
  199. package/src/init.ts +0 -1037
  200. package/src/inspect.ts +0 -883
  201. package/src/intl-polyfill.d.ts +0 -139
  202. package/src/is-ci.ts +0 -14
  203. package/src/is-interactive.ts +0 -16
  204. package/src/jest.d.ts +0 -4
  205. package/src/kv/helpers.ts +0 -433
  206. package/src/kv/index.ts +0 -594
  207. package/src/logger.ts +0 -123
  208. package/src/metrics/index.ts +0 -5
  209. package/src/metrics/metrics-config.ts +0 -239
  210. package/src/metrics/metrics-dispatcher.ts +0 -96
  211. package/src/metrics/metrics-usage-headers.ts +0 -24
  212. package/src/metrics/send-event.ts +0 -99
  213. package/src/miniflare-cli/README.md +0 -30
  214. package/src/miniflare-cli/assets.ts +0 -251
  215. package/src/miniflare-cli/index.ts +0 -210
  216. package/src/miniflare-cli/request-context.ts +0 -40
  217. package/src/miniflare-cli/tsconfig.json +0 -9
  218. package/src/miniflare-cli/tsconfig.tsbuildinfo +0 -1
  219. package/src/miniflare-cli/types.ts +0 -11
  220. package/src/module-collection.ts +0 -333
  221. package/src/mtls-certificate/cli.ts +0 -155
  222. package/src/open-in-browser.ts +0 -17
  223. package/src/package-manager.ts +0 -219
  224. package/src/pages/build.ts +0 -423
  225. package/src/pages/buildFunctions.ts +0 -140
  226. package/src/pages/constants.ts +0 -18
  227. package/src/pages/deployment-tails.ts +0 -281
  228. package/src/pages/deployments.tsx +0 -84
  229. package/src/pages/dev.ts +0 -734
  230. package/src/pages/errors.ts +0 -67
  231. package/src/pages/functions/buildPlugin.ts +0 -114
  232. package/src/pages/functions/buildWorker.ts +0 -350
  233. package/src/pages/functions/filepath-routing.test.ts +0 -234
  234. package/src/pages/functions/filepath-routing.ts +0 -189
  235. package/src/pages/functions/identifiers.ts +0 -78
  236. package/src/pages/functions/routes-consolidation.test.ts +0 -250
  237. package/src/pages/functions/routes-consolidation.ts +0 -73
  238. package/src/pages/functions/routes-transformation.test.ts +0 -282
  239. package/src/pages/functions/routes-transformation.ts +0 -115
  240. package/src/pages/functions/routes-validation.test.ts +0 -403
  241. package/src/pages/functions/routes-validation.ts +0 -202
  242. package/src/pages/functions/routes.ts +0 -151
  243. package/src/pages/functions/tsconfig.json +0 -8
  244. package/src/pages/functions/tsconfig.tsbuildinfo +0 -1
  245. package/src/pages/functions.ts +0 -86
  246. package/src/pages/hash.ts +0 -13
  247. package/src/pages/index.ts +0 -102
  248. package/src/pages/projects.tsx +0 -159
  249. package/src/pages/prompt-select-project.tsx +0 -31
  250. package/src/pages/publish.tsx +0 -267
  251. package/src/pages/types.ts +0 -46
  252. package/src/pages/upload.tsx +0 -469
  253. package/src/pages/utils.ts +0 -23
  254. package/src/parse.ts +0 -308
  255. package/src/paths.ts +0 -71
  256. package/src/proxy.ts +0 -694
  257. package/src/publish/index.ts +0 -274
  258. package/src/publish/publish.ts +0 -1065
  259. package/src/pubsub/index.ts +0 -286
  260. package/src/pubsub/pubsub-commands.ts +0 -623
  261. package/src/queues/cli/commands/consumer/add.ts +0 -71
  262. package/src/queues/cli/commands/consumer/index.ts +0 -19
  263. package/src/queues/cli/commands/consumer/remove.ts +0 -31
  264. package/src/queues/cli/commands/create.ts +0 -25
  265. package/src/queues/cli/commands/delete.ts +0 -26
  266. package/src/queues/cli/commands/index.ts +0 -35
  267. package/src/queues/cli/commands/list.ts +0 -25
  268. package/src/queues/client.ts +0 -136
  269. package/src/queues/utils.ts +0 -18
  270. package/src/r2/constants.ts +0 -4
  271. package/src/r2/helpers.ts +0 -132
  272. package/src/r2/index.ts +0 -289
  273. package/src/routes.ts +0 -140
  274. package/src/secret/index.ts +0 -377
  275. package/src/selfsigned.d.ts +0 -29
  276. package/src/sites.ts +0 -484
  277. package/src/tail/createTail.ts +0 -415
  278. package/src/tail/filters.ts +0 -277
  279. package/src/tail/index.ts +0 -211
  280. package/src/tail/printing.ts +0 -132
  281. package/src/traverse-module-graph.ts +0 -54
  282. package/src/tsconfig-sanity.ts +0 -16
  283. package/src/type-generation.ts +0 -181
  284. package/src/update-check.ts +0 -19
  285. package/src/user/access.ts +0 -68
  286. package/src/user/auth-variables.ts +0 -113
  287. package/src/user/choose-account.tsx +0 -39
  288. package/src/user/generate-auth-url.ts +0 -33
  289. package/src/user/generate-random-state.ts +0 -16
  290. package/src/user/index.ts +0 -2
  291. package/src/user/user.ts +0 -1234
  292. package/src/utils/collectKeyValues.ts +0 -14
  293. package/src/utils/render.ts +0 -93
  294. package/src/whoami.ts +0 -135
  295. package/src/worker.ts +0 -279
  296. package/src/yargs-types.ts +0 -37
  297. package/src/zones.ts +0 -191
@@ -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
- }
@@ -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
- }