binary-collections 2.0.9 → 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 (253) 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 -105
  33. package/lib/binary-collections.mjs +131 -84
  34. package/lib/changelog.cjs +3 -3
  35. package/lib/changelog.mjs +177 -171
  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 +3 -2
  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.js +51 -0
  91. package/lib/free-chatgpt.mjs +50 -0
  92. package/lib/git/gitattributes.cjs +1 -1
  93. package/lib/git/{gitattributes.d.mts → gitattributes.d.cts} +5 -7
  94. package/lib/git/gitattributes.mjs +2 -2
  95. package/lib/git/line-endings.cjs +297 -64
  96. package/lib/git/line-endings.mjs +4 -4
  97. package/lib/git/normalize.cjs +26 -36
  98. package/lib/git/normalize.mjs +2 -2
  99. package/lib/git/permissions.cjs +77 -11
  100. package/lib/git/permissions.mjs +3 -3
  101. package/lib/git/pull-strategy.cjs +76 -9
  102. package/lib/git/pull-strategy.mjs +3 -3
  103. package/lib/git/user-config.cjs +266 -83
  104. package/lib/git/user-config.mjs +4 -4
  105. package/lib/git/utils.cjs +40 -60
  106. package/lib/git/utils.mjs +2 -2
  107. package/lib/git-diff-cli.cjs +651 -0
  108. package/lib/git-diff-cli.d.ts +1 -0
  109. package/lib/git-diff-cli.js +15 -0
  110. package/lib/git-diff-cli.mjs +16 -0
  111. package/lib/git-diff.cjs +657 -58
  112. package/lib/git-diff.d.ts +38 -83
  113. package/lib/git-diff.js +152 -0
  114. package/lib/git-diff.mjs +23 -85
  115. package/lib/git-fix.cjs +685 -97
  116. package/lib/git-fix.mjs +14 -13
  117. package/lib/git-purge.cjs +3 -3
  118. package/lib/git-purge.d.cts +1 -0
  119. package/lib/git-purge.mjs +43 -37
  120. package/lib/index.cjs +7 -6
  121. package/lib/index.d.ts +1 -1
  122. package/lib/index.js +2 -5
  123. package/lib/index.mjs +4 -4
  124. package/lib/npm-run-series.cjs +3 -3
  125. package/lib/npm-run-series.mjs +42 -36
  126. package/lib/package-resolutions-updater.cjs +5 -5
  127. package/lib/package-resolutions-updater.mjs +266 -309
  128. package/lib/print-directory-tree.cjs +275 -210
  129. package/lib/print-directory-tree.mjs +2 -2
  130. package/lib/ps/connected-domain.cjs +25 -2
  131. package/lib/ps/connected-domain.d.ts +10 -2
  132. package/lib/ps/connected-domain.js +5 -2
  133. package/lib/ps/connected-domain.mjs +8 -4
  134. package/lib/ps/index.cjs +345 -322
  135. package/lib/ps/index.d.mjs +1 -1
  136. package/lib/ps/index.js +1 -1
  137. package/lib/ps/index.mjs +179 -182
  138. package/lib/ps/isWin.cjs +24 -1
  139. package/lib/ps/isWin.d.ts +1 -1
  140. package/lib/ps/isWin.js +3 -1
  141. package/lib/ps/isWin.mjs +8 -4
  142. package/lib/ps/table-parser.cjs +167 -159
  143. package/lib/ps/table-parser.d.ts +5 -0
  144. package/lib/ps/table-parser.js +10 -4
  145. package/lib/ps/table-parser.mjs +9 -5
  146. package/lib/remove-module.cjs +262 -0
  147. package/lib/remove-module.d.mts +1 -0
  148. package/lib/remove-module.mjs +111 -0
  149. package/lib/rmpath.cjs +274 -0
  150. package/lib/rmpath.d.mts +3 -0
  151. package/lib/rmpath.mjs +108 -0
  152. package/lib/submodule-install.cjs +264 -86
  153. package/lib/submodule-install.mjs +51 -3
  154. package/lib/submodule-remove-cli.cjs +103 -0
  155. package/lib/submodule-remove-cli.d.ts +1 -0
  156. package/lib/submodule-remove-cli.js +31 -0
  157. package/lib/submodule-remove-cli.mjs +28 -0
  158. package/lib/submodule-remove.cjs +43 -0
  159. package/lib/submodule-remove.d.cts +2 -0
  160. package/lib/submodule-remove.mjs +6 -0
  161. package/lib/utils/chatgpt.cjs +383 -0
  162. package/lib/utils/chatgpt.d.ts +31 -0
  163. package/lib/utils/chatgpt.js +541 -0
  164. package/lib/utils/chatgpt.mjs +8 -0
  165. package/lib/{utils.cjs → utils/index.cjs} +1 -1
  166. package/lib/{utils.mjs → utils/index.mjs} +2 -2
  167. package/lib/yarn-reinstall.cjs +172 -38
  168. package/lib/yarn-reinstall.mjs +2 -2
  169. package/package.json +91 -71
  170. package/readme.md +43 -69
  171. package/releases/readme.md +36 -0
  172. package/test/README.md +101 -0
  173. package/test/package.json +2 -1
  174. package/test-project/readme.md +26 -0
  175. package/tmp/test-repo/README.md +35 -0
  176. package/tmp/test-repo/package.json +1 -1
  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 -137
  192. package/lib/binary-collections.d.ts +0 -137
  193. package/lib/changelog.d.mts +0 -2
  194. package/lib/changelog.js +0 -226
  195. package/lib/chunk-DPKAJKFO.mjs +0 -171
  196. package/lib/chunk-G3THLIDT.mjs +0 -200
  197. package/lib/chunk-W3ENOM53.mjs +0 -18
  198. package/lib/clean-github-actions-caches.d.mts +0 -169
  199. package/lib/clean-github-actions-caches.d.ts +0 -169
  200. package/lib/del-gradle.d.mts +0 -2
  201. package/lib/del-node-modules.d.mts +0 -2
  202. package/lib/del-ps.d.mts +0 -2
  203. package/lib/del-yarn-caches.d.mts +0 -2
  204. package/lib/find-node-modules-cli.d.mts +0 -1
  205. package/lib/find-node-modules.d.mts +0 -13
  206. package/lib/find-node-modules.js +0 -53
  207. package/lib/git/line-endings.d.mts +0 -83
  208. package/lib/git/line-endings.d.ts +0 -83
  209. package/lib/git/normalize.d.mts +0 -43
  210. package/lib/git/normalize.d.ts +0 -43
  211. package/lib/git/permissions.d.mts +0 -17
  212. package/lib/git/permissions.d.ts +0 -17
  213. package/lib/git/pull-strategy.d.mts +0 -15
  214. package/lib/git/pull-strategy.d.ts +0 -15
  215. package/lib/git/user-config.d.mts +0 -105
  216. package/lib/git/user-config.d.ts +0 -105
  217. package/lib/git/utils.d.mts +0 -69
  218. package/lib/git/utils.d.ts +0 -69
  219. package/lib/git-diff.d.mts +0 -84
  220. package/lib/git-fix.d.mts +0 -141
  221. package/lib/git-fix.d.ts +0 -141
  222. package/lib/git-purge.d.mts +0 -2
  223. package/lib/git-purge.js +0 -59
  224. package/lib/index.d.mts +0 -1
  225. package/lib/npm-run-series.d.mts +0 -1
  226. package/lib/npm-run-series.d.ts +0 -2
  227. package/lib/npm-run-series.js +0 -86
  228. package/lib/package-resolutions-updater.d.ts +0 -352
  229. package/lib/print-directory-tree.d.mts +0 -234
  230. package/lib/print-directory-tree.d.ts +0 -234
  231. package/lib/ps/connected-domain.d.mts +0 -3
  232. package/lib/ps/index.d.d.mts +0 -26
  233. package/lib/ps/index.d.d.ts +0 -26
  234. package/lib/ps/index.d.mts +0 -26
  235. package/lib/ps/isWin.d.mts +0 -3
  236. package/lib/ps/table-parser.d.mts +0 -3
  237. package/lib/submodule-install.d.mts +0 -121
  238. package/lib/submodule-install.d.ts +0 -121
  239. package/lib/utils.d.mts +0 -40
  240. package/lib/utils.js +0 -181
  241. package/lib/yarn-reinstall.d.mts +0 -49
  242. package/lib/yarn-reinstall.d.ts +0 -49
  243. package/src/package-resolutions-updater.mjs +0 -350
  244. package/src/print-directory-tree.cjs +0 -234
  245. package/src/ps/index.js +0 -286
  246. package/src/yarn-reinstall.cjs +0 -49
  247. /package/{bin → binaries}/nodekill +0 -0
  248. /package/{bin → binaries}/nodekill.cmd +0 -0
  249. /package/lib/{binary-collections-config.d.ts → binary-collections-config.d.cts} +0 -0
  250. /package/lib/{changelog.d.ts → changelog.d.cts} +0 -0
  251. /package/lib/{git-purge.d.ts → free-chatgpt.d.ts} +0 -0
  252. /package/lib/{git-diff.d.cts → npm-run-series.d.cts} +0 -0
  253. /package/lib/{utils.d.ts → utils/index.d.cts} +0 -0
