binary-collections 2.0.8 → 2.0.10

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 (250) hide show
  1. package/binaries/binary-executor.cjs +43 -0
  2. package/{bin → binaries}/clean-nodemodule +0 -0
  3. package/binaries/clean-nodemodule.cjs +43 -0
  4. package/binaries/clean-nodemodule.cmd +4 -0
  5. package/{bin → binaries}/clean-nodemodules +0 -0
  6. package/binaries/clean-nodemodules.cjs +43 -0
  7. package/binaries/clean-nodemodules.cmd +5 -0
  8. package/{bin → binaries}/dev +0 -0
  9. package/binaries/dev.cjs +43 -0
  10. package/{bin → binaries}/empty +0 -0
  11. package/binaries/empty.cjs +43 -0
  12. package/{bin → binaries}/git-reduce-size +0 -0
  13. package/binaries/git-reduce-size.cjs +43 -0
  14. package/binaries/javakill.cjs +43 -0
  15. package/{bin → binaries}/javakill.cmd +0 -0
  16. package/{bin → binaries}/kill-process +0 -0
  17. package/binaries/kill-process.cjs +43 -0
  18. package/binaries/nodekill.cjs +43 -0
  19. package/{bin → binaries}/nodekill.ps1 +0 -0
  20. package/{bin → binaries}/prod +0 -0
  21. package/binaries/prod.cjs +43 -0
  22. package/{bin → binaries}/rmfind +0 -0
  23. package/binaries/rmfind.cjs +43 -0
  24. package/{bin → binaries}/rmx +0 -0
  25. package/binaries/rmx.cjs +43 -0
  26. package/{bin → binaries}/submodule-token +0 -0
  27. package/binaries/submodule-token.cjs +43 -0
  28. package/docs-src/clean-github-actions-caches.md +26 -0
  29. package/docs-src/free-chatgpt.md +26 -0
  30. package/lib/binary-collections-config.cjs +3 -2
  31. package/lib/binary-collections-config.mjs +2 -2
  32. package/lib/binary-collections.cjs +452 -87
  33. package/lib/binary-collections.mjs +247 -8
  34. package/lib/changelog.cjs +328 -0
  35. package/lib/changelog.mjs +205 -0
  36. package/lib/chunk-4EWQC6GZ.mjs +382 -0
  37. package/lib/chunk-4ZI7BQKQ.mjs +381 -0
  38. package/lib/chunk-5J2BEPY5.mjs +83 -0
  39. package/lib/{chunk-4BYBVEYC.mjs → chunk-66PAU5PS.mjs} +5 -4
  40. package/lib/chunk-6HHJRKFB.mjs +59 -0
  41. package/lib/chunk-6S4NXESK.mjs +26 -0
  42. package/lib/{chunk-ZYAQRPUL.mjs → chunk-7YD7IPFF.mjs} +2 -2
  43. package/lib/{chunk-SH3L6HHV.mjs → chunk-A2JQXI5Z.mjs} +2 -2
  44. package/lib/{chunk-EGSSKVDH.mjs → chunk-A3VUZEJK.mjs} +1 -1
  45. package/lib/chunk-AGZYRDC2.mjs +323 -0
  46. package/lib/{chunk-VVEZVNIV.mjs → chunk-AI4CVPJ7.mjs} +6 -6
  47. package/lib/chunk-BDCHCWHD.mjs +136 -0
  48. package/lib/chunk-BEZKJ25G.mjs +140 -0
  49. package/lib/chunk-DI5MDPSN.mjs +386 -0
  50. package/lib/{chunk-ONIBBBQ3.mjs → chunk-E6FDDAOO.mjs} +4 -3
  51. package/lib/chunk-FKI7IEB5.mjs +172 -0
  52. package/lib/chunk-GJTGHXRA.mjs +356 -0
  53. package/lib/{chunk-YV7DO3YV.mjs → chunk-HLGOWBEO.mjs} +1 -1
  54. package/lib/chunk-HMRMTYZM.mjs +40 -0
  55. package/lib/chunk-HN52G2YL.mjs +305 -0
  56. package/lib/chunk-HO6GHCOB.mjs +385 -0
  57. package/lib/chunk-LEM5OMRP.mjs +384 -0
  58. package/lib/{chunk-YX5U7XDR.mjs → chunk-M3YIYRHT.mjs} +6 -5
  59. package/lib/chunk-O6SWBEOQ.mjs +81 -0
  60. package/lib/{chunk-JGR2NW6D.mjs → chunk-PDSXF5HY.mjs} +3 -3
  61. package/lib/{chunk-AASHBCRW.mjs → chunk-QQ4A6DLD.mjs} +8 -0
  62. package/lib/chunk-RCP7DHVY.mjs +190 -0
  63. package/lib/chunk-SBNDSKG5.mjs +136 -0
  64. package/lib/chunk-U6SO4QEV.mjs +320 -0
  65. package/lib/{chunk-APBWENF6.mjs → chunk-V3N3JEUF.mjs} +3 -3
  66. package/lib/chunk-XD6BJK6Q.mjs +351 -0
  67. package/lib/chunk-XVBFFVCJ.mjs +209 -0
  68. package/lib/chunk-YXSFGA2D.mjs +383 -0
  69. package/lib/clean-github-actions-caches.cjs +243 -148
  70. package/lib/clean-github-actions-caches.mjs +4 -3
  71. package/lib/del-gradle.cjs +2 -2
  72. package/lib/del-gradle.js +1 -1
  73. package/lib/del-gradle.mjs +2 -2
  74. package/lib/del-node-modules.cjs +2 -2
  75. package/lib/del-node-modules.js +1 -1
  76. package/lib/del-node-modules.mjs +2 -2
  77. package/lib/del-ps.cjs +29 -8
  78. package/lib/del-ps.js +2 -2
  79. package/lib/del-ps.mjs +7 -5
  80. package/lib/del-yarn-caches.cjs +26 -5
  81. package/lib/del-yarn-caches.js +38 -3
  82. package/lib/del-yarn-caches.mjs +6 -6
  83. package/lib/find-node-modules-cli.cjs +5 -4
  84. package/lib/find-node-modules-cli.js +1 -1
  85. package/lib/find-node-modules-cli.mjs +2 -2
  86. package/lib/find-node-modules.cjs +4 -3
  87. package/lib/{find-node-modules.d.ts → find-node-modules.d.cts} +1 -1
  88. package/lib/find-node-modules.mjs +2 -2
  89. package/lib/free-chatgpt.cjs +548 -0
  90. package/lib/free-chatgpt.d.ts +1 -0
  91. package/lib/free-chatgpt.js +51 -0
  92. package/lib/free-chatgpt.mjs +50 -0
  93. package/lib/git/gitattributes.cjs +1 -1
  94. package/lib/git/{gitattributes.d.mts → gitattributes.d.cts} +5 -7
  95. package/lib/git/gitattributes.mjs +2 -2
  96. package/lib/git/line-endings.cjs +297 -64
  97. package/lib/git/line-endings.mjs +4 -4
  98. package/lib/git/normalize.cjs +26 -36
  99. package/lib/git/normalize.mjs +2 -2
  100. package/lib/git/permissions.cjs +77 -11
  101. package/lib/git/permissions.mjs +3 -3
  102. package/lib/git/pull-strategy.cjs +76 -9
  103. package/lib/git/pull-strategy.mjs +3 -3
  104. package/lib/git/user-config.cjs +266 -83
  105. package/lib/git/user-config.mjs +4 -4
  106. package/lib/git/utils.cjs +40 -60
  107. package/lib/git/utils.mjs +2 -2
  108. package/lib/git-diff-cli.cjs +651 -0
  109. package/lib/git-diff-cli.d.ts +1 -0
  110. package/lib/git-diff-cli.js +15 -0
  111. package/lib/git-diff-cli.mjs +16 -0
  112. package/lib/git-diff.cjs +657 -58
  113. package/lib/git-diff.d.ts +38 -83
  114. package/lib/git-diff.js +152 -0
  115. package/lib/git-diff.mjs +23 -85
  116. package/lib/git-fix.cjs +685 -97
  117. package/lib/git-fix.mjs +12 -11
  118. package/lib/git-purge.cjs +3 -3
  119. package/lib/git-purge.d.cts +1 -0
  120. package/lib/git-purge.mjs +43 -37
  121. package/lib/index.cjs +7 -6
  122. package/lib/index.d.ts +1 -1
  123. package/lib/index.js +2 -5
  124. package/lib/index.mjs +4 -4
  125. package/lib/npm-run-series.cjs +3 -3
  126. package/lib/npm-run-series.mjs +42 -36
  127. package/lib/package-resolutions-updater.cjs +174 -1
  128. package/lib/package-resolutions-updater.mjs +270 -290
  129. package/lib/print-directory-tree.cjs +275 -210
  130. package/lib/print-directory-tree.mjs +2 -2
  131. package/lib/ps/connected-domain.cjs +25 -2
  132. package/lib/ps/connected-domain.d.ts +10 -2
  133. package/lib/ps/connected-domain.js +5 -2
  134. package/lib/ps/connected-domain.mjs +8 -4
  135. package/lib/ps/index.cjs +345 -322
  136. package/lib/ps/index.d.mjs +1 -1
  137. package/lib/ps/index.js +1 -1
  138. package/lib/ps/index.mjs +179 -182
  139. package/lib/ps/isWin.cjs +24 -1
  140. package/lib/ps/isWin.d.ts +1 -1
  141. package/lib/ps/isWin.js +3 -1
  142. package/lib/ps/isWin.mjs +8 -4
  143. package/lib/ps/table-parser.cjs +167 -159
  144. package/lib/ps/table-parser.d.ts +5 -0
  145. package/lib/ps/table-parser.js +10 -4
  146. package/lib/ps/table-parser.mjs +9 -5
  147. package/lib/remove-module.cjs +262 -0
  148. package/lib/remove-module.d.mts +1 -0
  149. package/lib/remove-module.mjs +111 -0
  150. package/lib/rmpath.cjs +274 -0
  151. package/lib/rmpath.d.mts +3 -0
  152. package/lib/rmpath.mjs +108 -0
  153. package/lib/submodule-install.cjs +264 -85
  154. package/lib/submodule-install.mjs +56 -7
  155. package/lib/submodule-remove-cli.cjs +103 -0
  156. package/lib/submodule-remove-cli.d.ts +1 -0
  157. package/lib/submodule-remove-cli.js +31 -0
  158. package/lib/submodule-remove-cli.mjs +28 -0
  159. package/lib/submodule-remove.cjs +43 -0
  160. package/lib/submodule-remove.d.cts +2 -0
  161. package/lib/submodule-remove.mjs +6 -0
  162. package/lib/utils/chatgpt.cjs +383 -0
  163. package/lib/utils/chatgpt.d.ts +31 -0
  164. package/lib/utils/chatgpt.js +541 -0
  165. package/lib/utils/chatgpt.mjs +8 -0
  166. package/lib/{utils.cjs → utils/index.cjs} +1 -1
  167. package/lib/{utils.mjs → utils/index.mjs} +2 -2
  168. package/lib/yarn-reinstall.cjs +172 -38
  169. package/lib/yarn-reinstall.mjs +2 -2
  170. package/package.json +91 -71
  171. package/readme.md +43 -69
  172. package/releases/readme.md +36 -0
  173. package/test/README.md +101 -0
  174. package/test/package.json +2 -1
  175. package/test-project/readme.md +26 -0
  176. package/tmp/test-repo/README.md +35 -0
  177. package/tmp/typedoc/readme.md +320 -0
  178. package/bin/bash-dummy +0 -56
  179. package/bin/bash-dummy.cmd +0 -25
  180. package/bin/dir-tree.cmd +0 -7
  181. package/bin/git-diff +0 -4
  182. package/bin/git-diff.cmd +0 -7
  183. package/bin/git-fix +0 -36
  184. package/bin/git-fix.cmd +0 -7
  185. package/bin/rmpath +0 -70
  186. package/bin/submodule-install.txt +0 -118
  187. package/bin/submodule-remove +0 -46
  188. package/bin/submodule.txt +0 -172
  189. package/lib/binary-collections-config.d.mts +0 -18
  190. package/lib/binary-collections-config.js +0 -39
  191. package/lib/binary-collections.d.mts +0 -121
  192. package/lib/binary-collections.d.ts +0 -121
  193. package/lib/chunk-DPKAJKFO.mjs +0 -171
  194. package/lib/chunk-G3THLIDT.mjs +0 -200
  195. package/lib/chunk-W3ENOM53.mjs +0 -18
  196. package/lib/clean-github-actions-caches.d.mts +0 -169
  197. package/lib/clean-github-actions-caches.d.ts +0 -169
  198. package/lib/del-gradle.d.mts +0 -2
  199. package/lib/del-node-modules.d.mts +0 -2
  200. package/lib/del-ps.d.mts +0 -2
  201. package/lib/del-yarn-caches.d.mts +0 -2
  202. package/lib/find-node-modules-cli.d.mts +0 -1
  203. package/lib/find-node-modules.d.mts +0 -13
  204. package/lib/find-node-modules.js +0 -53
  205. package/lib/git/line-endings.d.mts +0 -83
  206. package/lib/git/line-endings.d.ts +0 -83
  207. package/lib/git/normalize.d.mts +0 -43
  208. package/lib/git/normalize.d.ts +0 -43
  209. package/lib/git/permissions.d.mts +0 -17
  210. package/lib/git/permissions.d.ts +0 -17
  211. package/lib/git/pull-strategy.d.mts +0 -15
  212. package/lib/git/pull-strategy.d.ts +0 -15
  213. package/lib/git/user-config.d.mts +0 -105
  214. package/lib/git/user-config.d.ts +0 -105
  215. package/lib/git/utils.d.mts +0 -69
  216. package/lib/git/utils.d.ts +0 -69
  217. package/lib/git-diff.d.mts +0 -84
  218. package/lib/git-fix.d.mts +0 -141
  219. package/lib/git-fix.d.ts +0 -141
  220. package/lib/git-purge.d.mts +0 -2
  221. package/lib/git-purge.js +0 -59
  222. package/lib/index.d.mts +0 -1
  223. package/lib/npm-run-series.d.mts +0 -1
  224. package/lib/npm-run-series.d.ts +0 -2
  225. package/lib/npm-run-series.js +0 -86
  226. package/lib/package-resolutions-updater.d.ts +0 -326
  227. package/lib/print-directory-tree.d.mts +0 -234
  228. package/lib/print-directory-tree.d.ts +0 -234
  229. package/lib/ps/connected-domain.d.mts +0 -3
  230. package/lib/ps/index.d.d.mts +0 -26
  231. package/lib/ps/index.d.d.ts +0 -26
  232. package/lib/ps/index.d.mts +0 -26
  233. package/lib/ps/isWin.d.mts +0 -3
  234. package/lib/ps/table-parser.d.mts +0 -3
  235. package/lib/submodule-install.d.mts +0 -121
  236. package/lib/submodule-install.d.ts +0 -121
  237. package/lib/utils.d.mts +0 -40
  238. package/lib/utils.js +0 -181
  239. package/lib/yarn-reinstall.d.mts +0 -49
  240. package/lib/yarn-reinstall.d.ts +0 -49
  241. package/src/package-resolutions-updater.mjs +0 -325
  242. package/src/print-directory-tree.cjs +0 -234
  243. package/src/ps/index.js +0 -286
  244. package/src/yarn-reinstall.cjs +0 -49
  245. /package/{bin → binaries}/nodekill +0 -0
  246. /package/{bin → binaries}/nodekill.cmd +0 -0
  247. /package/lib/{binary-collections-config.d.ts → binary-collections-config.d.cts} +0 -0
  248. /package/lib/{git-purge.d.ts → changelog.d.cts} +0 -0
  249. /package/lib/{git-diff.d.cts → npm-run-series.d.cts} +0 -0
  250. /package/lib/{utils.d.ts → utils/index.d.cts} +0 -0
