binary-collections 2.0.12 → 2.0.13
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 +89 -13
- package/binaries/clean-nodemodule.cjs +89 -13
- package/binaries/clean-nodemodules.cjs +89 -13
- package/binaries/dev.cjs +89 -13
- package/binaries/empty.cjs +89 -13
- package/binaries/git-reduce-size.cjs +89 -13
- package/binaries/javakill.cjs +89 -13
- package/binaries/kill-process.cjs +89 -13
- package/binaries/nodekill.cjs +89 -13
- package/binaries/prod.cjs +89 -13
- package/binaries/py.cjs +89 -13
- package/binaries/rmfind.cjs +89 -13
- package/binaries/rmx.cjs +89 -13
- package/binaries/submodule-token.cjs +89 -13
- package/binaries/test-cjs.cjs +89 -13
- package/binaries/test-esm.cjs +89 -13
- package/binaries/yarn-clean.cjs +89 -13
- package/binaries/yc +22 -1
- package/binaries/yc.cjs +89 -13
- package/binaries/ycw +256 -0
- package/binaries/ycw.cjs +254 -0
- package/docs-src/binary-collections.md +34 -0
- package/docs-src/changelog.md +26 -0
- package/docs-src/clean-github-actions-caches.md +115 -0
- package/docs-src/copy-move-file.md +59 -0
- package/docs-src/del-gradle.md +17 -0
- package/docs-src/del-ps.md +28 -0
- package/docs-src/downloader.md +62 -0
- package/docs-src/env-helpers.md +29 -0
- package/docs-src/find-node-modules.md +17 -0
- package/docs-src/free-chatgpt.md +26 -0
- package/docs-src/git-diff.md +33 -0
- package/docs-src/git-fix.md +34 -0
- package/docs-src/git-purge.md +17 -0
- package/docs-src/git-reduce-size.md +17 -0
- package/docs-src/git-undo.md +21 -0
- package/docs-src/kill-night-crows.md +26 -0
- package/docs-src/node-cache-cleaner.md +182 -0
- package/docs-src/node-executor.md +50 -0
- package/docs-src/node-package-packer.md +48 -0
- package/docs-src/npm-run-series.md +43 -0
- package/docs-src/package-resolutions-updater.md +22 -0
- package/docs-src/php-cs-fixer-staged.md +19 -0
- package/docs-src/print-directory-tree.md +35 -0
- package/docs-src/print-tarball-tree.md +55 -0
- package/docs-src/py.md +19 -0
- package/docs-src/remove-module.md +32 -0
- package/docs-src/rmfind-rmx.md +21 -0
- package/docs-src/rmpath.md +38 -0
- package/docs-src/run-by-checksum.md +87 -0
- package/docs-src/submodule-install.md +31 -0
- package/docs-src/submodule-remove.md +22 -0
- package/docs-src/submodule-token.md +17 -0
- package/docs-src/test-runners.md +21 -0
- package/docs-src/yarn-install.md +31 -0
- package/docs-src/yarn-reinstall.md +27 -0
- package/lib/binary-collections/config.cjs +1 -1
- package/lib/binary-collections/config.mjs +1 -1
- package/lib/binary-collections/findScript.cjs +35 -10
- package/lib/binary-collections/findScript.mjs +2 -2
- package/lib/binary-collections/listScript.cjs +35 -10
- package/lib/binary-collections/listScript.mjs +2 -2
- package/lib/binary-collections.cjs +45 -25
- package/lib/binary-collections.mjs +11 -11
- package/lib/changelog.cjs +7 -12
- package/lib/changelog.mjs +2 -2
- package/lib/{chunk-SPTECFE5.mjs → chunk-2MN4VPV2.mjs} +86 -20
- package/lib/{chunk-V2IBPCEV.mjs → chunk-6C7KTYGZ.mjs} +3 -1
- package/lib/{chunk-5RTXZVCW.mjs → chunk-6RK5UCTP.mjs} +5 -10
- package/lib/{chunk-FB2WKVJD.mjs → chunk-CD3HF3LK.mjs} +67 -35
- package/lib/{chunk-6PU7BAHB.mjs → chunk-FLYSZFLW.mjs} +1 -1
- package/lib/chunk-KLKAIFKI.mjs +40 -0
- package/lib/chunk-LVSPEFU2.mjs +86 -0
- package/lib/{chunk-2LSRSEXF.mjs → chunk-MGPYPKIE.mjs} +2 -2
- package/lib/{chunk-ZOWVMII3.mjs → chunk-NQXUYO67.mjs} +35 -10
- package/lib/{chunk-C6D2TTYU.mjs → chunk-OBXLTXFJ.mjs} +4 -2
- package/lib/chunk-QD4T255Z.mjs +40 -0
- package/lib/{chunk-XPJGCDOD.mjs → chunk-QII2EKCS.mjs} +14 -2
- package/lib/chunk-RDGDLSPD.mjs +76 -0
- package/lib/{chunk-NCZPTKDV.mjs → chunk-RDN6HF5Z.mjs} +1 -1
- package/lib/chunk-RJKTSUAX.mjs +123 -0
- package/lib/{chunk-66KDU4TX.mjs → chunk-TBWXE7ST.mjs} +36 -61
- package/lib/{chunk-M3YIYRHT.mjs → chunk-UY5VUEA3.mjs} +1 -1
- package/lib/chunk-WSHVPGNM.mjs +44 -0
- package/lib/{chunk-G5UUEWUO.mjs → chunk-X2B3X7D4.mjs} +1 -1
- package/lib/clean-github-actions-caches-cli.cjs +255 -213
- package/lib/clean-github-actions-caches-cli.mjs +25 -7
- package/lib/clean-github-actions-caches.cjs +231 -35
- package/lib/clean-github-actions-caches.d.cts +39 -1
- package/lib/clean-github-actions-caches.mjs +2 -1
- package/lib/cross-env/command.cjs +2 -2
- package/lib/cross-env/command.js +2 -2
- package/lib/cross-env/command.mjs +2 -2
- package/lib/cross-env/index.cjs +2 -2
- package/lib/cross-env/index.mjs +3 -3
- package/lib/cross-env/variable.mjs +2 -2
- package/lib/del-gradle.cjs +6 -11
- package/lib/del-gradle.mjs +1 -1
- package/lib/del-node-modules.cjs +185 -3
- package/lib/del-node-modules.js +3 -3
- package/lib/del-node-modules.mjs +6 -3
- package/lib/{del-ps.cjs → del-ps-cli.cjs} +36 -41
- package/lib/del-ps-cli.mjs +44 -0
- package/lib/del-yarn-caches.cjs +6 -11
- package/lib/del-yarn-caches.mjs +1 -1
- package/lib/downloader-cli.cjs +256 -0
- package/lib/downloader-cli.d.cts +2 -0
- package/lib/downloader-cli.mjs +90 -0
- package/lib/file/copy-cli.cjs +183 -2
- package/lib/file/copy-cli.mjs +6 -2
- package/lib/file/move-cli.cjs +183 -2
- package/lib/file/move-cli.mjs +6 -2
- package/lib/find-node-modules-cli.cjs +1 -1
- package/lib/find-node-modules-cli.mjs +1 -1
- package/lib/find-node-modules.cjs +1 -1
- package/lib/find-node-modules.mjs +1 -1
- package/lib/free-chatgpt.cjs +6 -11
- package/lib/free-chatgpt.mjs +1 -1
- package/lib/git/user-config.cjs +7 -12
- package/lib/git/user-config.mjs +2 -2
- package/lib/git-diff-cli.cjs +91 -30
- package/lib/git-diff-cli.mjs +3 -3
- package/lib/git-diff.cjs +91 -30
- package/lib/git-diff.js +85 -28
- package/lib/git-diff.mjs +3 -3
- package/lib/git-fix.cjs +7 -12
- package/lib/git-fix.mjs +2 -2
- package/lib/git-purge.cjs +7 -12
- package/lib/git-purge.mjs +2 -2
- package/lib/index.cjs +1 -1
- package/lib/index.mjs +1 -1
- package/lib/node-cache-cleaner-cli.cjs +185 -2
- package/lib/node-cache-cleaner-cli.js +2 -5
- package/lib/node-cache-cleaner-cli.mjs +8 -4
- package/lib/node-executor.cjs +183 -2
- package/lib/node-executor.mjs +5 -2
- package/lib/node-package-packer/build-readme.cjs +150 -0
- package/lib/node-package-packer/build-readme.d.mts +10 -0
- package/lib/node-package-packer/build-readme.mjs +10 -0
- package/lib/node-package-packer/build-tarball.cjs +495 -0
- package/lib/node-package-packer/build-tarball.d.mts +33 -0
- package/lib/node-package-packer/build-tarball.mjs +175 -0
- package/lib/node-package-packer-cli.cjs +525 -0
- package/lib/node-package-packer-cli.d.mts +1 -0
- package/lib/node-package-packer-cli.mjs +34 -0
- package/lib/npm-run-series.cjs +7 -12
- package/lib/npm-run-series.mjs +2 -2
- package/lib/package-resolutions-updater-cli.cjs +73 -76
- package/lib/package-resolutions-updater-cli.mjs +4 -3
- package/lib/package-resolutions-updater.cjs +71 -74
- package/lib/package-resolutions-updater.d.mts +34 -0
- package/lib/package-resolutions-updater.mjs +3 -2
- package/lib/php-cs-fixer-staged.cjs +1 -1
- package/lib/php-cs-fixer-staged.mjs +1 -1
- package/lib/print-directory-tree.cjs +16 -18
- package/lib/print-directory-tree.mjs +11 -8
- package/lib/print-tarball-tree.cjs +262 -0
- package/lib/print-tarball-tree.d.mts +1 -0
- package/lib/print-tarball-tree.mjs +68 -0
- package/lib/ps/index.cjs +10 -10
- package/lib/ps/index.mjs +4 -4
- package/lib/ps/table-parser.d.ts +3 -4
- package/lib/ps/table-parser.js +9 -16
- package/lib/remove-module.cjs +17 -22
- package/lib/remove-module.mjs +2 -2
- package/lib/rm-node-module-cli.cjs +171 -4
- package/lib/rm-node-module-cli.mjs +7 -4
- package/lib/rmpath-cli.cjs +285 -0
- package/lib/rmpath-cli.d.mts +1 -0
- package/lib/rmpath-cli.mjs +23 -0
- package/lib/rmpath.cjs +6 -217
- package/lib/rmpath.mjs +5 -101
- package/lib/run-by-checksum/cache.cjs +69 -0
- package/lib/run-by-checksum/cache.d.ts +19 -0
- package/lib/run-by-checksum/cache.js +50 -0
- package/lib/run-by-checksum/cache.mjs +12 -0
- package/lib/run-by-checksum/hash.cjs +72 -0
- package/lib/run-by-checksum/hash.d.ts +14 -0
- package/lib/run-by-checksum/hash.js +85 -0
- package/lib/{ps/isWin.mjs → run-by-checksum/hash.mjs} +5 -5
- package/lib/run-by-checksum/run.cjs +169 -0
- package/lib/run-by-checksum/run.d.ts +22 -0
- package/lib/run-by-checksum/run.js +93 -0
- package/lib/run-by-checksum/run.mjs +10 -0
- package/lib/run-by-checksum-cli.cjs +382 -0
- package/lib/run-by-checksum-cli.d.ts +2 -0
- package/lib/run-by-checksum-cli.js +43 -0
- package/lib/run-by-checksum-cli.mjs +56 -0
- package/lib/submodule-install.cjs +8 -13
- package/lib/submodule-install.mjs +3 -3
- package/lib/submodule-remove-cli.cjs +169 -2
- package/lib/submodule-remove-cli.js +2 -2
- package/lib/submodule-remove-cli.mjs +5 -2
- package/lib/utils/fetchResponse.cjs +24 -0
- package/lib/utils/fetchResponse.d.cts +25 -0
- package/lib/utils/fetchResponse.mjs +6 -0
- package/lib/utils/index.cjs +5 -10
- package/lib/utils/index.d.cts +2 -9
- package/lib/utils/index.mjs +1 -1
- package/lib/utils/isWindows.mjs +3 -1
- package/lib/utils/runBash.cjs +1 -1
- package/lib/utils/runBash.mjs +1 -1
- package/lib/yarn-per-branch-lock-installer.cjs +202 -11
- package/lib/yarn-per-branch-lock-installer.mjs +24 -11
- package/lib/yarn-reinstall.cjs +6 -11
- package/lib/yarn-reinstall.mjs +1 -1
- package/package.json +35 -10
- package/readme.html +2 -2
- package/readme.md +5 -5
- package/releases/readme.md +6 -3
- package/tmp/test-repo-runChecksum/test-complex-glob/README.md +1 -0
- package/tmp/test-repo-runChecksum/test-mixed-args/README.md +1 -0
- package/.opencode/package.json +0 -5
- package/lib/chunk-6S4NXESK.mjs +0 -26
- package/lib/del-ps.js +0 -32
- package/lib/del-ps.mjs +0 -43
- package/lib/ps/isWin.cjs +0 -26
- package/lib/ps/isWin.d.ts +0 -2
- package/lib/ps/isWin.js +0 -4
- package/test/package.json +0 -20
- package/test-project/package.json +0 -22
- package/test-project/workspaces/workspace-a/package.json +0 -135
- package/test-project/workspaces/workspace-a/test/demo/package.json +0 -25
- package/test-project/workspaces/workspace-b/package.json +0 -139
- package/test-project/workspaces/workspace-b/test/sample-project/package.json +0 -7
- package/test-project/workspaces/workspace-b/themes/hexo-theme-flowbite/package.json +0 -96
- package/tmp/rm-node-modules-test-project/package.json +0 -17
- package/tmp/rm-node-modules-test-project/packages/workspace-a/package.json +0 -16
- package/tmp/rm-node-modules-test-project/packages/workspace-b/package.json +0 -16
- package/tmp/test-repo/package.json +0 -17
- /package/lib/{del-ps.d.ts → del-ps-cli.d.mts} +0 -0
|
@@ -13,6 +13,173 @@ var init_cjs_shims = __esm({
|
|
|
13
13
|
}
|
|
14
14
|
});
|
|
15
15
|
|
|
16
|
+
// src/utils/index.cjs
|
|
17
|
+
var require_utils = __commonJS({
|
|
18
|
+
"src/utils/index.cjs"(exports2, module2) {
|
|
19
|
+
init_cjs_shims();
|
|
20
|
+
var fs = require("fs");
|
|
21
|
+
var path = require("upath");
|
|
22
|
+
var minimistLib = require("minimist");
|
|
23
|
+
var argv2 = minimistLib(process.argv.slice(2));
|
|
24
|
+
var { exec } = require("child_process");
|
|
25
|
+
var { promisify } = require("util");
|
|
26
|
+
var execAsync = promisify(exec);
|
|
27
|
+
async function parseGitRemotes2() {
|
|
28
|
+
try {
|
|
29
|
+
const { stdout } = await execAsync("git remote -v");
|
|
30
|
+
const lines = stdout.split("\n");
|
|
31
|
+
const remotes = {};
|
|
32
|
+
lines.forEach((line) => {
|
|
33
|
+
const [name, url] = line.split(" ");
|
|
34
|
+
if (name && url) {
|
|
35
|
+
const [repoUrl] = url.split(" ");
|
|
36
|
+
try {
|
|
37
|
+
const parsedUrl = new URL(repoUrl);
|
|
38
|
+
const pathParts = parsedUrl.pathname.split("/").filter(Boolean);
|
|
39
|
+
if (parsedUrl.hostname === "github.com" && pathParts.length === 2) {
|
|
40
|
+
let repoPath = pathParts.join("/");
|
|
41
|
+
if (repoPath.endsWith(".git")) {
|
|
42
|
+
repoPath = repoPath.slice(0, -4);
|
|
43
|
+
}
|
|
44
|
+
remotes[name] = repoPath;
|
|
45
|
+
}
|
|
46
|
+
} catch (e) {
|
|
47
|
+
console.error("URL Parsing Error:", e.message);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
return remotes;
|
|
52
|
+
} catch (error) {
|
|
53
|
+
console.error("Error:", error.message);
|
|
54
|
+
return {};
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
module2.exports.parseGitRemotes = parseGitRemotes2;
|
|
58
|
+
function getArgs2(opts) {
|
|
59
|
+
if (opts) {
|
|
60
|
+
return minimistLib(process.argv.slice(2), opts);
|
|
61
|
+
}
|
|
62
|
+
return argv2;
|
|
63
|
+
}
|
|
64
|
+
module2.exports.getArgs = getArgs2;
|
|
65
|
+
function del(fullPath) {
|
|
66
|
+
try {
|
|
67
|
+
if (!fs.existsSync(fullPath)) return;
|
|
68
|
+
const stat = fs.lstatSync(fullPath);
|
|
69
|
+
if (stat.isSymbolicLink()) {
|
|
70
|
+
try {
|
|
71
|
+
fs.unlinkSync(fullPath);
|
|
72
|
+
console.log("deleted symlink", fullPath);
|
|
73
|
+
} catch (e) {
|
|
74
|
+
console.log("failed delete symlink", fullPath, e && e.message);
|
|
75
|
+
}
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
if (stat.isDirectory()) {
|
|
79
|
+
const subdir = fs.readdirSync(fullPath).map((dirPath) => path.resolve(fullPath, dirPath));
|
|
80
|
+
for (let i = 0; i < subdir.length; i++) {
|
|
81
|
+
del(subdir[i]);
|
|
82
|
+
}
|
|
83
|
+
try {
|
|
84
|
+
fs.rmdirSync(fullPath);
|
|
85
|
+
console.log("deleted", fullPath);
|
|
86
|
+
} catch (_e) {
|
|
87
|
+
try {
|
|
88
|
+
fs.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7e3 });
|
|
89
|
+
console.log("deleted", fullPath);
|
|
90
|
+
} catch (ee) {
|
|
91
|
+
console.log("failed delete", fullPath, ee && ee.message);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
try {
|
|
97
|
+
fs.unlinkSync(fullPath);
|
|
98
|
+
console.log("deleted", fullPath);
|
|
99
|
+
} catch (_e) {
|
|
100
|
+
try {
|
|
101
|
+
fs.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7e3 });
|
|
102
|
+
console.log("deleted", fullPath);
|
|
103
|
+
} catch (ee) {
|
|
104
|
+
console.log("failed delete", fullPath, ee && ee.message);
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
} catch (err) {
|
|
108
|
+
console.log("failed delete", fullPath, err && err.message);
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
module2.exports.del = del;
|
|
112
|
+
function delStream(globStream) {
|
|
113
|
+
globStream.stream().on("data", (result) => {
|
|
114
|
+
const fullPath = path.resolve(process.cwd(), result);
|
|
115
|
+
try {
|
|
116
|
+
if (fs.existsSync(fullPath)) {
|
|
117
|
+
const stat = fs.lstatSync(fullPath);
|
|
118
|
+
if (stat.isSymbolicLink()) {
|
|
119
|
+
try {
|
|
120
|
+
fs.unlinkSync(fullPath);
|
|
121
|
+
console.log("deleted symlink", fullPath);
|
|
122
|
+
} catch (e) {
|
|
123
|
+
console.log("failed delete symlink", fullPath, e && e.message);
|
|
124
|
+
}
|
|
125
|
+
return;
|
|
126
|
+
}
|
|
127
|
+
if (stat.isDirectory()) {
|
|
128
|
+
const subdir = fs.readdirSync(fullPath).map((dirPath) => path.resolve(fullPath, dirPath));
|
|
129
|
+
for (let i = 0; i < subdir.length; i++) {
|
|
130
|
+
del(subdir[i]);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
del(fullPath);
|
|
135
|
+
} catch (err) {
|
|
136
|
+
console.log("failed processing", fullPath, err && err.message);
|
|
137
|
+
}
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
module2.exports.delStream = delStream;
|
|
141
|
+
function getFileTreeString(hashArray) {
|
|
142
|
+
const tree = {};
|
|
143
|
+
const hashMap = {};
|
|
144
|
+
for (const entry of hashArray) {
|
|
145
|
+
const [filePath, hash] = entry.split(" ");
|
|
146
|
+
hashMap[filePath] = hash;
|
|
147
|
+
const parts = filePath.split("/");
|
|
148
|
+
let current = tree;
|
|
149
|
+
for (let i = 0; i < parts.length; i++) {
|
|
150
|
+
const part = parts[i];
|
|
151
|
+
if (i === parts.length - 1) {
|
|
152
|
+
current[part] = null;
|
|
153
|
+
} else {
|
|
154
|
+
current[part] = current[part] || {};
|
|
155
|
+
current = current[part];
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
function printNode(node, prefix = "", parentPath = "") {
|
|
160
|
+
const keys = Object.keys(node).sort();
|
|
161
|
+
let lines = [];
|
|
162
|
+
keys.forEach((key, idx) => {
|
|
163
|
+
const isLast = idx === keys.length - 1;
|
|
164
|
+
const branch = isLast ? "\u2514\u2500\u2500 " : "\u251C\u2500\u2500 ";
|
|
165
|
+
const currentPath = parentPath ? parentPath + "/" + key : key;
|
|
166
|
+
if (node[key] === null) {
|
|
167
|
+
lines.push(prefix + branch + key + " [" + (hashMap[currentPath] || "") + "]");
|
|
168
|
+
} else {
|
|
169
|
+
lines.push(prefix + branch + key + "/");
|
|
170
|
+
lines = lines.concat(printNode(node[key], prefix + (isLast ? " " : "\u2502 "), currentPath));
|
|
171
|
+
}
|
|
172
|
+
});
|
|
173
|
+
return lines;
|
|
174
|
+
}
|
|
175
|
+
return printNode(tree, "", "").join("\n");
|
|
176
|
+
}
|
|
177
|
+
module2.exports.getFileTreeString = getFileTreeString;
|
|
178
|
+
var delay = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
179
|
+
module2.exports.delay = delay;
|
|
180
|
+
}
|
|
181
|
+
});
|
|
182
|
+
|
|
16
183
|
// src/utils/findEnvFiles.cjs
|
|
17
184
|
var require_findEnvFiles = __commonJS({
|
|
18
185
|
"src/utils/findEnvFiles.cjs"(exports2, module2) {
|
|
@@ -113,14 +280,14 @@ var require_clean_github_actions_caches = __commonJS({
|
|
|
113
280
|
"src/clean-github-actions-caches.cjs"(exports2, module2) {
|
|
114
281
|
init_cjs_shims();
|
|
115
282
|
var axios = require("axios");
|
|
116
|
-
var
|
|
283
|
+
var { getArgs: getArgs2 } = require_utils();
|
|
117
284
|
var { findEnvWithToken } = require_findEnvFiles();
|
|
118
285
|
require("dotenv").config({
|
|
119
286
|
path: findEnvWithToken(),
|
|
120
287
|
quiet: true,
|
|
121
288
|
overwrite: true
|
|
122
289
|
});
|
|
123
|
-
var ACCESS_TOKEN = process.env.
|
|
290
|
+
var ACCESS_TOKEN = process.env.ACCESS_TOKEN || process.env.GITHUB_TOKEN;
|
|
124
291
|
if (!ACCESS_TOKEN) {
|
|
125
292
|
throw new Error(
|
|
126
293
|
"Access token is not provided. Please set ACCESS_TOKEN or GITHUB_TOKEN in your environment variables."
|
|
@@ -143,6 +310,9 @@ Options:
|
|
|
143
310
|
-r, --repo <repo> GitHub repository (owner/repo). If omitted, the tool will
|
|
144
311
|
attempt to infer the repository from the current working
|
|
145
312
|
directory's git remotes.
|
|
313
|
+
-p, --prefix-depth <n>
|
|
314
|
+
Number of leading cache key segments to use as the
|
|
315
|
+
grouping prefix when splitting on /[-_]/. Default: 3.
|
|
146
316
|
|
|
147
317
|
Environment Variables:
|
|
148
318
|
ACCESS_TOKEN GitHub access token (preferred)
|
|
@@ -159,25 +329,26 @@ Examples:
|
|
|
159
329
|
clean-github-actions-caches --repo octocat/hello-world
|
|
160
330
|
|
|
161
331
|
# Run via npx without installing
|
|
162
|
-
|
|
332
|
+
npx --legacy-peer-deps -y binary-collections@https://raw.githubusercontent.com/dimaslanjaka/bin/master/releases/bin.tgz clean-github-actions-caches --repo owner/repo --prefix-depth 3
|
|
163
333
|
|
|
164
334
|
# Run via yarn dlx
|
|
165
|
-
|
|
335
|
+
yarn dlx binary-collections@https://raw.githubusercontent.com/dimaslanjaka/bin/master/releases/bin.tgz clean-github-actions-caches --prefix-depth 3
|
|
166
336
|
|
|
167
337
|
Notes:
|
|
168
338
|
- Ensure ACCESS_TOKEN or GITHUB_TOKEN is set and has permissions to manage Actions caches.
|
|
169
339
|
- Intended for repository maintainers with appropriate permissions.
|
|
170
340
|
`);
|
|
171
341
|
}
|
|
172
|
-
var
|
|
342
|
+
var argv2 = getArgs2({
|
|
173
343
|
alias: {
|
|
174
344
|
h: "help",
|
|
345
|
+
p: "prefix-depth",
|
|
175
346
|
r: "repo"
|
|
176
347
|
},
|
|
177
|
-
string: ["repo"],
|
|
348
|
+
string: ["prefix-depth", "repo"],
|
|
178
349
|
boolean: ["help"]
|
|
179
350
|
});
|
|
180
|
-
if (
|
|
351
|
+
if (argv2.help) {
|
|
181
352
|
printHelp();
|
|
182
353
|
process.exit(0);
|
|
183
354
|
}
|
|
@@ -203,7 +374,53 @@ Notes:
|
|
|
203
374
|
});
|
|
204
375
|
});
|
|
205
376
|
}
|
|
206
|
-
function
|
|
377
|
+
function normalizePrefixDepth(prefixDepth) {
|
|
378
|
+
const parsed = Number(prefixDepth);
|
|
379
|
+
if (!Number.isFinite(parsed) || parsed < 1) {
|
|
380
|
+
return 3;
|
|
381
|
+
}
|
|
382
|
+
return Math.floor(parsed);
|
|
383
|
+
}
|
|
384
|
+
function isChecksumSegment(segment) {
|
|
385
|
+
return /^[a-f0-9]{32,}$/i.test(segment);
|
|
386
|
+
}
|
|
387
|
+
function getMeaningfulCacheKeyParts(key) {
|
|
388
|
+
return String(key).split(/[-_]/).filter(Boolean).filter((segment) => !isChecksumSegment(segment));
|
|
389
|
+
}
|
|
390
|
+
function getCachePrefix(key, prefixDepth = 3) {
|
|
391
|
+
const normalizedDepth = normalizePrefixDepth(prefixDepth);
|
|
392
|
+
const parts = String(key).split(/[-_]/).filter(Boolean);
|
|
393
|
+
const meaningfulParts = getMeaningfulCacheKeyParts(key);
|
|
394
|
+
if (meaningfulParts.length !== parts.length) {
|
|
395
|
+
if (meaningfulParts.length < normalizedDepth) {
|
|
396
|
+
return `${meaningfulParts.join("-")}-`;
|
|
397
|
+
}
|
|
398
|
+
return meaningfulParts.join("-");
|
|
399
|
+
}
|
|
400
|
+
if (parts.length <= normalizedDepth) {
|
|
401
|
+
return parts.join("-");
|
|
402
|
+
}
|
|
403
|
+
return parts.slice(0, normalizedDepth).join("-");
|
|
404
|
+
}
|
|
405
|
+
function groupCachesByPrefix(caches, prefixDepth = 3) {
|
|
406
|
+
return caches.reduce(
|
|
407
|
+
/**
|
|
408
|
+
* @param {Record<string, Record<string, any>[]>} acc
|
|
409
|
+
* @param {Record<string, any>} item
|
|
410
|
+
* @returns {Record<string, Record<string, any>[]>}
|
|
411
|
+
*/
|
|
412
|
+
(acc, item) => {
|
|
413
|
+
const prefix = getCachePrefix(item.key, prefixDepth);
|
|
414
|
+
if (!acc[prefix]) {
|
|
415
|
+
acc[prefix] = [];
|
|
416
|
+
}
|
|
417
|
+
acc[prefix].push(item);
|
|
418
|
+
return acc;
|
|
419
|
+
},
|
|
420
|
+
{}
|
|
421
|
+
);
|
|
422
|
+
}
|
|
423
|
+
function get_caches2(GH_REPO, prefixDepth = 3) {
|
|
207
424
|
const url = `https://api.github.com/repos/${GH_REPO}/actions/caches`;
|
|
208
425
|
return new Promise((resolve, reject) => {
|
|
209
426
|
axios.get(url, {
|
|
@@ -213,227 +430,45 @@ Notes:
|
|
|
213
430
|
}
|
|
214
431
|
}).then((response) => {
|
|
215
432
|
const data = response.data.actions_caches;
|
|
216
|
-
const
|
|
217
|
-
const split = key.split(/[-_]/);
|
|
218
|
-
if (split.length === 3) {
|
|
219
|
-
return `${split[0]}-${split[1]}`;
|
|
220
|
-
}
|
|
221
|
-
if (split.length > 3) {
|
|
222
|
-
return `${split[0]}-${split[1]}-${split[2]}`;
|
|
223
|
-
}
|
|
224
|
-
return split[0];
|
|
225
|
-
};
|
|
226
|
-
const grouped = data.reduce(
|
|
227
|
-
/**
|
|
228
|
-
* @param {Record<string, Record<string, any>[]>} acc
|
|
229
|
-
* @param {Record<string, any>} item
|
|
230
|
-
* @returns {Record<string, Record<string, any>[]>}
|
|
231
|
-
*/
|
|
232
|
-
(acc, item) => {
|
|
233
|
-
const prefix = getPrefix(item.key);
|
|
234
|
-
if (!acc[prefix]) {
|
|
235
|
-
acc[prefix] = [];
|
|
236
|
-
}
|
|
237
|
-
acc[prefix].push(item);
|
|
238
|
-
return acc;
|
|
239
|
-
},
|
|
240
|
-
{}
|
|
241
|
-
);
|
|
433
|
+
const grouped = groupCachesByPrefix(data, prefixDepth);
|
|
242
434
|
resolve(grouped);
|
|
243
435
|
}).catch((error) => {
|
|
244
|
-
console.error("Error fetching data:", error);
|
|
245
436
|
reject(error);
|
|
246
437
|
});
|
|
247
438
|
});
|
|
248
439
|
}
|
|
249
440
|
module2.exports = {
|
|
250
441
|
deleteGitHubActionsCache: deleteGitHubActionsCache2,
|
|
251
|
-
|
|
442
|
+
getCachePrefix,
|
|
443
|
+
getMeaningfulCacheKeyParts,
|
|
444
|
+
get_caches: get_caches2,
|
|
445
|
+
groupCachesByPrefix,
|
|
446
|
+
isChecksumSegment,
|
|
447
|
+
normalizePrefixDepth
|
|
252
448
|
};
|
|
253
449
|
}
|
|
254
450
|
});
|
|
255
451
|
|
|
256
|
-
// src/utils/index.cjs
|
|
257
|
-
var require_utils = __commonJS({
|
|
258
|
-
"src/utils/index.cjs"(exports2, module2) {
|
|
259
|
-
init_cjs_shims();
|
|
260
|
-
var fs = require("fs");
|
|
261
|
-
var path = require("upath");
|
|
262
|
-
var argv = require("minimist")(process.argv.slice(2));
|
|
263
|
-
var { exec } = require("child_process");
|
|
264
|
-
var { URL: URL2 } = require("url");
|
|
265
|
-
var { promisify } = require("util");
|
|
266
|
-
var execAsync = promisify(exec);
|
|
267
|
-
async function parseGitRemotes2() {
|
|
268
|
-
try {
|
|
269
|
-
const { stdout } = await execAsync("git remote -v");
|
|
270
|
-
const lines = stdout.split("\n");
|
|
271
|
-
const remotes = {};
|
|
272
|
-
lines.forEach((line) => {
|
|
273
|
-
const [name, url] = line.split(" ");
|
|
274
|
-
if (name && url) {
|
|
275
|
-
const [repoUrl] = url.split(" ");
|
|
276
|
-
try {
|
|
277
|
-
const parsedUrl = new URL2(repoUrl);
|
|
278
|
-
const pathParts = parsedUrl.pathname.split("/").filter(Boolean);
|
|
279
|
-
if (parsedUrl.hostname === "github.com" && pathParts.length === 2) {
|
|
280
|
-
let repoPath = pathParts.join("/");
|
|
281
|
-
if (repoPath.endsWith(".git")) {
|
|
282
|
-
repoPath = repoPath.slice(0, -4);
|
|
283
|
-
}
|
|
284
|
-
remotes[name] = repoPath;
|
|
285
|
-
}
|
|
286
|
-
} catch (e) {
|
|
287
|
-
console.error("URL Parsing Error:", e.message);
|
|
288
|
-
}
|
|
289
|
-
}
|
|
290
|
-
});
|
|
291
|
-
return remotes;
|
|
292
|
-
} catch (error) {
|
|
293
|
-
console.error("Error:", error.message);
|
|
294
|
-
return {};
|
|
295
|
-
}
|
|
296
|
-
}
|
|
297
|
-
module2.exports.parseGitRemotes = parseGitRemotes2;
|
|
298
|
-
function joinPathPreserveDriveLetter(...segments) {
|
|
299
|
-
let fullPath = require("path").join(...segments);
|
|
300
|
-
if (/^[a-z]:\\/.test(fullPath)) {
|
|
301
|
-
fullPath = fullPath.charAt(0).toUpperCase() + fullPath.slice(1);
|
|
302
|
-
}
|
|
303
|
-
return fullPath;
|
|
304
|
-
}
|
|
305
|
-
module2.exports.joinPathPreserveDriveLetter = joinPathPreserveDriveLetter;
|
|
306
|
-
function getArgs() {
|
|
307
|
-
return argv;
|
|
308
|
-
}
|
|
309
|
-
module2.exports.getArgs = getArgs;
|
|
310
|
-
function del(fullPath) {
|
|
311
|
-
try {
|
|
312
|
-
if (!fs.existsSync(fullPath)) return;
|
|
313
|
-
const stat = fs.lstatSync(fullPath);
|
|
314
|
-
if (stat.isSymbolicLink()) {
|
|
315
|
-
try {
|
|
316
|
-
fs.unlinkSync(fullPath);
|
|
317
|
-
console.log("deleted symlink", fullPath);
|
|
318
|
-
} catch (e) {
|
|
319
|
-
console.log("failed delete symlink", fullPath, e && e.message);
|
|
320
|
-
}
|
|
321
|
-
return;
|
|
322
|
-
}
|
|
323
|
-
if (stat.isDirectory()) {
|
|
324
|
-
const subdir = fs.readdirSync(fullPath).map((dirPath) => path.resolve(fullPath, dirPath));
|
|
325
|
-
for (let i = 0; i < subdir.length; i++) {
|
|
326
|
-
del(subdir[i]);
|
|
327
|
-
}
|
|
328
|
-
try {
|
|
329
|
-
fs.rmdirSync(fullPath);
|
|
330
|
-
console.log("deleted", fullPath);
|
|
331
|
-
} catch (_e) {
|
|
332
|
-
try {
|
|
333
|
-
fs.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7e3 });
|
|
334
|
-
console.log("deleted", fullPath);
|
|
335
|
-
} catch (ee) {
|
|
336
|
-
console.log("failed delete", fullPath, ee && ee.message);
|
|
337
|
-
}
|
|
338
|
-
}
|
|
339
|
-
return;
|
|
340
|
-
}
|
|
341
|
-
try {
|
|
342
|
-
fs.unlinkSync(fullPath);
|
|
343
|
-
console.log("deleted", fullPath);
|
|
344
|
-
} catch (_e) {
|
|
345
|
-
try {
|
|
346
|
-
fs.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7e3 });
|
|
347
|
-
console.log("deleted", fullPath);
|
|
348
|
-
} catch (ee) {
|
|
349
|
-
console.log("failed delete", fullPath, ee && ee.message);
|
|
350
|
-
}
|
|
351
|
-
}
|
|
352
|
-
} catch (err) {
|
|
353
|
-
console.log("failed delete", fullPath, err && err.message);
|
|
354
|
-
}
|
|
355
|
-
}
|
|
356
|
-
module2.exports.del = del;
|
|
357
|
-
function delStream(globStream) {
|
|
358
|
-
globStream.stream().on("data", (result) => {
|
|
359
|
-
const fullPath = path.resolve(process.cwd(), result);
|
|
360
|
-
try {
|
|
361
|
-
if (fs.existsSync(fullPath)) {
|
|
362
|
-
const stat = fs.lstatSync(fullPath);
|
|
363
|
-
if (stat.isSymbolicLink()) {
|
|
364
|
-
try {
|
|
365
|
-
fs.unlinkSync(fullPath);
|
|
366
|
-
console.log("deleted symlink", fullPath);
|
|
367
|
-
} catch (e) {
|
|
368
|
-
console.log("failed delete symlink", fullPath, e && e.message);
|
|
369
|
-
}
|
|
370
|
-
return;
|
|
371
|
-
}
|
|
372
|
-
if (stat.isDirectory()) {
|
|
373
|
-
const subdir = fs.readdirSync(fullPath).map((dirPath) => path.resolve(fullPath, dirPath));
|
|
374
|
-
for (let i = 0; i < subdir.length; i++) {
|
|
375
|
-
del(subdir[i]);
|
|
376
|
-
}
|
|
377
|
-
}
|
|
378
|
-
}
|
|
379
|
-
del(fullPath);
|
|
380
|
-
} catch (err) {
|
|
381
|
-
console.log("failed processing", fullPath, err && err.message);
|
|
382
|
-
}
|
|
383
|
-
});
|
|
384
|
-
}
|
|
385
|
-
module2.exports.delStream = delStream;
|
|
386
|
-
function getFileTreeString(hashArray) {
|
|
387
|
-
const tree = {};
|
|
388
|
-
const hashMap = {};
|
|
389
|
-
for (const entry of hashArray) {
|
|
390
|
-
const [filePath, hash] = entry.split(" ");
|
|
391
|
-
hashMap[filePath] = hash;
|
|
392
|
-
const parts = filePath.split("/");
|
|
393
|
-
let current = tree;
|
|
394
|
-
for (let i = 0; i < parts.length; i++) {
|
|
395
|
-
const part = parts[i];
|
|
396
|
-
if (i === parts.length - 1) {
|
|
397
|
-
current[part] = null;
|
|
398
|
-
} else {
|
|
399
|
-
current[part] = current[part] || {};
|
|
400
|
-
current = current[part];
|
|
401
|
-
}
|
|
402
|
-
}
|
|
403
|
-
}
|
|
404
|
-
function printNode(node, prefix = "", parentPath = "") {
|
|
405
|
-
const keys = Object.keys(node).sort();
|
|
406
|
-
let lines = [];
|
|
407
|
-
keys.forEach((key, idx) => {
|
|
408
|
-
const isLast = idx === keys.length - 1;
|
|
409
|
-
const branch = isLast ? "\u2514\u2500\u2500 " : "\u251C\u2500\u2500 ";
|
|
410
|
-
const currentPath = parentPath ? parentPath + "/" + key : key;
|
|
411
|
-
if (node[key] === null) {
|
|
412
|
-
lines.push(prefix + branch + key + " [" + (hashMap[currentPath] || "") + "]");
|
|
413
|
-
} else {
|
|
414
|
-
lines.push(prefix + branch + key + "/");
|
|
415
|
-
lines = lines.concat(printNode(node[key], prefix + (isLast ? " " : "\u2502 "), currentPath));
|
|
416
|
-
}
|
|
417
|
-
});
|
|
418
|
-
return lines;
|
|
419
|
-
}
|
|
420
|
-
return printNode(tree, "", "").join("\n");
|
|
421
|
-
}
|
|
422
|
-
module2.exports.getFileTreeString = getFileTreeString;
|
|
423
|
-
var delay = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
424
|
-
module2.exports.delay = delay;
|
|
425
|
-
}
|
|
426
|
-
});
|
|
427
|
-
|
|
428
452
|
// src/clean-github-actions-caches-cli.cjs
|
|
429
453
|
init_cjs_shims();
|
|
430
454
|
var { get_caches, deleteGitHubActionsCache } = require_clean_github_actions_caches();
|
|
431
|
-
var { parseGitRemotes } = require_utils();
|
|
455
|
+
var { getArgs, parseGitRemotes } = require_utils();
|
|
456
|
+
var argv = getArgs({
|
|
457
|
+
alias: {
|
|
458
|
+
p: "prefix-depth",
|
|
459
|
+
r: "repo"
|
|
460
|
+
},
|
|
461
|
+
string: ["prefix-depth", "repo"]
|
|
462
|
+
});
|
|
432
463
|
(async () => {
|
|
464
|
+
var _a, _b, _c, _d;
|
|
433
465
|
try {
|
|
434
466
|
const remotes = await parseGitRemotes();
|
|
435
|
-
const GH_REPO = remotes.origin;
|
|
436
|
-
|
|
467
|
+
const GH_REPO = argv.repo || remotes.origin;
|
|
468
|
+
if (!GH_REPO) {
|
|
469
|
+
throw new Error("Repository is not provided and origin remote could not be inferred. Use --repo owner/repo.");
|
|
470
|
+
}
|
|
471
|
+
const caches = await get_caches(GH_REPO, argv["prefix-depth"]);
|
|
437
472
|
for (const key in caches) {
|
|
438
473
|
if (Object.hasOwnProperty.call(caches, key)) {
|
|
439
474
|
const items = caches[key].sort((a, b) => new Date(b.created_at) - new Date(a.created_at)).map((item) => ({
|
|
@@ -448,7 +483,10 @@ var { parseGitRemotes } = require_utils();
|
|
|
448
483
|
try {
|
|
449
484
|
await deleteGitHubActionsCache(GH_REPO, id);
|
|
450
485
|
} catch (err) {
|
|
451
|
-
|
|
486
|
+
const code = ((_a = err.response) == null ? void 0 : _a.status) || err.code || "UNKNOWN";
|
|
487
|
+
const message = ((_b = err.response) == null ? void 0 : _b.statusText) || err.message || "Unknown error";
|
|
488
|
+
console.error(`Error deleting cache ${id}: [${code}] [${message}]
|
|
489
|
+
${err.stack}`);
|
|
452
490
|
}
|
|
453
491
|
}
|
|
454
492
|
} else {
|
|
@@ -460,6 +498,10 @@ var { parseGitRemotes } = require_utils();
|
|
|
460
498
|
}
|
|
461
499
|
}
|
|
462
500
|
} catch (e) {
|
|
463
|
-
|
|
501
|
+
const code = ((_c = e.response) == null ? void 0 : _c.status) || e.code || "UNKNOWN";
|
|
502
|
+
const message = ((_d = e.response) == null ? void 0 : _d.statusText) || e.message || "Unknown error";
|
|
503
|
+
console.error(`[${code}] [${message}]
|
|
504
|
+
${e.stack}`);
|
|
505
|
+
process.exit(1);
|
|
464
506
|
}
|
|
465
507
|
})();
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
3
|
require_clean_github_actions_caches
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-CD3HF3LK.mjs";
|
|
5
5
|
import "./chunk-H44UWUFY.mjs";
|
|
6
6
|
import {
|
|
7
7
|
require_utils
|
|
8
|
-
} from "./chunk-
|
|
8
|
+
} from "./chunk-6RK5UCTP.mjs";
|
|
9
9
|
import {
|
|
10
10
|
__commonJS,
|
|
11
11
|
init_esm_shims
|
|
@@ -16,12 +16,23 @@ var require_clean_github_actions_caches_cli = __commonJS({
|
|
|
16
16
|
"src/clean-github-actions-caches-cli.cjs"() {
|
|
17
17
|
init_esm_shims();
|
|
18
18
|
var { get_caches, deleteGitHubActionsCache } = require_clean_github_actions_caches();
|
|
19
|
-
var { parseGitRemotes } = require_utils();
|
|
19
|
+
var { getArgs, parseGitRemotes } = require_utils();
|
|
20
|
+
var argv = getArgs({
|
|
21
|
+
alias: {
|
|
22
|
+
p: "prefix-depth",
|
|
23
|
+
r: "repo"
|
|
24
|
+
},
|
|
25
|
+
string: ["prefix-depth", "repo"]
|
|
26
|
+
});
|
|
20
27
|
(async () => {
|
|
28
|
+
var _a, _b, _c, _d;
|
|
21
29
|
try {
|
|
22
30
|
const remotes = await parseGitRemotes();
|
|
23
|
-
const GH_REPO = remotes.origin;
|
|
24
|
-
|
|
31
|
+
const GH_REPO = argv.repo || remotes.origin;
|
|
32
|
+
if (!GH_REPO) {
|
|
33
|
+
throw new Error("Repository is not provided and origin remote could not be inferred. Use --repo owner/repo.");
|
|
34
|
+
}
|
|
35
|
+
const caches = await get_caches(GH_REPO, argv["prefix-depth"]);
|
|
25
36
|
for (const key in caches) {
|
|
26
37
|
if (Object.hasOwnProperty.call(caches, key)) {
|
|
27
38
|
const items = caches[key].sort((a, b) => new Date(b.created_at) - new Date(a.created_at)).map((item) => ({
|
|
@@ -36,7 +47,10 @@ var require_clean_github_actions_caches_cli = __commonJS({
|
|
|
36
47
|
try {
|
|
37
48
|
await deleteGitHubActionsCache(GH_REPO, id);
|
|
38
49
|
} catch (err) {
|
|
39
|
-
|
|
50
|
+
const code = ((_a = err.response) == null ? void 0 : _a.status) || err.code || "UNKNOWN";
|
|
51
|
+
const message = ((_b = err.response) == null ? void 0 : _b.statusText) || err.message || "Unknown error";
|
|
52
|
+
console.error(`Error deleting cache ${id}: [${code}] [${message}]
|
|
53
|
+
${err.stack}`);
|
|
40
54
|
}
|
|
41
55
|
}
|
|
42
56
|
} else {
|
|
@@ -48,7 +62,11 @@ var require_clean_github_actions_caches_cli = __commonJS({
|
|
|
48
62
|
}
|
|
49
63
|
}
|
|
50
64
|
} catch (e) {
|
|
51
|
-
|
|
65
|
+
const code = ((_c = e.response) == null ? void 0 : _c.status) || e.code || "UNKNOWN";
|
|
66
|
+
const message = ((_d = e.response) == null ? void 0 : _d.statusText) || e.message || "Unknown error";
|
|
67
|
+
console.error(`[${code}] [${message}]
|
|
68
|
+
${e.stack}`);
|
|
69
|
+
process.exit(1);
|
|
52
70
|
}
|
|
53
71
|
})();
|
|
54
72
|
}
|