@maizzle/framework 6.0.0-rc.1 → 6.0.0-rc.3

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 (214) hide show
  1. package/bin/maizzle.mjs +1 -1
  2. package/dist/build.mjs +2 -1
  3. package/dist/build.mjs.map +1 -1
  4. package/dist/config/index.mjs +7 -0
  5. package/dist/config/index.mjs.map +1 -1
  6. package/dist/plugin.d.mts.map +1 -1
  7. package/dist/plugin.mjs +13 -0
  8. package/dist/plugin.mjs.map +1 -1
  9. package/dist/render/createRenderer.d.mts +2 -0
  10. package/dist/render/createRenderer.d.mts.map +1 -1
  11. package/dist/render/createRenderer.mjs +11 -4
  12. package/dist/render/createRenderer.mjs.map +1 -1
  13. package/dist/render/index.mjs +2 -1
  14. package/dist/render/index.mjs.map +1 -1
  15. package/dist/serve.mjs +2 -1
  16. package/dist/serve.mjs.map +1 -1
  17. package/dist/types/config.d.mts +3 -0
  18. package/dist/types/config.d.mts.map +1 -1
  19. package/dist/utils/detect.d.mts +5 -0
  20. package/dist/utils/detect.d.mts.map +1 -0
  21. package/dist/utils/detect.mjs +11 -0
  22. package/dist/utils/detect.mjs.map +1 -0
  23. package/node_modules/@clack/core/CHANGELOG.md +87 -4
  24. package/node_modules/@clack/core/README.md +1 -1
  25. package/node_modules/@clack/core/dist/index.d.mts +186 -48
  26. package/node_modules/@clack/core/dist/index.mjs +10 -14
  27. package/node_modules/@clack/core/dist/index.mjs.map +1 -1
  28. package/node_modules/@clack/core/package.json +7 -9
  29. package/node_modules/@clack/prompts/CHANGELOG.md +171 -7
  30. package/node_modules/@clack/prompts/README.md +66 -3
  31. package/node_modules/@clack/prompts/dist/index.d.mts +302 -76
  32. package/node_modules/@clack/prompts/dist/index.mjs +134 -84
  33. package/node_modules/@clack/prompts/dist/index.mjs.map +1 -1
  34. package/node_modules/@clack/prompts/package.json +14 -10
  35. package/node_modules/citty/LICENSE +0 -15
  36. package/node_modules/citty/README.md +166 -69
  37. package/node_modules/citty/dist/index.d.mts +88 -56
  38. package/node_modules/citty/dist/index.mjs +399 -437
  39. package/node_modules/citty/package.json +28 -35
  40. package/node_modules/giget/README.md +59 -11
  41. package/node_modules/giget/dist/THIRD-PARTY-LICENSES.md +205 -0
  42. package/node_modules/giget/dist/_chunks/giget.mjs +508 -0
  43. package/node_modules/giget/dist/_chunks/libs/citty.mjs +269 -0
  44. package/node_modules/giget/dist/_chunks/libs/nypm.d.mts +1 -0
  45. package/node_modules/giget/dist/_chunks/libs/nypm.mjs +669 -0
  46. package/node_modules/giget/dist/_chunks/libs/tar.mjs +2931 -0
  47. package/node_modules/giget/dist/_chunks/rolldown-runtime.mjs +14 -0
  48. package/node_modules/giget/dist/cli.d.mts +1 -0
  49. package/node_modules/giget/dist/cli.mjs +89 -111
  50. package/node_modules/giget/dist/index.d.mts +46 -35
  51. package/node_modules/giget/dist/index.mjs +2 -22
  52. package/node_modules/giget/package.json +32 -45
  53. package/node_modules/maizzle/README.md +140 -0
  54. package/node_modules/maizzle/bin/maizzle.mjs +5 -0
  55. package/node_modules/maizzle/dist/commands/new.d.mts +7 -0
  56. package/node_modules/maizzle/dist/commands/new.mjs +278 -0
  57. package/node_modules/{@maizzle/cli → maizzle}/dist/index.d.mts +1 -1
  58. package/node_modules/maizzle/dist/index.mjs +44 -0
  59. package/node_modules/{commander → maizzle/node_modules/commander}/Readme.md +94 -67
  60. package/node_modules/{commander → maizzle/node_modules/commander}/lib/argument.js +5 -4
  61. package/node_modules/{commander → maizzle/node_modules/commander}/lib/command.js +154 -39
  62. package/node_modules/{commander → maizzle/node_modules/commander}/lib/help.js +77 -39
  63. package/node_modules/{commander → maizzle/node_modules/commander}/lib/option.js +16 -3
  64. package/node_modules/{commander → maizzle/node_modules/commander}/package-support.json +4 -1
  65. package/node_modules/{commander → maizzle/node_modules/commander}/package.json +8 -8
  66. package/node_modules/{commander → maizzle/node_modules/commander}/typings/index.d.ts +71 -3
  67. package/node_modules/{@maizzle/cli → maizzle}/package.json +13 -11
  68. package/node_modules/tinyexec/README.md +49 -3
  69. package/node_modules/tinyexec/dist/main.d.mts +25 -14
  70. package/node_modules/tinyexec/dist/main.mjs +148 -100
  71. package/node_modules/tinyexec/package.json +9 -8
  72. package/package.json +3 -3
  73. package/node_modules/@clack/core/dist/index.cjs +0 -15
  74. package/node_modules/@clack/core/dist/index.cjs.map +0 -1
  75. package/node_modules/@clack/core/dist/index.d.cts +0 -211
  76. package/node_modules/@clack/core/dist/index.d.ts +0 -211
  77. package/node_modules/@clack/prompts/dist/index.cjs +0 -87
  78. package/node_modules/@clack/prompts/dist/index.cjs.map +0 -1
  79. package/node_modules/@clack/prompts/dist/index.d.cts +0 -165
  80. package/node_modules/@clack/prompts/dist/index.d.ts +0 -165
  81. package/node_modules/@maizzle/cli/README.md +0 -58
  82. package/node_modules/@maizzle/cli/dist/index.mjs +0 -42
  83. package/node_modules/citty/dist/index.cjs +0 -475
  84. package/node_modules/citty/dist/index.d.cts +0 -80
  85. package/node_modules/citty/dist/index.d.ts +0 -80
  86. package/node_modules/consola/LICENSE +0 -47
  87. package/node_modules/consola/README.md +0 -352
  88. package/node_modules/consola/basic.d.ts +0 -1
  89. package/node_modules/consola/browser.d.ts +0 -1
  90. package/node_modules/consola/core.d.ts +0 -1
  91. package/node_modules/consola/dist/basic.cjs +0 -32
  92. package/node_modules/consola/dist/basic.d.cts +0 -23
  93. package/node_modules/consola/dist/basic.d.mts +0 -21
  94. package/node_modules/consola/dist/basic.d.ts +0 -23
  95. package/node_modules/consola/dist/basic.mjs +0 -24
  96. package/node_modules/consola/dist/browser.cjs +0 -84
  97. package/node_modules/consola/dist/browser.d.cts +0 -23
  98. package/node_modules/consola/dist/browser.d.mts +0 -21
  99. package/node_modules/consola/dist/browser.d.ts +0 -23
  100. package/node_modules/consola/dist/browser.mjs +0 -76
  101. package/node_modules/consola/dist/chunks/prompt.cjs +0 -288
  102. package/node_modules/consola/dist/chunks/prompt.mjs +0 -280
  103. package/node_modules/consola/dist/core.cjs +0 -517
  104. package/node_modules/consola/dist/core.d.cts +0 -459
  105. package/node_modules/consola/dist/core.d.mts +0 -459
  106. package/node_modules/consola/dist/core.d.ts +0 -459
  107. package/node_modules/consola/dist/core.mjs +0 -512
  108. package/node_modules/consola/dist/index.cjs +0 -663
  109. package/node_modules/consola/dist/index.d.cts +0 -24
  110. package/node_modules/consola/dist/index.d.mts +0 -22
  111. package/node_modules/consola/dist/index.d.ts +0 -24
  112. package/node_modules/consola/dist/index.mjs +0 -651
  113. package/node_modules/consola/dist/shared/consola.DCGIlDNP.cjs +0 -75
  114. package/node_modules/consola/dist/shared/consola.DRwqZj3T.mjs +0 -72
  115. package/node_modules/consola/dist/shared/consola.DXBYu-KD.mjs +0 -288
  116. package/node_modules/consola/dist/shared/consola.DwRq1yyg.cjs +0 -312
  117. package/node_modules/consola/dist/utils.cjs +0 -64
  118. package/node_modules/consola/dist/utils.d.cts +0 -286
  119. package/node_modules/consola/dist/utils.d.mts +0 -286
  120. package/node_modules/consola/dist/utils.d.ts +0 -286
  121. package/node_modules/consola/dist/utils.mjs +0 -54
  122. package/node_modules/consola/lib/index.cjs +0 -10
  123. package/node_modules/consola/package.json +0 -136
  124. package/node_modules/consola/utils.d.ts +0 -1
  125. package/node_modules/create-maizzle/README.md +0 -86
  126. package/node_modules/create-maizzle/bin/create-maizzle.mjs +0 -4
  127. package/node_modules/create-maizzle/node_modules/@clack/core/CHANGELOG.md +0 -340
  128. package/node_modules/create-maizzle/node_modules/@clack/core/LICENSE +0 -9
  129. package/node_modules/create-maizzle/node_modules/@clack/core/README.md +0 -22
  130. package/node_modules/create-maizzle/node_modules/@clack/core/dist/index.d.mts +0 -349
  131. package/node_modules/create-maizzle/node_modules/@clack/core/dist/index.mjs +0 -11
  132. package/node_modules/create-maizzle/node_modules/@clack/core/dist/index.mjs.map +0 -1
  133. package/node_modules/create-maizzle/node_modules/@clack/core/package.json +0 -60
  134. package/node_modules/create-maizzle/node_modules/@clack/prompts/CHANGELOG.md +0 -576
  135. package/node_modules/create-maizzle/node_modules/@clack/prompts/LICENSE +0 -9
  136. package/node_modules/create-maizzle/node_modules/@clack/prompts/README.md +0 -270
  137. package/node_modules/create-maizzle/node_modules/@clack/prompts/dist/index.d.mts +0 -391
  138. package/node_modules/create-maizzle/node_modules/@clack/prompts/dist/index.mjs +0 -137
  139. package/node_modules/create-maizzle/node_modules/@clack/prompts/dist/index.mjs.map +0 -1
  140. package/node_modules/create-maizzle/node_modules/@clack/prompts/package.json +0 -65
  141. package/node_modules/create-maizzle/package.json +0 -47
  142. package/node_modules/create-maizzle/src/index.js +0 -242
  143. package/node_modules/defu/LICENSE +0 -21
  144. package/node_modules/defu/README.md +0 -171
  145. package/node_modules/defu/dist/defu.cjs +0 -77
  146. package/node_modules/defu/dist/defu.d.cts +0 -31
  147. package/node_modules/defu/dist/defu.d.mts +0 -29
  148. package/node_modules/defu/dist/defu.d.ts +0 -31
  149. package/node_modules/defu/dist/defu.mjs +0 -69
  150. package/node_modules/defu/lib/defu.cjs +0 -10
  151. package/node_modules/defu/lib/defu.d.cts +0 -12
  152. package/node_modules/defu/package.json +0 -48
  153. package/node_modules/giget/dist/shared/giget.OCaTp9b-.mjs +0 -468
  154. package/node_modules/node-fetch-native/LICENSE +0 -114
  155. package/node_modules/node-fetch-native/README.md +0 -225
  156. package/node_modules/node-fetch-native/dist/chunks/multipart-parser.cjs +0 -2
  157. package/node_modules/node-fetch-native/dist/chunks/multipart-parser.mjs +0 -2
  158. package/node_modules/node-fetch-native/dist/index.cjs +0 -1
  159. package/node_modules/node-fetch-native/dist/index.mjs +0 -1
  160. package/node_modules/node-fetch-native/dist/native.cjs +0 -1
  161. package/node_modules/node-fetch-native/dist/native.mjs +0 -1
  162. package/node_modules/node-fetch-native/dist/node.cjs +0 -19
  163. package/node_modules/node-fetch-native/dist/node.mjs +0 -19
  164. package/node_modules/node-fetch-native/dist/polyfill.cjs +0 -1
  165. package/node_modules/node-fetch-native/dist/polyfill.mjs +0 -1
  166. package/node_modules/node-fetch-native/dist/proxy-stub.cjs +0 -1
  167. package/node_modules/node-fetch-native/dist/proxy-stub.mjs +0 -1
  168. package/node_modules/node-fetch-native/dist/proxy.cjs +0 -58
  169. package/node_modules/node-fetch-native/dist/shared/node-fetch-native.DfbY2q-x.mjs +0 -1
  170. package/node_modules/node-fetch-native/dist/shared/node-fetch-native.DhEqb06g.cjs +0 -1
  171. package/node_modules/node-fetch-native/index.d.ts +0 -1
  172. package/node_modules/node-fetch-native/lib/empty.cjs +0 -0
  173. package/node_modules/node-fetch-native/lib/empty.mjs +0 -0
  174. package/node_modules/node-fetch-native/lib/index.cjs +0 -11
  175. package/node_modules/node-fetch-native/lib/index.d.cts +0 -10
  176. package/node_modules/node-fetch-native/lib/index.d.mts +0 -10
  177. package/node_modules/node-fetch-native/lib/index.d.ts +0 -10
  178. package/node_modules/node-fetch-native/lib/native.cjs +0 -11
  179. package/node_modules/node-fetch-native/lib/polyfill.d.cts +0 -1
  180. package/node_modules/node-fetch-native/lib/polyfill.d.mts +0 -1
  181. package/node_modules/node-fetch-native/lib/polyfill.d.ts +0 -1
  182. package/node_modules/node-fetch-native/lib/proxy.d.ts +0 -32
  183. package/node_modules/node-fetch-native/node.d.ts +0 -1
  184. package/node_modules/node-fetch-native/package.json +0 -138
  185. package/node_modules/node-fetch-native/polyfill.d.ts +0 -1
  186. package/node_modules/node-fetch-native/proxy.d.ts +0 -1
  187. package/node_modules/nypm/node_modules/citty/LICENSE +0 -21
  188. package/node_modules/nypm/node_modules/citty/README.md +0 -231
  189. package/node_modules/nypm/node_modules/citty/dist/index.d.mts +0 -112
  190. package/node_modules/nypm/node_modules/citty/dist/index.mjs +0 -425
  191. package/node_modules/nypm/node_modules/citty/package.json +0 -42
  192. /package/node_modules/{nypm/node_modules/citty → citty}/dist/THIRD-PARTY-LICENSES.md +0 -0
  193. /package/node_modules/{nypm/node_modules/citty → citty}/dist/_chunks/libs/scule.mjs +0 -0
  194. /package/node_modules/{@maizzle/cli → maizzle}/LICENSE +0 -0
  195. /package/node_modules/{@maizzle/cli → maizzle}/dist/commands/make/component.d.mts +0 -0
  196. /package/node_modules/{@maizzle/cli → maizzle}/dist/commands/make/component.mjs +0 -0
  197. /package/node_modules/{@maizzle/cli → maizzle}/dist/commands/make/config.d.mts +0 -0
  198. /package/node_modules/{@maizzle/cli → maizzle}/dist/commands/make/config.mjs +0 -0
  199. /package/node_modules/{@maizzle/cli → maizzle}/dist/commands/make/layout.d.mts +0 -0
  200. /package/node_modules/{@maizzle/cli → maizzle}/dist/commands/make/layout.mjs +0 -0
  201. /package/node_modules/{@maizzle/cli → maizzle}/dist/commands/make/scaffold.d.mts +0 -0
  202. /package/node_modules/{@maizzle/cli → maizzle}/dist/commands/make/scaffold.mjs +0 -0
  203. /package/node_modules/{@maizzle/cli → maizzle}/dist/commands/make/stubs/component.vue +0 -0
  204. /package/node_modules/{@maizzle/cli → maizzle}/dist/commands/make/stubs/config.ts +0 -0
  205. /package/node_modules/{@maizzle/cli → maizzle}/dist/commands/make/stubs/layout.vue +0 -0
  206. /package/node_modules/{@maizzle/cli → maizzle}/dist/commands/make/stubs/template.vue +0 -0
  207. /package/node_modules/{@maizzle/cli → maizzle}/dist/commands/make/template.d.mts +0 -0
  208. /package/node_modules/{@maizzle/cli → maizzle}/dist/commands/make/template.mjs +0 -0
  209. /package/node_modules/{commander → maizzle/node_modules/commander}/LICENSE +0 -0
  210. /package/node_modules/{commander → maizzle/node_modules/commander}/esm.mjs +0 -0
  211. /package/node_modules/{commander → maizzle/node_modules/commander}/index.js +0 -0
  212. /package/node_modules/{commander → maizzle/node_modules/commander}/lib/error.js +0 -0
  213. /package/node_modules/{commander → maizzle/node_modules/commander}/lib/suggestSimilar.js +0 -0
  214. /package/node_modules/{commander → maizzle/node_modules/commander}/typings/esm.d.mts +0 -0
