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.
- package/binaries/binary-executor.cjs +43 -0
- package/{bin → binaries}/clean-nodemodule +0 -0
- package/binaries/clean-nodemodule.cjs +43 -0
- package/binaries/clean-nodemodule.cmd +4 -0
- package/{bin → binaries}/clean-nodemodules +0 -0
- package/binaries/clean-nodemodules.cjs +43 -0
- package/binaries/clean-nodemodules.cmd +5 -0
- package/{bin → binaries}/dev +0 -0
- package/binaries/dev.cjs +43 -0
- package/{bin → binaries}/empty +0 -0
- package/binaries/empty.cjs +43 -0
- package/{bin → binaries}/git-reduce-size +0 -0
- package/binaries/git-reduce-size.cjs +43 -0
- package/binaries/javakill.cjs +43 -0
- package/{bin → binaries}/javakill.cmd +0 -0
- package/{bin → binaries}/kill-process +0 -0
- package/binaries/kill-process.cjs +43 -0
- package/binaries/nodekill.cjs +43 -0
- package/{bin → binaries}/nodekill.ps1 +0 -0
- package/{bin → binaries}/prod +0 -0
- package/binaries/prod.cjs +43 -0
- package/{bin → binaries}/rmfind +0 -0
- package/binaries/rmfind.cjs +43 -0
- package/{bin → binaries}/rmx +0 -0
- package/binaries/rmx.cjs +43 -0
- package/{bin → binaries}/submodule-token +0 -0
- package/binaries/submodule-token.cjs +43 -0
- package/docs-src/clean-github-actions-caches.md +26 -0
- package/docs-src/free-chatgpt.md +26 -0
- package/lib/binary-collections-config.cjs +3 -2
- package/lib/binary-collections-config.mjs +2 -2
- package/lib/binary-collections.cjs +452 -105
- package/lib/binary-collections.mjs +131 -84
- package/lib/changelog.cjs +3 -3
- package/lib/changelog.mjs +177 -171
- package/lib/chunk-4EWQC6GZ.mjs +382 -0
- package/lib/chunk-4ZI7BQKQ.mjs +381 -0
- package/lib/chunk-5J2BEPY5.mjs +83 -0
- package/lib/{chunk-4BYBVEYC.mjs → chunk-66PAU5PS.mjs} +5 -4
- package/lib/chunk-6HHJRKFB.mjs +59 -0
- package/lib/chunk-6S4NXESK.mjs +26 -0
- package/lib/{chunk-ZYAQRPUL.mjs → chunk-7YD7IPFF.mjs} +2 -2
- package/lib/{chunk-SH3L6HHV.mjs → chunk-A2JQXI5Z.mjs} +2 -2
- package/lib/{chunk-EGSSKVDH.mjs → chunk-A3VUZEJK.mjs} +1 -1
- package/lib/chunk-AGZYRDC2.mjs +323 -0
- package/lib/{chunk-VVEZVNIV.mjs → chunk-AI4CVPJ7.mjs} +6 -6
- package/lib/chunk-BDCHCWHD.mjs +136 -0
- package/lib/chunk-BEZKJ25G.mjs +140 -0
- package/lib/chunk-DI5MDPSN.mjs +386 -0
- package/lib/{chunk-ONIBBBQ3.mjs → chunk-E6FDDAOO.mjs} +4 -3
- package/lib/chunk-FKI7IEB5.mjs +172 -0
- package/lib/chunk-GJTGHXRA.mjs +356 -0
- package/lib/{chunk-YV7DO3YV.mjs → chunk-HLGOWBEO.mjs} +1 -1
- package/lib/chunk-HMRMTYZM.mjs +40 -0
- package/lib/chunk-HN52G2YL.mjs +305 -0
- package/lib/chunk-HO6GHCOB.mjs +385 -0
- package/lib/chunk-LEM5OMRP.mjs +384 -0
- package/lib/{chunk-YX5U7XDR.mjs → chunk-M3YIYRHT.mjs} +6 -5
- package/lib/chunk-O6SWBEOQ.mjs +81 -0
- package/lib/{chunk-JGR2NW6D.mjs → chunk-PDSXF5HY.mjs} +3 -3
- package/lib/{chunk-AASHBCRW.mjs → chunk-QQ4A6DLD.mjs} +8 -0
- package/lib/chunk-RCP7DHVY.mjs +190 -0
- package/lib/chunk-SBNDSKG5.mjs +136 -0
- package/lib/chunk-U6SO4QEV.mjs +320 -0
- package/lib/{chunk-APBWENF6.mjs → chunk-V3N3JEUF.mjs} +3 -3
- package/lib/chunk-XD6BJK6Q.mjs +351 -0
- package/lib/chunk-XVBFFVCJ.mjs +209 -0
- package/lib/chunk-YXSFGA2D.mjs +383 -0
- package/lib/clean-github-actions-caches.cjs +243 -148
- package/lib/clean-github-actions-caches.mjs +3 -2
- package/lib/del-gradle.cjs +2 -2
- package/lib/del-gradle.js +1 -1
- package/lib/del-gradle.mjs +2 -2
- package/lib/del-node-modules.cjs +2 -2
- package/lib/del-node-modules.js +1 -1
- package/lib/del-node-modules.mjs +2 -2
- package/lib/del-ps.cjs +29 -8
- package/lib/del-ps.js +2 -2
- package/lib/del-ps.mjs +7 -5
- package/lib/del-yarn-caches.cjs +26 -5
- package/lib/del-yarn-caches.js +38 -3
- package/lib/del-yarn-caches.mjs +6 -6
- package/lib/find-node-modules-cli.cjs +5 -4
- package/lib/find-node-modules-cli.js +1 -1
- package/lib/find-node-modules-cli.mjs +2 -2
- package/lib/find-node-modules.cjs +4 -3
- package/lib/{find-node-modules.d.ts → find-node-modules.d.cts} +1 -1
- package/lib/find-node-modules.mjs +2 -2
- package/lib/free-chatgpt.cjs +548 -0
- package/lib/free-chatgpt.js +51 -0
- package/lib/free-chatgpt.mjs +50 -0
- package/lib/git/gitattributes.cjs +1 -1
- package/lib/git/{gitattributes.d.mts → gitattributes.d.cts} +5 -7
- package/lib/git/gitattributes.mjs +2 -2
- package/lib/git/line-endings.cjs +297 -64
- package/lib/git/line-endings.mjs +4 -4
- package/lib/git/normalize.cjs +26 -36
- package/lib/git/normalize.mjs +2 -2
- package/lib/git/permissions.cjs +77 -11
- package/lib/git/permissions.mjs +3 -3
- package/lib/git/pull-strategy.cjs +76 -9
- package/lib/git/pull-strategy.mjs +3 -3
- package/lib/git/user-config.cjs +266 -83
- package/lib/git/user-config.mjs +4 -4
- package/lib/git/utils.cjs +40 -60
- package/lib/git/utils.mjs +2 -2
- package/lib/git-diff-cli.cjs +651 -0
- package/lib/git-diff-cli.d.ts +1 -0
- package/lib/git-diff-cli.js +15 -0
- package/lib/git-diff-cli.mjs +16 -0
- package/lib/git-diff.cjs +657 -58
- package/lib/git-diff.d.ts +38 -83
- package/lib/git-diff.js +152 -0
- package/lib/git-diff.mjs +23 -85
- package/lib/git-fix.cjs +685 -97
- package/lib/git-fix.mjs +14 -13
- package/lib/git-purge.cjs +3 -3
- package/lib/git-purge.d.cts +1 -0
- package/lib/git-purge.mjs +43 -37
- package/lib/index.cjs +7 -6
- package/lib/index.d.ts +1 -1
- package/lib/index.js +2 -5
- package/lib/index.mjs +4 -4
- package/lib/npm-run-series.cjs +3 -3
- package/lib/npm-run-series.mjs +42 -36
- package/lib/package-resolutions-updater.cjs +5 -5
- package/lib/package-resolutions-updater.mjs +266 -309
- package/lib/print-directory-tree.cjs +275 -210
- package/lib/print-directory-tree.mjs +2 -2
- package/lib/ps/connected-domain.cjs +25 -2
- package/lib/ps/connected-domain.d.ts +10 -2
- package/lib/ps/connected-domain.js +5 -2
- package/lib/ps/connected-domain.mjs +8 -4
- package/lib/ps/index.cjs +345 -322
- package/lib/ps/index.d.mjs +1 -1
- package/lib/ps/index.js +1 -1
- package/lib/ps/index.mjs +179 -182
- package/lib/ps/isWin.cjs +24 -1
- package/lib/ps/isWin.d.ts +1 -1
- package/lib/ps/isWin.js +3 -1
- package/lib/ps/isWin.mjs +8 -4
- package/lib/ps/table-parser.cjs +167 -159
- package/lib/ps/table-parser.d.ts +5 -0
- package/lib/ps/table-parser.js +10 -4
- package/lib/ps/table-parser.mjs +9 -5
- package/lib/remove-module.cjs +262 -0
- package/lib/remove-module.d.mts +1 -0
- package/lib/remove-module.mjs +111 -0
- package/lib/rmpath.cjs +274 -0
- package/lib/rmpath.d.mts +3 -0
- package/lib/rmpath.mjs +108 -0
- package/lib/submodule-install.cjs +264 -86
- package/lib/submodule-install.mjs +51 -3
- package/lib/submodule-remove-cli.cjs +103 -0
- package/lib/submodule-remove-cli.d.ts +1 -0
- package/lib/submodule-remove-cli.js +31 -0
- package/lib/submodule-remove-cli.mjs +28 -0
- package/lib/submodule-remove.cjs +43 -0
- package/lib/submodule-remove.d.cts +2 -0
- package/lib/submodule-remove.mjs +6 -0
- package/lib/utils/chatgpt.cjs +383 -0
- package/lib/utils/chatgpt.d.ts +31 -0
- package/lib/utils/chatgpt.js +541 -0
- package/lib/utils/chatgpt.mjs +8 -0
- package/lib/{utils.cjs → utils/index.cjs} +1 -1
- package/lib/{utils.mjs → utils/index.mjs} +2 -2
- package/lib/yarn-reinstall.cjs +172 -38
- package/lib/yarn-reinstall.mjs +2 -2
- package/package.json +91 -71
- package/readme.md +43 -69
- package/releases/readme.md +36 -0
- package/test/README.md +101 -0
- package/test/package.json +2 -1
- package/test-project/readme.md +26 -0
- package/tmp/test-repo/README.md +35 -0
- package/tmp/test-repo/package.json +1 -1
- package/tmp/typedoc/readme.md +320 -0
- package/bin/bash-dummy +0 -56
- package/bin/bash-dummy.cmd +0 -25
- package/bin/dir-tree.cmd +0 -7
- package/bin/git-diff +0 -4
- package/bin/git-diff.cmd +0 -7
- package/bin/git-fix +0 -36
- package/bin/git-fix.cmd +0 -7
- package/bin/rmpath +0 -70
- package/bin/submodule-install.txt +0 -118
- package/bin/submodule-remove +0 -46
- package/bin/submodule.txt +0 -172
- package/lib/binary-collections-config.d.mts +0 -18
- package/lib/binary-collections-config.js +0 -39
- package/lib/binary-collections.d.mts +0 -137
- package/lib/binary-collections.d.ts +0 -137
- package/lib/changelog.d.mts +0 -2
- package/lib/changelog.js +0 -226
- package/lib/chunk-DPKAJKFO.mjs +0 -171
- package/lib/chunk-G3THLIDT.mjs +0 -200
- package/lib/chunk-W3ENOM53.mjs +0 -18
- package/lib/clean-github-actions-caches.d.mts +0 -169
- package/lib/clean-github-actions-caches.d.ts +0 -169
- package/lib/del-gradle.d.mts +0 -2
- package/lib/del-node-modules.d.mts +0 -2
- package/lib/del-ps.d.mts +0 -2
- package/lib/del-yarn-caches.d.mts +0 -2
- package/lib/find-node-modules-cli.d.mts +0 -1
- package/lib/find-node-modules.d.mts +0 -13
- package/lib/find-node-modules.js +0 -53
- package/lib/git/line-endings.d.mts +0 -83
- package/lib/git/line-endings.d.ts +0 -83
- package/lib/git/normalize.d.mts +0 -43
- package/lib/git/normalize.d.ts +0 -43
- package/lib/git/permissions.d.mts +0 -17
- package/lib/git/permissions.d.ts +0 -17
- package/lib/git/pull-strategy.d.mts +0 -15
- package/lib/git/pull-strategy.d.ts +0 -15
- package/lib/git/user-config.d.mts +0 -105
- package/lib/git/user-config.d.ts +0 -105
- package/lib/git/utils.d.mts +0 -69
- package/lib/git/utils.d.ts +0 -69
- package/lib/git-diff.d.mts +0 -84
- package/lib/git-fix.d.mts +0 -141
- package/lib/git-fix.d.ts +0 -141
- package/lib/git-purge.d.mts +0 -2
- package/lib/git-purge.js +0 -59
- package/lib/index.d.mts +0 -1
- package/lib/npm-run-series.d.mts +0 -1
- package/lib/npm-run-series.d.ts +0 -2
- package/lib/npm-run-series.js +0 -86
- package/lib/package-resolutions-updater.d.ts +0 -352
- package/lib/print-directory-tree.d.mts +0 -234
- package/lib/print-directory-tree.d.ts +0 -234
- package/lib/ps/connected-domain.d.mts +0 -3
- package/lib/ps/index.d.d.mts +0 -26
- package/lib/ps/index.d.d.ts +0 -26
- package/lib/ps/index.d.mts +0 -26
- package/lib/ps/isWin.d.mts +0 -3
- package/lib/ps/table-parser.d.mts +0 -3
- package/lib/submodule-install.d.mts +0 -121
- package/lib/submodule-install.d.ts +0 -121
- package/lib/utils.d.mts +0 -40
- package/lib/utils.js +0 -181
- package/lib/yarn-reinstall.d.mts +0 -49
- package/lib/yarn-reinstall.d.ts +0 -49
- package/src/package-resolutions-updater.mjs +0 -350
- package/src/print-directory-tree.cjs +0 -234
- package/src/ps/index.js +0 -286
- package/src/yarn-reinstall.cjs +0 -49
- /package/{bin → binaries}/nodekill +0 -0
- /package/{bin → binaries}/nodekill.cmd +0 -0
- /package/lib/{binary-collections-config.d.ts → binary-collections-config.d.cts} +0 -0
- /package/lib/{changelog.d.ts → changelog.d.cts} +0 -0
- /package/lib/{git-purge.d.ts → free-chatgpt.d.ts} +0 -0
- /package/lib/{git-diff.d.cts → npm-run-series.d.cts} +0 -0
- /package/lib/{utils.d.ts → utils/index.d.cts} +0 -0
|
@@ -1,339 +1,296 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
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
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
// Show help if --help/-h is passed
|
|
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;
|
|
48
24
|
if (args.help || args.h) {
|
|
49
|
-
|
|
25
|
+
showHelp();
|
|
50
26
|
}
|
|
51
|
-
/**
|
|
52
|
-
* Display help information for the package-resolutions-updater script.
|
|
53
|
-
*/
|
|
54
27
|
function showHelp() {
|
|
55
|
-
|
|
56
|
-
GitHub Package Resolutions Updater
|
|
57
|
-
Usage
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
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);
|
|
66
55
|
}
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
{ pkg: "hexo-generator-redirect", branch: "master", repo: "hexo-generator-redirect", owner: "dimaslanjaka" },
|
|
104
|
-
{ pkg: "binary-collections", branch: "master", repo: "bin", owner: "dimaslanjaka" },
|
|
105
|
-
{ pkg: "@types/hexo", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
106
|
-
{ pkg: "@types/git-command-helper", branch: "pre-release", repo: "git-command-helper", owner: "dimaslanjaka" }
|
|
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" }
|
|
107
92
|
];
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
let pkg;
|
|
93
|
+
var pkgPath = path.join(process.cwd(), "package.json");
|
|
94
|
+
var pkg;
|
|
111
95
|
try {
|
|
112
|
-
|
|
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);
|
|
113
100
|
}
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
"octokit-rest.js/19.0.7",
|
|
121
|
-
"GitHub CLI/2.40.0",
|
|
122
|
-
"Mozilla/5.0 (compatible; GitHubCopilot/1.0)",
|
|
123
|
-
"PostmanRuntime/7.32.3",
|
|
124
|
-
"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)"
|
|
125
107
|
];
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
let selectedUserAgent;
|
|
108
|
+
var userAgentDir = path.join(os.tmpdir(), "nodejs");
|
|
109
|
+
var userAgentFile = path.join(userAgentDir, "useragent.txt");
|
|
110
|
+
var selectedUserAgent;
|
|
130
111
|
try {
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
selectedUserAgent = fileAgent;
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
if (!selectedUserAgent) {
|
|
140
|
-
selectedUserAgent = GITHUB_USER_AGENTS[Math.floor(Math.random() * GITHUB_USER_AGENTS.length)];
|
|
141
|
-
fs.writeFileSync(userAgentFile, selectedUserAgent, "utf-8");
|
|
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;
|
|
142
117
|
}
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
// fallback to random if any error
|
|
118
|
+
}
|
|
119
|
+
if (!selectedUserAgent) {
|
|
146
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)];
|
|
147
125
|
}
|
|
148
|
-
/**
|
|
149
|
-
* Fetch JSON from a URL with GitHub headers.
|
|
150
|
-
* @param {string} url
|
|
151
|
-
* @returns {Promise<any>}
|
|
152
|
-
*/
|
|
153
126
|
function fetchJson(url) {
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
}
|
|
176
|
-
/**
|
|
177
|
-
* Get latest commit SHA from a specific branch.
|
|
178
|
-
*/
|
|
179
|
-
function getLatestCommit(owner_1, repo_1) {
|
|
180
|
-
return __awaiter(this, arguments, void 0, function* (owner, repo, branch = "main") {
|
|
181
|
-
var _a, _b, _c, _d;
|
|
182
|
-
const url = `https://api.github.com/repos/${owner}/${repo}/commits/${branch}`;
|
|
183
|
-
const json = yield fetchJson(url);
|
|
184
|
-
const sha = json.sha;
|
|
185
|
-
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);
|
|
186
|
-
if (!sha || !dateStr) {
|
|
187
|
-
console.log(json);
|
|
188
|
-
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}`));
|
|
189
149
|
}
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
branch,
|
|
194
|
-
sha,
|
|
195
|
-
date: new Date(dateStr).toISOString()
|
|
196
|
-
};
|
|
197
|
-
});
|
|
150
|
+
});
|
|
151
|
+
}).on("error", reject);
|
|
152
|
+
});
|
|
198
153
|
}
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
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
|
+
};
|
|
171
|
+
}
|
|
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
|
+
};
|
|
232
201
|
}
|
|
233
|
-
/**
|
|
234
|
-
* Replace the branch or commit in a GitHub raw URL with the latest hash.
|
|
235
|
-
*/
|
|
236
202
|
function replaceRawWithLatestHash(url, latestHash) {
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
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}`;
|
|
242
207
|
}
|
|
243
|
-
/**
|
|
244
|
-
* Parse GitHub URLs and extract owner, repo, branch, and original URL.
|
|
245
|
-
*/
|
|
246
208
|
function parseGitHubUrl(url) {
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
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}`);
|
|
269
231
|
}
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
catch (error) {
|
|
287
|
-
console.log(`⏭️ Skipping ${ansiColors.yellow(currentPkgName)}: ${error.message}`);
|
|
288
|
-
continue;
|
|
289
|
-
}
|
|
290
|
-
try {
|
|
291
|
-
const override = specialPackageOverrides.find((p) => p.pkg === currentPkgName);
|
|
292
|
-
const latest = override
|
|
293
|
-
? yield getLatestCommit(override.owner, override.repo, override.branch)
|
|
294
|
-
: yield getLatestCommitAcrossBranches(repo.owner, repo.repo);
|
|
295
|
-
const new_url = replaceRawWithLatestHash(url, latest.sha);
|
|
296
|
-
updates.push({
|
|
297
|
-
currentPkgName,
|
|
298
|
-
url,
|
|
299
|
-
new_url,
|
|
300
|
-
repo,
|
|
301
|
-
latest
|
|
302
|
-
});
|
|
303
|
-
}
|
|
304
|
-
catch (error) {
|
|
305
|
-
console.log(`❌ Failed to process ${ansiColors.red(currentPkgName)}: ${error.message}`);
|
|
306
|
-
}
|
|
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;
|
|
307
248
|
}
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
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}`);
|
|
311
262
|
}
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
catch (e) {
|
|
332
|
-
console.error(ansiColors.red(`Failed to write package.json: ${e.message}`));
|
|
333
|
-
process.exit(1);
|
|
334
|
-
}
|
|
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")}`);
|
|
335
282
|
}
|
|
336
|
-
|
|
337
|
-
|
|
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);
|
|
338
292
|
}
|
|
339
|
-
}
|
|
293
|
+
} else {
|
|
294
|
+
console.log(ansiColors.green("No changes to package.json were necessary."));
|
|
295
|
+
}
|
|
296
|
+
})();
|