@@ -1,316 +1,296 @@
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
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
28
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
29
- return new (P || (P = Promise))(function (resolve, reject) {
30
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
31
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
32
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
33
- step((generator = generator.apply(thisArg, _arguments || [])).next());
34
- });
35
- };
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import {
3
+ require_utils
4
+ } from "./chunk-V3N3JEUF.mjs";
5
+ import {
6
+ __toESM,
7
+ init_esm_shims
8
+ } from "./chunk-QQ4A6DLD.mjs";
9
+
10
+ // src/package-resolutions-updater.mjs
11
+ init_esm_shims();
12
+ var utils = __toESM(require_utils(), 1);
36
13
  import ansiColors from "ansi-colors";
37
14
  import * as dotenv from "dotenv";
38
15
  import fs from "fs";
39
16
  import https from "https";
40
17
  import os from "os";
41
18
  import path from "path";
42
- const projectDir = process.cwd();
43
- const envPath = path.join(projectDir, ".env");
44
- // Load the .env file using dotenv (ESM import)
45
- if (fs.existsSync(envPath))
46
- dotenv.config({ path: envPath });
47
- // 📌 Static override rules
48
- const specialPackageOverrides = [
49
- // SBG packages
50
- { pkg: "sbg-utility", branch: "sbg-utility", repo: "static-blog-generator", owner: "dimaslanjaka" },
51
- { pkg: "sbg-api", branch: "sbg-api", repo: "static-blog-generator", owner: "dimaslanjaka" },
52
- { pkg: "instant-indexing", branch: "instant-indexing", repo: "static-blog-generator", owner: "dimaslanjaka" },
53
- { pkg: "sbg-server", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
54
- { pkg: "sbg-cli", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
55
- { pkg: "static-blog-generator", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
56
- // Hexo family
57
- { pkg: "hexo", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
58
- { pkg: "hexo-util", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
59
- { pkg: "warehouse", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
60
- { pkg: "hexo-server", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
61
- { pkg: "hexo-log", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
62
- { pkg: "hexo-front-matter", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
63
- { pkg: "hexo-cli", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
64
- { pkg: "hexo-asset-link", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
65
- { pkg: "hexo-post-parser", branch: "pre-release", repo: "hexo-post-parser", owner: "dimaslanjaka" },
66
- { pkg: "hexo-seo", branch: "pre-release", repo: "hexo-seo", owner: "dimaslanjaka" },
67
- { pkg: "hexo-is", branch: "master", repo: "hexo-is", owner: "dimaslanjaka" },
68
- { pkg: "markdown-it", branch: "master", repo: "markdown-it", owner: "dimaslanjaka" },
69
- { pkg: "hexo-renderers", branch: "pre-release", repo: "hexo-renderers", owner: "dimaslanjaka" },
70
- { pkg: "hexo-shortcodes", branch: "pre-release", repo: "hexo-shortcodes", owner: "dimaslanjaka" },
71
- { pkg: "google-news-sitemap", branch: "master", repo: "google-news-sitemap", owner: "dimaslanjaka" },
72
- { pkg: "git-command-helper", branch: "pre-release", repo: "git-command-helper", owner: "dimaslanjaka" },
73
- {
74
- pkg: "nodejs-package-types",
75
- branch: "main",
76
- repo: "nodejs-package-types",
77
- owner: "dimaslanjaka"
78
- },
79
- { pkg: "cross-spawn", branch: "private", repo: "node-cross-spawn", owner: "dimaslanjaka" },
80
- { pkg: "hexo-generator-redirect", branch: "master", repo: "hexo-generator-redirect", owner: "dimaslanjaka" },
81
- { pkg: "binary-collections", branch: "master", repo: "bin", owner: "dimaslanjaka" },
82
- { pkg: "@types/hexo", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
83
- { pkg: "@types/git-command-helper", branch: "pre-release", repo: "git-command-helper", owner: "dimaslanjaka" }
19
+ var projectDir = process.cwd();
20
+ var envPath = path.join(projectDir, ".env");
21
+ var args = utils.getArgs();
22
+ if (fs.existsSync(envPath)) dotenv.config({ path: envPath });
23
+ var ACCESS_TOKEN = process.env.GITHUB_TOKEN || process.env.ACCESS_TOKEN;
24
+ if (args.help || args.h) {
25
+ showHelp();
26
+ }
27
+ function showHelp() {
28
+ const helpText = `
29
+ GitHub Package Resolutions Updater
30
+ Usage:
31
+ node src/package-resolutions-updater.mjs [options]
32
+ Options:
33
+ --help, -h Show this help message
34
+ Description:
35
+ 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.
36
+ Features:
37
+ - Parses GitHub URLs to extract repository owner, name, and branch.
38
+ - Fetches the latest commit SHA across all branches using GitHub's API.
39
+ - Replaces the old branch or commit in the URL with the latest SHA.
40
+ - Overwrites package.json with the updated URLs.
41
+ Requirements:
42
+ - GitHub Personal Access Token (GITHUB_TOKEN) via .env
43
+ - ESM support (type: "module" in package.json)
44
+ - Node.js v18+ recommended
45
+ Dependencies:
46
+ - ansi-colors \u2013 for styled terminal output
47
+ - dotenv \u2013 to load GitHub token from .env
48
+ Examples:
49
+ node src/package-resolutions-updater.mjs
50
+ node src/package-resolutions-updater.mjs --help
51
+
52
+ `;
53
+ console.log(helpText);
54
+ process.exit(0);
55
+ }
56
+ var specialPackageOverrides = [
57
+ // SBG packages
58
+ { pkg: "sbg-utility", branch: "sbg-utility", repo: "static-blog-generator", owner: "dimaslanjaka" },
59
+ { pkg: "sbg-api", branch: "sbg-api", repo: "static-blog-generator", owner: "dimaslanjaka" },
60
+ { pkg: "instant-indexing", branch: "instant-indexing", repo: "static-blog-generator", owner: "dimaslanjaka" },
61
+ { pkg: "sbg-server", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
62
+ { pkg: "sbg-cli", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
63
+ { pkg: "static-blog-generator", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
64
+ // Hexo family
65
+ { pkg: "hexo", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
66
+ { pkg: "hexo-util", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
67
+ { pkg: "warehouse", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
68
+ { pkg: "hexo-server", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
69
+ { pkg: "hexo-log", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
70
+ { pkg: "hexo-front-matter", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
71
+ { pkg: "hexo-cli", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
72
+ { pkg: "hexo-asset-link", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
73
+ { pkg: "hexo-post-parser", branch: "pre-release", repo: "hexo-post-parser", owner: "dimaslanjaka" },
74
+ { pkg: "hexo-seo", branch: "pre-release", repo: "hexo-seo", owner: "dimaslanjaka" },
75
+ { pkg: "hexo-is", branch: "master", repo: "hexo-is", owner: "dimaslanjaka" },
76
+ { pkg: "markdown-it", branch: "master", repo: "markdown-it", owner: "dimaslanjaka" },
77
+ { pkg: "hexo-renderers", branch: "pre-release", repo: "hexo-renderers", owner: "dimaslanjaka" },
78
+ { pkg: "hexo-shortcodes", branch: "pre-release", repo: "hexo-shortcodes", owner: "dimaslanjaka" },
79
+ { pkg: "google-news-sitemap", branch: "master", repo: "google-news-sitemap", owner: "dimaslanjaka" },
80
+ { pkg: "git-command-helper", branch: "pre-release", repo: "git-command-helper", owner: "dimaslanjaka" },
81
+ {
82
+ pkg: "nodejs-package-types",
83
+ branch: "main",
84
+ repo: "nodejs-package-types",
85
+ owner: "dimaslanjaka"
86
+ },
87
+ { pkg: "cross-spawn", branch: "private", repo: "node-cross-spawn", owner: "dimaslanjaka" },
88
+ { pkg: "hexo-generator-redirect", branch: "master", repo: "hexo-generator-redirect", owner: "dimaslanjaka" },
89
+ { pkg: "binary-collections", branch: "master", repo: "bin", owner: "dimaslanjaka" },
90
+ { pkg: "@types/hexo", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
91
+ { pkg: "@types/git-command-helper", branch: "pre-release", repo: "git-command-helper", owner: "dimaslanjaka" }
84
92
  ];
85
- // --- Optimized: Load package.json once at the top ---
86
- const pkgPath = path.join(process.cwd(), "package.json");
87
- let pkg;
93
+ var pkgPath = path.join(process.cwd(), "package.json");
94
+ var pkg;
88
95
  try {
89
- pkg = JSON.parse(fs.readFileSync(pkgPath, "utf-8"));
96
+ pkg = JSON.parse(fs.readFileSync(pkgPath, "utf-8"));
97
+ } catch (e) {
98
+ console.error(ansiColors.red(`Failed to read package.json: ${e.message}`));
99
+ process.exit(1);
90
100
  }
91
- catch (e) {
92
- console.error(ansiColors.red(`Failed to read package.json: ${e.message}`));
93
- process.exit(1);
94
- }
95
- // --- Use a random User-Agent for GitHub API requests ---
96
- const GITHUB_USER_AGENTS = [
97
- "octokit-rest.js/19.0.7",
98
- "GitHub CLI/2.40.0",
99
- "Mozilla/5.0 (compatible; GitHubCopilot/1.0)",
100
- "PostmanRuntime/7.32.3",
101
- "binary-collections-resolver/1.0 (+https://github.com/dimaslanjaka/bin)"
101
+ var GITHUB_USER_AGENTS = [
102
+ "octokit-rest.js/19.0.7",
103
+ "GitHub CLI/2.40.0",
104
+ "Mozilla/5.0 (compatible; GitHubCopilot/1.0)",
105
+ "PostmanRuntime/7.32.3",
106
+ "binary-collections-resolver/1.0 (+https://github.com/dimaslanjaka/bin)"
102
107
  ];
103
- // --- User-Agent persistence in system temp folder ---
104
- const userAgentDir = path.join(os.tmpdir(), "nodejs");
105
- const userAgentFile = path.join(userAgentDir, "useragent.txt");
106
- let selectedUserAgent;
108
+ var userAgentDir = path.join(os.tmpdir(), "nodejs");
109
+ var userAgentFile = path.join(userAgentDir, "useragent.txt");
110
+ var selectedUserAgent;
107
111
  try {
108
- if (!fs.existsSync(userAgentDir))
109
- fs.mkdirSync(userAgentDir, { recursive: true });
110
- if (fs.existsSync(userAgentFile)) {
111
- const fileAgent = fs.readFileSync(userAgentFile, "utf-8").trim();
112
- if (GITHUB_USER_AGENTS.includes(fileAgent)) {
113
- selectedUserAgent = fileAgent;
114
- }
112
+ if (!fs.existsSync(userAgentDir)) fs.mkdirSync(userAgentDir, { recursive: true });
113
+ if (fs.existsSync(userAgentFile)) {
114
+ const fileAgent = fs.readFileSync(userAgentFile, "utf-8").trim();
115
+ if (GITHUB_USER_AGENTS.includes(fileAgent)) {
116
+ selectedUserAgent = fileAgent;
115
117
  }
116
- if (!selectedUserAgent) {
117
- selectedUserAgent = GITHUB_USER_AGENTS[Math.floor(Math.random() * GITHUB_USER_AGENTS.length)];
118
- fs.writeFileSync(userAgentFile, selectedUserAgent, "utf-8");
119
- }
120
- }
121
- catch (_e) {
122
- // fallback to random if any error
118
+ }
119
+ if (!selectedUserAgent) {
123
120
  selectedUserAgent = GITHUB_USER_AGENTS[Math.floor(Math.random() * GITHUB_USER_AGENTS.length)];
121
+ fs.writeFileSync(userAgentFile, selectedUserAgent, "utf-8");
122
+ }
123
+ } catch (_e) {
124
+ selectedUserAgent = GITHUB_USER_AGENTS[Math.floor(Math.random() * GITHUB_USER_AGENTS.length)];
124
125
  }
125
- /**
126
- * Fetch JSON from a URL with GitHub headers.
127
- * @param {string} url
128
- * @returns {Promise<any>}
129
- */
130
126
  function fetchJson(url) {
131
- const headers = Object.assign({ "User-Agent": selectedUserAgent, Accept: "application/vnd.github.v3+json", "X-GitHub-Api-Version": "2022-11-28" }, (process.env.GITHUB_TOKEN ? { Authorization: `token ${process.env.GITHUB_TOKEN}` } : {}));
132
- return new Promise((resolve, reject) => {
133
- https
134
- .get(url, { headers }, (res) => {
135
- let data = "";
136
- res.on("data", (chunk) => (data += chunk));
137
- res.on("end", () => {
138
- try {
139
- const json = JSON.parse(data);
140
- if (res.statusCode < 200 || res.statusCode >= 300) {
141
- return reject(new Error(`GitHub API Error ${res.statusCode}: ${json.message || "Unknown error"}\nURL: ${url}`));
142
- }
143
- resolve(json);
144
- }
145
- catch (_a) {
146
- reject(new Error(`Invalid JSON from: ${url}`));
147
- }
148
- });
149
- })
150
- .on("error", reject);
151
- });
152
- }
153
- /**
154
- * Get latest commit SHA from a specific branch.
155
- */
156
- function getLatestCommit(owner_1, repo_1) {
157
- return __awaiter(this, arguments, void 0, function* (owner, repo, branch = "main") {
158
- var _a, _b, _c, _d;
159
- const url = `https://api.github.com/repos/${owner}/${repo}/commits/${branch}`;
160
- const json = yield fetchJson(url);
161
- const sha = json.sha;
162
- const dateStr = ((_b = (_a = json.commit) === null || _a === void 0 ? void 0 : _a.committer) === null || _b === void 0 ? void 0 : _b.date) || ((_d = (_c = json.commit) === null || _c === void 0 ? void 0 : _c.author) === null || _d === void 0 ? void 0 : _d.date);
163
- if (!sha || !dateStr) {
164
- console.log(json);
165
- throw new Error(`Missing SHA or date for ${owner}/${repo}@${branch}`);
127
+ const headers = {
128
+ "User-Agent": selectedUserAgent,
129
+ Accept: "application/vnd.github.v3+json",
130
+ "X-GitHub-Api-Version": "2022-11-28",
131
+ ...ACCESS_TOKEN ? { Authorization: `token ${ACCESS_TOKEN}` } : {}
132
+ };
133
+ return new Promise((resolve, reject) => {
134
+ https.get(url, { headers }, (res) => {
135
+ let data = "";
136
+ res.on("data", (chunk) => data += chunk);
137
+ res.on("end", () => {
138
+ try {
139
+ const json = JSON.parse(data);
140
+ if (res.statusCode < 200 || res.statusCode >= 300) {
141
+ return reject(
142
+ new Error(`GitHub API Error ${res.statusCode}: ${json.message || "Unknown error"}
143
+ URL: ${url}`)
144
+ );
145
+ }
146
+ resolve(json);
147
+ } catch {
148
+ reject(new Error(`Invalid JSON from: ${url}`));
166
149
  }
167
- return {
168
- owner,
169
- repo,
170
- branch,
171
- sha,
172
- date: new Date(dateStr).toISOString()
173
- };
174
- });
150
+ });
151
+ }).on("error", reject);
152
+ });
153
+ }
154
+ async function getLatestCommit(owner, repo, branch = "main") {
155
+ var _a, _b, _c, _d;
156
+ const url = `https://api.github.com/repos/${owner}/${repo}/commits/${branch}`;
157
+ const json = await fetchJson(url);
158
+ const sha = json.sha;
159
+ const dateStr = ((_b = (_a = json.commit) == null ? void 0 : _a.committer) == null ? void 0 : _b.date) || ((_d = (_c = json.commit) == null ? void 0 : _c.author) == null ? void 0 : _d.date);
160
+ if (!sha || !dateStr) {
161
+ console.log(json);
162
+ throw new Error(`Missing SHA or date for ${owner}/${repo}@${branch}`);
163
+ }
164
+ return {
165
+ owner,
166
+ repo,
167
+ branch,
168
+ sha,
169
+ date: new Date(dateStr).toISOString()
170
+ };
175
171
  }
176
- /**
177
- * Get latest commit SHA from all branches and pick the latest.
178
- */
179
- function getLatestCommitAcrossBranches(owner, repo) {
180
- return __awaiter(this, void 0, void 0, function* () {
181
- const branches = yield fetchJson(`https://api.github.com/repos/${owner}/${repo}/branches`);
182
- const commits = yield Promise.all(branches.map((_a) => __awaiter(this, [_a], void 0, function* ({ name, commit }) {
183
- var _b, _c, _d, _f;
184
- const commitSha = commit === null || commit === void 0 ? void 0 : commit.sha;
185
- if (!commitSha) {
186
- console.warn(`No commit SHA for '${owner}/${repo}' branch: ${name}`);
187
- return { branch: name, sha: "", date: new Date(0) };
188
- }
189
- try {
190
- const commitData = yield fetchJson(`https://api.github.com/repos/${owner}/${repo}/commits/${commitSha}`);
191
- const dateStr = ((_c = (_b = commitData.commit) === null || _b === void 0 ? void 0 : _b.committer) === null || _c === void 0 ? void 0 : _c.date) || ((_f = (_d = commitData.commit) === null || _d === void 0 ? void 0 : _d.author) === null || _f === void 0 ? void 0 : _f.date);
192
- const date = dateStr ? new Date(dateStr) : new Date(0);
193
- return { branch: name, sha: commitData.sha, date };
194
- }
195
- catch (e) {
196
- console.warn(`Failed to fetch commit for ${name}: ${e.message}`);
197
- return { branch: name, sha: commitSha, date: new Date(0) };
198
- }
199
- })));
200
- const latest = commits.reduce((a, b) => (a.date > b.date ? a : b), { date: new Date(0) });
201
- return {
202
- owner,
203
- repo,
204
- branch: latest.branch,
205
- sha: latest.sha,
206
- date: latest.date.toISOString()
207
- };
208
- });
172
+ async function getLatestCommitAcrossBranches(owner, repo) {
173
+ const branches = await fetchJson(`https://api.github.com/repos/${owner}/${repo}/branches`);
174
+ const commits = await Promise.all(
175
+ branches.map(async ({ name, commit }) => {
176
+ var _a, _b, _c, _d;
177
+ const commitSha = commit == null ? void 0 : commit.sha;
178
+ if (!commitSha) {
179
+ console.warn(`No commit SHA for '${owner}/${repo}' branch: ${name}`);
180
+ return { branch: name, sha: "", date: /* @__PURE__ */ new Date(0) };
181
+ }
182
+ try {
183
+ const commitData = await fetchJson(`https://api.github.com/repos/${owner}/${repo}/commits/${commitSha}`);
184
+ const dateStr = ((_b = (_a = commitData.commit) == null ? void 0 : _a.committer) == null ? void 0 : _b.date) || ((_d = (_c = commitData.commit) == null ? void 0 : _c.author) == null ? void 0 : _d.date);
185
+ const date = dateStr ? new Date(dateStr) : /* @__PURE__ */ new Date(0);
186
+ return { branch: name, sha: commitData.sha, date };
187
+ } catch (e) {
188
+ console.warn(`Failed to fetch commit for ${name}: ${e.message}`);
189
+ return { branch: name, sha: commitSha, date: /* @__PURE__ */ new Date(0) };
190
+ }
191
+ })
192
+ );
193
+ const latest = commits.reduce((a, b) => a.date > b.date ? a : b, { date: /* @__PURE__ */ new Date(0) });
194
+ return {
195
+ owner,
196
+ repo,
197
+ branch: latest.branch,
198
+ sha: latest.sha,
199
+ date: latest.date.toISOString()
200
+ };
209
201
  }
210
- /**
211
- * Replace the branch or commit in a GitHub raw URL with the latest hash.
212
- */
213
202
  function replaceRawWithLatestHash(url, latestHash) {
214
- const match = url.match(/^https:\/\/github\.com\/([^/]+)\/([^/]+)\/raw\/([^/]+)\/(.+)$/);
215
- if (!match)
216
- throw new Error("Invalid GitHub raw URL");
217
- const [, owner, repo, _oldHash, path] = match;
218
- return `https://github.com/${owner}/${repo}/raw/${latestHash}/${path}`;
203
+ const match = url.match(/^https:\/\/github\.com\/([^/]+)\/([^/]+)\/raw\/([^/]+)\/(.+)$/);
204
+ if (!match) throw new Error("Invalid GitHub raw URL");
205
+ const [, owner, repo, _oldHash, path2] = match;
206
+ return `https://github.com/${owner}/${repo}/raw/${latestHash}/${path2}`;
219
207
  }
220
- /**
221
- * Parse GitHub URLs and extract owner, repo, branch, and original URL.
222
- */
223
208
  function parseGitHubUrl(url) {
224
- const ghRepoRoot = /^https:\/\/github\.com\/([^/]+)\/([^/]+)\/?$/;
225
- const ghTreeOrBlob = /^https:\/\/github\.com\/([^/]+)\/([^/]+)\/(tree|blob)\/([^/]+(?:\/[^/]+)*)/;
226
- const ghRaw = /^https:\/\/raw\.githubusercontent\.com\/([^/]+)\/([^/]+)\/([^/]+)(\/.+)?$/;
227
- const ghDotComRaw = /^https:\/\/github\.com\/([^/]+)\/([^/]+)\/raw\/([^/]+)\/.+/;
228
- let match;
229
- if ((match = url.match(ghRaw))) {
230
- const [, owner, repo, branch] = match;
231
- return { owner, repo, branch, url };
232
- }
233
- if ((match = url.match(ghDotComRaw))) {
234
- const [, owner, repo, branch] = match;
235
- return { owner, repo, branch, url };
236
- }
237
- if ((match = url.match(ghTreeOrBlob))) {
238
- const [, owner, repo, , branchPath] = match;
239
- return { owner, repo, branch: branchPath, url };
240
- }
241
- if ((match = url.match(ghRepoRoot))) {
242
- const [, owner, repo] = match;
243
- return { owner, repo, url };
244
- }
245
- throw new Error(`Unsupported GitHub URL: ${url}`);
209
+ const ghRepoRoot = /^https:\/\/github\.com\/([^/]+)\/([^/]+)\/?$/;
210
+ const ghTreeOrBlob = /^https:\/\/github\.com\/([^/]+)\/([^/]+)\/(tree|blob)\/([^/]+(?:\/[^/]+)*)/;
211
+ const ghRaw = /^https:\/\/raw\.githubusercontent\.com\/([^/]+)\/([^/]+)\/([^/]+)(\/.+)?$/;
212
+ const ghDotComRaw = /^https:\/\/github\.com\/([^/]+)\/([^/]+)\/raw\/([^/]+)\/.+/;
213
+ let match;
214
+ if (match = url.match(ghRaw)) {
215
+ const [, owner, repo, branch] = match;
216
+ return { owner, repo, branch, url };
217
+ }
218
+ if (match = url.match(ghDotComRaw)) {
219
+ const [, owner, repo, branch] = match;
220
+ return { owner, repo, branch, url };
221
+ }
222
+ if (match = url.match(ghTreeOrBlob)) {
223
+ const [, owner, repo, , branchPath] = match;
224
+ return { owner, repo, branch: branchPath, url };
225
+ }
226
+ if (match = url.match(ghRepoRoot)) {
227
+ const [, owner, repo] = match;
228
+ return { owner, repo, url };
229
+ }
230
+ throw new Error(`Unsupported GitHub URL: ${url}`);
246
231
  }
247
- // --- Main logic ---
248
- (() => __awaiter(void 0, void 0, void 0, function* () {
249
- const entries = Object.entries(pkg.resolutions || {});
250
- if (entries.length === 0) {
251
- console.log(ansiColors.yellow("No resolutions found in package.json"));
252
- return;
232
+ (async () => {
233
+ const entries = Object.entries(pkg.resolutions || {});
234
+ if (entries.length === 0) {
235
+ console.log(ansiColors.yellow("No resolutions found in package.json"));
236
+ return;
237
+ }
238
+ console.log(`Processing ${entries.length} resolution(s)...`);
239
+ const updates = [];
240
+ for (const [currentPkgName, url] of entries) {
241
+ let repo;
242
+ try {
243
+ repo = parseGitHubUrl(url);
244
+ console.log(`\u2705 Valid GitHub URL for ${ansiColors.cyan(currentPkgName)}: ${url}`);
245
+ } catch (error) {
246
+ console.log(`\u23ED\uFE0F Skipping ${ansiColors.yellow(currentPkgName)}: ${error.message}`);
247
+ continue;
253
248
  }
254
- console.log(`Processing ${entries.length} resolution(s)...`);
255
- const updates = [];
256
- for (const [currentPkgName, url] of entries) {
257
- // Validate if URL is a GitHub URL
258
- let repo;
259
- try {
260
- repo = parseGitHubUrl(url);
261
- console.log(`✅ Valid GitHub URL for ${ansiColors.cyan(currentPkgName)}: ${url}`);
262
- }
263
- catch (error) {
264
- console.log(`⏭️ Skipping ${ansiColors.yellow(currentPkgName)}: ${error.message}`);
265
- continue;
266
- }
267
- try {
268
- const override = specialPackageOverrides.find((p) => p.pkg === currentPkgName);
269
- const latest = override
270
- ? yield getLatestCommit(override.owner, override.repo, override.branch)
271
- : yield getLatestCommitAcrossBranches(repo.owner, repo.repo);
272
- const new_url = replaceRawWithLatestHash(url, latest.sha);
273
- updates.push({
274
- currentPkgName,
275
- url,
276
- new_url,
277
- repo,
278
- latest
279
- });
280
- }
281
- catch (error) {
282
- console.log(`❌ Failed to process ${ansiColors.red(currentPkgName)}: ${error.message}`);
283
- }
284
- }
285
- if (updates.length === 0) {
286
- console.log(ansiColors.yellow("No GitHub URLs were processed"));
287
- return;
249
+ try {
250
+ const override = specialPackageOverrides.find((p) => p.pkg === currentPkgName);
251
+ const latest = override ? await getLatestCommit(override.owner, override.repo, override.branch) : await getLatestCommitAcrossBranches(repo.owner, repo.repo);
252
+ const new_url = replaceRawWithLatestHash(url, latest.sha);
253
+ updates.push({
254
+ currentPkgName,
255
+ url,
256
+ new_url,
257
+ repo,
258
+ latest
259
+ });
260
+ } catch (error) {
261
+ console.log(`\u274C Failed to process ${ansiColors.red(currentPkgName)}: ${error.message}`);
288
262
  }
289
- console.log(`\n📝 Applying updates to ${updates.length} GitHub URL(s)...`);
290
- let changed = false;
291
- for (const { currentPkgName, url, new_url, repo, latest } of updates) {
292
- if (url !== new_url) {
293
- console.log(`\n${ansiColors.cyan(currentPkgName)}:`);
294
- console.log(" from:", url.replace(repo.branch, ansiColors.red(repo.branch)));
295
- console.log(" to:", new_url.replace(latest.sha, ansiColors.green(latest.sha)));
296
- pkg.resolutions[currentPkgName] = new_url;
297
- changed = true;
298
- }
299
- else {
300
- console.log(`\n${ansiColors.cyan(currentPkgName)}: ${ansiColors.gray("already up-to-date")}`);
301
- }
302
- }
303
- if (changed) {
304
- try {
305
- fs.writeFileSync(pkgPath, JSON.stringify(pkg, null, 2) + "\n");
306
- console.log(`\n✅ package.json updated successfully`);
307
- }
308
- catch (e) {
309
- console.error(ansiColors.red(`Failed to write package.json: ${e.message}`));
310
- process.exit(1);
311
- }
263
+ }
264
+ if (updates.length === 0) {
265
+ console.log(ansiColors.yellow("No GitHub URLs were processed"));
266
+ return;
267
+ }
268
+ console.log(`
269
+ \u{1F4DD} Applying updates to ${updates.length} GitHub URL(s)...`);
270
+ let changed = false;
271
+ for (const { currentPkgName, url, new_url, repo, latest } of updates) {
272
+ if (url !== new_url) {
273
+ console.log(`
274
+ ${ansiColors.cyan(currentPkgName)}:`);
275
+ console.log(" from:", url.replace(repo.branch, ansiColors.red(repo.branch)));
276
+ console.log(" to:", new_url.replace(latest.sha, ansiColors.green(latest.sha)));
277
+ pkg.resolutions[currentPkgName] = new_url;
278
+ changed = true;
279
+ } else {
280
+ console.log(`
281
+ ${ansiColors.cyan(currentPkgName)}: ${ansiColors.gray("already up-to-date")}`);
312
282
  }
313
- else {
314
- console.log(ansiColors.green("No changes to package.json were necessary."));
283
+ }
284
+ if (changed) {
285
+ try {
286
+ fs.writeFileSync(pkgPath, JSON.stringify(pkg, null, 2) + "\n");
287
+ console.log(`
288
+ \u2705 package.json updated successfully`);
289
+ } catch (e) {
290
+ console.error(ansiColors.red(`Failed to write package.json: ${e.message}`));
291
+ process.exit(1);
315
292
  }
316
- }))();
293
+ } else {
294
+ console.log(ansiColors.green("No changes to package.json were necessary."));
295
+ }
296
+ })();