@@ -0,0 +1,508 @@
1
+ import { a as resolve$1, i as relative, n as basename$1, r as dirname$1 } from "./libs/nypm.mjs";
2
+ import { createWriteStream, existsSync, readdirSync, renameSync } from "node:fs";
3
+ import { mkdir, mkdtemp, readFile, rm, writeFile } from "node:fs/promises";
4
+ import { PassThrough, Readable, pipeline } from "node:stream";
5
+ import { pipeline as pipeline$1 } from "node:stream/promises";
6
+ import { spawn, spawnSync } from "node:child_process";
7
+ import { homedir, tmpdir } from "node:os";
8
+ import { promisify } from "node:util";
9
+ import { join } from "node:path";
10
+ //#region src/_utils.ts
11
+ async function download(url, filePath, options = {}) {
12
+ const infoPath = filePath + ".json";
13
+ const info = JSON.parse(await readFile(infoPath, "utf8").catch(() => "{}"));
14
+ const etag = (await sendFetch(url, {
15
+ method: "HEAD",
16
+ headers: options.headers
17
+ }).catch(() => void 0))?.headers.get("etag");
18
+ if (info.etag === etag && existsSync(filePath)) return;
19
+ if (typeof etag === "string") info.etag = etag;
20
+ const response = await sendFetch(url, { headers: options.headers });
21
+ if (response.status >= 400) throw new Error(`Failed to download ${url}: ${response.status} ${response.statusText}`);
22
+ const stream = createWriteStream(filePath);
23
+ await promisify(pipeline)(response.body, stream);
24
+ await writeFile(infoPath, JSON.stringify(info), "utf8");
25
+ }
26
+ const inputRegex = /^(?<repo>[-\w.]+\/[-\w.]+)(?<subdir>[^#]+)?(?<ref>#[-\w./@]+)?/;
27
+ const expandedInputRegex = /^(?<repo>[-\w.]+(?:\/[-\w.]+)+?)(?:::(?<subdir>[^#]*))?(?<ref>#[-\w./@]+)?$/;
28
+ function parseGitURI(input, options) {
29
+ const useExpanded = options?.expandRepo || input.includes("::");
30
+ const m = input.match(useExpanded ? expandedInputRegex : inputRegex)?.groups || {};
31
+ const subdir = useExpanded ? m.subdir ? "/" + m.subdir : "/" : m.subdir || "/";
32
+ return {
33
+ repo: m.repo || "",
34
+ subdir,
35
+ ref: m.ref ? m.ref.slice(1) : "main"
36
+ };
37
+ }
38
+ function debug(...args) {
39
+ if (process.env.DEBUG) console.debug("[giget]", ...args);
40
+ }
41
+ async function sendFetch(url, options = {}) {
42
+ if (options.headers?.["sec-fetch-mode"]) options.mode = options.headers["sec-fetch-mode"];
43
+ const res = await fetch(url, {
44
+ ...options,
45
+ headers: normalizeHeaders(options.headers)
46
+ }).catch((error) => {
47
+ throw new Error(`Failed to download ${url}: ${error}`, { cause: error });
48
+ });
49
+ if (options.validateStatus && res.status >= 400) throw new Error(`Failed to fetch ${url}: ${res.status} ${res.statusText}`);
50
+ return res;
51
+ }
52
+ function cacheDirectory() {
53
+ const cacheDir = process.env.XDG_CACHE_HOME ? resolve$1(process.env.XDG_CACHE_HOME, "giget") : resolve$1(homedir(), ".cache/giget");
54
+ if (process.platform === "win32") {
55
+ const windowsCacheDir = resolve$1(tmpdir(), "giget");
56
+ if (!existsSync(windowsCacheDir) && existsSync(cacheDir)) try {
57
+ renameSync(cacheDir, windowsCacheDir);
58
+ } catch {}
59
+ return windowsCacheDir;
60
+ }
61
+ return cacheDir;
62
+ }
63
+ function normalizeHeaders(headers = {}) {
64
+ const normalized = {};
65
+ for (const [key, value] of Object.entries(headers)) {
66
+ if (!value) continue;
67
+ normalized[key.toLowerCase()] = value;
68
+ }
69
+ return normalized;
70
+ }
71
+ function currentShell() {
72
+ if (process.env.SHELL) return process.env.SHELL;
73
+ if (process.platform === "win32") return "cmd.exe";
74
+ return "/bin/bash";
75
+ }
76
+ function startShell(cwd) {
77
+ cwd = resolve$1(cwd);
78
+ const shell = currentShell();
79
+ console.info(`(experimental) Opening shell in ${relative(process.cwd(), cwd)}...`);
80
+ spawnSync(shell, [], {
81
+ cwd,
82
+ shell: true,
83
+ stdio: "inherit"
84
+ });
85
+ }
86
+ //#endregion
87
+ //#region src/git.ts
88
+ const git = (input, options) => {
89
+ const parsed = parseGitCloneURI(input);
90
+ return {
91
+ name: parsed.name,
92
+ version: parsed.subdir ? `${parsed.version || "default"}-${parsed.subdir.replaceAll("/", "-")}` : parsed.version,
93
+ tar: ({ auth } = {}) => _cloneAndTar(parsed, auth ?? options.auth)
94
+ };
95
+ };
96
+ function parseGitCloneURI(input, opts = {}) {
97
+ const cwd = opts.cwd ?? process.cwd();
98
+ let uri = input.replace(/#.*$/, "");
99
+ let pathSubdir;
100
+ if (/^[./]/.test(input)) uri = resolve$1(cwd, uri);
101
+ else if (/^https?:\/\//.test(uri)) {
102
+ const httpMatch = /^(https?:\/\/[^/]+)\/([\w.-]+\/[\w.-]+?)(?:\.git)?(?:\/(.+))?$/.exec(uri);
103
+ if (httpMatch) {
104
+ const [, origin, repo, rest] = httpMatch;
105
+ uri = `${origin}/${repo}`;
106
+ if (rest) pathSubdir = rest;
107
+ }
108
+ } else if (uri.includes("@")) {
109
+ const sshMatch = /^(.*?:[\w.-]+\/[\w.-]+?)(?:\.git)?(?:\/(.+))?$/.exec(uri);
110
+ if (sshMatch) {
111
+ const [, repoUri, rest] = sshMatch;
112
+ uri = repoUri;
113
+ if (rest) pathSubdir = rest;
114
+ }
115
+ } else {
116
+ const hostMap = {
117
+ "github:": "https://github.com/",
118
+ "gh:": "https://github.com/",
119
+ "gitlab:": "https://gitlab.com/",
120
+ "bitbucket:": "https://bitbucket.org/",
121
+ "sourcehut:": "https://git.sr.ht/~"
122
+ };
123
+ const host = /^(.+?:)/.exec(uri)?.at(1);
124
+ if (host && hostMap[host]) uri = uri.replace(host, hostMap[host]);
125
+ else if (!host) uri = `${(process.env.GIGET_GIT_HOST || "https://github.com/").replace(/\/$/, "")}/${uri}`;
126
+ const httpMatch = /^(https?:\/\/[^/]+\/~?[\w.-]+\/[\w.-]+?)(?:\.git)?(?:\/(.+))?$/.exec(uri);
127
+ if (httpMatch) {
128
+ const [, repoUri, rest] = httpMatch;
129
+ uri = repoUri;
130
+ if (rest) pathSubdir = rest;
131
+ }
132
+ }
133
+ const name = uri.replace(/^https?:\/\//, "").replace(/^.+@/, "").replace(/(\.git)?(#.*)?$/, "").replace(/^\W+/, "").replaceAll(/[:/]/g, "-");
134
+ const [version, hashSubdir] = /#(.+)$/.exec(input)?.at(1)?.split(":") ?? [];
135
+ const resolvedVersion = version || void 0;
136
+ const subdir = hashSubdir || pathSubdir;
137
+ return {
138
+ uri,
139
+ name,
140
+ ...resolvedVersion && { version: resolvedVersion },
141
+ ...subdir && { subdir }
142
+ };
143
+ }
144
+ async function _cloneAndTar(parsed, token) {
145
+ const tmpDir = await mkdtemp(join(tmpdir(), "giget-git-"));
146
+ if (token && /[\r\n]/.test(token)) throw new Error("Auth token must not contain newline characters");
147
+ const execEnv = {
148
+ ...process.env,
149
+ GIT_TERMINAL_PROMPT: "0"
150
+ };
151
+ if (token) {
152
+ execEnv.GIT_CONFIG_COUNT = "1";
153
+ execEnv.GIT_CONFIG_KEY_0 = "http.extraHeader";
154
+ execEnv.GIT_CONFIG_VALUE_0 = `Authorization: Bearer ${token}`;
155
+ }
156
+ const execOpts = {
157
+ env: execEnv,
158
+ timeout: 6e4
159
+ };
160
+ const status = _createStatus();
161
+ const gitExec = (args) => _gitSpawn(args, execOpts, status);
162
+ const gitExecIn = (args) => _gitSpawn(args, {
163
+ ...execOpts,
164
+ cwd: tmpDir
165
+ }, status);
166
+ try {
167
+ const cloneArgs = [
168
+ "clone",
169
+ "--progress",
170
+ "--depth",
171
+ "1"
172
+ ];
173
+ if (parsed.subdir) cloneArgs.push("--filter=blob:none", "--sparse", "--no-checkout");
174
+ if (parsed.version) cloneArgs.push("--branch", parsed.version);
175
+ cloneArgs.push("--", parsed.uri, tmpDir);
176
+ try {
177
+ status.update("Cloning...");
178
+ await gitExec(cloneArgs);
179
+ status.update("Cloned.");
180
+ } catch (cloneError) {
181
+ if (!parsed.version) throw cloneError;
182
+ debug("Shallow clone failed, falling back to full clone:", cloneError);
183
+ status.update("Shallow clone failed, cloning...");
184
+ await rm(tmpDir, {
185
+ recursive: true,
186
+ force: true
187
+ });
188
+ await mkdir(tmpDir, { recursive: true });
189
+ await gitExecIn(["init"]);
190
+ await gitExecIn([
191
+ "remote",
192
+ "add",
193
+ "origin",
194
+ parsed.uri
195
+ ]);
196
+ await gitExecIn(["fetch", "origin"]);
197
+ await gitExecIn(["checkout", parsed.version]);
198
+ status.update("Fetched.");
199
+ }
200
+ if (parsed.subdir) {
201
+ status.update(`Sparse checkout ${parsed.subdir}...`);
202
+ await gitExecIn([
203
+ "sparse-checkout",
204
+ "set",
205
+ parsed.subdir
206
+ ]);
207
+ await gitExecIn(["checkout"]);
208
+ }
209
+ status.update("Packing...");
210
+ const tarDir = parsed.subdir ? join(tmpDir, parsed.subdir) : tmpDir;
211
+ const { create } = await import("./libs/tar.mjs").then((n) => n.t);
212
+ status.done();
213
+ const stream = create({
214
+ gzip: true,
215
+ cwd: tarDir,
216
+ filter: (path) => !path.startsWith(".git/") && path !== ".git" && !path.startsWith("./.git/") && path !== "./.git"
217
+ }, ["."]).pipe(new PassThrough());
218
+ let cleaned = false;
219
+ const cleanup = () => {
220
+ if (cleaned) return;
221
+ cleaned = true;
222
+ rm(tmpDir, {
223
+ recursive: true,
224
+ force: true
225
+ });
226
+ };
227
+ stream.on("end", cleanup);
228
+ stream.on("error", cleanup);
229
+ stream.on("close", cleanup);
230
+ return stream;
231
+ } catch (error) {
232
+ status.done();
233
+ await rm(tmpDir, {
234
+ recursive: true,
235
+ force: true
236
+ });
237
+ throw error;
238
+ }
239
+ }
240
+ const _spinnerFrames = [
241
+ "⠋",
242
+ "⠙",
243
+ "⠹",
244
+ "⠸",
245
+ "⠼",
246
+ "⠴",
247
+ "⠦",
248
+ "⠧",
249
+ "⠇",
250
+ "⠏"
251
+ ];
252
+ function _gitSpawn(args, opts, status) {
253
+ return new Promise((resolve, reject) => {
254
+ const proc = spawn("git", args, {
255
+ ...opts,
256
+ stdio: [
257
+ "ignore",
258
+ "pipe",
259
+ "pipe"
260
+ ]
261
+ });
262
+ proc.stdout.resume();
263
+ let lastLine = "";
264
+ proc.stderr?.on("data", (chunk) => {
265
+ const str = chunk.toString();
266
+ for (const line of str.split(/[\r\n]/)) {
267
+ const clean = line.trim();
268
+ if (clean) lastLine = clean;
269
+ }
270
+ if (status) status.update(lastLine);
271
+ });
272
+ proc.on("close", (code) => {
273
+ if (code === 0) resolve(lastLine);
274
+ else reject(/* @__PURE__ */ new Error(`git ${args[0]} exited with code ${code}. Is git installed?`));
275
+ });
276
+ proc.on("error", (err) => {
277
+ if (err.code === "ENOENT") reject(/* @__PURE__ */ new Error("git is not installed or not found in PATH"));
278
+ else reject(err);
279
+ });
280
+ });
281
+ }
282
+ function _createStatus() {
283
+ if (!process.stderr.isTTY) return {
284
+ update(_text) {},
285
+ done() {}
286
+ };
287
+ let msg = "";
288
+ let frame = 0;
289
+ const render = () => {
290
+ const spinner = _spinnerFrames[frame % _spinnerFrames.length];
291
+ frame++;
292
+ process.stderr.write(`\x1B[2K\r\x1B[2m${spinner} ${msg}\x1B[0m`);
293
+ };
294
+ const interval = setInterval(render, 80);
295
+ return {
296
+ update(text) {
297
+ msg = text;
298
+ render();
299
+ },
300
+ done() {
301
+ clearInterval(interval);
302
+ process.stderr.write("\x1B[2K\r");
303
+ }
304
+ };
305
+ }
306
+ //#endregion
307
+ //#region src/providers.ts
308
+ const http = async (input, options) => {
309
+ if (input.endsWith(".json")) return await _httpJSON(input, options);
310
+ const url = new URL(input);
311
+ let name = basename$1(url.pathname);
312
+ try {
313
+ const head = await sendFetch(url.href, {
314
+ method: "HEAD",
315
+ validateStatus: true,
316
+ headers: { authorization: options.auth ? `Bearer ${options.auth}` : void 0 }
317
+ });
318
+ if ((head.headers.get("content-type") || "").includes("application/json")) return await _httpJSON(input, options);
319
+ const filename = head.headers.get("content-disposition")?.match(/filename="?(.+)"?/)?.[1];
320
+ if (filename) name = filename.split(".")[0];
321
+ } catch (error) {
322
+ debug(`Failed to fetch HEAD for ${url.href}:`, error);
323
+ }
324
+ return {
325
+ name: `${name}-${url.href.slice(0, 8)}`,
326
+ version: "",
327
+ subdir: "",
328
+ tar: url.href,
329
+ defaultDir: name,
330
+ headers: { Authorization: options.auth ? `Bearer ${options.auth}` : void 0 }
331
+ };
332
+ };
333
+ const _httpJSON = async (input, options) => {
334
+ const info = await (await sendFetch(input, {
335
+ validateStatus: true,
336
+ headers: { authorization: options.auth ? `Bearer ${options.auth}` : void 0 }
337
+ })).json();
338
+ if (!info.tar || !info.name) throw new Error(`Invalid template info from ${input}. name or tar fields are missing!`);
339
+ return info;
340
+ };
341
+ const github = (input, options) => {
342
+ const parsed = parseGitURI(input);
343
+ const githubAPIURL = process.env.GIGET_GITHUB_URL || "https://api.github.com";
344
+ return {
345
+ name: parsed.repo.replace("/", "-"),
346
+ version: parsed.ref,
347
+ subdir: parsed.subdir,
348
+ headers: {
349
+ Authorization: options.auth ? `Bearer ${options.auth}` : void 0,
350
+ Accept: "application/vnd.github+json",
351
+ "X-GitHub-Api-Version": "2022-11-28"
352
+ },
353
+ url: `${githubAPIURL.replace("api.github.com", "github.com")}/${parsed.repo}/tree/${parsed.ref}${parsed.subdir}`,
354
+ tar: `${githubAPIURL}/repos/${parsed.repo}/tarball/${parsed.ref}`
355
+ };
356
+ };
357
+ const gitlab = (input, options) => {
358
+ const parsed = parseGitURI(input, { expandRepo: true });
359
+ const gitlab = process.env.GIGET_GITLAB_URL || "https://gitlab.com";
360
+ return {
361
+ name: parsed.repo.replace("/", "-"),
362
+ version: parsed.ref,
363
+ subdir: parsed.subdir,
364
+ headers: {
365
+ authorization: options.auth ? `Bearer ${options.auth}` : void 0,
366
+ "sec-fetch-mode": "same-origin"
367
+ },
368
+ url: `${gitlab}/${parsed.repo}/tree/${parsed.ref}${parsed.subdir}`,
369
+ tar: `${gitlab}/${parsed.repo}/-/archive/${parsed.ref}.tar.gz`
370
+ };
371
+ };
372
+ const bitbucket = (input, options) => {
373
+ const parsed = parseGitURI(input);
374
+ return {
375
+ name: parsed.repo.replace("/", "-"),
376
+ version: parsed.ref,
377
+ subdir: parsed.subdir,
378
+ headers: { authorization: options.auth ? `Bearer ${options.auth}` : void 0 },
379
+ url: `https://bitbucket.com/${parsed.repo}/src/${parsed.ref}${parsed.subdir}`,
380
+ tar: `https://bitbucket.org/${parsed.repo}/get/${parsed.ref}.tar.gz`
381
+ };
382
+ };
383
+ const sourcehut = (input, options) => {
384
+ const parsed = parseGitURI(input);
385
+ return {
386
+ name: parsed.repo.replace("/", "-"),
387
+ version: parsed.ref,
388
+ subdir: parsed.subdir,
389
+ headers: { authorization: options.auth ? `Bearer ${options.auth}` : void 0 },
390
+ url: `https://git.sr.ht/~${parsed.repo}/tree/${parsed.ref}/item${parsed.subdir}`,
391
+ tar: `https://git.sr.ht/~${parsed.repo}/archive/${parsed.ref}.tar.gz`
392
+ };
393
+ };
394
+ const providers = {
395
+ http,
396
+ https: http,
397
+ git,
398
+ github,
399
+ gh: github,
400
+ gitlab,
401
+ bitbucket,
402
+ sourcehut
403
+ };
404
+ //#endregion
405
+ //#region src/registry.ts
406
+ const DEFAULT_REGISTRY = "https://raw.githubusercontent.com/unjs/giget/main/templates";
407
+ const registryProvider = (registryEndpoint = DEFAULT_REGISTRY, options = {}) => {
408
+ return (async (input) => {
409
+ const start = Date.now();
410
+ const registryURL = `${registryEndpoint}/${input}.json`;
411
+ const result = await sendFetch(registryURL, { headers: { authorization: options.auth ? `Bearer ${options.auth}` : void 0 } });
412
+ if (result.status >= 400) throw new Error(`Failed to download ${input} template info from ${registryURL}: ${result.status} ${result.statusText}`);
413
+ const info = await result.json();
414
+ if (!info.tar || !info.name) throw new Error(`Invalid template info from ${registryURL}. name or tar fields are missing!`);
415
+ debug(`Fetched ${input} template info from ${registryURL} in ${Date.now() - start}ms`);
416
+ return info;
417
+ });
418
+ };
419
+ //#endregion
420
+ //#region src/giget.ts
421
+ const sourceProtoRe = /^([\w+-.]+):/;
422
+ async function downloadTemplate(input, options = {}) {
423
+ options.registry = process.env.GIGET_REGISTRY ?? options.registry;
424
+ options.auth = process.env.GIGET_AUTH ?? options.auth;
425
+ const registry = options.registry === false ? void 0 : registryProvider(options.registry, { auth: options.auth });
426
+ let providerName = options.provider || (registry ? "registry" : "github");
427
+ let source = input;
428
+ const sourceProviderMatch = input.match(sourceProtoRe);
429
+ if (sourceProviderMatch) {
430
+ providerName = sourceProviderMatch[1];
431
+ source = input.slice(sourceProviderMatch[0].length);
432
+ if (providerName === "http" || providerName === "https") source = input;
433
+ }
434
+ if (providerName.endsWith("+git")) {
435
+ source = `${providerName.slice(0, -4)}:${source}`;
436
+ providerName = "git";
437
+ }
438
+ const provider = options.providers?.[providerName] || providers[providerName] || registry;
439
+ if (!provider) throw new Error(`Unsupported provider: ${providerName}`);
440
+ const template = await Promise.resolve().then(() => provider(source, { auth: options.auth })).catch((error) => {
441
+ throw new Error(`Failed to download template from ${providerName}: ${error.message}`);
442
+ });
443
+ if (!template) throw new Error(`Failed to resolve template from ${providerName}`);
444
+ template.name = (template.name || "template").replace(/[^\da-z-]/gi, "-");
445
+ template.defaultDir = (template.defaultDir || template.name).replace(/[^\da-z-]/gi, "-");
446
+ const tarPath = resolve$1(resolve$1(cacheDirectory(), providerName, template.name), (template.version || template.name) + ".tar.gz");
447
+ if (options.preferOffline && existsSync(tarPath)) options.offline = true;
448
+ if (!options.offline) {
449
+ await mkdir(dirname$1(tarPath), { recursive: true });
450
+ const s = Date.now();
451
+ if (typeof template.tar === "function") {
452
+ const tarFn = template.tar;
453
+ await (async () => {
454
+ const stream = await tarFn({ auth: options.auth });
455
+ await pipeline$1(stream instanceof Readable ? stream : Readable.fromWeb(stream), createWriteStream(tarPath));
456
+ })().catch((error) => {
457
+ if (!existsSync(tarPath)) throw error;
458
+ debug("Download error. Using cached version:", error);
459
+ options.offline = true;
460
+ });
461
+ } else await download(template.tar, tarPath, { headers: {
462
+ Authorization: options.auth ? `Bearer ${options.auth}` : void 0,
463
+ ...normalizeHeaders(template.headers)
464
+ } }).catch((error) => {
465
+ if (!existsSync(tarPath)) throw error;
466
+ debug("Download error. Using cached version:", error);
467
+ options.offline = true;
468
+ });
469
+ debug(`Downloaded to ${tarPath} in ${Date.now() - s}ms`);
470
+ }
471
+ if (!existsSync(tarPath)) throw new Error(`Tarball not found: ${tarPath} (offline: ${options.offline})`);
472
+ const extractPath = resolve$1(resolve$1(options.cwd || "."), options.dir || template.defaultDir);
473
+ if (options.forceClean) await rm(extractPath, {
474
+ recursive: true,
475
+ force: true
476
+ });
477
+ if (!options.force && existsSync(extractPath) && readdirSync(extractPath).length > 0) throw new Error(`Destination ${extractPath} already exists.`);
478
+ await mkdir(extractPath, { recursive: true });
479
+ const s = Date.now();
480
+ const subdir = template.subdir?.replace(/^\//, "") || "";
481
+ const { extract } = await import("./libs/tar.mjs").then((n) => n.t);
482
+ await extract({
483
+ file: tarPath,
484
+ cwd: extractPath,
485
+ onReadEntry(entry) {
486
+ entry.path = entry.path.split("/").splice(1).join("/");
487
+ if (subdir) if (entry.path.startsWith(subdir + "/")) entry.path = entry.path.slice(subdir.length);
488
+ else entry.path = "";
489
+ }
490
+ });
491
+ debug(`Extracted to ${extractPath} in ${Date.now() - s}ms`);
492
+ if (options.install) {
493
+ debug("Installing dependencies...");
494
+ const { installDependencies } = await import("./libs/nypm.mjs").then((n) => n.t);
495
+ await installDependencies({
496
+ cwd: extractPath,
497
+ silent: options.silent,
498
+ ...typeof options.install === "object" ? options.install : {}
499
+ });
500
+ }
501
+ return {
502
+ ...template,
503
+ source,
504
+ dir: extractPath
505
+ };
506
+ }
507
+ //#endregion
508
+ export { registryProvider as n, startShell as r, downloadTemplate as t };