binary-collections 2.0.9 → 2.0.11

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 (306) hide show
  1. package/.puppeterrc.cjs +25 -0
  2. package/binaries/binary-executor.cjs +178 -0
  3. package/{bin → binaries}/clean-nodemodule +0 -0
  4. package/binaries/clean-nodemodule.cjs +178 -0
  5. package/binaries/clean-nodemodule.cmd +4 -0
  6. package/{bin → binaries}/clean-nodemodules +0 -0
  7. package/binaries/clean-nodemodules.cjs +178 -0
  8. package/binaries/clean-nodemodules.cmd +5 -0
  9. package/{bin → binaries}/dev +0 -0
  10. package/binaries/dev.cjs +178 -0
  11. package/{bin → binaries}/empty +0 -0
  12. package/binaries/empty.cjs +178 -0
  13. package/{bin → binaries}/git-reduce-size +0 -0
  14. package/binaries/git-reduce-size.cjs +178 -0
  15. package/binaries/javakill.cjs +178 -0
  16. package/{bin → binaries}/javakill.cmd +0 -0
  17. package/binaries/kill-night-crows.bat +7 -0
  18. package/binaries/kill-night-crows.ps1 +172 -0
  19. package/{bin → binaries}/kill-process +0 -0
  20. package/binaries/kill-process.cjs +178 -0
  21. package/binaries/nodekill.cjs +178 -0
  22. package/{bin → binaries}/nodekill.ps1 +0 -0
  23. package/{bin → binaries}/prod +0 -0
  24. package/binaries/prod.cjs +178 -0
  25. package/binaries/py +111 -0
  26. package/binaries/py.cjs +178 -0
  27. package/binaries/py.cmd +49 -0
  28. package/{bin → binaries}/rmfind +0 -0
  29. package/binaries/rmfind.cjs +178 -0
  30. package/{bin → binaries}/rmx +0 -0
  31. package/binaries/rmx.cjs +178 -0
  32. package/{bin → binaries}/submodule-token +0 -0
  33. package/binaries/submodule-token.cjs +178 -0
  34. package/binaries/test-cjs +10 -0
  35. package/binaries/test-cjs.cjs +178 -0
  36. package/binaries/test-cjs.cmd +11 -0
  37. package/binaries/yarn-clean +32 -0
  38. package/binaries/yarn-clean.cjs +178 -0
  39. package/binaries/yarn-clean.cmd +30 -0
  40. package/binaries/yarn-clean.py +148 -0
  41. package/docs-src/clean-github-actions-caches.md +26 -0
  42. package/docs-src/free-chatgpt.md +26 -0
  43. package/lib/binary-collections-config.cjs +3 -2
  44. package/lib/binary-collections-config.mjs +2 -2
  45. package/lib/binary-collections.cjs +513 -105
  46. package/lib/binary-collections.mjs +178 -117
  47. package/lib/changelog.cjs +64 -16
  48. package/lib/changelog.mjs +177 -171
  49. package/lib/{chunk-VVEZVNIV.mjs → chunk-2CBJCW7E.mjs} +3 -3
  50. package/lib/chunk-34IQDTLZ.mjs +27 -0
  51. package/lib/chunk-3HFFECCI.mjs +27 -0
  52. package/lib/chunk-4UHL4WVN.mjs +136 -0
  53. package/lib/{chunk-4BYBVEYC.mjs → chunk-66PAU5PS.mjs} +5 -4
  54. package/lib/chunk-6HHJRKFB.mjs +59 -0
  55. package/lib/chunk-6S4NXESK.mjs +26 -0
  56. package/lib/chunk-7XTEJHOE.mjs +193 -0
  57. package/lib/{chunk-ZYAQRPUL.mjs → chunk-7YD7IPFF.mjs} +2 -2
  58. package/lib/{chunk-SH3L6HHV.mjs → chunk-A2JQXI5Z.mjs} +2 -2
  59. package/lib/{chunk-EGSSKVDH.mjs → chunk-A3VUZEJK.mjs} +1 -1
  60. package/lib/chunk-AJDD5DZM.mjs +109 -0
  61. package/lib/chunk-BZWVHODJ.mjs +62 -0
  62. package/lib/chunk-FCDQGYBF.mjs +136 -0
  63. package/lib/chunk-FKI7IEB5.mjs +172 -0
  64. package/lib/chunk-GEYA2USY.mjs +207 -0
  65. package/lib/chunk-GJTGHXRA.mjs +356 -0
  66. package/lib/{chunk-YV7DO3YV.mjs → chunk-HLGOWBEO.mjs} +1 -1
  67. package/lib/chunk-ID2WBTE2.mjs +80 -0
  68. package/lib/chunk-JXFOHKDM.mjs +239 -0
  69. package/lib/{chunk-YX5U7XDR.mjs → chunk-M3YIYRHT.mjs} +6 -5
  70. package/lib/chunk-N436BNBK.mjs +514 -0
  71. package/lib/chunk-NCXAP7AA.mjs +31 -0
  72. package/lib/chunk-PDN26I7O.mjs +188 -0
  73. package/lib/{chunk-JGR2NW6D.mjs → chunk-PDSXF5HY.mjs} +3 -3
  74. package/lib/{chunk-AASHBCRW.mjs → chunk-QQ4A6DLD.mjs} +8 -0
  75. package/lib/{chunk-ONIBBBQ3.mjs → chunk-RWLXRTYP.mjs} +4 -3
  76. package/lib/chunk-TOIVAQF7.mjs +136 -0
  77. package/lib/chunk-V5SKYJUB.mjs +136 -0
  78. package/lib/chunk-WSRETQCA.mjs +59 -0
  79. package/lib/chunk-XA3SNBPA.mjs +184 -0
  80. package/lib/chunk-XVBFFVCJ.mjs +209 -0
  81. package/lib/chunk-YYLIQQKF.mjs +31 -0
  82. package/lib/{chunk-APBWENF6.mjs → chunk-Z6JLYU2J.mjs} +63 -16
  83. package/lib/chunk-ZDMWBSYF.mjs +81 -0
  84. package/lib/clean-github-actions-caches.cjs +291 -148
  85. package/lib/clean-github-actions-caches.mjs +4 -3
  86. package/lib/del-gradle.cjs +63 -15
  87. package/lib/del-gradle.js +2 -1
  88. package/lib/del-gradle.mjs +2 -2
  89. package/lib/del-node-modules.cjs +143 -148
  90. package/lib/del-node-modules.js +210 -14
  91. package/lib/del-node-modules.mjs +149 -18
  92. package/lib/del-ps.cjs +90 -21
  93. package/lib/del-ps.js +3 -2
  94. package/lib/del-ps.mjs +7 -5
  95. package/lib/del-yarn-caches.cjs +87 -18
  96. package/lib/del-yarn-caches.js +38 -3
  97. package/lib/del-yarn-caches.mjs +6 -6
  98. package/lib/find-node-modules-cli.cjs +5 -4
  99. package/lib/find-node-modules-cli.js +2 -1
  100. package/lib/find-node-modules-cli.mjs +2 -2
  101. package/lib/find-node-modules.cjs +4 -3
  102. package/lib/{find-node-modules.d.ts → find-node-modules.d.cts} +1 -1
  103. package/lib/find-node-modules.mjs +2 -2
  104. package/lib/free-chatgpt.cjs +754 -0
  105. package/lib/free-chatgpt.js +51 -0
  106. package/lib/free-chatgpt.mjs +50 -0
  107. package/lib/git/gitattributes.cjs +2 -1
  108. package/lib/git/{gitattributes.d.ts → gitattributes.d.cts} +7 -2
  109. package/lib/git/gitattributes.mjs +2 -2
  110. package/lib/git/line-endings.cjs +298 -64
  111. package/lib/git/line-endings.mjs +4 -4
  112. package/lib/git/normalize.cjs +26 -36
  113. package/lib/git/normalize.mjs +2 -2
  114. package/lib/git/permissions.cjs +77 -11
  115. package/lib/git/permissions.mjs +3 -3
  116. package/lib/git/pull-strategy.cjs +76 -9
  117. package/lib/git/pull-strategy.mjs +3 -3
  118. package/lib/git/undo-commit-cli.cjs +110 -0
  119. package/lib/git/undo-commit-cli.d.ts +1 -0
  120. package/lib/git/undo-commit-cli.js +4 -0
  121. package/lib/git/undo-commit-cli.mjs +14 -0
  122. package/lib/git/undo-commit.cjs +81 -0
  123. package/lib/git/undo-commit.d.cts +1 -0
  124. package/lib/git/undo-commit.mjs +7 -0
  125. package/lib/git/undo-staged-cli.cjs +110 -0
  126. package/lib/git/undo-staged-cli.d.ts +1 -0
  127. package/lib/git/undo-staged-cli.js +4 -0
  128. package/lib/git/undo-staged-cli.mjs +14 -0
  129. package/lib/git/undo-staged.cjs +81 -0
  130. package/lib/git/undo-staged.d.cts +1 -0
  131. package/lib/git/undo-staged.mjs +7 -0
  132. package/lib/git/user-config.cjs +313 -83
  133. package/lib/git/user-config.mjs +4 -4
  134. package/lib/git/utils.cjs +40 -60
  135. package/lib/git/utils.mjs +2 -2
  136. package/lib/git-diff-cli.cjs +857 -0
  137. package/lib/git-diff-cli.js +16 -0
  138. package/lib/git-diff-cli.mjs +17 -0
  139. package/lib/git-diff.cjs +862 -58
  140. package/lib/git-diff.d.ts +38 -83
  141. package/lib/git-diff.js +152 -0
  142. package/lib/git-diff.mjs +23 -85
  143. package/lib/git-fix.cjs +733 -97
  144. package/lib/git-fix.mjs +10 -9
  145. package/lib/git-purge.cjs +64 -16
  146. package/lib/git-purge.d.cts +1 -0
  147. package/lib/git-purge.mjs +43 -37
  148. package/lib/index.cjs +7 -6
  149. package/lib/index.d.ts +1 -1
  150. package/lib/index.js +2 -5
  151. package/lib/index.mjs +4 -4
  152. package/lib/kill-night-crows.cjs +87 -0
  153. package/lib/kill-night-crows.d.mts +1 -0
  154. package/lib/kill-night-crows.mjs +65 -0
  155. package/lib/npm-run-series.cjs +63 -16
  156. package/lib/npm-run-series.mjs +42 -36
  157. package/lib/package-resolutions-updater-cli.cjs +560 -0
  158. package/lib/package-resolutions-updater-cli.d.mts +1 -0
  159. package/lib/package-resolutions-updater-cli.mjs +124 -0
  160. package/lib/package-resolutions-updater.cjs +178 -158
  161. package/lib/package-resolutions-updater.d.mts +32 -1
  162. package/lib/package-resolutions-updater.mjs +17 -338
  163. package/lib/php-cs-fixer-staged.cjs +105 -0
  164. package/lib/php-cs-fixer-staged.d.cts +2 -0
  165. package/lib/php-cs-fixer-staged.mjs +117 -0
  166. package/lib/print-directory-tree.cjs +320 -207
  167. package/lib/print-directory-tree.mjs +3 -3
  168. package/lib/ps/connected-domain.cjs +25 -2
  169. package/lib/ps/connected-domain.d.ts +10 -2
  170. package/lib/ps/connected-domain.js +5 -2
  171. package/lib/ps/connected-domain.mjs +8 -4
  172. package/lib/ps/index.cjs +345 -322
  173. package/lib/ps/index.d.mjs +1 -1
  174. package/lib/ps/index.js +2 -1
  175. package/lib/ps/index.mjs +179 -182
  176. package/lib/ps/isWin.cjs +24 -1
  177. package/lib/ps/isWin.d.ts +1 -1
  178. package/lib/ps/isWin.js +3 -1
  179. package/lib/ps/isWin.mjs +8 -4
  180. package/lib/ps/table-parser.cjs +167 -159
  181. package/lib/ps/table-parser.d.ts +5 -0
  182. package/lib/ps/table-parser.js +10 -4
  183. package/lib/ps/table-parser.mjs +9 -5
  184. package/lib/remove-module.cjs +310 -0
  185. package/lib/remove-module.d.mts +1 -0
  186. package/lib/remove-module.mjs +111 -0
  187. package/lib/rmpath.cjs +322 -0
  188. package/lib/rmpath.d.mts +3 -0
  189. package/lib/rmpath.mjs +108 -0
  190. package/lib/submodule-install.cjs +311 -86
  191. package/lib/submodule-install.mjs +53 -5
  192. package/lib/submodule-remove-cli.cjs +107 -0
  193. package/lib/submodule-remove-cli.d.ts +1 -0
  194. package/lib/submodule-remove-cli.js +31 -0
  195. package/lib/submodule-remove-cli.mjs +28 -0
  196. package/lib/submodule-remove.cjs +46 -0
  197. package/lib/submodule-remove.d.cts +2 -0
  198. package/lib/submodule-remove.mjs +6 -0
  199. package/lib/utils/chatgpt.cjs +541 -0
  200. package/lib/utils/chatgpt.d.ts +31 -0
  201. package/lib/utils/chatgpt.js +708 -0
  202. package/lib/utils/chatgpt.mjs +8 -0
  203. package/lib/utils/findEnvFiles.cjs +107 -0
  204. package/lib/utils/findEnvFiles.d.ts +8 -0
  205. package/lib/utils/findEnvFiles.js +121 -0
  206. package/lib/utils/findEnvFiles.mjs +8 -0
  207. package/lib/utils/findWorkspaceRoot.cjs +70 -0
  208. package/lib/utils/findWorkspaceRoot.d.ts +9 -0
  209. package/lib/utils/findWorkspaceRoot.js +57 -0
  210. package/lib/utils/findWorkspaceRoot.mjs +40 -0
  211. package/lib/{utils.cjs → utils/index.cjs} +61 -14
  212. package/lib/{utils.mjs → utils/index.mjs} +2 -2
  213. package/lib/utils/isGithubTokenValid.cjs +64 -0
  214. package/lib/utils/isGithubTokenValid.d.ts +7 -0
  215. package/lib/utils/isGithubTokenValid.js +48 -0
  216. package/lib/utils/isGithubTokenValid.mjs +36 -0
  217. package/lib/yarn-reinstall.cjs +220 -38
  218. package/lib/yarn-reinstall.mjs +2 -2
  219. package/package.json +138 -104
  220. package/readme.md +48 -75
  221. package/releases/readme.md +36 -0
  222. package/requirements.txt +1 -0
  223. package/test/README.md +101 -0
  224. package/test/package.json +2 -1
  225. package/test-project/readme.md +26 -0
  226. package/tmp/test-repo/README.md +35 -0
  227. package/tmp/test-repo/package.json +1 -1
  228. package/tmp/typedoc/readme.md +320 -0
  229. package/bin/bash-dummy +0 -56
  230. package/bin/bash-dummy.cmd +0 -25
  231. package/bin/dir-tree.cmd +0 -7
  232. package/bin/git-diff +0 -4
  233. package/bin/git-diff.cmd +0 -7
  234. package/bin/git-fix +0 -36
  235. package/bin/git-fix.cmd +0 -7
  236. package/bin/rmpath +0 -70
  237. package/bin/submodule-install.txt +0 -118
  238. package/bin/submodule-remove +0 -46
  239. package/bin/submodule.txt +0 -172
  240. package/lib/binary-collections-config.d.mts +0 -18
  241. package/lib/binary-collections-config.js +0 -39
  242. package/lib/binary-collections.d.mts +0 -137
  243. package/lib/binary-collections.d.ts +0 -137
  244. package/lib/changelog.d.mts +0 -2
  245. package/lib/changelog.js +0 -226
  246. package/lib/chunk-DPKAJKFO.mjs +0 -171
  247. package/lib/chunk-G3THLIDT.mjs +0 -200
  248. package/lib/chunk-W3ENOM53.mjs +0 -18
  249. package/lib/clean-github-actions-caches.d.mts +0 -169
  250. package/lib/clean-github-actions-caches.d.ts +0 -169
  251. package/lib/del-gradle.d.mts +0 -2
  252. package/lib/del-node-modules.d.mts +0 -2
  253. package/lib/del-ps.d.mts +0 -2
  254. package/lib/del-yarn-caches.d.mts +0 -2
  255. package/lib/find-node-modules-cli.d.mts +0 -1
  256. package/lib/find-node-modules.d.mts +0 -13
  257. package/lib/find-node-modules.js +0 -53
  258. package/lib/git/gitattributes.d.mts +0 -35
  259. package/lib/git/gitattributes.js +0 -223
  260. package/lib/git/line-endings.d.mts +0 -83
  261. package/lib/git/line-endings.d.ts +0 -83
  262. package/lib/git/normalize.d.mts +0 -43
  263. package/lib/git/normalize.d.ts +0 -43
  264. package/lib/git/permissions.d.mts +0 -17
  265. package/lib/git/permissions.d.ts +0 -17
  266. package/lib/git/pull-strategy.d.mts +0 -15
  267. package/lib/git/pull-strategy.d.ts +0 -15
  268. package/lib/git/user-config.d.mts +0 -105
  269. package/lib/git/user-config.d.ts +0 -105
  270. package/lib/git/utils.d.mts +0 -69
  271. package/lib/git/utils.d.ts +0 -69
  272. package/lib/git-diff.d.mts +0 -84
  273. package/lib/git-fix.d.mts +0 -141
  274. package/lib/git-fix.d.ts +0 -141
  275. package/lib/git-purge.d.mts +0 -2
  276. package/lib/git-purge.js +0 -59
  277. package/lib/index.d.mts +0 -1
  278. package/lib/npm-run-series.d.mts +0 -1
  279. package/lib/npm-run-series.js +0 -86
  280. package/lib/package-resolutions-updater.d.ts +0 -352
  281. package/lib/print-directory-tree.d.mts +0 -234
  282. package/lib/print-directory-tree.d.ts +0 -234
  283. package/lib/ps/connected-domain.d.mts +0 -3
  284. package/lib/ps/index.d.d.mts +0 -26
  285. package/lib/ps/index.d.d.ts +0 -26
  286. package/lib/ps/index.d.mts +0 -26
  287. package/lib/ps/isWin.d.mts +0 -3
  288. package/lib/ps/table-parser.d.mts +0 -3
  289. package/lib/submodule-install.d.mts +0 -121
  290. package/lib/submodule-install.d.ts +0 -121
  291. package/lib/utils.d.mts +0 -40
  292. package/lib/utils.js +0 -181
  293. package/lib/yarn-reinstall.d.mts +0 -49
  294. package/lib/yarn-reinstall.d.ts +0 -49
  295. package/src/package-resolutions-updater.mjs +0 -350
  296. package/src/print-directory-tree.cjs +0 -234
  297. package/src/ps/index.js +0 -286
  298. package/src/yarn-reinstall.cjs +0 -49
  299. /package/{bin → binaries}/nodekill +0 -0
  300. /package/{bin → binaries}/nodekill.cmd +0 -0
  301. /package/lib/{binary-collections-config.d.ts → binary-collections-config.d.cts} +0 -0
  302. /package/lib/{changelog.d.ts → changelog.d.cts} +0 -0
  303. /package/lib/{git-purge.d.ts → free-chatgpt.d.ts} +0 -0
  304. /package/lib/{git-diff.d.cts → git-diff-cli.d.ts} +0 -0
  305. /package/lib/{npm-run-series.d.ts → npm-run-series.d.cts} +0 -0
  306. /package/lib/{utils.d.ts → utils/index.d.cts} +0 -0
