binary-collections 2.0.10 → 2.0.12
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.
- package/.opencode/package.json +5 -0
- package/.puppeterrc.cjs +25 -0
- package/binaries/binary-executor.cjs +138 -3
- package/binaries/clean-nodemodule.cjs +138 -3
- package/binaries/clean-nodemodules.cjs +138 -3
- package/binaries/dev.cjs +138 -3
- package/binaries/empty.cjs +138 -3
- package/binaries/git-reduce-size.cjs +138 -3
- package/binaries/javakill.cjs +138 -3
- package/binaries/kill-night-crows.bat +7 -0
- package/binaries/kill-night-crows.ps1 +172 -0
- package/binaries/kill-process.cjs +138 -3
- package/binaries/nodekill.cjs +138 -3
- package/binaries/prod.cjs +138 -3
- package/binaries/py +111 -0
- package/binaries/py.cjs +178 -0
- package/binaries/py.cmd +49 -0
- package/binaries/rmfind.cjs +138 -3
- package/binaries/rmx +15 -1
- package/binaries/rmx.cjs +138 -3
- package/binaries/rmx.cmd +12 -0
- package/binaries/submodule-token.cjs +138 -3
- package/binaries/test-cjs +18 -0
- package/binaries/test-cjs.cjs +178 -0
- package/binaries/test-cjs.cmd +26 -0
- package/binaries/test-esm +16 -0
- package/binaries/test-esm.cjs +178 -0
- package/binaries/test-esm.cmd +23 -0
- package/binaries/yarn-clean +32 -0
- package/binaries/yarn-clean.cjs +178 -0
- package/binaries/yarn-clean.cmd +30 -0
- package/binaries/yarn-clean.py +166 -0
- package/binaries/yc +110 -0
- package/binaries/yc.cjs +178 -0
- package/lib/binary-collections/config.cjs +126 -0
- package/lib/binary-collections/config.mjs +7 -0
- package/lib/binary-collections/executeScript.cjs +19 -0
- package/lib/binary-collections/executeScript.d.cts +12 -0
- package/lib/binary-collections/executeScript.mjs +6 -0
- package/lib/binary-collections/findScript.cjs +284 -0
- package/lib/binary-collections/findScript.d.cts +12 -0
- package/lib/binary-collections/findScript.mjs +7 -0
- package/lib/binary-collections/listScript.cjs +266 -0
- package/lib/binary-collections/listScript.d.cts +19 -0
- package/lib/binary-collections/listScript.mjs +7 -0
- package/lib/binary-collections.cjs +342 -194
- package/lib/binary-collections.mjs +22 -268
- package/lib/changelog.cjs +61 -13
- package/lib/changelog.mjs +1 -1
- package/lib/{chunk-E6FDDAOO.mjs → chunk-2LSRSEXF.mjs} +2 -2
- package/lib/chunk-34IQDTLZ.mjs +27 -0
- package/lib/chunk-3HFFECCI.mjs +27 -0
- package/lib/{chunk-V3N3JEUF.mjs → chunk-5RTXZVCW.mjs} +60 -13
- package/lib/chunk-66KDU4TX.mjs +268 -0
- package/lib/chunk-6PU7BAHB.mjs +61 -0
- package/lib/{chunk-6HHJRKFB.mjs → chunk-BZWVHODJ.mjs} +4 -1
- package/lib/chunk-C6D2TTYU.mjs +32 -0
- package/lib/chunk-FB2WKVJD.mjs +158 -0
- package/lib/{chunk-66PAU5PS.mjs → chunk-G5UUEWUO.mjs} +9 -5
- package/lib/{chunk-HO6GHCOB.mjs → chunk-GAGABICI.mjs} +198 -63
- package/lib/chunk-H44UWUFY.mjs +105 -0
- package/lib/chunk-NCZPTKDV.mjs +79 -0
- package/lib/chunk-NGFK3EYW.mjs +28 -0
- package/lib/chunk-NVEG3LEZ.mjs +143 -0
- package/lib/chunk-OGXVGBRI.mjs +29 -0
- package/lib/chunk-OXV52GD5.mjs +62 -0
- package/lib/{chunk-PDSXF5HY.mjs → chunk-PDN26I7O.mjs} +1 -0
- package/lib/chunk-PXBMHE7O.mjs +35 -0
- package/lib/chunk-R5FJOR63.mjs +47 -0
- package/lib/chunk-SPTECFE5.mjs +180 -0
- package/lib/chunk-UXCFNAR6.mjs +55 -0
- package/lib/chunk-V2IBPCEV.mjs +39 -0
- package/lib/chunk-XPJGCDOD.mjs +14 -0
- package/lib/{chunk-AI4CVPJ7.mjs → chunk-ZDMWBSYF.mjs} +4 -4
- package/lib/chunk-ZOWVMII3.mjs +228 -0
- package/lib/clean-github-actions-caches-cli.cjs +465 -0
- package/lib/clean-github-actions-caches-cli.d.cts +1 -0
- package/lib/clean-github-actions-caches-cli.mjs +56 -0
- package/lib/clean-github-actions-caches.cjs +152 -160
- package/lib/clean-github-actions-caches.d.cts +15 -1
- package/lib/clean-github-actions-caches.mjs +4 -130
- package/lib/cross-env/command.cjs +63 -0
- package/lib/cross-env/command.d.ts +8 -0
- package/lib/cross-env/command.js +45 -0
- package/lib/cross-env/command.mjs +9 -0
- package/lib/cross-env/index.cjs +178 -0
- package/lib/cross-env/index.d.ts +8 -0
- package/lib/cross-env/index.js +102 -0
- package/lib/cross-env/index.mjs +101 -0
- package/lib/cross-env/variable.cjs +60 -0
- package/lib/cross-env/variable.d.ts +7 -0
- package/lib/cross-env/variable.js +59 -0
- package/lib/cross-env/variable.mjs +9 -0
- package/lib/del-gradle.cjs +61 -13
- package/lib/del-gradle.js +9 -8
- package/lib/del-gradle.mjs +1 -1
- package/lib/del-node-modules.cjs +143 -148
- package/lib/del-node-modules.js +210 -14
- package/lib/del-node-modules.mjs +148 -17
- package/lib/del-ps.cjs +61 -13
- package/lib/del-ps.js +9 -8
- package/lib/del-ps.mjs +1 -1
- package/lib/del-yarn-caches.cjs +61 -13
- package/lib/del-yarn-caches.js +2 -2
- package/lib/del-yarn-caches.mjs +1 -1
- package/lib/file/copy-cli.cjs +92 -0
- package/lib/file/copy-cli.d.mts +1 -0
- package/lib/file/copy-cli.mjs +55 -0
- package/lib/file/copy.cjs +56 -0
- package/lib/file/copy.d.mts +1 -0
- package/lib/file/copy.mjs +8 -0
- package/lib/file/move-cli.cjs +91 -0
- package/lib/file/move-cli.d.mts +1 -0
- package/lib/file/move-cli.mjs +55 -0
- package/lib/file/move.cjs +55 -0
- package/lib/file/move.d.mts +1 -0
- package/lib/file/move.mjs +8 -0
- package/lib/find-node-modules-cli.js +2 -1
- package/lib/free-chatgpt.cjs +259 -47
- package/lib/free-chatgpt.js +10 -10
- package/lib/free-chatgpt.mjs +2 -2
- package/lib/git/gitattributes.cjs +1 -0
- package/lib/git/gitattributes.d.cts +7 -2
- package/lib/git/gitattributes.mjs +1 -1
- package/lib/git/line-endings.cjs +2 -1
- package/lib/git/line-endings.mjs +2 -2
- package/lib/git/undo-commit-cli.cjs +110 -0
- package/lib/git/undo-commit-cli.d.ts +1 -0
- package/lib/git/undo-commit-cli.js +4 -0
- package/lib/git/undo-commit-cli.mjs +14 -0
- package/lib/git/undo-commit.cjs +81 -0
- package/lib/git/undo-commit.d.cts +1 -0
- package/lib/git/undo-commit.mjs +7 -0
- package/lib/git/undo-staged-cli.cjs +110 -0
- package/lib/git/undo-staged-cli.d.ts +1 -0
- package/lib/git/undo-staged-cli.js +4 -0
- package/lib/git/undo-staged-cli.mjs +14 -0
- package/lib/git/undo-staged.cjs +81 -0
- package/lib/git/undo-staged.d.cts +1 -0
- package/lib/git/undo-staged.mjs +7 -0
- package/lib/git/user-config.cjs +61 -14
- package/lib/git/user-config.mjs +2 -2
- package/lib/git-diff-cli.cjs +427 -75
- package/lib/git-diff-cli.d.ts +1 -0
- package/lib/git-diff-cli.js +1 -0
- package/lib/git-diff-cli.mjs +6 -4
- package/lib/git-diff.cjs +426 -75
- package/lib/git-diff.d.ts +2 -1
- package/lib/git-diff.js +91 -34
- package/lib/git-diff.mjs +5 -4
- package/lib/git-fix.cjs +64 -16
- package/lib/git-fix.mjs +10 -10
- package/lib/git-purge.cjs +61 -13
- package/lib/git-purge.mjs +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/kill-night-crows.cjs +87 -0
- package/lib/kill-night-crows.d.mts +1 -0
- package/lib/kill-night-crows.mjs +65 -0
- package/lib/node-cache-cleaner/npm.cjs +65 -0
- package/lib/node-cache-cleaner/npm.d.ts +2 -0
- package/lib/node-cache-cleaner/npm.js +41 -0
- package/lib/node-cache-cleaner/npm.mjs +10 -0
- package/lib/node-cache-cleaner/npx.cjs +89 -0
- package/lib/node-cache-cleaner/npx.d.ts +4 -0
- package/lib/node-cache-cleaner/npx.js +82 -0
- package/lib/{ps/index.d.mjs → node-cache-cleaner/npx.mjs} +6 -5
- package/lib/node-cache-cleaner/yarn.cjs +73 -0
- package/lib/node-cache-cleaner/yarn.d.ts +2 -0
- package/lib/node-cache-cleaner/yarn.js +62 -0
- package/lib/node-cache-cleaner/yarn.mjs +10 -0
- package/lib/node-cache-cleaner-cli.cjs +182 -0
- package/lib/node-cache-cleaner-cli.d.ts +2 -0
- package/lib/node-cache-cleaner-cli.js +60 -0
- package/lib/node-cache-cleaner-cli.mjs +56 -0
- package/lib/node-executor.cjs +91 -0
- package/lib/node-executor.d.cts +2 -0
- package/lib/node-executor.mjs +103 -0
- package/lib/npm-run-series.cjs +79 -39
- package/lib/npm-run-series.mjs +20 -6
- package/lib/package-resolutions-updater-cli.cjs +645 -0
- package/lib/package-resolutions-updater-cli.d.mts +1 -0
- package/lib/package-resolutions-updater-cli.mjs +102 -0
- package/lib/package-resolutions-updater.cjs +259 -133
- package/lib/package-resolutions-updater.d.mts +51 -1
- package/lib/package-resolutions-updater.mjs +18 -294
- package/lib/php-cs-fixer-staged.cjs +105 -0
- package/lib/php-cs-fixer-staged.d.cts +2 -0
- package/lib/php-cs-fixer-staged.mjs +117 -0
- package/lib/print-directory-tree.cjs +62 -14
- package/lib/print-directory-tree.mjs +2 -2
- package/lib/ps/connected-domain.d.ts +1 -1
- package/lib/ps/connected-domain.js +10 -10
- package/lib/ps/index.cjs +1 -1
- package/lib/ps/index.mjs +177 -171
- package/lib/ps/isWin.js +1 -1
- package/lib/ps/table-parser.js +6 -6
- package/lib/remove-module.cjs +61 -13
- package/lib/remove-module.mjs +1 -1
- package/lib/rm-node-module-cli.cjs +222 -0
- package/lib/rm-node-module-cli.d.cts +1 -0
- package/lib/rm-node-module-cli.mjs +89 -0
- package/lib/rm-node-modules.cjs +127 -0
- package/lib/rm-node-modules.d.cts +35 -0
- package/lib/{binary-collections-config.mjs → rm-node-modules.mjs} +3 -3
- package/lib/rmpath.cjs +63 -15
- package/lib/rmpath.mjs +2 -2
- package/lib/submodule-install.cjs +107 -47
- package/lib/submodule-install.mjs +48 -35
- package/lib/submodule-remove-cli.cjs +6 -3
- package/lib/submodule-remove-cli.js +3 -3
- package/lib/submodule-remove-cli.mjs +2 -3
- package/lib/submodule-remove.cjs +4 -1
- package/lib/submodule-remove.mjs +1 -1
- package/lib/utils/chatgpt.cjs +198 -34
- package/lib/utils/chatgpt.js +260 -93
- package/lib/utils/chatgpt.mjs +1 -1
- package/lib/utils/findEnvFiles.cjs +89 -0
- package/lib/utils/findEnvFiles.d.cts +19 -0
- package/lib/utils/findEnvFiles.mjs +6 -0
- package/lib/utils/findWorkspaceRoot.cjs +70 -0
- package/lib/utils/findWorkspaceRoot.d.ts +9 -0
- package/lib/utils/findWorkspaceRoot.js +57 -0
- package/lib/utils/findWorkspaceRoot.mjs +40 -0
- package/lib/utils/index.cjs +60 -13
- package/lib/utils/index.mjs +1 -1
- package/lib/utils/isGithubTokenValid.cjs +64 -0
- package/lib/utils/isGithubTokenValid.d.ts +7 -0
- package/lib/utils/isGithubTokenValid.js +48 -0
- package/lib/utils/isGithubTokenValid.mjs +36 -0
- package/lib/{ps/index.d.cjs → utils/isWindows.cjs} +17 -3
- package/lib/utils/isWindows.d.ts +5 -0
- package/lib/utils/isWindows.js +10 -0
- package/lib/utils/isWindows.mjs +8 -0
- package/lib/utils/runBash.cjs +53 -0
- package/lib/utils/runBash.d.cts +12 -0
- package/lib/utils/runBash.mjs +66 -0
- package/lib/yarn-per-branch-lock-installer.cjs +97 -0
- package/lib/yarn-per-branch-lock-installer.d.cts +2 -0
- package/lib/yarn-per-branch-lock-installer.mjs +109 -0
- package/lib/yarn-reinstall.cjs +61 -13
- package/lib/yarn-reinstall.mjs +1 -1
- package/package.json +133 -110
- package/readme.html +784 -0
- package/readme.md +116 -229
- package/releases/readme.md +1 -1
- package/requirements.txt +1 -0
- package/test/README.md +2 -2
- package/test-project/package.json +8 -2
- package/test-project/workspaces/workspace-a/package.json +135 -0
- package/test-project/workspaces/workspace-a/readme.md +20 -0
- package/test-project/workspaces/workspace-a/release/readme.md +42 -0
- package/test-project/workspaces/workspace-a/test/demo/package.json +25 -0
- package/test-project/workspaces/workspace-a/test/readme.md +12 -0
- package/test-project/workspaces/workspace-b/package.json +139 -0
- package/test-project/workspaces/workspace-b/readme.md +94 -0
- package/test-project/workspaces/workspace-b/requirements.txt +1 -0
- package/test-project/workspaces/workspace-b/test/sample-project/package.json +7 -0
- package/test-project/workspaces/workspace-b/themes/hexo-theme-flowbite/package.json +96 -0
- package/test-project/workspaces/workspace-b/themes/hexo-theme-flowbite/readme.md +156 -0
- package/tmp/rm-node-modules-test-project/package.json +17 -0
- package/tmp/rm-node-modules-test-project/packages/workspace-a/package.json +16 -0
- package/tmp/rm-node-modules-test-project/packages/workspace-b/package.json +16 -0
- package/tmp/test-repo/README.md +2 -35
- package/tmp/test-repo/package.json +13 -3
- package/docs-src/clean-github-actions-caches.md +0 -26
- package/docs-src/free-chatgpt.md +0 -26
- package/lib/binary-collections-config.cjs +0 -15
- package/lib/chunk-4EWQC6GZ.mjs +0 -382
- package/lib/chunk-4ZI7BQKQ.mjs +0 -381
- package/lib/chunk-5J2BEPY5.mjs +0 -83
- package/lib/chunk-AGZYRDC2.mjs +0 -323
- package/lib/chunk-BDCHCWHD.mjs +0 -136
- package/lib/chunk-BEZKJ25G.mjs +0 -140
- package/lib/chunk-DI5MDPSN.mjs +0 -386
- package/lib/chunk-GJTGHXRA.mjs +0 -356
- package/lib/chunk-HMRMTYZM.mjs +0 -40
- package/lib/chunk-HN52G2YL.mjs +0 -305
- package/lib/chunk-LEM5OMRP.mjs +0 -384
- package/lib/chunk-O6SWBEOQ.mjs +0 -81
- package/lib/chunk-RCP7DHVY.mjs +0 -190
- package/lib/chunk-SBNDSKG5.mjs +0 -136
- package/lib/chunk-U6SO4QEV.mjs +0 -320
- package/lib/chunk-XD6BJK6Q.mjs +0 -351
- package/lib/chunk-YXSFGA2D.mjs +0 -383
- package/lib/git/gitattributes.d.ts +0 -33
- package/lib/git/gitattributes.js +0 -223
- package/lib/ps/index.d.ts +0 -2
- package/lib/ps/index.js +0 -253
- package/tmp/typedoc/readme.md +0 -320
- /package/lib/{binary-collections-config.d.cts → binary-collections/config.d.cts} +0 -0
package/lib/npm-run-series.mjs
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
3
3
|
import {
|
|
4
4
|
require_utils
|
|
5
|
-
} from "./chunk-
|
|
5
|
+
} from "./chunk-5RTXZVCW.mjs";
|
|
6
6
|
import {
|
|
7
7
|
__commonJS,
|
|
8
8
|
__require,
|
|
@@ -13,6 +13,7 @@ import {
|
|
|
13
13
|
var require_npm_run_series = __commonJS({
|
|
14
14
|
"src/npm-run-series.cjs"() {
|
|
15
15
|
init_esm_shims();
|
|
16
|
+
var { spawnSync } = __require("child_process");
|
|
16
17
|
var fs = __require("fs");
|
|
17
18
|
var path = __require("path");
|
|
18
19
|
var { Minimatch } = __require("minimatch");
|
|
@@ -22,8 +23,22 @@ var require_npm_run_series = __commonJS({
|
|
|
22
23
|
var packagejson = path.join(cwd, "package.json");
|
|
23
24
|
var verbose = args["v"] || args["verbose"];
|
|
24
25
|
var usingYarn = args["yarn"];
|
|
26
|
+
function runCommand(command, commandArgs) {
|
|
27
|
+
const result = spawnSync(command, commandArgs, {
|
|
28
|
+
cwd,
|
|
29
|
+
shell: true,
|
|
30
|
+
stdio: "inherit"
|
|
31
|
+
});
|
|
32
|
+
if (result.error) {
|
|
33
|
+
throw result.error;
|
|
34
|
+
}
|
|
35
|
+
if (result.status !== 0) {
|
|
36
|
+
process.exitCode = result.status ?? 1;
|
|
37
|
+
return false;
|
|
38
|
+
}
|
|
39
|
+
return true;
|
|
40
|
+
}
|
|
25
41
|
(async function npmRunSeries() {
|
|
26
|
-
const { execa } = await import("execa");
|
|
27
42
|
if (fs.existsSync(packagejson)) {
|
|
28
43
|
const parse = JSON.parse(fs.readFileSync(packagejson, "utf-8"));
|
|
29
44
|
if (parse !== null && typeof parse === "object") {
|
|
@@ -39,10 +54,9 @@ var require_npm_run_series = __commonJS({
|
|
|
39
54
|
const match = matcher.match(scriptName);
|
|
40
55
|
if (verbose) console.log({ pattern, scriptName, match });
|
|
41
56
|
if (match === true) {
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
});
|
|
57
|
+
const command = usingYarn ? "yarn" : "npm";
|
|
58
|
+
const completed = runCommand(command, ["run", scriptName]);
|
|
59
|
+
if (!completed) return;
|
|
46
60
|
}
|
|
47
61
|
}
|
|
48
62
|
}
|
|
@@ -0,0 +1,645 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __esm = (fn, res) => function __init() {
|
|
9
|
+
return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
|
|
10
|
+
};
|
|
11
|
+
var __commonJS = (cb, mod) => function __require() {
|
|
12
|
+
return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
|
|
13
|
+
};
|
|
14
|
+
var __copyProps = (to, from, except, desc) => {
|
|
15
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
16
|
+
for (let key of __getOwnPropNames(from))
|
|
17
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
18
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
19
|
+
}
|
|
20
|
+
return to;
|
|
21
|
+
};
|
|
22
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
23
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
24
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
25
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
26
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
27
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
28
|
+
mod
|
|
29
|
+
));
|
|
30
|
+
|
|
31
|
+
// node_modules/tsup/assets/cjs_shims.js
|
|
32
|
+
var init_cjs_shims = __esm({
|
|
33
|
+
"node_modules/tsup/assets/cjs_shims.js"() {
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
// src/utils/index.cjs
|
|
38
|
+
var require_utils = __commonJS({
|
|
39
|
+
"src/utils/index.cjs"(exports2, module2) {
|
|
40
|
+
init_cjs_shims();
|
|
41
|
+
var fs3 = require("fs");
|
|
42
|
+
var path3 = require("upath");
|
|
43
|
+
var argv = require("minimist")(process.argv.slice(2));
|
|
44
|
+
var { exec } = require("child_process");
|
|
45
|
+
var { URL: URL2 } = require("url");
|
|
46
|
+
var { promisify } = require("util");
|
|
47
|
+
var execAsync = promisify(exec);
|
|
48
|
+
async function parseGitRemotes() {
|
|
49
|
+
try {
|
|
50
|
+
const { stdout } = await execAsync("git remote -v");
|
|
51
|
+
const lines = stdout.split("\n");
|
|
52
|
+
const remotes = {};
|
|
53
|
+
lines.forEach((line) => {
|
|
54
|
+
const [name, url] = line.split(" ");
|
|
55
|
+
if (name && url) {
|
|
56
|
+
const [repoUrl] = url.split(" ");
|
|
57
|
+
try {
|
|
58
|
+
const parsedUrl = new URL2(repoUrl);
|
|
59
|
+
const pathParts = parsedUrl.pathname.split("/").filter(Boolean);
|
|
60
|
+
if (parsedUrl.hostname === "github.com" && pathParts.length === 2) {
|
|
61
|
+
let repoPath = pathParts.join("/");
|
|
62
|
+
if (repoPath.endsWith(".git")) {
|
|
63
|
+
repoPath = repoPath.slice(0, -4);
|
|
64
|
+
}
|
|
65
|
+
remotes[name] = repoPath;
|
|
66
|
+
}
|
|
67
|
+
} catch (e) {
|
|
68
|
+
console.error("URL Parsing Error:", e.message);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
return remotes;
|
|
73
|
+
} catch (error) {
|
|
74
|
+
console.error("Error:", error.message);
|
|
75
|
+
return {};
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
module2.exports.parseGitRemotes = parseGitRemotes;
|
|
79
|
+
function joinPathPreserveDriveLetter(...segments) {
|
|
80
|
+
let fullPath = require("path").join(...segments);
|
|
81
|
+
if (/^[a-z]:\\/.test(fullPath)) {
|
|
82
|
+
fullPath = fullPath.charAt(0).toUpperCase() + fullPath.slice(1);
|
|
83
|
+
}
|
|
84
|
+
return fullPath;
|
|
85
|
+
}
|
|
86
|
+
module2.exports.joinPathPreserveDriveLetter = joinPathPreserveDriveLetter;
|
|
87
|
+
function getArgs2() {
|
|
88
|
+
return argv;
|
|
89
|
+
}
|
|
90
|
+
module2.exports.getArgs = getArgs2;
|
|
91
|
+
function del(fullPath) {
|
|
92
|
+
try {
|
|
93
|
+
if (!fs3.existsSync(fullPath)) return;
|
|
94
|
+
const stat = fs3.lstatSync(fullPath);
|
|
95
|
+
if (stat.isSymbolicLink()) {
|
|
96
|
+
try {
|
|
97
|
+
fs3.unlinkSync(fullPath);
|
|
98
|
+
console.log("deleted symlink", fullPath);
|
|
99
|
+
} catch (e) {
|
|
100
|
+
console.log("failed delete symlink", fullPath, e && e.message);
|
|
101
|
+
}
|
|
102
|
+
return;
|
|
103
|
+
}
|
|
104
|
+
if (stat.isDirectory()) {
|
|
105
|
+
const subdir = fs3.readdirSync(fullPath).map((dirPath) => path3.resolve(fullPath, dirPath));
|
|
106
|
+
for (let i = 0; i < subdir.length; i++) {
|
|
107
|
+
del(subdir[i]);
|
|
108
|
+
}
|
|
109
|
+
try {
|
|
110
|
+
fs3.rmdirSync(fullPath);
|
|
111
|
+
console.log("deleted", fullPath);
|
|
112
|
+
} catch (_e) {
|
|
113
|
+
try {
|
|
114
|
+
fs3.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7e3 });
|
|
115
|
+
console.log("deleted", fullPath);
|
|
116
|
+
} catch (ee) {
|
|
117
|
+
console.log("failed delete", fullPath, ee && ee.message);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
return;
|
|
121
|
+
}
|
|
122
|
+
try {
|
|
123
|
+
fs3.unlinkSync(fullPath);
|
|
124
|
+
console.log("deleted", fullPath);
|
|
125
|
+
} catch (_e) {
|
|
126
|
+
try {
|
|
127
|
+
fs3.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7e3 });
|
|
128
|
+
console.log("deleted", fullPath);
|
|
129
|
+
} catch (ee) {
|
|
130
|
+
console.log("failed delete", fullPath, ee && ee.message);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
} catch (err) {
|
|
134
|
+
console.log("failed delete", fullPath, err && err.message);
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
module2.exports.del = del;
|
|
138
|
+
function delStream(globStream) {
|
|
139
|
+
globStream.stream().on("data", (result) => {
|
|
140
|
+
const fullPath = path3.resolve(process.cwd(), result);
|
|
141
|
+
try {
|
|
142
|
+
if (fs3.existsSync(fullPath)) {
|
|
143
|
+
const stat = fs3.lstatSync(fullPath);
|
|
144
|
+
if (stat.isSymbolicLink()) {
|
|
145
|
+
try {
|
|
146
|
+
fs3.unlinkSync(fullPath);
|
|
147
|
+
console.log("deleted symlink", fullPath);
|
|
148
|
+
} catch (e) {
|
|
149
|
+
console.log("failed delete symlink", fullPath, e && e.message);
|
|
150
|
+
}
|
|
151
|
+
return;
|
|
152
|
+
}
|
|
153
|
+
if (stat.isDirectory()) {
|
|
154
|
+
const subdir = fs3.readdirSync(fullPath).map((dirPath) => path3.resolve(fullPath, dirPath));
|
|
155
|
+
for (let i = 0; i < subdir.length; i++) {
|
|
156
|
+
del(subdir[i]);
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
del(fullPath);
|
|
161
|
+
} catch (err) {
|
|
162
|
+
console.log("failed processing", fullPath, err && err.message);
|
|
163
|
+
}
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
module2.exports.delStream = delStream;
|
|
167
|
+
function getFileTreeString(hashArray) {
|
|
168
|
+
const tree = {};
|
|
169
|
+
const hashMap = {};
|
|
170
|
+
for (const entry of hashArray) {
|
|
171
|
+
const [filePath, hash] = entry.split(" ");
|
|
172
|
+
hashMap[filePath] = hash;
|
|
173
|
+
const parts = filePath.split("/");
|
|
174
|
+
let current = tree;
|
|
175
|
+
for (let i = 0; i < parts.length; i++) {
|
|
176
|
+
const part = parts[i];
|
|
177
|
+
if (i === parts.length - 1) {
|
|
178
|
+
current[part] = null;
|
|
179
|
+
} else {
|
|
180
|
+
current[part] = current[part] || {};
|
|
181
|
+
current = current[part];
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
function printNode(node, prefix = "", parentPath = "") {
|
|
186
|
+
const keys = Object.keys(node).sort();
|
|
187
|
+
let lines = [];
|
|
188
|
+
keys.forEach((key, idx) => {
|
|
189
|
+
const isLast = idx === keys.length - 1;
|
|
190
|
+
const branch = isLast ? "\u2514\u2500\u2500 " : "\u251C\u2500\u2500 ";
|
|
191
|
+
const currentPath = parentPath ? parentPath + "/" + key : key;
|
|
192
|
+
if (node[key] === null) {
|
|
193
|
+
lines.push(prefix + branch + key + " [" + (hashMap[currentPath] || "") + "]");
|
|
194
|
+
} else {
|
|
195
|
+
lines.push(prefix + branch + key + "/");
|
|
196
|
+
lines = lines.concat(printNode(node[key], prefix + (isLast ? " " : "\u2502 "), currentPath));
|
|
197
|
+
}
|
|
198
|
+
});
|
|
199
|
+
return lines;
|
|
200
|
+
}
|
|
201
|
+
return printNode(tree, "", "").join("\n");
|
|
202
|
+
}
|
|
203
|
+
module2.exports.getFileTreeString = getFileTreeString;
|
|
204
|
+
var delay = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
205
|
+
module2.exports.delay = delay;
|
|
206
|
+
}
|
|
207
|
+
});
|
|
208
|
+
|
|
209
|
+
// src/utils/findEnvFiles.cjs
|
|
210
|
+
var require_findEnvFiles = __commonJS({
|
|
211
|
+
"src/utils/findEnvFiles.cjs"(exports2, module2) {
|
|
212
|
+
init_cjs_shims();
|
|
213
|
+
var fs3 = require("fs");
|
|
214
|
+
var path3 = require("path");
|
|
215
|
+
var glob = require("glob");
|
|
216
|
+
var DEFAULT_IGNORES = [
|
|
217
|
+
"**/node_modules/**",
|
|
218
|
+
"**/.git/**",
|
|
219
|
+
"**/.yarn/**",
|
|
220
|
+
"**/.pnpm/**",
|
|
221
|
+
"**/dist/**",
|
|
222
|
+
"**/build/**",
|
|
223
|
+
"**/coverage/**",
|
|
224
|
+
"**/vendor/**",
|
|
225
|
+
"**/tmp/**",
|
|
226
|
+
"**/.cache/**",
|
|
227
|
+
"**/assets/**",
|
|
228
|
+
"**/logs/**",
|
|
229
|
+
"**/output/**",
|
|
230
|
+
"**/public/**",
|
|
231
|
+
"**/static/**",
|
|
232
|
+
"**/temp/**",
|
|
233
|
+
"**/backup/**",
|
|
234
|
+
"**/backups/**",
|
|
235
|
+
"**/examples/**",
|
|
236
|
+
"**/docs/**",
|
|
237
|
+
"**/tests/**",
|
|
238
|
+
"**/__tests__/**",
|
|
239
|
+
"**/spec/**",
|
|
240
|
+
"**/__specs__/**",
|
|
241
|
+
"**/scripts/**",
|
|
242
|
+
"**/bin/**",
|
|
243
|
+
"**/hooks/**",
|
|
244
|
+
"**/config/**",
|
|
245
|
+
"**/configs/**",
|
|
246
|
+
"**/settings/**",
|
|
247
|
+
"**/.vscode/**",
|
|
248
|
+
"**/.idea/**"
|
|
249
|
+
];
|
|
250
|
+
function findEnvFiles2(startDir = process.cwd(), filter) {
|
|
251
|
+
const found = /* @__PURE__ */ new Set();
|
|
252
|
+
function addFile(file) {
|
|
253
|
+
const normalized = path3.normalize(file);
|
|
254
|
+
if (typeof filter === "function" && !filter(normalized)) {
|
|
255
|
+
return;
|
|
256
|
+
}
|
|
257
|
+
found.add(normalized);
|
|
258
|
+
}
|
|
259
|
+
let current = path3.resolve(startDir);
|
|
260
|
+
while (true) {
|
|
261
|
+
const envPath2 = path3.join(current, ".env");
|
|
262
|
+
if (fs3.existsSync(envPath2)) {
|
|
263
|
+
addFile(envPath2);
|
|
264
|
+
}
|
|
265
|
+
const parent = path3.dirname(current);
|
|
266
|
+
if (parent === current) {
|
|
267
|
+
break;
|
|
268
|
+
}
|
|
269
|
+
current = parent;
|
|
270
|
+
}
|
|
271
|
+
const files = glob.globSync("**/.env*", {
|
|
272
|
+
cwd: startDir,
|
|
273
|
+
absolute: true,
|
|
274
|
+
nodir: true,
|
|
275
|
+
ignore: DEFAULT_IGNORES
|
|
276
|
+
});
|
|
277
|
+
for (const file of files) {
|
|
278
|
+
addFile(file);
|
|
279
|
+
}
|
|
280
|
+
return [...found];
|
|
281
|
+
}
|
|
282
|
+
function findEnvWithToken(startDir = process.cwd(), tokenName = "GITHUB_TOKEN") {
|
|
283
|
+
const envFiles = findEnvFiles2(startDir);
|
|
284
|
+
return envFiles.find((file) => {
|
|
285
|
+
try {
|
|
286
|
+
const content = fs3.readFileSync(file, "utf-8");
|
|
287
|
+
const regex = new RegExp(`^\\s*${tokenName}\\s*=`, "m");
|
|
288
|
+
return regex.test(content);
|
|
289
|
+
} catch (err) {
|
|
290
|
+
console.warn(`Failed to read ${file}: ${err instanceof Error ? err.message : String(err)}`);
|
|
291
|
+
return false;
|
|
292
|
+
}
|
|
293
|
+
});
|
|
294
|
+
}
|
|
295
|
+
module2.exports = {
|
|
296
|
+
DEFAULT_IGNORES,
|
|
297
|
+
findEnvFiles: findEnvFiles2,
|
|
298
|
+
findEnvWithToken,
|
|
299
|
+
default: findEnvFiles2
|
|
300
|
+
};
|
|
301
|
+
}
|
|
302
|
+
});
|
|
303
|
+
|
|
304
|
+
// src/package-resolutions-updater-cli.mjs
|
|
305
|
+
init_cjs_shims();
|
|
306
|
+
var import_ansi_colors = __toESM(require("ansi-colors"), 1);
|
|
307
|
+
var import_fs2 = __toESM(require("fs"), 1);
|
|
308
|
+
var import_path2 = __toESM(require("path"), 1);
|
|
309
|
+
|
|
310
|
+
// src/package-resolutions-updater.mjs
|
|
311
|
+
init_cjs_shims();
|
|
312
|
+
var dotenv = __toESM(require("dotenv"), 1);
|
|
313
|
+
var import_fs = __toESM(require("fs"), 1);
|
|
314
|
+
var import_https = __toESM(require("https"), 1);
|
|
315
|
+
var import_os = __toESM(require("os"), 1);
|
|
316
|
+
var import_path = __toESM(require("path"), 1);
|
|
317
|
+
var utils = __toESM(require_utils(), 1);
|
|
318
|
+
var import_findEnvFiles = __toESM(require_findEnvFiles(), 1);
|
|
319
|
+
var import_git_command_helper = require("git-command-helper");
|
|
320
|
+
var import_axios = __toESM(require("axios"), 1);
|
|
321
|
+
var projectDir = process.cwd();
|
|
322
|
+
var envPath = import_path.default.join(projectDir, ".env");
|
|
323
|
+
var args = utils.getArgs();
|
|
324
|
+
if (!import_fs.default.existsSync(envPath)) {
|
|
325
|
+
const envFiles = (0, import_findEnvFiles.findEnvFiles)(projectDir, (file) => {
|
|
326
|
+
const content = import_fs.default.readFileSync(file, "utf-8");
|
|
327
|
+
return /GITHUB_TOKEN|ACCESS_TOKEN/.test(content);
|
|
328
|
+
});
|
|
329
|
+
if (envFiles.length > 0) {
|
|
330
|
+
envPath = envFiles[0];
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
if (import_fs.default.existsSync(envPath)) {
|
|
334
|
+
dotenv.config({ path: envPath, quiet: true, override: true });
|
|
335
|
+
}
|
|
336
|
+
var ACCESS_TOKEN = process.env.GITHUB_TOKEN || process.env.ACCESS_TOKEN;
|
|
337
|
+
if (args.help || args.h) {
|
|
338
|
+
showHelp();
|
|
339
|
+
}
|
|
340
|
+
function showHelp() {
|
|
341
|
+
const helpText = `
|
|
342
|
+
GitHub Package Resolutions Updater
|
|
343
|
+
Usage:
|
|
344
|
+
node src/package-resolutions-updater.mjs [options]
|
|
345
|
+
Options:
|
|
346
|
+
--help, -h Show this help message
|
|
347
|
+
Description:
|
|
348
|
+
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.
|
|
349
|
+
Features:
|
|
350
|
+
- Parses GitHub URLs to extract repository owner, name, and branch.
|
|
351
|
+
- Fetches the latest commit SHA across all branches using GitHub's API.
|
|
352
|
+
- Replaces the old branch or commit in the URL with the latest SHA.
|
|
353
|
+
- Overwrites package.json with the updated URLs.
|
|
354
|
+
Requirements:
|
|
355
|
+
- GitHub Personal Access Token (GITHUB_TOKEN) via .env
|
|
356
|
+
- ESM support (type: "module" in package.json)
|
|
357
|
+
- Node.js v18+ recommended
|
|
358
|
+
Dependencies:
|
|
359
|
+
- ansi-colors \u2013 for styled terminal output
|
|
360
|
+
- dotenv \u2013 to load GitHub token from .env
|
|
361
|
+
Examples:
|
|
362
|
+
node src/package-resolutions-updater.mjs
|
|
363
|
+
node src/package-resolutions-updater.mjs --help
|
|
364
|
+
|
|
365
|
+
`;
|
|
366
|
+
console.log(helpText);
|
|
367
|
+
process.exit(0);
|
|
368
|
+
}
|
|
369
|
+
var GITHUB_USER_AGENTS = [
|
|
370
|
+
"octokit-rest.js/19.0.7",
|
|
371
|
+
"GitHub CLI/2.40.0",
|
|
372
|
+
"Mozilla/5.0 (compatible; GitHubCopilot/1.0)",
|
|
373
|
+
"PostmanRuntime/7.32.3",
|
|
374
|
+
"binary-collections-resolver/1.0 (+https://github.com/dimaslanjaka/bin)"
|
|
375
|
+
];
|
|
376
|
+
var userAgentDir = import_path.default.join(import_os.default.tmpdir(), "nodejs");
|
|
377
|
+
var userAgentFile = import_path.default.join(userAgentDir, "useragent.txt");
|
|
378
|
+
var selectedUserAgent;
|
|
379
|
+
try {
|
|
380
|
+
if (!import_fs.default.existsSync(userAgentDir)) import_fs.default.mkdirSync(userAgentDir, { recursive: true });
|
|
381
|
+
if (import_fs.default.existsSync(userAgentFile)) {
|
|
382
|
+
const fileAgent = import_fs.default.readFileSync(userAgentFile, "utf-8").trim();
|
|
383
|
+
if (GITHUB_USER_AGENTS.includes(fileAgent)) {
|
|
384
|
+
selectedUserAgent = fileAgent;
|
|
385
|
+
}
|
|
386
|
+
}
|
|
387
|
+
if (!selectedUserAgent) {
|
|
388
|
+
selectedUserAgent = GITHUB_USER_AGENTS[Math.floor(Math.random() * GITHUB_USER_AGENTS.length)];
|
|
389
|
+
import_fs.default.writeFileSync(userAgentFile, selectedUserAgent, "utf-8");
|
|
390
|
+
}
|
|
391
|
+
} catch (_e) {
|
|
392
|
+
selectedUserAgent = GITHUB_USER_AGENTS[Math.floor(Math.random() * GITHUB_USER_AGENTS.length)];
|
|
393
|
+
}
|
|
394
|
+
function fetchJson(url) {
|
|
395
|
+
const headers = {
|
|
396
|
+
"User-Agent": selectedUserAgent,
|
|
397
|
+
Accept: "application/vnd.github.v3+json",
|
|
398
|
+
"X-GitHub-Api-Version": "2022-11-28",
|
|
399
|
+
...ACCESS_TOKEN ? { Authorization: `token ${ACCESS_TOKEN}` } : {}
|
|
400
|
+
};
|
|
401
|
+
return new Promise((resolve, reject) => {
|
|
402
|
+
import_https.default.get(url, { headers }, (res) => {
|
|
403
|
+
let data = "";
|
|
404
|
+
res.on("data", (chunk) => data += chunk);
|
|
405
|
+
res.on("end", () => {
|
|
406
|
+
try {
|
|
407
|
+
const json = JSON.parse(data);
|
|
408
|
+
if (res.statusCode < 200 || res.statusCode >= 300) {
|
|
409
|
+
return reject(
|
|
410
|
+
new Error(`GitHub API Error ${res.statusCode}: ${json.message || "Unknown error"}
|
|
411
|
+
URL: ${url}`)
|
|
412
|
+
);
|
|
413
|
+
}
|
|
414
|
+
resolve(json);
|
|
415
|
+
} catch {
|
|
416
|
+
reject(new Error(`Invalid JSON from: ${url}`));
|
|
417
|
+
}
|
|
418
|
+
});
|
|
419
|
+
}).on("error", reject);
|
|
420
|
+
});
|
|
421
|
+
}
|
|
422
|
+
async function getLatestCommit(owner, repo, branch = "main") {
|
|
423
|
+
var _a, _b, _c, _d;
|
|
424
|
+
const url = `https://api.github.com/repos/${owner}/${repo}/commits/${branch}`;
|
|
425
|
+
const json = await fetchJson(url);
|
|
426
|
+
const sha = json.sha;
|
|
427
|
+
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);
|
|
428
|
+
if (!sha || !dateStr) {
|
|
429
|
+
console.log(json);
|
|
430
|
+
throw new Error(`Missing SHA or date for ${owner}/${repo}@${branch}`);
|
|
431
|
+
}
|
|
432
|
+
return {
|
|
433
|
+
owner,
|
|
434
|
+
repo,
|
|
435
|
+
branch,
|
|
436
|
+
sha,
|
|
437
|
+
date: new Date(dateStr).toISOString()
|
|
438
|
+
};
|
|
439
|
+
}
|
|
440
|
+
async function getLatestCommitAcrossBranches(owner, repo) {
|
|
441
|
+
const branches = await fetchJson(`https://api.github.com/repos/${owner}/${repo}/branches`);
|
|
442
|
+
const commits = await Promise.all(
|
|
443
|
+
branches.map(async ({ name, commit }) => {
|
|
444
|
+
var _a, _b, _c, _d;
|
|
445
|
+
const commitSha = commit == null ? void 0 : commit.sha;
|
|
446
|
+
if (!commitSha) {
|
|
447
|
+
console.warn(`No commit SHA for '${owner}/${repo}' branch: ${name}`);
|
|
448
|
+
return { branch: name, sha: "", date: /* @__PURE__ */ new Date(0) };
|
|
449
|
+
}
|
|
450
|
+
try {
|
|
451
|
+
const commitData = await fetchJson(`https://api.github.com/repos/${owner}/${repo}/commits/${commitSha}`);
|
|
452
|
+
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);
|
|
453
|
+
const date = dateStr ? new Date(dateStr) : /* @__PURE__ */ new Date(0);
|
|
454
|
+
return { branch: name, sha: commitData.sha, date };
|
|
455
|
+
} catch (e) {
|
|
456
|
+
console.warn(`Failed to fetch commit for ${name}: ${e.message}`);
|
|
457
|
+
return { branch: name, sha: commitSha, date: /* @__PURE__ */ new Date(0) };
|
|
458
|
+
}
|
|
459
|
+
})
|
|
460
|
+
);
|
|
461
|
+
const latest = commits.reduce((a, b) => a.date > b.date ? a : b, { date: /* @__PURE__ */ new Date(0) });
|
|
462
|
+
return {
|
|
463
|
+
owner,
|
|
464
|
+
repo,
|
|
465
|
+
branch: latest.branch,
|
|
466
|
+
sha: latest.sha,
|
|
467
|
+
date: latest.date.toISOString()
|
|
468
|
+
};
|
|
469
|
+
}
|
|
470
|
+
function replaceRawWithLatestHash(url, latestHash) {
|
|
471
|
+
const parsed = (0, import_git_command_helper.parseGitHubUrl)(url);
|
|
472
|
+
if (!parsed || !parsed.owner || !parsed.repo || !parsed.branch) {
|
|
473
|
+
throw new Error("Invalid GitHub raw URL");
|
|
474
|
+
}
|
|
475
|
+
const branchPrefix = `${parsed.branch}/`;
|
|
476
|
+
const rawPrefix = parsed.host === "github.com" ? `raw/${branchPrefix}` : branchPrefix;
|
|
477
|
+
const refsPrefix = `refs/heads/${branchPrefix}`;
|
|
478
|
+
const path3 = parsed.path.startsWith(rawPrefix) ? parsed.path.slice(rawPrefix.length) : parsed.path.startsWith(refsPrefix) ? parsed.path.slice(refsPrefix.length) : parsed.path.startsWith(branchPrefix) ? parsed.path.slice(branchPrefix.length) : parsed.path;
|
|
479
|
+
if (parsed.host === "github.com") {
|
|
480
|
+
return `https://github.com/${parsed.owner}/${parsed.repo}/raw/${latestHash}/${path3}`;
|
|
481
|
+
}
|
|
482
|
+
if (parsed.host === "raw.githubusercontent.com") {
|
|
483
|
+
return `https://raw.githubusercontent.com/${parsed.owner}/${parsed.repo}/${latestHash}/${path3}`;
|
|
484
|
+
}
|
|
485
|
+
throw new Error("Invalid GitHub raw URL");
|
|
486
|
+
}
|
|
487
|
+
async function resolvePackageResolutionUpdates(resolutions, specialPackageOverrides = []) {
|
|
488
|
+
const updates = [];
|
|
489
|
+
for (const [currentPkgName, url] of Object.entries(resolutions || {})) {
|
|
490
|
+
let repo;
|
|
491
|
+
try {
|
|
492
|
+
repo = (0, import_git_command_helper.parseGitHubUrl)(url);
|
|
493
|
+
} catch (error) {
|
|
494
|
+
updates.push({
|
|
495
|
+
skipped: true,
|
|
496
|
+
currentPkgName,
|
|
497
|
+
url,
|
|
498
|
+
error
|
|
499
|
+
});
|
|
500
|
+
continue;
|
|
501
|
+
}
|
|
502
|
+
try {
|
|
503
|
+
const override = specialPackageOverrides.find((p) => p.pkg === currentPkgName);
|
|
504
|
+
const latest = override ? await getLatestCommit(override.owner, override.repo, override.branch) : await getLatestCommitAcrossBranches(repo.owner, repo.repo);
|
|
505
|
+
const new_url = replaceRawWithLatestHash(url, latest.sha);
|
|
506
|
+
await import_axios.default.head(new_url, {
|
|
507
|
+
headers: {
|
|
508
|
+
"User-Agent": selectedUserAgent,
|
|
509
|
+
Accept: "application/vnd.github.v3+json",
|
|
510
|
+
"X-GitHub-Api-Version": "2022-11-28",
|
|
511
|
+
...ACCESS_TOKEN ? { Authorization: `token ${ACCESS_TOKEN}` } : {}
|
|
512
|
+
}
|
|
513
|
+
}).then((response) => {
|
|
514
|
+
if (response.status < 200 || response.status >= 300) {
|
|
515
|
+
updates.push({
|
|
516
|
+
failed: true,
|
|
517
|
+
currentPkgName,
|
|
518
|
+
url,
|
|
519
|
+
new_url,
|
|
520
|
+
repo,
|
|
521
|
+
latest,
|
|
522
|
+
error: new Error(`New URL is not accessible, status code: ${response.status}`)
|
|
523
|
+
});
|
|
524
|
+
return;
|
|
525
|
+
}
|
|
526
|
+
updates.push({
|
|
527
|
+
currentPkgName,
|
|
528
|
+
url,
|
|
529
|
+
new_url,
|
|
530
|
+
repo,
|
|
531
|
+
latest
|
|
532
|
+
});
|
|
533
|
+
}).catch((e) => {
|
|
534
|
+
updates.push({
|
|
535
|
+
failed: true,
|
|
536
|
+
currentPkgName,
|
|
537
|
+
url,
|
|
538
|
+
new_url,
|
|
539
|
+
repo,
|
|
540
|
+
latest,
|
|
541
|
+
error: new Error(`New URL is not accessible: ${e.message}`)
|
|
542
|
+
});
|
|
543
|
+
return null;
|
|
544
|
+
});
|
|
545
|
+
} catch (error) {
|
|
546
|
+
updates.push({
|
|
547
|
+
failed: true,
|
|
548
|
+
currentPkgName,
|
|
549
|
+
url,
|
|
550
|
+
repo,
|
|
551
|
+
error
|
|
552
|
+
});
|
|
553
|
+
}
|
|
554
|
+
}
|
|
555
|
+
return updates;
|
|
556
|
+
}
|
|
557
|
+
|
|
558
|
+
// src/package-resolutions-updater-cli.mjs
|
|
559
|
+
(async () => {
|
|
560
|
+
const specialPackageOverrides = [
|
|
561
|
+
// SBG packages
|
|
562
|
+
{ pkg: "sbg-utility", branch: "sbg-utility", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
563
|
+
{ pkg: "sbg-api", branch: "sbg-api", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
564
|
+
{ pkg: "instant-indexing", branch: "instant-indexing", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
565
|
+
{ pkg: "sbg-server", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
566
|
+
{ pkg: "sbg-cli", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
567
|
+
{ pkg: "static-blog-generator", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
568
|
+
// Hexo family
|
|
569
|
+
// { pkg: "hexo", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
570
|
+
// { pkg: "hexo-util", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
571
|
+
{ pkg: "hexo-post-parser", branch: "pre-release", repo: "hexo-post-parser", owner: "dimaslanjaka" },
|
|
572
|
+
{ pkg: "hexo-seo", branch: "pre-release", repo: "hexo-seo", owner: "dimaslanjaka" },
|
|
573
|
+
{ pkg: "hexo-is", branch: "master", repo: "hexo-is", owner: "dimaslanjaka" },
|
|
574
|
+
{ pkg: "markdown-it", branch: "master", repo: "markdown-it", owner: "dimaslanjaka" },
|
|
575
|
+
{ pkg: "hexo-renderers", branch: "pre-release", repo: "hexo-renderers", owner: "dimaslanjaka" },
|
|
576
|
+
{ pkg: "hexo-shortcodes", branch: "pre-release", repo: "hexo-shortcodes", owner: "dimaslanjaka" },
|
|
577
|
+
{ pkg: "google-news-sitemap", branch: "master", repo: "google-news-sitemap", owner: "dimaslanjaka" },
|
|
578
|
+
{ pkg: "git-command-helper", branch: "pre-release", repo: "git-command-helper", owner: "dimaslanjaka" },
|
|
579
|
+
{
|
|
580
|
+
pkg: "nodejs-package-types",
|
|
581
|
+
branch: "main",
|
|
582
|
+
repo: "nodejs-package-types",
|
|
583
|
+
owner: "dimaslanjaka"
|
|
584
|
+
},
|
|
585
|
+
{ pkg: "cross-spawn", branch: "private", repo: "node-cross-spawn", owner: "dimaslanjaka" },
|
|
586
|
+
{ pkg: "hexo-generator-redirect", branch: "master", repo: "hexo-generator-redirect", owner: "dimaslanjaka" },
|
|
587
|
+
{ pkg: "binary-collections", branch: "master", repo: "bin", owner: "dimaslanjaka" },
|
|
588
|
+
// { pkg: "@types/hexo", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
589
|
+
{ pkg: "@types/git-command-helper", branch: "pre-release", repo: "git-command-helper", owner: "dimaslanjaka" }
|
|
590
|
+
];
|
|
591
|
+
const pkgPath = import_path2.default.join(process.cwd(), "package.json");
|
|
592
|
+
let pkg;
|
|
593
|
+
try {
|
|
594
|
+
pkg = JSON.parse(import_fs2.default.readFileSync(pkgPath, "utf-8"));
|
|
595
|
+
} catch (e) {
|
|
596
|
+
console.error(import_ansi_colors.default.red(`Failed to read package.json: ${e.message}`));
|
|
597
|
+
process.exit(1);
|
|
598
|
+
}
|
|
599
|
+
const entries = Object.entries(pkg.resolutions || {});
|
|
600
|
+
if (entries.length === 0) {
|
|
601
|
+
console.log(import_ansi_colors.default.yellow("No resolutions found in package.json"));
|
|
602
|
+
return;
|
|
603
|
+
}
|
|
604
|
+
console.log(`\u2699\uFE0F Processing ${entries.length} resolution(s)...`);
|
|
605
|
+
const updates = await resolvePackageResolutionUpdates(pkg.resolutions, specialPackageOverrides);
|
|
606
|
+
const validUpdates = updates.filter((u) => !u.skipped && !u.failed);
|
|
607
|
+
for (const update of updates) {
|
|
608
|
+
if (update.skipped) {
|
|
609
|
+
console.log(`\u23ED\uFE0F Skipping ${import_ansi_colors.default.yellow(update.currentPkgName)}: ${update.error.message}`);
|
|
610
|
+
}
|
|
611
|
+
if (update.failed) {
|
|
612
|
+
console.log(`\u274C Failed to process ${import_ansi_colors.default.red(update.currentPkgName)}: ${update.error.message}`);
|
|
613
|
+
}
|
|
614
|
+
}
|
|
615
|
+
console.log("");
|
|
616
|
+
if (validUpdates.length === 0) {
|
|
617
|
+
console.log(import_ansi_colors.default.yellow("No GitHub URLs were processed"));
|
|
618
|
+
return;
|
|
619
|
+
}
|
|
620
|
+
console.log(`\u{1F4DD} Applying updates to ${validUpdates.length} GitHub URL(s)...`);
|
|
621
|
+
let changed = false;
|
|
622
|
+
for (const { currentPkgName, url, new_url, repo, latest } of validUpdates) {
|
|
623
|
+
if (url !== new_url) {
|
|
624
|
+
console.log(`${import_ansi_colors.default.cyan(currentPkgName)}:`);
|
|
625
|
+
console.log(" from:", url.replace(repo.branch, import_ansi_colors.default.red(repo.branch)));
|
|
626
|
+
console.log(" to:", new_url.replace(latest.sha, import_ansi_colors.default.green(latest.sha)));
|
|
627
|
+
pkg.resolutions[currentPkgName] = new_url;
|
|
628
|
+
changed = true;
|
|
629
|
+
} else {
|
|
630
|
+
console.log(`${import_ansi_colors.default.cyan(currentPkgName)}: ${import_ansi_colors.default.gray("already up-to-date")}`);
|
|
631
|
+
}
|
|
632
|
+
}
|
|
633
|
+
console.log("\n\u{1F4CC} Summary:");
|
|
634
|
+
if (changed) {
|
|
635
|
+
try {
|
|
636
|
+
import_fs2.default.writeFileSync(pkgPath, JSON.stringify(pkg, null, 2) + "\n");
|
|
637
|
+
console.log(`\u2705 package.json updated successfully`);
|
|
638
|
+
} catch (e) {
|
|
639
|
+
console.error(import_ansi_colors.default.red(`Failed to write package.json: ${e.message}`));
|
|
640
|
+
process.exit(1);
|
|
641
|
+
}
|
|
642
|
+
} else {
|
|
643
|
+
console.log(import_ansi_colors.default.green("No changes to package.json were necessary."));
|
|
644
|
+
}
|
|
645
|
+
})();
|