package/lib/git-fix.d.ts DELETED
@@ -1,141 +0,0 @@
1
- #!/usr/bin/env node
2
- const { isGitRepository } = require("./git/utils.cjs");
3
- const { forceLfLineEndings } = require("./git/line-endings.cjs");
4
- const { ignoreFilePermissions } = require("./git/permissions.cjs");
5
- const { setPullStrategy } = require("./git/pull-strategy.cjs");
6
- const { configureGitUser } = require("./git/user-config.cjs");
7
- const { normalizeLineEndings } = require("./git/normalize.cjs");
8
- const { getArgs } = require("./utils.js");
9
- const path = require("upath");
10
-
11
- function showHelp() {
12
- console.log("Git Fix Utility");
13
- console.log("----------------------------");
14
- console.log("Fixes common Git configuration issues:");
15
- console.log("• Forces LF line endings (core.autocrlf = false)");
16
- console.log("• Ignores file permission changes (core.filemode = false)");
17
- console.log("• Sets pull strategy to false (prevents auto-rebase)");
18
- console.log("• Normalizes existing line endings");
19
- console.log("• Configures Git user from environment variables");
20
- console.log("");
21
- console.log("Usage:");
22
- console.log(" git-fix Apply all fixes");
23
- console.log(" git-fix --lf-only Force LF line endings only");
24
- console.log(" git-fix --permissions Ignore file permissions only");
25
- console.log(" git-fix --normalize Normalize existing files only");
26
- console.log(" git-fix --user Configure Git user from environment");
27
- console.log(" git-fix --user NAME EMAIL Configure Git user with specified name and email");
28
- console.log(" git-fix --help | -h Show this help message");
29
- console.log("");
30
- console.log("Options can be combined: git-fix --lf-only --permissions");
31
- console.log("");
32
- console.log("User configuration precedence:");
33
- console.log(" 1. CLI arguments (--user NAME EMAIL)");
34
- console.log(" 2. Environment variables (GITHUB_USER, GITHUB_EMAIL)");
35
- console.log(" 3. Skip if neither provided");
36
- console.log("");
37
- console.log("Environment variables for --user option:");
38
- console.log(" GITHUB_USER - Git username (for user.name)");
39
- console.log(" GITHUB_EMAIL - Git email (for user.email)");
40
- process.exit(0);
41
- }
42
-
43
- const args = getArgs();
44
-
45
- let userConfig = { hasUserFlag: false, cliUser: null, cliEmail: null };
46
- if (Object.prototype.hasOwnProperty.call(args, "user")) {
47
- userConfig.hasUserFlag = true;
48
- // args.user can be string, array, or boolean
49
- if (Array.isArray(args.user)) {
50
- if (args.user.length === 2) {
51
- userConfig.cliUser = args.user[0];
52
- userConfig.cliEmail = args.user[1];
53
- } else if (args.user.length === 1) {
54
- // Only one value provided, error
55
- console.error("[✗] Error: --user requires both NAME and EMAIL or no arguments");
56
- console.error("Usage: --user (uses environment variables) or --user NAME EMAIL");
57
- process.exit(1);
58
- }
59
- // If length === 0, treat as env
60
- } else if (typeof args.user === "string") {
61
- // Only one value provided, error
62
- console.error("[✗] Error: --user requires both NAME and EMAIL or no arguments");
63
- console.error("Usage: --user (uses environment variables) or --user NAME EMAIL");
64
- process.exit(1);
65
- }
66
- }
67
-
68
- // Show help if requested
69
- if (args.help || args.h) {
70
- showHelp();
71
- process.exit(0); // Exit after showing help
72
- }
73
-
74
- console.log("[i] Current working directory:", path.toUnix(process.cwd()));
75
-
76
- // Check if we're in a git repository
77
- if (!isGitRepository(process.cwd())) {
78
- console.error("[✗] Error: Not in a git repository");
79
- console.error("Please run this command from within a git repository");
80
- process.exit(1);
81
- } else {
82
- console.log("[✓] Detected git repository");
83
- }
84
-
85
- console.log("Git Fix Utility");
86
- console.log("===============");
87
-
88
- // Parse options
89
- const options = {
90
- lfOnly: args["lf-only"] === true,
91
- permissions: args["permissions"] === true,
92
- normalize: args["normalize"] === true,
93
- user: userConfig.hasUserFlag,
94
- updateRemote: args["update-remote"] === true,
95
- all: Object.keys(args).filter((k) => k !== "_" && args[k] === true).length === 0 && !userConfig.hasUserFlag
96
- };
97
-
98
- // Execute requested fixes
99
- if (options.all || options.lfOnly) {
100
- forceLfLineEndings();
101
- }
102
-
103
- if (options.all || options.permissions) {
104
- ignoreFilePermissions();
105
- }
106
-
107
- if (options.all) {
108
- setPullStrategy();
109
- }
110
-
111
- if (options.all || options.user) {
112
- configureGitUser(userConfig.cliUser, userConfig.cliEmail, { updateRemote: options.updateRemote });
113
- } else if (options.updateRemote) {
114
- // If --update-remote is present without --user or --all, still call configureGitUser
115
- configureGitUser(null, null, { updateRemote: true });
116
- }
117
-
118
- if (options.all || options.normalize) {
119
- normalizeLineEndings();
120
- }
121
-
122
- console.log("\n=== Summary ===");
123
- console.log("[✓] Git fix utility completed successfully");
124
-
125
- if (options.all || options.lfOnly || options.normalize) {
126
- console.log("[i] Line endings are now configured for LF");
127
- }
128
-
129
- if (options.all || options.permissions) {
130
- console.log("[i] File permission changes will be ignored");
131
- }
132
-
133
- if (options.all || options.user) {
134
- const username = userConfig.cliUser || process.env.GITHUB_USER?.trim();
135
- const email = userConfig.cliEmail || process.env.GITHUB_EMAIL?.trim();
136
- if (username || email) {
137
- console.log("[i] Git user configuration has been applied");
138
- }
139
- }
140
-
141
- console.log("[i] Repository is ready for cross-platform development");
@@ -1,2 +0,0 @@
1
-
2
- export { }
package/lib/git-purge.js DELETED
@@ -1,59 +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 { spawnAsync } = require("cross-spawn");
11
- const glob = require("glob");
12
- const path = require("path");
13
- const { delay } = require("./utils");
14
- /** @type {string[]} */
15
- const dirs = [];
16
- /**
17
- * fetch directories
18
- * @param {string|string[]} pattern
19
- * @param {(filePath: string) => any} callback
20
- */
21
- const fetchDirs = (pattern, callback) => {
22
- const globStream = new glob.Glob(pattern, {
23
- withFileTypes: false,
24
- cwd: process.cwd(),
25
- ignore: ["**/node_modules/**", "**/vendor/**"]
26
- });
27
- globStream.stream().on("data", (result) => {
28
- const fullPath = path.resolve(process.cwd(), result);
29
- if (typeof callback == "function")
30
- callback(fullPath);
31
- const base = path.dirname(fullPath);
32
- // push directory when not exist
33
- if (!dirs.includes(base))
34
- dirs.push(base);
35
- start();
36
- });
37
- };
38
- let running = false;
39
- function start() {
40
- return __awaiter(this, void 0, void 0, function* () {
41
- // skip run when still running
42
- if (running)
43
- return;
44
- while (dirs.length > 0) {
45
- // start
46
- running = true;
47
- const cwd = dirs.shift();
48
- console.log("pruning reflog", cwd);
49
- yield spawnAsync("git", ["reflog", "expire", "--expire=all", "--all"], { cwd, stdio: "pipe", shell: true }).catch((e) => console.log("failed prune reflog", e.message));
50
- // git gc --prune=now --aggressive
51
- // delay 3s
52
- yield delay(3);
53
- // stop
54
- running = false;
55
- }
56
- });
57
- }
58
- // script starts here
59
- fetchDirs("**/.git");
package/lib/index.d.mts DELETED
@@ -1 +0,0 @@
1
- export { default as findNodeModules } from './find-node-modules.mjs';
@@ -1 +0,0 @@
1
- #!/usr/bin/env node
@@ -1,2 +0,0 @@
1
- #!/usr/bin/env node
2
- export {};
@@ -1,86 +0,0 @@
1
- #!/usr/bin/env node
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
36
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
37
- return new (P || (P = Promise))(function (resolve, reject) {
38
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
39
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
40
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
41
- step((generator = generator.apply(thisArg, _arguments || [])).next());
42
- });
43
- };
44
- const fs = require("fs");
45
- const path = require("path");
46
- const { Minimatch } = require("minimatch");
47
- const { getArgs } = require("./utils.js");
48
- const args = getArgs();
49
- const cwd = process.cwd();
50
- const packagejson = path.join(cwd, "package.json");
51
- const verbose = args["v"] || args["verbose"];
52
- const usingYarn = args["yarn"];
53
- (function npmRunSeries() {
54
- return __awaiter(this, void 0, void 0, function* () {
55
- const { execa } = yield Promise.resolve().then(() => __importStar(require("execa")));
56
- if (fs.existsSync(packagejson)) {
57
- /**
58
- * @type {import('../package.json')}
59
- */
60
- const parse = JSON.parse(fs.readFileSync(packagejson, "utf-8"));
61
- if (parse !== null && typeof parse === "object") {
62
- if ("scripts" in parse) {
63
- const patterns = args._;
64
- const scripts = parse.scripts;
65
- const scriptNames = Object.keys(scripts);
66
- for (let i = 0; i < patterns.length; i++) {
67
- const pattern = patterns[i];
68
- const matcher = new Minimatch(pattern, { nonegate: true });
69
- for (let ii = 0; ii < scriptNames.length; ii++) {
70
- const scriptName = scriptNames[ii];
71
- const match = matcher.match(scriptName);
72
- if (verbose)
73
- console.log({ pattern, scriptName, match });
74
- if (match === true) {
75
- yield execa(usingYarn ? "yarn" : "npm", ["run", scriptName], {
76
- cwd,
77
- stdio: "inherit"
78
- });
79
- }
80
- }
81
- }
82
- }
83
- }
84
- }
85
- });
86
- })();
@@ -1,352 +0,0 @@
1
- import ansiColors from 'ansi-colors';
2
- import * as dotenv from 'dotenv';
3
- import fs from 'fs';
4
- import https from 'https';
5
- import os from 'os';
6
- import path from 'path';
7
- import { getArgs } from './utils.js';
8
- import 'minimist';
9
-
10
- /**
11
- * 📦 GitHub Package Resolver
12
- *
13
- * This script updates the commit hashes in `package.json`'s `resolutions` field
14
- * for GitHub tarball URLs (typically using `raw/branch-name/...`) to point to the
15
- * latest commit SHA of the corresponding repository and branch.
16
- *
17
- * 🔍 Features:
18
- * - Parses GitHub URLs to extract repository owner, name, and branch.
19
- * - Fetches the latest commit SHA across all branches using GitHub's API.
20
- * - Replaces the old branch or commit in the URL with the latest SHA.
21
- * - Overwrites `package.json` with the updated URLs.
22
- *
23
- * 🛠 Requirements:
24
- * - GitHub Personal Access Token (GITHUB_TOKEN) via `.env`
25
- * - ESM support (`type: "module"` in `package.json`)
26
- * - Node.js v18+ recommended for ESM and `fetch` fallback compatibility
27
- *
28
- * 🧩 Dependencies:
29
- * - `ansi-colors` – for styled terminal output
30
- * - `dotenv` – to load GitHub token from `.env`
31
- *
32
- * ✅ Use case:
33
- * - Ensures package resolutions always use immutable SHAs instead of mutable branch names.
34
- * - Helps achieve deterministic builds in monorepos or projects with internal GitHub packages.
35
- */
36
-
37
-
38
- const projectDir = process.cwd();
39
- const envPath = path.join(projectDir, ".env");
40
- const args = getArgs();
41
- const ACCESS_TOKEN = process.env.GITHUB_TOKEN || process.env.ACCESS_TOKEN;
42
-
43
- // Show help if --help/-h is passed
44
- if (args.help || args.h) {
45
- showHelp();
46
- }
47
-
48
- /**
49
- * Display help information for the package-resolutions-updater script.
50
- */
51
- function showHelp() {
52
- const helpText = `\n\
53
- GitHub Package Resolutions Updater\n\
54
- Usage:\n node src/package-resolutions-updater.mjs [options]\n\
55
- Options:\n --help, -h Show this help message\n\
56
- 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\
57
- 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\
58
- Requirements:\n - GitHub Personal Access Token (GITHUB_TOKEN) via .env\n - ESM support (type: "module" in package.json)\n - Node.js v18+ recommended\n\
59
- Dependencies:\n - ansi-colors – for styled terminal output\n - dotenv – to load GitHub token from .env\n\
60
- Examples:\n node src/package-resolutions-updater.mjs\n node src/package-resolutions-updater.mjs --help\n\n`;
61
- console.log(helpText);
62
- process.exit(0);
63
- }
64
-
65
- // Load the .env file using dotenv (ESM import)
66
- if (fs.existsSync(envPath)) dotenv.config({ path: envPath });
67
-
68
- // 📌 Static override rules
69
- const specialPackageOverrides = [
70
- // SBG packages
71
- { pkg: "sbg-utility", branch: "sbg-utility", repo: "static-blog-generator", owner: "dimaslanjaka" },
72
- { pkg: "sbg-api", branch: "sbg-api", repo: "static-blog-generator", owner: "dimaslanjaka" },
73
- { pkg: "instant-indexing", branch: "instant-indexing", repo: "static-blog-generator", owner: "dimaslanjaka" },
74
- { pkg: "sbg-server", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
75
- { pkg: "sbg-cli", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
76
- { pkg: "static-blog-generator", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
77
- // Hexo family
78
- { pkg: "hexo", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
79
- { pkg: "hexo-util", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
80
- { pkg: "warehouse", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
81
- { pkg: "hexo-server", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
82
- { pkg: "hexo-log", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
83
- { pkg: "hexo-front-matter", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
84
- { pkg: "hexo-cli", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
85
- { pkg: "hexo-asset-link", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
86
- { pkg: "hexo-post-parser", branch: "pre-release", repo: "hexo-post-parser", owner: "dimaslanjaka" },
87
- { pkg: "hexo-seo", branch: "pre-release", repo: "hexo-seo", owner: "dimaslanjaka" },
88
- { pkg: "hexo-is", branch: "master", repo: "hexo-is", owner: "dimaslanjaka" },
89
- { pkg: "markdown-it", branch: "master", repo: "markdown-it", owner: "dimaslanjaka" },
90
- { pkg: "hexo-renderers", branch: "pre-release", repo: "hexo-renderers", owner: "dimaslanjaka" },
91
- { pkg: "hexo-shortcodes", branch: "pre-release", repo: "hexo-shortcodes", owner: "dimaslanjaka" },
92
- { pkg: "google-news-sitemap", branch: "master", repo: "google-news-sitemap", owner: "dimaslanjaka" },
93
- { pkg: "git-command-helper", branch: "pre-release", repo: "git-command-helper", owner: "dimaslanjaka" },
94
- {
95
- pkg: "nodejs-package-types",
96
- branch: "main",
97
- repo: "nodejs-package-types",
98
- owner: "dimaslanjaka"
99
- },
100
- { pkg: "cross-spawn", branch: "private", repo: "node-cross-spawn", owner: "dimaslanjaka" },
101
- { pkg: "hexo-generator-redirect", branch: "master", repo: "hexo-generator-redirect", owner: "dimaslanjaka" },
102
- { pkg: "binary-collections", branch: "master", repo: "bin", owner: "dimaslanjaka" },
103
- { pkg: "@types/hexo", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
104
- { pkg: "@types/git-command-helper", branch: "pre-release", repo: "git-command-helper", owner: "dimaslanjaka" }
105
- ];
106
-
107
- // --- Optimized: Load package.json once at the top ---
108
- const pkgPath = path.join(process.cwd(), "package.json");
109
- let pkg;
110
- try {
111
- pkg = JSON.parse(fs.readFileSync(pkgPath, "utf-8"));
112
- } catch (e) {
113
- console.error(ansiColors.red(`Failed to read package.json: ${e.message}`));
114
- process.exit(1);
115
- }
116
-
117
- // --- Use a random User-Agent for GitHub API requests ---
118
- const GITHUB_USER_AGENTS = [
119
- "octokit-rest.js/19.0.7",
120
- "GitHub CLI/2.40.0",
121
- "Mozilla/5.0 (compatible; GitHubCopilot/1.0)",
122
- "PostmanRuntime/7.32.3",
123
- "binary-collections-resolver/1.0 (+https://github.com/dimaslanjaka/bin)"
124
- ];
125
-
126
- // --- User-Agent persistence in system temp folder ---
127
- const userAgentDir = path.join(os.tmpdir(), "nodejs");
128
- const userAgentFile = path.join(userAgentDir, "useragent.txt");
129
- let selectedUserAgent;
130
- try {
131
- if (!fs.existsSync(userAgentDir)) fs.mkdirSync(userAgentDir, { recursive: true });
132
- if (fs.existsSync(userAgentFile)) {
133
- const fileAgent = fs.readFileSync(userAgentFile, "utf-8").trim();
134
- if (GITHUB_USER_AGENTS.includes(fileAgent)) {
135
- selectedUserAgent = fileAgent;
136
- }
137
- }
138
- if (!selectedUserAgent) {
139
- selectedUserAgent = GITHUB_USER_AGENTS[Math.floor(Math.random() * GITHUB_USER_AGENTS.length)];
140
- fs.writeFileSync(userAgentFile, selectedUserAgent, "utf-8");
141
- }
142
- } catch (_e) {
143
- // fallback to random if any error
144
- selectedUserAgent = GITHUB_USER_AGENTS[Math.floor(Math.random() * GITHUB_USER_AGENTS.length)];
145
- }
146
-
147
- /**
148
- * Fetch JSON from a URL with GitHub headers.
149
- * @param {string} url
150
- * @returns {Promise<any>}
151
- */
152
- function fetchJson(url) {
153
- const headers = {
154
- "User-Agent": selectedUserAgent,
155
- Accept: "application/vnd.github.v3+json",
156
- "X-GitHub-Api-Version": "2022-11-28",
157
- ...(ACCESS_TOKEN ? { Authorization: `token ${ACCESS_TOKEN}` } : {})
158
- };
159
- return new Promise((resolve, reject) => {
160
- https
161
- .get(url, { headers }, (res) => {
162
- let data = "";
163
- res.on("data", (chunk) => (data += chunk));
164
- res.on("end", () => {
165
- try {
166
- const json = JSON.parse(data);
167
- if (res.statusCode < 200 || res.statusCode >= 300) {
168
- return reject(
169
- new Error(`GitHub API Error ${res.statusCode}: ${json.message || "Unknown error"}\nURL: ${url}`)
170
- );
171
- }
172
- resolve(json);
173
- } catch {
174
- reject(new Error(`Invalid JSON from: ${url}`));
175
- }
176
- });
177
- })
178
- .on("error", reject);
179
- });
180
- }
181
-
182
- /**
183
- * Get latest commit SHA from a specific branch.
184
- */
185
- async function getLatestCommit(owner, repo, branch = "main") {
186
- const url = `https://api.github.com/repos/${owner}/${repo}/commits/${branch}`;
187
- const json = await fetchJson(url);
188
-
189
- const sha = json.sha;
190
- const dateStr = json.commit?.committer?.date || json.commit?.author?.date;
191
-
192
- if (!sha || !dateStr) {
193
- console.log(json);
194
- throw new Error(`Missing SHA or date for ${owner}/${repo}@${branch}`);
195
- }
196
-
197
- return {
198
- owner,
199
- repo,
200
- branch,
201
- sha,
202
- date: new Date(dateStr).toISOString()
203
- };
204
- }
205
-
206
- /**
207
- * Get latest commit SHA from all branches and pick the latest.
208
- */
209
- async function getLatestCommitAcrossBranches(owner, repo) {
210
- const branches = await fetchJson(`https://api.github.com/repos/${owner}/${repo}/branches`);
211
-
212
- const commits = await Promise.all(
213
- branches.map(async ({ name, commit }) => {
214
- const commitSha = commit?.sha;
215
- if (!commitSha) {
216
- console.warn(`No commit SHA for '${owner}/${repo}' branch: ${name}`);
217
- return { branch: name, sha: "", date: new Date(0) };
218
- }
219
-
220
- try {
221
- const commitData = await fetchJson(`https://api.github.com/repos/${owner}/${repo}/commits/${commitSha}`);
222
- const dateStr = commitData.commit?.committer?.date || commitData.commit?.author?.date;
223
- const date = dateStr ? new Date(dateStr) : new Date(0);
224
- return { branch: name, sha: commitData.sha, date };
225
- } catch (e) {
226
- console.warn(`Failed to fetch commit for ${name}: ${e.message}`);
227
- return { branch: name, sha: commitSha, date: new Date(0) };
228
- }
229
- })
230
- );
231
-
232
- const latest = commits.reduce((a, b) => (a.date > b.date ? a : b), { date: new Date(0) });
233
-
234
- return {
235
- owner,
236
- repo,
237
- branch: latest.branch,
238
- sha: latest.sha,
239
- date: latest.date.toISOString()
240
- };
241
- }
242
-
243
- /**
244
- * Replace the branch or commit in a GitHub raw URL with the latest hash.
245
- */
246
- function replaceRawWithLatestHash(url, latestHash) {
247
- const match = url.match(/^https:\/\/github\.com\/([^/]+)\/([^/]+)\/raw\/([^/]+)\/(.+)$/);
248
- if (!match) throw new Error("Invalid GitHub raw URL");
249
-
250
- const [, owner, repo, _oldHash, path] = match;
251
- return `https://github.com/${owner}/${repo}/raw/${latestHash}/${path}`;
252
- }
253
-
254
- /**
255
- * Parse GitHub URLs and extract owner, repo, branch, and original URL.
256
- */
257
- function parseGitHubUrl(url) {
258
- const ghRepoRoot = /^https:\/\/github\.com\/([^/]+)\/([^/]+)\/?$/;
259
- const ghTreeOrBlob = /^https:\/\/github\.com\/([^/]+)\/([^/]+)\/(tree|blob)\/([^/]+(?:\/[^/]+)*)/;
260
- const ghRaw = /^https:\/\/raw\.githubusercontent\.com\/([^/]+)\/([^/]+)\/([^/]+)(\/.+)?$/;
261
- const ghDotComRaw = /^https:\/\/github\.com\/([^/]+)\/([^/]+)\/raw\/([^/]+)\/.+/;
262
-
263
- let match;
264
-
265
- if ((match = url.match(ghRaw))) {
266
- const [, owner, repo, branch] = match;
267
- return { owner, repo, branch, url };
268
- }
269
-
270
- if ((match = url.match(ghDotComRaw))) {
271
- const [, owner, repo, branch] = match;
272
- return { owner, repo, branch, url };
273
- }
274
-
275
- if ((match = url.match(ghTreeOrBlob))) {
276
- const [, owner, repo, , branchPath] = match;
277
- return { owner, repo, branch: branchPath, url };
278
- }
279
-
280
- if ((match = url.match(ghRepoRoot))) {
281
- const [, owner, repo] = match;
282
- return { owner, repo, url };
283
- }
284
-
285
- throw new Error(`Unsupported GitHub URL: ${url}`);
286
- }
287
-
288
- // --- Main logic ---
289
- (async () => {
290
- const entries = Object.entries(pkg.resolutions || {});
291
- if (entries.length === 0) {
292
- console.log(ansiColors.yellow("No resolutions found in package.json"));
293
- return;
294
- }
295
- console.log(`Processing ${entries.length} resolution(s)...`);
296
- const updates = [];
297
- for (const [currentPkgName, url] of entries) {
298
- // Validate if URL is a GitHub URL
299
- let repo;
300
- try {
301
- repo = parseGitHubUrl(url);
302
- console.log(`✅ Valid GitHub URL for ${ansiColors.cyan(currentPkgName)}: ${url}`);
303
- } catch (error) {
304
- console.log(`⏭️ Skipping ${ansiColors.yellow(currentPkgName)}: ${error.message}`);
305
- continue;
306
- }
307
- try {
308
- const override = specialPackageOverrides.find((p) => p.pkg === currentPkgName);
309
- const latest = override
310
- ? await getLatestCommit(override.owner, override.repo, override.branch)
311
- : await getLatestCommitAcrossBranches(repo.owner, repo.repo);
312
- const new_url = replaceRawWithLatestHash(url, latest.sha);
313
- updates.push({
314
- currentPkgName,
315
- url,
316
- new_url,
317
- repo,
318
- latest
319
- });
320
- } catch (error) {
321
- console.log(`❌ Failed to process ${ansiColors.red(currentPkgName)}: ${error.message}`);
322
- }
323
- }
324
- if (updates.length === 0) {
325
- console.log(ansiColors.yellow("No GitHub URLs were processed"));
326
- return;
327
- }
328
- console.log(`\n📝 Applying updates to ${updates.length} GitHub URL(s)...`);
329
- let changed = false;
330
- for (const { currentPkgName, url, new_url, repo, latest } of updates) {
331
- if (url !== new_url) {
332
- console.log(`\n${ansiColors.cyan(currentPkgName)}:`);
333
- console.log(" from:", url.replace(repo.branch, ansiColors.red(repo.branch)));
334
- console.log(" to:", new_url.replace(latest.sha, ansiColors.green(latest.sha)));
335
- pkg.resolutions[currentPkgName] = new_url;
336
- changed = true;
337
- } else {
338
- console.log(`\n${ansiColors.cyan(currentPkgName)}: ${ansiColors.gray("already up-to-date")}`);
339
- }
340
- }
341
- if (changed) {
342
- try {
343
- fs.writeFileSync(pkgPath, JSON.stringify(pkg, null, 2) + "\n");
344
- console.log(`\n✅ package.json updated successfully`);
345
- } catch (e) {
346
- console.error(ansiColors.red(`Failed to write package.json: ${e.message}`));
347
- process.exit(1);
348
- }
349
- } else {
350
- console.log(ansiColors.green("No changes to package.json were necessary."));
351
- }
352
- })();