package/lib/utils.js DELETED
@@ -1,181 +0,0 @@
1
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
- return new (P || (P = Promise))(function (resolve, reject) {
4
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
- step((generator = generator.apply(thisArg, _arguments || [])).next());
8
- });
9
- };
10
- const fs = require("fs");
11
- const path = require("upath");
12
- const argv = require("minimist")(process.argv.slice(2));
13
- const { exec } = require("child_process");
14
- const { URL } = require("url");
15
- const { promisify } = require("util");
16
- /**
17
- * Promisified version of Node.js exec function for async shell command execution.
18
- * @type {(command: string) => Promise<{ stdout: string, stderr: string }>}
19
- */
20
- const execAsync = promisify(exec);
21
- function parseGitRemotes() {
22
- return __awaiter(this, void 0, void 0, function* () {
23
- try {
24
- // Run the `git remote -v` command
25
- const { stdout } = yield execAsync("git remote -v");
26
- // Split the output into lines
27
- const lines = stdout.split("\n");
28
- // Object to hold the remotes
29
- const remotes = {};
30
- // Process each line
31
- lines.forEach((line) => {
32
- const [name, url] = line.split("\t");
33
- if (name && url) {
34
- const [repoUrl] = url.split(" ");
35
- try {
36
- // Parse the URL
37
- const parsedUrl = new URL(repoUrl);
38
- // Extract the path from the URL
39
- const pathParts = parsedUrl.pathname.split("/").filter(Boolean);
40
- // Check if the URL is from GitHub and has the username/repo format
41
- if (parsedUrl.hostname === "github.com" && pathParts.length === 2) {
42
- // Remove the `.git` suffix if present
43
- let repoPath = pathParts.join("/");
44
- if (repoPath.endsWith(".git")) {
45
- repoPath = repoPath.slice(0, -4); // Remove the `.git` suffix
46
- }
47
- remotes[name] = repoPath;
48
- }
49
- }
50
- catch (e) {
51
- console.error("URL Parsing Error:", e.message);
52
- }
53
- }
54
- });
55
- return remotes;
56
- }
57
- catch (error) {
58
- console.error("Error:", error.message);
59
- return {};
60
- }
61
- });
62
- }
63
- module.exports.parseGitRemotes = parseGitRemotes;
64
- /**
65
- * Joins all given path segments together and normalizes the resulting path.
66
- * Preserves the case of the drive letter on Windows.
67
- *
68
- * @param {...string} segments Path segments to join.
69
- * @returns {string} Normalized path with drive letter case preserved.
70
- */
71
- function joinPathPreserveDriveLetter(...segments) {
72
- let fullPath = require("path").join(...segments);
73
- // Check if the path starts with a drive letter (e.g., C:\)
74
- if (/^[a-z]:\\/.test(fullPath)) {
75
- // Convert the drive letter to uppercase
76
- fullPath = fullPath.charAt(0).toUpperCase() + fullPath.slice(1);
77
- }
78
- return fullPath;
79
- }
80
- module.exports.joinPathPreserveDriveLetter = joinPathPreserveDriveLetter;
81
- /**
82
- * Returns parsed command line arguments using minimist.
83
- * @returns {import('minimist').ParsedArgs} Parsed command line arguments
84
- */
85
- function getArgs() {
86
- return argv;
87
- }
88
- module.exports.getArgs = getArgs;
89
- /**
90
- * Recursively deletes a file or directory at the given path.
91
- * @param {string} fullPath Absolute path to the file or directory to delete.
92
- */
93
- function del(fullPath) {
94
- if (fs.statSync(fullPath).isDirectory()) {
95
- // delete all files each package directory
96
- const subdir = fs.readdirSync(fullPath).map((dirPath) => path.resolve(fullPath, dirPath));
97
- for (let i = 0; i < subdir.length; i++) {
98
- del(subdir[i]);
99
- }
100
- }
101
- else {
102
- try {
103
- fs.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7000 });
104
- console.log("deleted", fullPath);
105
- }
106
- catch (_) {
107
- console.log("failed delete", fullPath);
108
- }
109
- }
110
- }
111
- module.exports.del = del;
112
- /**
113
- * Handles a glob stream to delete matched files and directories recursively.
114
- * @param {glob.Glob} globStream Glob stream object.
115
- */
116
- function delStream(globStream) {
117
- globStream.stream().on("data", (result) => {
118
- const fullPath = path.resolve(process.cwd(), result);
119
- if (fs.statSync(fullPath).isDirectory()) {
120
- // delete all files each package directory
121
- const subdir = fs.readdirSync(fullPath).map((dirPath) => path.resolve(fullPath, dirPath));
122
- for (let i = 0; i < subdir.length; i++) {
123
- del(subdir[i]);
124
- }
125
- }
126
- del(fullPath);
127
- });
128
- }
129
- module.exports.delStream = delStream;
130
- /**
131
- * Creates a directory/file tree string from an array of file paths and hashes.
132
- * @param {string[]} hashArray Array of strings in the format 'relative/path/to/file hash'.
133
- * @returns {string} Directory/file tree as a string, with file hashes.
134
- */
135
- function getFileTreeString(hashArray) {
136
- const tree = {};
137
- // Map file paths to hashes for quick lookup
138
- const hashMap = {};
139
- for (const entry of hashArray) {
140
- const [filePath, hash] = entry.split(" ");
141
- hashMap[filePath] = hash;
142
- const parts = filePath.split("/");
143
- let current = tree;
144
- for (let i = 0; i < parts.length; i++) {
145
- const part = parts[i];
146
- if (i === parts.length - 1) {
147
- current[part] = null; // file
148
- }
149
- else {
150
- current[part] = current[part] || {};
151
- current = current[part];
152
- }
153
- }
154
- }
155
- function printNode(node, prefix = "", parentPath = "") {
156
- const keys = Object.keys(node).sort();
157
- let lines = [];
158
- keys.forEach((key, idx) => {
159
- const isLast = idx === keys.length - 1;
160
- const branch = isLast ? "└── " : "├── ";
161
- const currentPath = parentPath ? parentPath + "/" + key : key;
162
- if (node[key] === null) {
163
- lines.push(prefix + branch + key + " [" + (hashMap[currentPath] || "") + "]");
164
- }
165
- else {
166
- lines.push(prefix + branch + key + "/");
167
- lines = lines.concat(printNode(node[key], prefix + (isLast ? " " : "│ "), currentPath));
168
- }
169
- });
170
- return lines;
171
- }
172
- return printNode(tree, "", "").join("\n");
173
- }
174
- module.exports.getFileTreeString = getFileTreeString;
175
- /**
176
- * Creates an async delay for the specified number of milliseconds.
177
- * @param {number} ms Number of milliseconds to delay.
178
- * @returns {Promise<void>} Promise that resolves after the specified delay.
179
- */
180
- const delay = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
181
- module.exports.delay = delay;
@@ -1,49 +0,0 @@
1
- const { execSync } = require("child_process");
2
- const { getArgs } = require("./utils.js");
3
- const args = getArgs();
4
- const positional = args._ || [];
5
-
6
- if (positional.length === 0) {
7
- console.error("Usage: yarn-reinstall <packageName> [--dev|-D|--peer|-P|--optional|-O]");
8
- process.exit(1);
9
- }
10
-
11
- const packageName = positional[0];
12
- const flags = positional.slice(1).concat(
13
- Object.keys(args)
14
- .filter((k) => k !== "_" && args[k] === true)
15
- .map((k) => `--${k}`)
16
- );
17
-
18
- if (!packageName) {
19
- console.error("Please provide a package name.");
20
- process.exit(1);
21
- }
22
-
23
- // Remove and add commands
24
- const removeCmd = `yarn remove ${packageName}`;
25
- const addCmd = `yarn add ${packageName} ${flags.join(" ")}`.trim();
26
-
27
- try {
28
- // Check if the package is installed before removing
29
- let isInstalled = false;
30
- try {
31
- const listOutput = execSync(`yarn list --pattern "${packageName}" --depth=0`, { encoding: "utf8" });
32
- isInstalled = listOutput.includes(packageName + "@");
33
- } catch (_e) {
34
- // If yarn list fails, assume not installed
35
- isInstalled = false;
36
- }
37
-
38
- if (isInstalled) {
39
- console.log(`Running: ${removeCmd}`);
40
- execSync(removeCmd, { stdio: "inherit" });
41
- } else {
42
- console.warn(`Package "${packageName}" was not installed or not referenced, skipping remove.`);
43
- }
44
-
45
- console.log(`Running: ${addCmd}`);
46
- execSync(addCmd, { stdio: "inherit" });
47
- } catch (err) {
48
- process.exit(err.status || 1);
49
- }
@@ -1,49 +0,0 @@
1
- const { execSync } = require("child_process");
2
- const { getArgs } = require("./utils.js");
3
- const args = getArgs();
4
- const positional = args._ || [];
5
-
6
- if (positional.length === 0) {
7
- console.error("Usage: yarn-reinstall <packageName> [--dev|-D|--peer|-P|--optional|-O]");
8
- process.exit(1);
9
- }
10
-
11
- const packageName = positional[0];
12
- const flags = positional.slice(1).concat(
13
- Object.keys(args)
14
- .filter((k) => k !== "_" && args[k] === true)
15
- .map((k) => `--${k}`)
16
- );
17
-
18
- if (!packageName) {
19
- console.error("Please provide a package name.");
20
- process.exit(1);
21
- }
22
-
23
- // Remove and add commands
24
- const removeCmd = `yarn remove ${packageName}`;
25
- const addCmd = `yarn add ${packageName} ${flags.join(" ")}`.trim();
26
-
27
- try {
28
- // Check if the package is installed before removing
29
- let isInstalled = false;
30
- try {
31
- const listOutput = execSync(`yarn list --pattern "${packageName}" --depth=0`, { encoding: "utf8" });
32
- isInstalled = listOutput.includes(packageName + "@");
33
- } catch (_e) {
34
- // If yarn list fails, assume not installed
35
- isInstalled = false;
36
- }
37
-
38
- if (isInstalled) {
39
- console.log(`Running: ${removeCmd}`);
40
- execSync(removeCmd, { stdio: "inherit" });
41
- } else {
42
- console.warn(`Package "${packageName}" was not installed or not referenced, skipping remove.`);
43
- }
44
-
45
- console.log(`Running: ${addCmd}`);
46
- execSync(addCmd, { stdio: "inherit" });
47
- } catch (err) {
48
- process.exit(err.status || 1);
49
- }
@@ -1,350 +0,0 @@
1
- /**
2
- * 📦 GitHub Package Resolver
3
- *
4
- * This script updates the commit hashes in `package.json`'s `resolutions` field
5
- * for GitHub tarball URLs (typically using `raw/branch-name/...`) to point to the
6
- * latest commit SHA of the corresponding repository and branch.
7
- *
8
- * 🔍 Features:
9
- * - Parses GitHub URLs to extract repository owner, name, and branch.
10
- * - Fetches the latest commit SHA across all branches using GitHub's API.
11
- * - Replaces the old branch or commit in the URL with the latest SHA.
12
- * - Overwrites `package.json` with the updated URLs.
13
- *
14
- * 🛠 Requirements:
15
- * - GitHub Personal Access Token (GITHUB_TOKEN) via `.env`
16
- * - ESM support (`type: "module"` in `package.json`)
17
- * - Node.js v18+ recommended for ESM and `fetch` fallback compatibility
18
- *
19
- * 🧩 Dependencies:
20
- * - `ansi-colors` – for styled terminal output
21
- * - `dotenv` – to load GitHub token from `.env`
22
- *
23
- * ✅ Use case:
24
- * - Ensures package resolutions always use immutable SHAs instead of mutable branch names.
25
- * - Helps achieve deterministic builds in monorepos or projects with internal GitHub packages.
26
- */
27
-
28
- import ansiColors from "ansi-colors";
29
- import * as dotenv from "dotenv";
30
- import fs from "fs";
31
- import https from "https";
32
- import os from "os";
33
- import path from "path";
34
- import { getArgs } from "./utils.js";
35
-
36
- const projectDir = process.cwd();
37
- const envPath = path.join(projectDir, ".env");
38
- const args = getArgs();
39
- const ACCESS_TOKEN = process.env.GITHUB_TOKEN || process.env.ACCESS_TOKEN;
40
-
41
- // Show help if --help/-h is passed
42
- if (args.help || args.h) {
43
- showHelp();
44
- }
45
-
46
- /**
47
- * Display help information for the package-resolutions-updater script.
48
- */
49
- function showHelp() {
50
- const helpText = `\n\
51
- GitHub Package Resolutions Updater\n\
52
- Usage:\n node src/package-resolutions-updater.mjs [options]\n\
53
- Options:\n --help, -h Show this help message\n\
54
- Description:\n Updates the commit hashes in package.json's 'resolutions' field for GitHub tarball URLs to point to the latest commit SHA of the corresponding repository and branch.\n\
55
- Features:\n - Parses GitHub URLs to extract repository owner, name, and branch.\n - Fetches the latest commit SHA across all branches using GitHub's API.\n - Replaces the old branch or commit in the URL with the latest SHA.\n - Overwrites package.json with the updated URLs.\n\
56
- Requirements:\n - GitHub Personal Access Token (GITHUB_TOKEN) via .env\n - ESM support (type: "module" in package.json)\n - Node.js v18+ recommended\n\
57
- Dependencies:\n - ansi-colors – for styled terminal output\n - dotenv – to load GitHub token from .env\n\
58
- Examples:\n node src/package-resolutions-updater.mjs\n node src/package-resolutions-updater.mjs --help\n\n`;
59
- console.log(helpText);
60
- process.exit(0);
61
- }
62
-
63
- // Load the .env file using dotenv (ESM import)
64
- if (fs.existsSync(envPath)) dotenv.config({ path: envPath });
65
-
66
- // 📌 Static override rules
67
- const specialPackageOverrides = [
68
- // SBG packages
69
- { pkg: "sbg-utility", branch: "sbg-utility", repo: "static-blog-generator", owner: "dimaslanjaka" },
70
- { pkg: "sbg-api", branch: "sbg-api", repo: "static-blog-generator", owner: "dimaslanjaka" },
71
- { pkg: "instant-indexing", branch: "instant-indexing", repo: "static-blog-generator", owner: "dimaslanjaka" },
72
- { pkg: "sbg-server", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
73
- { pkg: "sbg-cli", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
74
- { pkg: "static-blog-generator", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
75
- // Hexo family
76
- { pkg: "hexo", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
77
- { pkg: "hexo-util", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
78
- { pkg: "warehouse", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
79
- { pkg: "hexo-server", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
80
- { pkg: "hexo-log", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
81
- { pkg: "hexo-front-matter", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
82
- { pkg: "hexo-cli", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
83
- { pkg: "hexo-asset-link", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
84
- { pkg: "hexo-post-parser", branch: "pre-release", repo: "hexo-post-parser", owner: "dimaslanjaka" },
85
- { pkg: "hexo-seo", branch: "pre-release", repo: "hexo-seo", owner: "dimaslanjaka" },
86
- { pkg: "hexo-is", branch: "master", repo: "hexo-is", owner: "dimaslanjaka" },
87
- { pkg: "markdown-it", branch: "master", repo: "markdown-it", owner: "dimaslanjaka" },
88
- { pkg: "hexo-renderers", branch: "pre-release", repo: "hexo-renderers", owner: "dimaslanjaka" },
89
- { pkg: "hexo-shortcodes", branch: "pre-release", repo: "hexo-shortcodes", owner: "dimaslanjaka" },
90
- { pkg: "google-news-sitemap", branch: "master", repo: "google-news-sitemap", owner: "dimaslanjaka" },
91
- { pkg: "git-command-helper", branch: "pre-release", repo: "git-command-helper", owner: "dimaslanjaka" },
92
- {
93
- pkg: "nodejs-package-types",
94
- branch: "main",
95
- repo: "nodejs-package-types",
96
- owner: "dimaslanjaka"
97
- },
98
- { pkg: "cross-spawn", branch: "private", repo: "node-cross-spawn", owner: "dimaslanjaka" },
99
- { pkg: "hexo-generator-redirect", branch: "master", repo: "hexo-generator-redirect", owner: "dimaslanjaka" },
100
- { pkg: "binary-collections", branch: "master", repo: "bin", owner: "dimaslanjaka" },
101
- { pkg: "@types/hexo", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
102
- { pkg: "@types/git-command-helper", branch: "pre-release", repo: "git-command-helper", owner: "dimaslanjaka" }
103
- ];
104
-
105
- // --- Optimized: Load package.json once at the top ---
106
- const pkgPath = path.join(process.cwd(), "package.json");
107
- let pkg;
108
- try {
109
- pkg = JSON.parse(fs.readFileSync(pkgPath, "utf-8"));
110
- } catch (e) {
111
- console.error(ansiColors.red(`Failed to read package.json: ${e.message}`));
112
- process.exit(1);
113
- }
114
-
115
- // --- Use a random User-Agent for GitHub API requests ---
116
- const GITHUB_USER_AGENTS = [
117
- "octokit-rest.js/19.0.7",
118
- "GitHub CLI/2.40.0",
119
- "Mozilla/5.0 (compatible; GitHubCopilot/1.0)",
120
- "PostmanRuntime/7.32.3",
121
- "binary-collections-resolver/1.0 (+https://github.com/dimaslanjaka/bin)"
122
- ];
123
-
124
- // --- User-Agent persistence in system temp folder ---
125
- const userAgentDir = path.join(os.tmpdir(), "nodejs");
126
- const userAgentFile = path.join(userAgentDir, "useragent.txt");
127
- let selectedUserAgent;
128
- try {
129
- if (!fs.existsSync(userAgentDir)) fs.mkdirSync(userAgentDir, { recursive: true });
130
- if (fs.existsSync(userAgentFile)) {
131
- const fileAgent = fs.readFileSync(userAgentFile, "utf-8").trim();
132
- if (GITHUB_USER_AGENTS.includes(fileAgent)) {
133
- selectedUserAgent = fileAgent;
134
- }
135
- }
136
- if (!selectedUserAgent) {
137
- selectedUserAgent = GITHUB_USER_AGENTS[Math.floor(Math.random() * GITHUB_USER_AGENTS.length)];
138
- fs.writeFileSync(userAgentFile, selectedUserAgent, "utf-8");
139
- }
140
- } catch (_e) {
141
- // fallback to random if any error
142
- selectedUserAgent = GITHUB_USER_AGENTS[Math.floor(Math.random() * GITHUB_USER_AGENTS.length)];
143
- }
144
-
145
- /**
146
- * Fetch JSON from a URL with GitHub headers.
147
- * @param {string} url
148
- * @returns {Promise<any>}
149
- */
150
- function fetchJson(url) {
151
- const headers = {
152
- "User-Agent": selectedUserAgent,
153
- Accept: "application/vnd.github.v3+json",
154
- "X-GitHub-Api-Version": "2022-11-28",
155
- ...(ACCESS_TOKEN ? { Authorization: `token ${ACCESS_TOKEN}` } : {})
156
- };
157
- return new Promise((resolve, reject) => {
158
- https
159
- .get(url, { headers }, (res) => {
160
- let data = "";
161
- res.on("data", (chunk) => (data += chunk));
162
- res.on("end", () => {
163
- try {
164
- const json = JSON.parse(data);
165
- if (res.statusCode < 200 || res.statusCode >= 300) {
166
- return reject(
167
- new Error(`GitHub API Error ${res.statusCode}: ${json.message || "Unknown error"}\nURL: ${url}`)
168
- );
169
- }
170
- resolve(json);
171
- } catch {
172
- reject(new Error(`Invalid JSON from: ${url}`));
173
- }
174
- });
175
- })
176
- .on("error", reject);
177
- });
178
- }
179
-
180
- /**
181
- * Get latest commit SHA from a specific branch.
182
- */
183
- async function getLatestCommit(owner, repo, branch = "main") {
184
- const url = `https://api.github.com/repos/${owner}/${repo}/commits/${branch}`;
185
- const json = await fetchJson(url);
186
-
187
- const sha = json.sha;
188
- const dateStr = json.commit?.committer?.date || json.commit?.author?.date;
189
-
190
- if (!sha || !dateStr) {
191
- console.log(json);
192
- throw new Error(`Missing SHA or date for ${owner}/${repo}@${branch}`);
193
- }
194
-
195
- return {
196
- owner,
197
- repo,
198
- branch,
199
- sha,
200
- date: new Date(dateStr).toISOString()
201
- };
202
- }
203
-
204
- /**
205
- * Get latest commit SHA from all branches and pick the latest.
206
- */
207
- async function getLatestCommitAcrossBranches(owner, repo) {
208
- const branches = await fetchJson(`https://api.github.com/repos/${owner}/${repo}/branches`);
209
-
210
- const commits = await Promise.all(
211
- branches.map(async ({ name, commit }) => {
212
- const commitSha = commit?.sha;
213
- if (!commitSha) {
214
- console.warn(`No commit SHA for '${owner}/${repo}' branch: ${name}`);
215
- return { branch: name, sha: "", date: new Date(0) };
216
- }
217
-
218
- try {
219
- const commitData = await fetchJson(`https://api.github.com/repos/${owner}/${repo}/commits/${commitSha}`);
220
- const dateStr = commitData.commit?.committer?.date || commitData.commit?.author?.date;
221
- const date = dateStr ? new Date(dateStr) : new Date(0);
222
- return { branch: name, sha: commitData.sha, date };
223
- } catch (e) {
224
- console.warn(`Failed to fetch commit for ${name}: ${e.message}`);
225
- return { branch: name, sha: commitSha, date: new Date(0) };
226
- }
227
- })
228
- );
229
-
230
- const latest = commits.reduce((a, b) => (a.date > b.date ? a : b), { date: new Date(0) });
231
-
232
- return {
233
- owner,
234
- repo,
235
- branch: latest.branch,
236
- sha: latest.sha,
237
- date: latest.date.toISOString()
238
- };
239
- }
240
-
241
- /**
242
- * Replace the branch or commit in a GitHub raw URL with the latest hash.
243
- */
244
- function replaceRawWithLatestHash(url, latestHash) {
245
- const match = url.match(/^https:\/\/github\.com\/([^/]+)\/([^/]+)\/raw\/([^/]+)\/(.+)$/);
246
- if (!match) throw new Error("Invalid GitHub raw URL");
247
-
248
- const [, owner, repo, _oldHash, path] = match;
249
- return `https://github.com/${owner}/${repo}/raw/${latestHash}/${path}`;
250
- }
251
-
252
- /**
253
- * Parse GitHub URLs and extract owner, repo, branch, and original URL.
254
- */
255
- function parseGitHubUrl(url) {
256
- const ghRepoRoot = /^https:\/\/github\.com\/([^/]+)\/([^/]+)\/?$/;
257
- const ghTreeOrBlob = /^https:\/\/github\.com\/([^/]+)\/([^/]+)\/(tree|blob)\/([^/]+(?:\/[^/]+)*)/;
258
- const ghRaw = /^https:\/\/raw\.githubusercontent\.com\/([^/]+)\/([^/]+)\/([^/]+)(\/.+)?$/;
259
- const ghDotComRaw = /^https:\/\/github\.com\/([^/]+)\/([^/]+)\/raw\/([^/]+)\/.+/;
260
-
261
- let match;
262
-
263
- if ((match = url.match(ghRaw))) {
264
- const [, owner, repo, branch] = match;
265
- return { owner, repo, branch, url };
266
- }
267
-
268
- if ((match = url.match(ghDotComRaw))) {
269
- const [, owner, repo, branch] = match;
270
- return { owner, repo, branch, url };
271
- }
272
-
273
- if ((match = url.match(ghTreeOrBlob))) {
274
- const [, owner, repo, , branchPath] = match;
275
- return { owner, repo, branch: branchPath, url };
276
- }
277
-
278
- if ((match = url.match(ghRepoRoot))) {
279
- const [, owner, repo] = match;
280
- return { owner, repo, url };
281
- }
282
-
283
- throw new Error(`Unsupported GitHub URL: ${url}`);
284
- }
285
-
286
- // --- Main logic ---
287
- (async () => {
288
- const entries = Object.entries(pkg.resolutions || {});
289
- if (entries.length === 0) {
290
- console.log(ansiColors.yellow("No resolutions found in package.json"));
291
- return;
292
- }
293
- console.log(`Processing ${entries.length} resolution(s)...`);
294
- const updates = [];
295
- for (const [currentPkgName, url] of entries) {
296
- // Validate if URL is a GitHub URL
297
- let repo;
298
- try {
299
- repo = parseGitHubUrl(url);
300
- console.log(`✅ Valid GitHub URL for ${ansiColors.cyan(currentPkgName)}: ${url}`);
301
- } catch (error) {
302
- console.log(`⏭️ Skipping ${ansiColors.yellow(currentPkgName)}: ${error.message}`);
303
- continue;
304
- }
305
- try {
306
- const override = specialPackageOverrides.find((p) => p.pkg === currentPkgName);
307
- const latest = override
308
- ? await getLatestCommit(override.owner, override.repo, override.branch)
309
- : await getLatestCommitAcrossBranches(repo.owner, repo.repo);
310
- const new_url = replaceRawWithLatestHash(url, latest.sha);
311
- updates.push({
312
- currentPkgName,
313
- url,
314
- new_url,
315
- repo,
316
- latest
317
- });
318
- } catch (error) {
319
- console.log(`❌ Failed to process ${ansiColors.red(currentPkgName)}: ${error.message}`);
320
- }
321
- }
322
- if (updates.length === 0) {
323
- console.log(ansiColors.yellow("No GitHub URLs were processed"));
324
- return;
325
- }
326
- console.log(`\n📝 Applying updates to ${updates.length} GitHub URL(s)...`);
327
- let changed = false;
328
- for (const { currentPkgName, url, new_url, repo, latest } of updates) {
329
- if (url !== new_url) {
330
- console.log(`\n${ansiColors.cyan(currentPkgName)}:`);
331
- console.log(" from:", url.replace(repo.branch, ansiColors.red(repo.branch)));
332
- console.log(" to:", new_url.replace(latest.sha, ansiColors.green(latest.sha)));
333
- pkg.resolutions[currentPkgName] = new_url;
334
- changed = true;
335
- } else {
336
- console.log(`\n${ansiColors.cyan(currentPkgName)}: ${ansiColors.gray("already up-to-date")}`);
337
- }
338
- }
339
- if (changed) {
340
- try {
341
- fs.writeFileSync(pkgPath, JSON.stringify(pkg, null, 2) + "\n");
342
- console.log(`\n✅ package.json updated successfully`);
343
- } catch (e) {
344
- console.error(ansiColors.red(`Failed to write package.json: ${e.message}`));
345
- process.exit(1);
346
- }
347
- } else {
348
- console.log(ansiColors.green("No changes to package.json were necessary."));
349
- }
350
- })();